Navigation

    MagicMirror Forum

    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unsolved
    • Solved
    • MagicMirror² Repository
    • Documentation
    • Donate
    • Discord
    MagicMirror² v2.15.0 is available! For more information about this release, check out this topic.

    module develop help!

    Development
    3
    11
    3340
    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.
    • wireshark
      wireshark last edited by

      This post is deleted!
      Sean 1 Reply Last reply Reply Quote 0
      • Sean
        Sean Module Developer @wireshark last edited by

        @wireshark
        You have not understood the structure of MagicMirror module and basic javascript syntax.
        I suggest you study more with other modules.

        1 Reply Last reply Reply Quote 0
        • Sean
          Sean Module Developer last edited by

          Usually, a MagicMirror module should have several method implementations.

          .start() : called when module is loaded on bootup. (and after all modules are loaded.) You could use this function for initialization.
          .getDom() : called when view of modules is needed to refresh You could use this function to draw your content on Mirror.

          And there are many points to study.
          See this. https://github.com/MichMich/MagicMirror/tree/develop/modules

          wireshark 1 Reply Last reply Reply Quote 0
          • wireshark
            wireshark @Sean last edited by

            This post is deleted!
            Sean 1 Reply Last reply Reply Quote 0
            • Sean
              Sean Module Developer @wireshark last edited by

              @wireshark I didn’t look inside deeply.
              But in getDom() didn’t you draw anything. You just try to alert something on success.
              Ok, maybe you are just in developing stage. It’s ok.
              So, You should invoke getDom() with updateDom() when it is needed.
              By example, in your start(), you can update your dom like this.

              start: function() {
                var self = this
                setInterval(function(){
                  self.updateDom()
                }, 60*1000)
              },
              

              After loaded, this module function start() would set interval timer to execute updateDom() for refreshing view. every time when updateDom() is called, getDom() will be executed. So, your getDom() will be executed every 60*1000 milsec.

              1 Reply Last reply Reply Quote 0
              • Sean
                Sean Module Developer last edited by Sean

                But this is not so good, because, start() could be executed before DOM created. This could give your module unintended errors. My recommendation is starting your job after DOM_OBJECTS_CREATED notification received. This notification would be fired when all modules are loaded and draw their first DOM view.

                notificationReceived: function(noti, payload, sender) {
                  if (noti == "DOM_OBJECTS_CREATED") {
                    //do your job
                    // e.g) set Timer to refreshing data and update view with updateDom()
                  }
                },
                
                1 Reply Last reply Reply Quote -1
                • Sean
                  Sean Module Developer last edited by

                  And the last, you SHOULD DRAW YOUR DOM for real rendering.

                  getDom: function() {
                    // do your job...
                    yourDOM = document.createElement("div")
                    yourDOM.innerHTML = "Something"
                    return yourDOM // DOM which has your content inside, should be returned.
                  },
                  
                  
                  
                  wireshark 1 Reply Last reply Reply Quote 0
                  • wireshark
                    wireshark @Sean last edited by

                    This post is deleted!
                    Sean 1 Reply Last reply Reply Quote 0
                    • Sean
                      Sean Module Developer @wireshark last edited by

                      @wireshark
                      Run with npm start dev. And see the logs and errors. They tell you what are real problems. And even for us, without exact information, we couldn’t help.
                      Anyway, what it means ‘doesn’t work’? It has errors? Black screen?
                      I think if it works, just alert window would be popped up. (Return value of xhr.send() might be not what you really want.) You’d better to investigate codes around alert().

                      wireshark 1 Reply Last reply Reply Quote 0
                      • wireshark
                        wireshark @Sean last edited by

                        This post is deleted!
                        1 Reply Last reply Reply Quote 0
                        • 1
                        • 2
                        • 1 / 2
                        • First post
                          Last post
                        Enjoying MagicMirror? Please consider a donation!
                        MagicMirror created by Michael Teeuw.
                        Forum managed by Paul-Vincent Roll and Rodrigo Ramírez Norambuena.
                        This forum is using NodeBB as its core | Contributors
                        Contact | Privacy Policy