The goals of this project are to create a nice looking and useful list of modules for MagicMirror² and to do some rudimentary testing of the modules (to generate improvement suggestions for the developers).
Feedback and pull requests are very welcome.
The official list in the wiki is a simple text list without filters and images. This list now contains over 1000 modules, so it is not so easy for users to pick out modules.
Based on the official list, we automatically create a website with filter functions and integrated images. You can check it out here: https://kristjanesperanto.github.io/MagicMirror-3rd-Party-Modules/
Add your module to the official list in the wiki. Twice a day the new list will be updated based on the official list.
This is a list of information that we can display on the web page and where the information comes from. This should help you to improve the presentation of your module. Keep in mind that the web page will not be updated immediately, it may take a few days for your changes to arrive.
MMM-MyFancyModule
.BruceWayne
.package.json
must be a free license in the license field. Take a look at this package.json as an example.package.json
. Take a look at this package.json as an example.package.json
. Take a look at this package.json as an example.Also check the result file to see if there are any notes on your module.
The aim of the tests is to increase the quality of the modules, also in order to be able to present them optimally in the module list. Due to the huge number of modules, the tests can only remain rudimentary.
If you have ideas for further tests, you are welcome to create an issue or pull request. And if you as a developer do not like a test, you are welcome to give feedback or simply ignore the result.
The results of the tests you can see in the result.md.
Here are some test results:
package.json
. We need this file to gather information about the module. - We need information like the license and keywords.node_modules
. This shouldn't be uploaded. Add node_modules/
to .gitignore
._node_helper.js
: Try to replace it with vlc
._node_helper.js
: Replace it with built-in fetch._MMM-
). Consider renaming your module.README.md
: Replace it with MagicMirror²
.nodejs.yml
: Replace it with v4.nodejs.yml
: Update to current version.For running the scripts and developing you need:
git clone https://github.com/KristjanESPERANTO/MagicMirror-3rd-Party-Modules
cd MagicMirror-3rd-Party-Modules
npm install
With npm start
you can call up a cli menu that offers you options for execution.
You can run all scripts in the right order by npm run all
.
Note: Running all scripts requires a lot of time (> 10 min) and space on your hard drive (> 2 GB).
This script reads the GitHub info of the modules from the respective GitHub repo and writes it to a json file.
This script reads data, such as the number of stars, via the GitHub API for a few modules.
This script reads the module list (created by the script before) and clones all modules.
Note: This script takes a long time (> 10 min) to download all modules and also takes up a lot of space on your hard drive (> 2 GB).
This script expands the module list with information from the package.json
files from the modules (if available).
The script also adds an image. To do this, it searches the module's repo for an image that contains "screenshot" or "example" in it's name. If it doesn't find anything like that, it takes the first image it finds in the repo.
Note: Images will only be included if a free license is specified in the package.json
.
This script goes through all cloned modules and performs various checks. The result is written to the files result.md
and modules.json
.
This script is for developers who want to test their own modules themselves. It can also be used to test other branches.
This script replaces the first script create_module_list.js
for this case.
How can you use it?
ownModuleList.json
(use ownModuleList_sample.json
as template). The only obligatory field is "url", but you can also enter a "branch".npm run ownList
.result.md
.package.json
is handled in different scripts. This could be done in one.result.md
to docs.MMM-Remote-Control
: https://github.com/Jopyth/MMM-Remote-Control/blob/master/modules.json / MMM-Remote-Control-Repository
https://github.com/MMRIZE/MMM-Remote-Control-Repositorynpm run all
extend the package.json in modules to collect more additional information (based on a proposal from MMRIZE)
"MagicMirror": {
"screenshot": {
"license": "MIT",
"url": "https://somewhere.com/screenshot.png"
},
"required": {
"mm": "2.25",
"node": "18.0",
"ApiKey": true
},
"notice" : [
"This will not work in Windows.",
"Pre-dependency required. Please read README."
]
}
package.json
: https://github.com/elliefairholm/on-this-day/issues/10moment
in use? https://momentjs.com/docs/#/-project-status/.
moment
is not really dead yet (it is no longer being developed, but it is still being maintained), so there is no urgent reason to change now. This is a test for the future when the Temporal API is ready.