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.

    How can I update my chart?

    Scheduled Pinned Locked Moved Troubleshooting
    21 Posts 3 Posters 7.3k 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.
    • D Offline
      doridol @sdetweil
      last edited by

      @sdetweil I define myChart in getDom like this

      getDom: function () {
                  const wrapper = document.createElement("div");
                  
                  this.ctx = document.createElement("canvas");
                  this.ctx.style.width = "700px";
                  this.ctx.style.height = '700px';
                  
                  wrapper.appendChild(this.ctx)
                  
                  labels = [2,4,6,8]
                  
                  this.myChart = new Chart(this.ctx, {
      
                      type: 'line',
                      data: {
                          labels: labels,
                          
                          datasets: [{
                              
                              data: [1,2,3,4],
      
                              backgroundColor: 'rgba(255,255,255,0.3)',
                              borderColor: 'white',
                              
                              borderWidth: 2,
                              
                              fill: true,
                              
                          }]
                      },
      
                      options: {
      
                          title: {
                                  display: true,
                                  text: 'Air-Quality',
                          },
      
                          scales: {
      
                              xAxes: [{
      
                                  gridLines: {
                                      color: 'rgba(255,255,255,0.2)',
                                  },
                              }],
                          },
                      }
                  });
                  return wrapper;
              }
          });
      

      and I’ll only update myChart in socketNotificationReceived

      S 1 Reply Last reply Reply Quote 0
      • S Do not disturb
        sdetweil @doridol
        last edited by

        @doridol that is USE, not really define

        I don’t like side effects… create on 1st use… ugh.

        also, you will UPDATE in notification, but need to CREATE in getdom, or somewhere

        Sam

        How to add modules

        learning how to use browser developers window for css changes

        D 2 Replies Last reply Reply Quote 0
        • D Offline
          doridol @sdetweil
          last edited by

          @sdetweil oh… it is very difficult to update chart… really thanks for your help I seem I have to study more…

          1 Reply Last reply Reply Quote 0
          • D Offline
            doridol @sdetweil
            last edited by

            @sdetweil I have really really last question I changed my socketNotificationReceived like this

            socketNotificationReceived: function(notification, payload) {
                        if (notification === "TEXT_RESULT") {
                            this.textDataRecived = payload;
                            this.loaded = true;
                        }
            
                        
                        if(count < 2)
                        {
                            this.updateDom();
                            count = count + 1;
                        }
                        else
                        {
                            this.myChart.data.datasets.data = this.textDataRecived
                            console.log(this.myChart.data.datasets.data)
                            this.myChart.update();
                        }
                    },
            

            and console.log(this.myChart.data.datasets.data) successfully print this.textDataRecived but my chart is not updated in the screen why???

            S 1 Reply Last reply Reply Quote 0
            • S Do not disturb
              sdetweil @doridol
              last edited by

              @doridol i do not know anything about the chart.update() method… I don’t use it.

              Sam

              How to add modules

              learning how to use browser developers window for css changes

              D 1 Reply Last reply Reply Quote 0
              • D Offline
                doridol @sdetweil
                last edited by

                @sdetweil okay thanks for you a lot of help:beaming_face_with_smiling_eyes:

                S 1 Reply Last reply Reply Quote 0
                • S Do not disturb
                  sdetweil @doridol
                  last edited by

                  @doridol i use destroy() and then build another

                  Sam

                  How to add modules

                  learning how to use browser developers window for css changes

                  D 1 Reply Last reply Reply Quote 0
                  • D Offline
                    doridol @sdetweil
                    last edited by doridol

                    @sdetweil I finally update my chart with this.myChart.update()!!! it is all for your help now I can get sleep…

                    1 Reply Last reply Reply Quote 0
                    • 1
                    • 2
                    • 3
                    • 3 / 3
                    • 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