MagicMirror Forum
    • Recent
    • Tags
    • Unsolved
    • Solved
    • MagicMirror² Repository
    • Documentation
    • 3rd-Party-Modules
    • Donate
    • Discord
    • Register
    • Login
    A New Chapter for MagicMirror: The Community Takes the Lead
    Read the statement by Michael Teeuw here.

    Default Weather module still not displaying

    Scheduled Pinned Locked Moved Solved Troubleshooting
    39 Posts 6 Posters 16.3k Views 6 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • Jarhead96097J Offline
      Jarhead96097 @OldSunGuy
      last edited by

      @OldSunGuy I use the MMM-ModuleScheduler 3rd party module to control when my MM turns off everything except the clock and dims the display at night. “daytime_scheduler” is the class I used to turn off those modules at night.

      Jarhead96097

      1 Reply Last reply Reply Quote 0
      • Jarhead96097J Offline
        Jarhead96097 @sdetweil
        last edited by

        @sdetweil here is what my weather.js (newly rebuilt, but not yet configured) has on lines 148 to 166:

        	// What to do when the weather provider has new information available?
        	updateAvailable: function () {
        		Log.log("New weather information available.");
        		this.updateDom(0);
        		this.scheduleUpdate();
        
        		if (this.weatherProvider.currentWeather()) {
        			this.sendNotification("CURRENTWEATHER_TYPE", { type: this.weatherProvider.currentWeather().weatherType.replace("-", "_") });
        		}
        
        		const notificationPayload = {
        			currentWeather: this.weatherProvider?.currentWeatherObject?.simpleClone() ?? null,
        			forecastArray: this.weatherProvider?.weatherForecastArray?.map((ar) => ar.simpleClone()) ?? [],
        			hourlyArray: this.weatherProvider?.weatherHourlyArray?.map((ar) => ar.simpleClone()) ?? [],
        			locationName: this.weatherProvider?.fetchedLocationName,
        			providerName: this.weatherProvider.providerName
        		};
        		this.sendNotification("WEATHER_UPDATED", notificationPayload);
        	},
        

        Jarhead96097

        Jarhead96097J S 2 Replies Last reply Reply Quote 0
        • Jarhead96097J Offline
          Jarhead96097 @Jarhead96097
          last edited by

          @sdetweil Sam, thanks for all of your help. I’ve finished rebuilding without running ‘npm audit fix’ and everything is working as it should! I used your installation script and everything worked fine. I also took the opportunity to move things around and try a couple of new 3rd party modules… everything is back to normal!

          Thanks again,
          Jarhead96097

          Jarhead96097

          S 1 Reply Last reply Reply Quote 1
          • S Offline
            sdetweil @Jarhead96097
            last edited by

            @Jarhead96097 said in Default Weather module still not displaying:

              const notificationPayload = {
              	currentWeather: this.weatherProvider?.currentWeatherObject?.simpleClone() ?? null,
            

            thats line 158 and159.

            the only thing i can think of is the ?. (optional chaining) operator…
            but its been long supported… and it works on my 16.9.1 node version

            see item 2 in the list here
            https://www.freecodecamp.org/news/how-the-question-mark-works-in-javascript/

            Sam

            How to add modules

            learning how to use browser developers window for css changes

            1 Reply Last reply Reply Quote 0
            • S Offline
              sdetweil @Jarhead96097
              last edited by

              @Jarhead96097 great news!!!

              Sam

              How to add modules

              learning how to use browser developers window for css changes

              1 Reply Last reply Reply Quote 0
              • B Offline
                Blackeye @sdetweil
                last edited by

                @sdetweil Moin, line 159 of weather-js looks like this:

                currentWeather: this.weatherProvider?.currentWeatherObject?.simpleClone() ?? null,
                

                The pm2 error log shows:

                /home/<myusername>/.pm2/logs/MagicMirror-error.log last 50 lines:
                1|MagicMir | failed to load swrast driver
                1|MagicMir | [06.08.2022 09:46.00.374] [ERROR] WARNING! Could not load config file. Starting with default configuration. Error found: Error: The module '/home/lookyhere/MagicMirror/modules/MMM-PIR-Sensor/node_modules/epoll/build/Release/epoll.node'
                1|MagicMir | was compiled against a different Node.js version using
                1|MagicMir | NODE_MODULE_VERSION 73. This version of Node.js requires
                1|MagicMir | NODE_MODULE_VERSION 107. Please try re-compiling or re-installing
                1|MagicMir | the module (for instance, using `npm rebuild` or `npm install`).
                

                Looks like I should re-install. Which is the best method, in your opinion?
                Many thanks for your help - I want to get this thing on the wall soon!

                S 1 Reply Last reply Reply Quote 0
                • S Offline
                  sdetweil @Blackeye
                  last edited by

                  @Blackeye see

                  https://forum.magicmirror.builders/topic/16074/electron-rebuild-and-magicmirror-v2-18-and-more?page=1

                  Sam

                  How to add modules

                  learning how to use browser developers window for css changes

                  B 1 Reply Last reply Reply Quote 0
                  • B Offline
                    Blackeye @sdetweil
                    last edited by

                    @sdetweil Hi Sam, Many thanks for the suggestion - I followed your advice on that page. Here’s what happened halfway through:

                    from ../src/epoll.cc:11:
                    /home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node_modules/epoll/20.0.1/include/node/v8-ma                                     ybe.h:106:45: error: ‘is_lvalue_reference_v’ is not a member of ‘std’; did you mean ‘is_lvalue_                                     reference’?
                      106 |   template <class U, std::enable_if_t<!std::is_lvalue_reference_v<U>>*>
                          |                                             ^~~~~~~~~~~~~~~~~~~~~
                          |                                             is_lvalue_reference
                    /home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node_modules/epoll/20.0.1/include/node/v8-ma                                     ybe.h:106:66: warning: logical not is only applied to the left hand side of comparison [-Wlogic                                     al-not-parentheses]
                      106 |   template <class U, std::enable_if_t<!std::is_lvalue_reference_v<U>>*>
                          |                                                                  ^
                    /home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node_modules/epoll/20.0.1/include/node/v8-ma                                     ybe.h:106:67: error: template argument 1 is invalid
                      106 |   template <class U, std::enable_if_t<!std::is_lvalue_reference_v<U>>*>
                          |                                                                   ^
                    /home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node_modules/epoll/20.0.1/include/node/v8-ma                                     ybe.h:106:71: error: expected unqualified-id before ‘>’ token
                      106 |   template <class U, std::enable_if_t<!std::is_lvalue_reference_v<U>>*>
                          |                                                                       ^
                    /home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node_modules/epoll/20.0.1/include/node/v8-ma                                     ybe.h:123:43: error: ‘is_lvalue_reference_v’ is not a member of ‘std’; did you mean ‘is_lvalue_                                     reference’?
                      123 | template <class T, std::enable_if_t<!std::is_lvalue_reference_v<T>>* = nullptr>
                    
                    

                    and finally:

                    ✖ MagicMirror Rebuild Failed
                    
                    An unhandled error occurred inside electron-rebuild
                    node-gyp failed to rebuild '/home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node_modules/epo                                     ll'.
                    Error: `make` failed with exit code: 2
                    

                    This will all mean a lot more to you than it does for me.

                    B 1 Reply Last reply Reply Quote 0
                    • B Offline
                      Blackeye @Blackeye
                      last edited by

                      @sdetweil And this is the final part of the error message, in bright red:

                       at ModuleRebuilder.rebuildNodeGypModule (/home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor                                     /node_modules/magicmirror-rebuild/build/module-rebuilder.js:193:19)
                          at processTicksAndRejections (node:internal/process/task_queues:96:5)
                          at async Rebuilder.rebuildModuleAt (/home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node                                     _modules/magicmirror-rebuild/build/rebuild.js:180:9)
                          at async Rebuilder.rebuild (/home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node_modules                                     /magicmirror-rebuild/build/rebuild.js:143:17)
                          at async /home/<myusername>/MagicMirror/modules/MMM-PIR-Sensor/node_modules/magicmirror-rebuil                                     d/build/cli.js:141:9
                      
                      
                      S 2 Replies Last reply Reply Quote 0
                      • S Offline
                        sdetweil @Blackeye
                        last edited by

                        @Blackeye hm. 1st time I’ve seen his tools fail…

                        @bugsounet any guidance

                        Sam

                        How to add modules

                        learning how to use browser developers window for css changes

                        bugsounetB 1 Reply Last reply Reply Quote 0
                        • bugsounetB Offline
                          bugsounet Banned @sdetweil
                          last edited by bugsounet

                          @sdetweil yes

                          epoll/20.0.1 means it uses electron v20.0.1 for MagicMirror instead of v19.x that why it crash.

                          I’ll leave it up to you to explain it :)

                          1 Reply Last reply Reply Quote 0
                          • S Offline
                            sdetweil @Blackeye
                            last edited by sdetweil

                            @Blackeye ok, heres a way around the problem

                            fix MM install to have one new tool

                            cd ~/MagicMirror
                            npm install electron-rebuild
                            

                            fix MMM-PIR-Sensor

                            cd ~/MagicMirror/modules/MMM-PIR-Sensor
                            nano package.json 
                            

                            scroll down to

                              "scripts": {
                                "postinstall": "node_modules/.bin/electron-rebuild -e ../../node_modules/electron"
                              },
                            

                            change the postinstall line so it looks like this

                              "scripts": {
                                "postinstall": "~/MagicMirror/node_modules/.bin/electron-rebuild -e ../../node_modules/electron"
                              },
                            

                            ctrl-o to save the updated package.json
                            ctrl-x to exit the editor

                            then

                            npm install
                            

                            should work correctly now

                            I just tested this on my MM 2.20 version, on both my linux machine and my pi4 with bullseye

                            Sam

                            How to add modules

                            learning how to use browser developers window for css changes

                            B 1 Reply Last reply Reply Quote 0
                            • B Offline
                              Blackeye @sdetweil
                              last edited by Blackeye

                              @sdetweil said in Default Weather module still not displaying:

                              ~/MagicMirror/node_modules/.bin/electron-rebuild -e …/…/node_modules/electron

                              Yes! It installed correctly this time, so that change in the path did the trick. I did get some warnings however:

                              npm WARN deprecated har-validator@5.1.5: this library is no longer supported
                              npm WARN deprecated uuid@3.4.0: Please upgrade  to version 7 or higher.  Older versions may use Math.random() in certain cir                                 cumstances, which is known to be problematic.  See https://v8.dev/blog/math-random for details.
                              npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142
                              

                              So it is not quite a perfect solution, but it works!
                              Many thanks for the suggestions and the solution!

                              S 1 Reply Last reply Reply Quote 0
                              • S Offline
                                sdetweil @Blackeye
                                last edited by

                                @Blackeye ignore the warnings, nothing we can do about them.

                                the ‘problem’ here is that the compiler needs to know what version of electron to build for, but can’t figure it out.

                                using electron-rebuild from the mm libs solves that

                                Sam

                                How to add modules

                                learning how to use browser developers window for css changes

                                1 Reply Last reply Reply Quote 0

                                Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                With your input, this post could be even better 💗

                                Register Login
                                • 1
                                • 2
                                • 2 / 2
                                • First post
                                  Last post
                                Enjoying MagicMirror? Please consider a donation!
                                MagicMirror created by Michael Teeuw.
                                Forum managed by Sam, technical setup by Karsten.
                                This forum is using NodeBB as its core | Contributors
                                Contact | Privacy Policy