Read the statement by Michael Teeuw here.
How to load a <script> src = " " </script> into my mirror?
-
I also updated JSfiddle example with sum calculation logic: https://jsfiddle.net/morozgrafix/8oz1t9g4/2/
-
@morozgrafix Thanks for your outline. It is very, very helpful and appreciated. So I tried to take what you suggested to turn it into my code, and put it onto GitHub.
I created a GitHub repository that contains my
.css
,.csv
, anddatafeed.js
. My areas of confusion (which you’ll probably see in the code) are around how I called in theremoteFile
in my getDom. I am not sure if I did that correctly. https://github.com/brennn1/Magic-Mirror-Datafeed-ModuleMy
.csv
is coming in the format which you’ll see on the Github - so each data point is separated by a new line. So I changed where you had theline.split(",")
toline.split("\n")
.Do you see anything obvious that will cause me problems? I will go ahead and see what errors I get when I load it onto my mirror.
-
@nbrenn perfect!!! i can now see your full code and have better idea what you are trying to achieve.
Your data file is not really a CSV (Comma Separated Values) file, just a text file with values on each line, so you were correct to remove that
line.split(",")
part. I already spotted a few things where your code will not work correctly. I will take a closer look at it later tonight and hopefully together we can get this resolved. -
@nbrenn I’ve reworked the code to follow that logic outline to get
Your sum is 37
to show up in the middle of the MM. You can find a PR on GitHub or just look at my fork of your repo. Most of the code is commented and hopefully easy to follow. I also added some configuration options for better flexibility.Since you didn’t need a table any longer, I took some shortcuts with processing the data and just calculating the sum of all numeric values from the file. You can add the module to the MM and then as it runs update the datafile with new values, MM should update in about a minute or whatever your
updateInterval
is set to.Let me know if you have any questions.
P.S. I didn’t run it on RasPi, but it should work without a problem. :fingers_crossed: Also if you are planning to make this module available for others it may be worth renaming it to
MMM-datafeed
to follow the standard naming conventions. -
@morozgrafix This looks awesome! I will try to work with this over the next couple days and will let you know if I have any other questions! Thanks!
-
@nbrenn sounds good. Good luck!
-
@morozgrafix Everything is working very well so far!
I am updating my “Sum” daily, but I would like to be able to show the previous day’s sum. Could I store the value of the sum at 11:59pm, each evening, and then display that value in addition to the current day’s sum?
Additionally, how could I modify the line of code:
this.sum = lines.reduce((a, b) => a + b, 0);
to allow for me to sum across multiple columns? So, if my .csv has 3 columns, I’d like the sum total of them.
-
This post is deleted! -
@nbrenn sorry swamped at work today. That line just takes all of the values from each line and adds them up. It will not work for multiple columns and true csv files. You would need to resort to logic that we had initially in JSfiddle. If I have time I will look into this later today.
-
@morozgrafix I think I can work around this by changing the SQL query (that generates my .csv) to include just one column. Then I can implement it as a new module, placed above the current one.