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.

    Simple(?) module to send a notification every x minutes?

    Scheduled Pinned Locked Moved Solved Requests
    35 Posts 3 Posters 20.6k Views 3 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.
    • S Offline
      sdetweil @MMRIZE
      last edited by sdetweil

      @MMRIZE should wait til modules are ready. use interval timer

      @UncleRoger try this

      https://github.com/sdetweil/MMM-SendNotification

      Sam

      How to add modules

      learning how to use browser developers window for css changes

      M UncleRogerU 2 Replies Last reply Reply Quote 0
      • M Offline
        MMRIZE @sdetweil
        last edited by

        @sdetweil
        Yup. You are right.
        Just little things;

        • Generally, you are right. After ALL_MODULES_STARTED notification, it would be better to start communication. But sending notifications is harmless, so I put it into start, just for example.
        • Personally, I prefer loop of timeout than normal interval. But interval would be more obvious.
        S 1 Reply Last reply Reply Quote 0
        • UncleRogerU Offline
          UncleRoger @sdetweil
          last edited by UncleRoger

          @sdetweil said in Simple(?) module to send a notification every x minutes?:

          https://github.com/sdetweil/MMM-SendNotification

          Thank you so much! That got a lot farther than I ever did. When it gets to the point of actually sending the notification, however, I see an error in the browser console:

          sendNotification: Notification should be a string.
          

          As far as I can tell, the notification (this.config.notification) is a string. Is there something else that I can do to force it to be considered a string?

          Note: the only change I made was to add a bunch of console.log messages so I could try to understand what was going on and then, when I saw that error, commented out the sendnotification line (which made the error disappear). When I uncommented it, the error came back.

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

            @UncleRoger do a git pull in the module folder… just posted a fix

            Sam

            How to add modules

            learning how to use browser developers window for css changes

            UncleRogerU 1 Reply Last reply Reply Quote 0
            • UncleRogerU Offline
              UncleRoger @sdetweil
              last edited by

              @sdetweil
              Got the new version (typo in “notification”?) and it seems to work except that it ignores the interval and just constantly sends the notification.

              Also, there’s an error showing in the console log:

              Parameter mismatch in module.show: callback is not an optional parameter! 3 module.js:394:8
              

              with different numbers. I’m not sure that’s a problem (MMM-BackgroundSlideshow has the same error and it works fine) but I thought I’d mention it.

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

                @UncleRoger can u post the module config

                Sam

                How to add modules

                learning how to use browser developers window for css changes

                UncleRogerU 1 Reply Last reply Reply Quote 0
                • UncleRogerU Offline
                  UncleRoger @sdetweil
                  last edited by

                  @sdetweil
                  This is what I have:

                  {
                    module: 'MMM-SendNotification',
                    position: 'top_right',
                    classes: "fixed",
                    config: {
                      interval: 60000, // 1 minute interval
                      notification: 'PAGE_CHANGED',
                      payload: 1,
                    },
                  },
                  

                  Thank you for your patience and assistance! You are amazing!

                  S 2 Replies Last reply Reply Quote 0
                  • S Offline
                    sdetweil @UncleRoger
                    last edited by

                    @UncleRoger no position, as there is no UI…

                    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 @UncleRoger
                      last edited by sdetweil

                      @UncleRoger I ran your config in debug ( npm start dev) with a stop on the actual sendNotification and it happens once every minute.

                      I don’t have pages or carousel installed…
                      Screenshot at 2023-12-14 09-13-43.png

                      Sam

                      How to add modules

                      learning how to use browser developers window for css changes

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

                        @MMRIZE said in Simple(?) module to send a notification every x minutes?:

                        But sending notifications is harmless, so I put it into start, just for example.

                        not harmless to the receiver if not setup yet

                        Sam

                        How to add modules

                        learning how to use browser developers window for css changes

                        1 Reply Last reply Reply Quote 0
                        • UncleRogerU Offline
                          UncleRoger @sdetweil
                          last edited by

                          @sdetweil
                          I’ve no clue how to run it the way you did with the stop and all, but I did start commenting out modules and it seems that MMM-pages is the culprit.

                          Without it, SendNotification works fine but when it’s active, SendNotification sends multiple notifications per second:
                          9ecae590-6ded-457d-95e8-22d29295e0a3-image.png
                          It may be that MMM-pages is suspending and resuming MMM-SendNotification with each change, even though it’s set as “fixed”, and maybe that’s triggering it?

                          It may be that this is just something that won’t work for me.

                          I really appreciate your help!

                          S 2 Replies Last reply Reply Quote 0
                          • S Offline
                            sdetweil @UncleRoger
                            last edited by

                            @UncleRoger ok, I’ll check it out… hang on…

                            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 @UncleRoger
                              last edited by sdetweil

                              @UncleRoger ok… it was pages (for the error)

                              if you are using my fork

                                  cd ~/MagicMirror/modules/MMM-Pages
                                  git pull 
                              

                              if u are NOT using my fork

                              cd ~/MagicMirror/modules
                              

                              then rename the MMM-Pages folder out of the way (the command is mv)
                              then

                              git clone https://github.com/sdetweil/MMM-Pages
                              

                              also, two parms need to be added

                              here is the updated config

                              			{
                                      module: 'MMM-Pages',
                                      config: {
                                              modules:
                                                  [[ "page1" ],
                                                   [ "page2" ],
                                              //     [ "page3"],
                                                  ],
                                              fixed: [ "fixed" ],
                                              hiddenPages: {
                                                  "screenSaver": [ "screensaver_page" ],
                                                  "admin": [ "admin_page" ],
                                              },
                                              animationTime: 10000,
                                              rotationTime: 10000,
                                      }
                                    }
                              

                              rotationtime defaults to 0!!!

                              Sam

                              How to add modules

                              learning how to use browser developers window for css changes

                              UncleRogerU 1 Reply Last reply Reply Quote 0
                              • UncleRogerU Offline
                                UncleRoger @sdetweil
                                last edited by

                                @sdetweil
                                I switched to your fork and while it’s better, it’s still sending a notification every several seconds.
                                Here’s my config:

                                		{
                                			module: "MMM-Pages",
                                                        classes: "fixed",
                                			config:	{
                                				modules:[	[ "page1" ],
                                							[ "page2" ],
                                						],
                                				fixed: [ "fixed" ],
                                				rotationTime:	10000,
                                				animationTime:	10000,
                                			}
                                		},
                                

                                and

                                        {
                                            module: 'MMM-SendNotification',
                                            classes: "fixed",
                                            config: {
                                                interval: 3600000, // 1 minute interval
                                                notification: 'PAGE_CHANGED',
                                                payload: 1,
                                            },
                                        },
                                

                                (I upped the interval to see if that would do anything. It didn’t.)

                                I’ve commented out all the other modules except the clock, MMM-BackgroundSlideshow, and MMM-ViewNotifications.

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

                                  @UncleRoger ok, git pull the latest
                                  and restart

                                  I now check to see if the handler was turned off on resume, so don’t start another

                                  lmk

                                  Sam

                                  How to add modules

                                  learning how to use browser developers window for css changes

                                  UncleRogerU 1 Reply Last reply Reply Quote 0
                                  • UncleRogerU Offline
                                    UncleRoger @sdetweil
                                    last edited by

                                    @sdetweil
                                    That worked! Thank you so much!

                                    Now I am just being cheeky but if you are bored and want to add a feature, it would be great to be able to reset the timer based on a notification. (In my case, if MMM-Keypress sends a PAGE_INCREMENT notification to change pages, restart the timer from that point.)

                                    Anyway, I am getting really close to having everything the way I want it and am hoping that I can build an actual frame for the mirror and mount it next week and I couldn’t have done it without all your help (and so many others, like @MMRIZE and everyone who wrote the modules I’m using.) So, really, thank you!

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

                                      @UncleRoger done, git pull to update

                                      if the notification received matches the configured notification restart the timer

                                      Sam

                                      How to add modules

                                      learning how to use browser developers window for css changes

                                      UncleRogerU 1 Reply Last reply Reply Quote 0
                                      • UncleRogerU Offline
                                        UncleRoger @sdetweil
                                        last edited by

                                        @sdetweil
                                        You truly are amazing!

                                        Am I right in thinking that if I change this:

                                              } else if(topic==this.config.notification){
                                        

                                        to this:

                                              } else if(topic==this.config.resetNotification){
                                        

                                        and put this in the config:

                                        resetNotification: "DIFF_NOTIF",
                                        

                                        in addition to the notification: setting, then I can have it reset when a different notification is received? And I’m assuming all modules get all the notifications?

                                        This would be so that if someone comes up and pushed the button to switch to the info display close to the end of the timer, it will reset it so they have time to look at what they want.

                                        UncleRogerU S 3 Replies Last reply Reply Quote 0
                                        • UncleRogerU Offline
                                          UncleRoger @UncleRoger
                                          last edited by

                                          @sdetweil
                                          I made that change and it does indeed work as I’d hoped. This is totally awesome!

                                          Thank you!

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

                                            @UncleRoger yes, make sure to add a default value in the defaults section

                                            one could consider a list of notifications that cause reset, then you can search the list w includes()

                                            as it’s a list, you could pre or postpend the notification to send to that list too

                                            this stops the code from growing with other else clauses

                                            resetNotifications:[]

                                            in start maybe,
                                            this.config.resetNotifications.unshift(this.config.notification)

                                            that puts the actual notification of the front of the list

                                            the in notificationReceived

                                            if(this.config.resetNotifications.includes(notification)
                                            resetTimer()

                                            only one test

                                            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
                                            • 1 / 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