Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. JSON Tabelle FuelPriceMonitor [Austria]

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.5k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    985

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.3k

JSON Tabelle FuelPriceMonitor [Austria]

Scheduled Pinned Locked Moved JavaScript
77 Posts 6 Posters 8.0k Views 7 Watching
  • 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.
  • liv-in-skyL liv-in-sky

    @mrfloppy

    ändere mal diese zeile 151

    Image 204.png

    das ist der code zum einsetzen:

    else {if (ergebnis=="") ergebnis=mylat+','+mylong}
    
    M Offline
    M Offline
    mrfloppy
    wrote on last edited by
    #59

    @liv-in-sky
    schau mal

    Screenshot 2023-02-13 202548.jpg Screenshot 2023-02-13 165807.jpg

    vor 3Std hatte der Lohberger noch KM, jetzt nicht mehr.

    liv-in-skyL 2 Replies Last reply
    0
    • M mrfloppy

      @liv-in-sky
      schau mal

      Screenshot 2023-02-13 202548.jpg Screenshot 2023-02-13 165807.jpg

      vor 3Std hatte der Lohberger noch KM, jetzt nicht mehr.

      liv-in-skyL Offline
      liv-in-skyL Offline
      liv-in-sky
      wrote on last edited by
      #60

      @mrfloppy

      dann müßtest du bitte mal rausfinden, ob es wieder diese ID öfters als ordner gibt

      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

      M 1 Reply Last reply
      0
      • liv-in-skyL liv-in-sky

        @mrfloppy

        dann müßtest du bitte mal rausfinden, ob es wieder diese ID öfters als ordner gibt

        M Offline
        M Offline
        mrfloppy
        wrote on last edited by mrfloppy
        #61

        @liv-in-sky sehe gerade was anderes-> schau mal
        dd8d397c-8133-45c2-9d84-ffcb3ee14c16-image.png
        da stimmt was mit der liste gar nicht
        der ist gar nicht auf Platz 2 (DP 1)

        Edit: Wenn ich das Script neu starte stimmt die JsonListe in der VIS
        Ist das Update deines Scriptes ev zu schnell? Und die DP noch nicht fertig geschrieben im FUELPRICE?

        liv-in-skyL 1 Reply Last reply
        0
        • M mrfloppy

          @liv-in-sky
          schau mal

          Screenshot 2023-02-13 202548.jpg Screenshot 2023-02-13 165807.jpg

          vor 3Std hatte der Lohberger noch KM, jetzt nicht mehr.

          liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          wrote on last edited by
          #62

          @mrfloppy hast du mal den browser refresht - evtl sind die dp nicht upgerdatet im admin

          nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

          M 1 Reply Last reply
          0
          • liv-in-skyL liv-in-sky

            @mrfloppy hast du mal den browser refresht - evtl sind die dp nicht upgerdatet im admin

            M Offline
            M Offline
            mrfloppy
            wrote on last edited by
            #63

            @liv-in-sky ja habe ich gehabt

            1 Reply Last reply
            0
            • M mrfloppy

              @liv-in-sky sehe gerade was anderes-> schau mal
              dd8d397c-8133-45c2-9d84-ffcb3ee14c16-image.png
              da stimmt was mit der liste gar nicht
              der ist gar nicht auf Platz 2 (DP 1)

              Edit: Wenn ich das Script neu starte stimmt die JsonListe in der VIS
              Ist das Update deines Scriptes ev zu schnell? Und die DP noch nicht fertig geschrieben im FUELPRICE?

              liv-in-skyL Offline
              liv-in-skyL Offline
              liv-in-sky
              wrote on last edited by
              #64

              @mrfloppy

              ich muss das morgen ansehen - heute geht leider nicht

              aber wenn ich so schnell drüber nachdenke - das script wird getriggert, wenn der erste dp geschrieben wird - evtl kann tatsächlich das script schneller sein, als der adapter

              du kannst mal das noch testen ungefähr bei zeile 70 diesen "on" block austauschen mit

              on({id: triggerArr, change: "ne"}, async function (obj) {
                  var value = obj.state.val;
                  var oldValue = obj.oldState.val;
                  if (myPause) {setTimeout(async function () { mainFunc();}, 5000); /*log("Wert: "+value+" ID: "+obj.id+" AlterWert: "+oldValue);*/ myPause=false; setTimeout(async function () { myPause=true;}, 10000);}
                });
              

              nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

              M 1 Reply Last reply
              0
              • liv-in-skyL liv-in-sky

                @mrfloppy

                ich muss das morgen ansehen - heute geht leider nicht

                aber wenn ich so schnell drüber nachdenke - das script wird getriggert, wenn der erste dp geschrieben wird - evtl kann tatsächlich das script schneller sein, als der adapter

                du kannst mal das noch testen ungefähr bei zeile 70 diesen "on" block austauschen mit

                on({id: triggerArr, change: "ne"}, async function (obj) {
                    var value = obj.state.val;
                    var oldValue = obj.oldState.val;
                    if (myPause) {setTimeout(async function () { mainFunc();}, 5000); /*log("Wert: "+value+" ID: "+obj.id+" AlterWert: "+oldValue);*/ myPause=false; setTimeout(async function () { myPause=true;}, 10000);}
                  });
                
                M Offline
                M Offline
                mrfloppy
                wrote on last edited by
                #65

                @liv-in-sky
                danke, getauscht und werde beobachten die nächsten Tage

                liv-in-skyL 1 Reply Last reply
                0
                • M mrfloppy

                  @liv-in-sky
                  danke, getauscht und werde beobachten die nächsten Tage

                  liv-in-skyL Offline
                  liv-in-skyL Offline
                  liv-in-sky
                  wrote on last edited by
                  #66

                  @mrfloppy ich hatte heute morgen auch 2 mit 0 als km - da waren aber tasächlich 2 ordner mit der id vorhanden und in beiden ordnern war die location null

                  von daher

                  • wenn wieder ein 0km steht, bitte nach den ordnern mit der id suchen und kontrollieren, ob da was drinsteht
                  • und auch ab und zu die daten auf richtigkeit überprüfen - es muss nämlich ein ganz besonderer fall sein, damit da die alten daten drinstehen - und zwar, wenn einer der ersten 2-3 datensätze verändert wird, dann kann es sein, das das script sofort losgelaufen ist und schneller war als der adapter - sollte aber jetzt behoben sein

                  nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                  1 Reply Last reply
                  0
                  • liv-in-skyL liv-in-sky

                    hier ein script um den Fuelpricemonitor adapter in die vis zu bekommen (und telegram)

                    @mrfloppy
                    @Chaot
                    @Negalein

                    • show cheapest overall stations muss in instanz aktiviert sein
                    • ich nutze das inventwo widget und das map widget - muss dann auch installiert sein (inventwo funktioniert nicht mit vis app)
                    • pro sprit typ entsteht eine tabelle - dp unter:0_userdata.0.FUELPRICEMONITOR
                    • es gibt einen dp mit den telegram-text und im setting kann aktiviert werden dass es autom. eine nachricht an teleg. sendet (nachricht wird upgedatet und nicht neu geschrieben)
                    • im oberen bereich des scriptes das setting beachten und einstellen
                    • Die Bilder müssen unter /vis.0/Tankstellen mit dem vis dateimanager hochgeladen werden

                    sieht dann so aus (beispiel: super und diesel):

                    Image 186.png

                    Image 180.png

                    Image 182.png

                    bilder.7z

                    [{"tpl":"tplOsm","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","mCount":"6","maxZoom":"0","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"hideControls":true,"markersSwap1":true,"markersLon-oid1":"javascript.0.FUELPRICEMONITOR.Targets.SUP0er","markersLat-oid1":"","markersWidth1":"13","markersHeight1":"13","markersOffsetX1":"","markersOffsetY1":"","markersImage1":"/vis.0/armin/img/zahl/1-green.png","markersLon-oid2":"javascript.0.FUELPRICEMONITOR.Targets.SUP1er","markersSwap2":true,"markersLon-oid3":"javascript.0.FUELPRICEMONITOR.Targets.SUP2er","markersSwap3":true,"markersLon-oid4":"javascript.0.FUELPRICEMONITOR.Targets.SUP3er","markersSwap4":true,"markersImage4":"/vis.0/armin/img/zahl/4-green.png","markersImage3":"/vis.0/armin/img/zahl/3-green.png","markersImage2":"/vis.0/armin/img/zahl/2-green.png","markersLon-oid6":"javascript.0.FUELPRICEMONITOR.Targets.home","markersSwap6":true,"markersImage6":"/vis.0/armin/img/haus2.png","g_markers_§4":true,"markersWidth2":"13","markersHeight2":"13","markersWidth3":"13","markersHeight3":"13","markersWidth4":"13","markersHeight4":"13","markersWidth6":"17","markersHeight6":"17","markersLon-oid5":"javascript.0.FUELPRICEMONITOR.Targets.SUP4er","markersSwap5":true,"markersImage5":"/vis.0/armin/img/zahl/5-green.png","markersWidth5":"13","markersHeight5":"13"},"style":{"left":"699px","top":"54px","width":"341px","height":"220px","z-index":"600"},"widgetSet":"map"},{"tpl":"tplOsm","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","mCount":"6","maxZoom":"0","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"hideControls":true,"markersSwap1":true,"markersLon-oid1":"javascript.0.FUELPRICEMONITOR.Targets.DIE0er","markersLat-oid1":"","markersWidth1":"13","markersHeight1":"13","markersOffsetX1":"","markersOffsetY1":"","markersImage1":"/vis.0/armin/img/zahl/1-green.png","markersLon-oid2":"javascript.0.FUELPRICEMONITOR.Targets.DIE1er","markersSwap2":true,"markersLon-oid3":"javascript.0.FUELPRICEMONITOR.Targets.DIE2er","markersSwap3":true,"markersLon-oid4":"javascript.0.FUELPRICEMONITOR.Targets.DIE3er","markersSwap4":true,"markersImage4":"/vis.0/armin/img/zahl/4-green.png","markersImage3":"/vis.0/armin/img/zahl/3-green.png","markersImage2":"/vis.0/armin/img/zahl/2-green.png","markersLon-oid6":"javascript.0.FUELPRICEMONITOR.Targets.home","markersSwap6":true,"markersImage6":"/vis.0/armin/img/haus2.png","g_markers_§4":true,"markersWidth2":"13","markersHeight2":"13","markersWidth3":"13","markersHeight3":"13","markersWidth4":"13","markersHeight4":"13","markersWidth6":"17","markersHeight6":"17","markersLon-oid5":"javascript.0.FUELPRICEMONITOR.Targets.DIE4er","markersSwap5":true,"markersImage5":"/vis.0/armin/img/zahl/5-green.png","markersWidth5":"13","markersHeight5":"13"},"style":{"left":"698px","top":"310px","width":"341px","height":"220px"},"widgetSet":"map"},{"tpl":"i-vis-jsontable","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":true,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","iTblRowLimit":"20","iTableRefreshRate":"0","iTblSortOrder":"asc","iColCount":"8","iColShow1":false,"iTblHeadTextAlign1":"center","iTblTextAlign1":"center","iTblCellFormat1":"normal","iTblCellImageSize1":"200","iTblCellBooleanCheckbox1":"false","iTblCellBooleanColorFalse1":"#ff0000","iTblCellBooleanColorTrue1":"#00ff00","iTblCellNumberDecimals1":"2","iTblCellNumberDecimalSeperator1":".","iTblCellNumberThousandSeperator1":",","iTblCellThresholdsDp1":"","iTblCellThresholdsText1":"","iOpacityAll":"1","iTblRowEvenColor":"#060d14","iTblRowUnevenColor":"#1d1f20","iTblHeaderColor":"#fff","iRowSpacing":"3.4","iTblRowEvenTextColor":"#ffffff","iTblRowUnevenTextColor":"#ffffff","iTblHeaderTextColor":"#000","iBorderSize":"0","iBorderStyleLeft":"none","iBorderStyleRight":"none","iBorderStyleUp":"none","iBorderStyleDown":"none","iBorderColor":"#ffffff","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"oid":"0_userdata.0.FUELPRICEMONITOR.DIEJsonAnzeige","iTblShowHead":true,"iColShow2":"true","iTblHeadTextAlign2":"left","iTblTextAlign2":"left","iTblCellFormat2":"image","iTblCellImageSize2":"30","iTblCellBooleanCheckbox2":"false","iTblCellBooleanColorFalse2":"#ff0000","iTblCellBooleanColorTrue2":"#00ff00","iTblCellNumberDecimals2":"2","iTblCellNumberDecimalSeperator2":".","iTblCellNumberThousandSeperator2":",","iTblCellThresholdsDp2":"","iTblCellThresholdsText2":"","iColShow3":"true","iTblHeadTextAlign3":"left","iTblTextAlign3":"left","iTblCellFormat3":"normal","iTblCellImageSize3":"200","iTblCellBooleanCheckbox3":false,"iTblCellBooleanColorFalse3":"#ff0000","iTblCellBooleanColorTrue3":"#00ff00","iTblCellNumberDecimals3":"2","iTblCellNumberDecimalSeperator3":".","iTblCellNumberThousandSeperator3":",","iTblCellThresholdsDp3":"","iTblCellThresholdsText3":"","iColShow4":"true","iTblHeadTextAlign4":"left","iTblTextAlign4":"left","iTblCellFormat4":"normal","iTblCellImageSize4":"200","iTblCellBooleanCheckbox4":"false","iTblCellBooleanColorFalse4":"#ff0000","iTblCellBooleanColorTrue4":"#00ff00","iTblCellNumberDecimals4":"2","iTblCellNumberDecimalSeperator4":".","iTblCellNumberThousandSeperator4":",","iTblCellThresholdsDp4":"","iTblCellThresholdsText4":"","iColShow5":true,"iTblHeadTextAlign5":"center","iTblTextAlign5":"center","iTblCellFormat5":"normal","iTblCellImageSize5":"200","iTblCellBooleanCheckbox5":"false","iTblCellBooleanColorFalse5":"#ff0000","iTblCellBooleanColorTrue5":"#00ff00","iTblCellNumberDecimals5":"2","iTblCellNumberDecimalSeperator5":".","iTblCellNumberThousandSeperator5":",","iTblCellThresholdsDp5":"","iTblCellThresholdsText5":"","iColShow6":false,"iTblHeadTextAlign6":"center","iTblTextAlign6":"center","iTblCellFormat6":"normal","iTblCellImageSize6":"200","iTblCellBooleanCheckbox6":"false","iTblCellBooleanColorFalse6":"#ff0000","iTblCellBooleanColorTrue6":"#00ff00","iTblCellNumberDecimals6":"2","iTblCellNumberDecimalSeperator6":".","iTblCellNumberThousandSeperator6":",","iTblCellThresholdsDp6":"","iTblCellThresholdsText6":"","iColShow7":false,"iTblHeadTextAlign7":"center","iTblTextAlign7":"center","iTblCellFormat7":"normal","iTblCellImageSize7":"200","iTblCellBooleanCheckbox7":"false","iTblCellBooleanColorFalse7":"#ff0000","iTblCellBooleanColorTrue7":"#00ff00","iTblCellNumberDecimals7":"2","iTblCellNumberDecimalSeperator7":".","iTblCellNumberThousandSeperator7":",","iTblCellThresholdsDp7":"","iTblCellThresholdsText7":"","iColShow8":"true","iTblHeadTextAlign8":"center","iTblTextAlign8":"center","iTblCellFormat8":"normal","iTblCellImageSize8":"200","iTblCellBooleanCheckbox8":"false","iTblCellBooleanColorFalse8":"#ff0000","iTblCellBooleanColorTrue8":"#00ff00","iTblCellNumberDecimals8":"2","iTblCellNumberDecimalSeperator8":".","iTblCellNumberThousandSeperator8":",","iTblCellThresholdsDp8":"","iTblCellThresholdsText8":"","iColShow9":"true","iTblHeadTextAlign9":"center","iTblTextAlign9":"center","iTblCellFormat9":"normal","iTblCellImageSize9":"200","iTblCellBooleanCheckbox9":"false","iTblCellBooleanColorFalse9":"#ff0000","iTblCellBooleanColorTrue9":"#00ff00","iTblCellNumberDecimals9":"2","iTblCellNumberDecimalSeperator9":".","iTblCellNumberThousandSeperator9":",","iTblCellThresholdsDp9":"","iTblCellThresholdsText9":"","iTblFixedHead":true,"iTblSortAttr":"","iColName1":"","iColName2":"","iColWidth2":"","iVertScroll":true,"iColPreText1":"","iColPreText2":"","iColPreText4":"","iTblDummyRow":"keine Daten","class":"runde_bilder_inventwo"},"style":{"left":"18px","top":"311px","width":"641px","height":"293px","font-size":"15px","overflow-y":"scroll","z-index":"100"},"widgetSet":"vis-inventwo"},{"tpl":"i-vis-jsontable","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":true,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","iTblRowLimit":"20","iTableRefreshRate":"0","iTblSortOrder":"asc","iColCount":"8","iColShow1":false,"iTblHeadTextAlign1":"center","iTblTextAlign1":"center","iTblCellFormat1":"normal","iTblCellImageSize1":"200","iTblCellBooleanCheckbox1":"false","iTblCellBooleanColorFalse1":"#ff0000","iTblCellBooleanColorTrue1":"#00ff00","iTblCellNumberDecimals1":"2","iTblCellNumberDecimalSeperator1":".","iTblCellNumberThousandSeperator1":",","iTblCellThresholdsDp1":"","iTblCellThresholdsText1":"","iOpacityAll":"1","iTblRowEvenColor":"#060d14","iTblRowUnevenColor":"#1d1f20","iTblHeaderColor":"#fff","iRowSpacing":"3.4","iTblRowEvenTextColor":"#ffffff","iTblRowUnevenTextColor":"#ffffff","iTblHeaderTextColor":"#000","iBorderSize":"0","iBorderStyleLeft":"none","iBorderStyleRight":"none","iBorderStyleUp":"none","iBorderStyleDown":"none","iBorderColor":"#ffffff","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"oid":"0_userdata.0.FUELPRICEMONITOR.SUPJsonAnzeige","iTblShowHead":true,"iColShow2":"true","iTblHeadTextAlign2":"left","iTblTextAlign2":"left","iTblCellFormat2":"image","iTblCellImageSize2":"30","iTblCellBooleanCheckbox2":"false","iTblCellBooleanColorFalse2":"#ff0000","iTblCellBooleanColorTrue2":"#00ff00","iTblCellNumberDecimals2":"2","iTblCellNumberDecimalSeperator2":".","iTblCellNumberThousandSeperator2":",","iTblCellThresholdsDp2":"","iTblCellThresholdsText2":"","iColShow3":"true","iTblHeadTextAlign3":"left","iTblTextAlign3":"left","iTblCellFormat3":"normal","iTblCellImageSize3":"200","iTblCellBooleanCheckbox3":false,"iTblCellBooleanColorFalse3":"#ff0000","iTblCellBooleanColorTrue3":"#00ff00","iTblCellNumberDecimals3":"2","iTblCellNumberDecimalSeperator3":".","iTblCellNumberThousandSeperator3":",","iTblCellThresholdsDp3":"","iTblCellThresholdsText3":"","iColShow4":"true","iTblHeadTextAlign4":"left","iTblTextAlign4":"left","iTblCellFormat4":"normal","iTblCellImageSize4":"200","iTblCellBooleanCheckbox4":"false","iTblCellBooleanColorFalse4":"#ff0000","iTblCellBooleanColorTrue4":"#00ff00","iTblCellNumberDecimals4":"2","iTblCellNumberDecimalSeperator4":".","iTblCellNumberThousandSeperator4":",","iTblCellThresholdsDp4":"","iTblCellThresholdsText4":"","iColShow5":true,"iTblHeadTextAlign5":"center","iTblTextAlign5":"center","iTblCellFormat5":"normal","iTblCellImageSize5":"200","iTblCellBooleanCheckbox5":"false","iTblCellBooleanColorFalse5":"#ff0000","iTblCellBooleanColorTrue5":"#00ff00","iTblCellNumberDecimals5":"2","iTblCellNumberDecimalSeperator5":".","iTblCellNumberThousandSeperator5":",","iTblCellThresholdsDp5":"","iTblCellThresholdsText5":"","iColShow6":false,"iTblHeadTextAlign6":"center","iTblTextAlign6":"center","iTblCellFormat6":"normal","iTblCellImageSize6":"200","iTblCellBooleanCheckbox6":"false","iTblCellBooleanColorFalse6":"#ff0000","iTblCellBooleanColorTrue6":"#00ff00","iTblCellNumberDecimals6":"2","iTblCellNumberDecimalSeperator6":".","iTblCellNumberThousandSeperator6":",","iTblCellThresholdsDp6":"","iTblCellThresholdsText6":"","iColShow7":false,"iTblHeadTextAlign7":"center","iTblTextAlign7":"center","iTblCellFormat7":"normal","iTblCellImageSize7":"200","iTblCellBooleanCheckbox7":"false","iTblCellBooleanColorFalse7":"#ff0000","iTblCellBooleanColorTrue7":"#00ff00","iTblCellNumberDecimals7":"2","iTblCellNumberDecimalSeperator7":".","iTblCellNumberThousandSeperator7":",","iTblCellThresholdsDp7":"","iTblCellThresholdsText7":"","iColShow8":"true","iTblHeadTextAlign8":"center","iTblTextAlign8":"center","iTblCellFormat8":"normal","iTblCellImageSize8":"200","iTblCellBooleanCheckbox8":"false","iTblCellBooleanColorFalse8":"#ff0000","iTblCellBooleanColorTrue8":"#00ff00","iTblCellNumberDecimals8":"2","iTblCellNumberDecimalSeperator8":".","iTblCellNumberThousandSeperator8":",","iTblCellThresholdsDp8":"","iTblCellThresholdsText8":"","iColShow9":"true","iTblHeadTextAlign9":"center","iTblTextAlign9":"center","iTblCellFormat9":"normal","iTblCellImageSize9":"200","iTblCellBooleanCheckbox9":"false","iTblCellBooleanColorFalse9":"#ff0000","iTblCellBooleanColorTrue9":"#00ff00","iTblCellNumberDecimals9":"2","iTblCellNumberDecimalSeperator9":".","iTblCellNumberThousandSeperator9":",","iTblCellThresholdsDp9":"","iTblCellThresholdsText9":"","iTblFixedHead":true,"iTblSortAttr":"","iColName1":"","iColName2":"","iColWidth2":"","iVertScroll":true,"iColPreText1":"","iColPreText2":"","iColPreText4":"","iTblDummyRow":"keine Daten","iColAfterText2":"","iColAttr2":"","class":"runde_bilder_inventwo"},"style":{"left":"22px","top":"51px","width":"641px","height":"293px","font-size":"15px","overflow-y":"scroll","z-index":"100"},"widgetSet":"vis-inventwo"}]
                    

                    // @liv-in-sky 13.02.23 15:12
                    let anzahlAnzeige=5;
                    let mySprit=["SUP","DIE"]; //oder ["GAS","DIE","SUP"] je nachdem, was man braucht
                    let telegramInstanz="telegram.0"  // wenn nicht genutzt:   let telegramInstanz="";
                    let emailInstanz=""; //  hier email instanz eintragen z.B. "email.0" - bei "" wird keine mail gesendet
                    let emailUser="xx@yyyy.at"
                    // Die Bilder müssen unter /vis.0/Tankstellen liegen   !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
                    
                    const config = getObject('system.config');
                    const mylat =  config.common.latitude  //.replace(/(.*\..+?.+?.+?.+?.+?.+?).+/,"$1"); //*/"48." //l
                    const mylong = config.common.longitude  //.replace(/(.*\..+?.+?.+?.+?.+?.+?).+/,"$1"); log(mylat)
                    
                    const defaultPic="/vis.0/Tankstellen/default.png"
                    const pictures=[{"firma":"BP","pic":"/vis.0/Tankstellen/bp.png"},
                                   {"firma":"Genol","pic":"/vis.0/Tankstellen/genol.png"},
                                   {"firma":"eni","pic":"/vis.0/Tankstellen/eni.png"},
                                   {"firma":"Diskont","pic":"/vis.0/Tankstellen/diskont.png"},
                                   {"firma":"Turmöl","pic":"/vis.0/Tankstellen/turmoel.png"},
                                   {"firma":"paradies","pic":"/vis.0/Tankstellen/treibstoffparadies.png"},
                                   {"firma":"Lohberger","pic":"/vis.0/Tankstellen/lohberger.png"},
                                   {"firma":"SB-Tankstelle","pic":"/vis.0/Tankstellen/sb.jpg"},
                                   {"firma":"Hofer","pic":"/vis.0/Tankstellen/hofer.png"},
                                   {"firma":"AVIA","pic":"/vis.0/Tankstellen/avia.png"},
                                   {"firma":"avanti","pic":"/vis.0/Tankstellen/avanti.png"},
                                   {"firma":"Shell","pic":"/vis.0/Tankstellen/shell.png"},
                                   {"firma":"Aral","pic":"/vis.0/Tankstellen/Aral.png"},
                                   {"firma":"JET","pic":"/vis.0/Tankstellen/jet.png"},
                                   {"firma":"Ultsch","pic":"/vis.0/Tankstellen/ultsch.png"},
                                   {"firma":"IQ","pic":"/vis.0/Tankstellen/iq.jpg"},
                                   {"firma":"bft","pic":"/vis.0/Tankstellen/bft.png"}
                                  ]
                    
                    //let myTelegramTextOld=["","",""];   
                    let telegramIsSent=[false,false,false];           
                    
                    for (let i=0;i<mySprit.length;i++){
                    if(!existsState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'JsonAnzeige')) createState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'JsonAnzeige', "", { name: "JsonAnzeige"+mySprit[i], type:'string' });
                    if(!existsState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'telegram_messageid')) createState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'telegram_messageid', "", { name: "telegram_messageid"+mySprit[i], type:'string' });
                    if(!existsState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'telegram_chatid')) createState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'telegram_chatid', "", { name: "telegram_chatid"+mySprit[i], type:'string' }); 
                    if(!existsState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'TelegramNachricht')) createState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'TelegramNachricht', "", { name: "TelegramNachricht"+mySprit[i], type:'string' });
                    if(!existsState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'EmailNachricht')) createState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[i]+'EmailNachricht', "", { name: "EmailNachricht"+mySprit[i], type:'string' });
                    if ( existsState("javascript." + instance + ".FUELPRICEMONITOR.Targets.home"))  setState("javascript." + instance + ".FUELPRICEMONITOR.Targets.home",mylat+','+mylong);
                          else  createState("javascript." + instance + ".FUELPRICEMONITOR.Targets.home", mylat+','+mylong, {type: "string", name: "Koordinaten FPM HOME", role: "value", read: true, write: true, } ); 
                    }
                    
                    
                    
                    
                    async function delTel(){
                       if(telegramInstanz!=""){
                       for (let b=0;b<mySprit.length;b++){await wait(2000);
                          if(getState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[b]+'telegram_chatid').val!="") deletetext(mySprit[b]) // telegram reset !!
                    }}}
                    
                    delTel(); //delete old telegram
                    
                    let triggerArr=[];
                    
                    for (let b=0;b<mySprit.length;b++){
                    
                      for(let bb=0;bb<anzahlAnzeige;bb++){
                       triggerArr.push('fuelpricemonitor.0.cheapestOverAll_'+mySprit[b]+'.'+bb+'.amount');
                       triggerArr.push('fuelpricemonitor.0.cheapestOverAll_'+mySprit[b]+'.'+bb+'.address')
                                       
                    }}
                    
                    
                    //log(triggerArr.toString())
                    let myPause=true;
                    on({id: triggerArr, change: "ne"}, async function (obj) {
                       var value = obj.state.val;
                       var oldValue = obj.oldState.val;
                       if (myPause) {setTimeout(async function () { mainFunc();}, 5000); /*log("Wert: "+value+" ID: "+obj.id+" AlterWert: "+oldValue);*/ myPause=false; setTimeout(async function () { myPause=true;}, 10000);}
                     });
                    
                    
                    
                    
                    async function mainFunc() {  
                    for (let a=0;a<mySprit.length;a++){
                    
                    let myTelegramText="";
                    let myEmailText="";
                    
                    let unserJsonArray=[];
                    $('fuelpricemonitor.*.cheapestOverAll_'+mySprit[a]+'.*.address').each(function(id, i) {   
                            let indexArr=id.split('.');
                            let index=Number(indexArr[3]);
                            let val0=getState(id).val; if(val0==null) val0="nicht angegeben"
                            let val1=getState(id.replace("address","amount")).val;
                            let val2;
                            if(getState(id.replace("address","name")).val==null) {val2="nicht angegeben"} else {val2=getState(id.replace("address","name")).val.replace(" Tankstelle","").replace(" TANKSTELLE","")}
                            let val3=getState(id.replace("address","id")).val;               
                            let val4=searchLoc(val3);
                            let val5=getDistanceFromLatLonInKm(mylat, mylong, val4.split(',')[0], val4.split(',')[1])
                            let theAddressDate="Adresse (Last Update: "+formatDate(getDateObject((new Date().getTime())), "SS:mm - TT.MM.")+")";
                    
                    if(val1!=null && index<anzahlAnzeige){
                    unserJsonArray.push({ "Index":    index,
                                         [mySprit[a]]:     getPic(val2),
                                         [theAddressDate]:  val0,
                                         "Preis":    val1,
                                         "Name":     val2,
                                         "ID":       val3,
                                         "Koordinaten": val4,
                                         "Dis(km)":  val5,
                                         "Adresse": val0 })
                    
                    
                    if (  existsState("javascript." + instance + ".FUELPRICEMONITOR.Targets."+mySprit[a]+index+"er"))   setState("javascript." + instance + ".FUELPRICEMONITOR.Targets."+mySprit[a]+index+"er",val4.toString());
                          else     createState("javascript." + instance + ".FUELPRICEMONITOR.Targets."+mySprit[a]+index+"er", val4.toString(), {type: "string", name: "Koordinaten FPM "+mySprit[a]+ index, role: "value", read: true, write: true, } ); }
                    
                    
                    
                    })
                    
                    //log(JSON.stringify(unserJsonArray));
                    
                    // in eigenen dp speichern - type zeichenkette
                    setState("0_userdata.0.FUELPRICEMONITOR."+mySprit[a]+"JsonAnzeige",JSON.stringify(unserJsonArray));
                    
                       myTelegramText="<b><u>Letztes Update:  </u></b>"+formatDate(getDateObject((new Date().getTime())), "SS:mm -- TT.MM.")+"\n"+mySprit[a]+"\n\n";
                       myEmailText=myTelegramText+"<br><br>";
                    for(let i=0;i<unserJsonArray.length;i++){
                       myTelegramText=myTelegramText+unserJsonArray[i].Adresse+"\n"+unserJsonArray[i].Name+" - Preis: "+unserJsonArray[i].Preis+"  -  Distanz: "+unserJsonArray[i]["Dis(km)"]+" km\n\n";
                       myEmailText=myEmailText+unserJsonArray[i].Adresse+"<br>"+unserJsonArray[i].Name+" - Preis: "+unserJsonArray[i].Preis+"  -  Distanz: "+unserJsonArray[i]["Dis(km)"]+" km<br><br>";
                    }
                    if(telegramInstanz!=""){await wait(3000);
                    if(/*myTelegramTextOld[a]!=myTelegramText&&*/!telegramIsSent[a])  {sendtext(myTelegramText,mySprit[a]);telegramIsSent[a]=true;
                                                                           } else{ updatetext(myTelegramText,mySprit[a]);
                                                                                                                        }
                    //myTelegramTextOld[a]=myTelegramText;
                    } 
                    
                    
                    if(emailInstanz!="") sendMail(emailInstanz,myEmailText,emailUser,mySprit[a])
                    setState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[a]+'TelegramNachricht',JSON.stringify(myTelegramText));
                    setState('0_userdata.0.FUELPRICEMONITOR.'+mySprit[a]+'EmailNachricht',JSON.stringify(myEmailText));
                    }}
                    
                    
                    
                    function searchLoc(theId){
                    let  ergebnis="";
                    $('fuelpricemonitor.0.*.*.location.latitude').each(function(id, i) {
                       let indexArr=id.split('.');
                       let indexId=indexArr[3];
                       
                      // log(theId +"  "+indexId )
                       if(indexId==theId ){
                                                                        //log(getState(id).val+","+getState(id.replace("latitude","longitude")).val)
                                                                        if(getState(id).val!=null){
                                                                        ergebnis= (getState(id).val+","+getState(id.replace("latitude","longitude")).val).toString()}
                                                                        else {if (ergebnis=="") ergebnis=mylat+','+mylong}
                                                                        //if(theId=="6051") log(ergebnis)
                                                                        } 
                                                                        
                    })
                    //log (ergebnis)
                    return ergebnis;
                    
                    }
                    
                    function getPic(nameTanke){
                    let defaultTanke=defaultPic
                    
                    for(let i=0;i<pictures.length;i++){//log(nameTanke+"   -  "+pictures[i].firma+"  -  "+nameTanke.indexOf(pictures[i].firma))
                     // if(pictures[i].firma.includes(nameTanke)) {defaultTanke=pictures[i].pic }
                      if(nameTanke.indexOf(pictures[i].firma)>-1) {defaultTanke=pictures[i].pic; break }
                    }
                    //log(defaultTanke)
                    return defaultTanke
                    
                    }
                    /*
                    function getDistanceFromLatLonInKm(lat1, lon1, lat2, lon2) {
                     var R = 6371; // Radius of the earth in km
                     var dLat = deg2rad(lat2-lat1);  // deg2rad below
                     var dLon = deg2rad(lon2-lon1); 
                     var a = 
                       Math.sin(dLat/2) * Math.sin(dLat/2) +
                       Math.cos(deg2rad(lat1)) * Math.cos(deg2rad(lat2)) * 
                       Math.sin(dLon/2) * Math.sin(dLon/2)
                       ; 
                     var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a)); 
                     var d = R * c; // Distance in km
                     return Math.round(d);
                    }
                    */
                    
                    function getDistanceFromLatLonInKm(lat1, lon1, lat2, lon2) {
                     var p = 0.017453292519943295;    // Math.PI / 180
                     var c = Math.cos;
                     var a = 0.5 - c((lat2 - lat1) * p)/2 + 
                             c(lat1 * p) * c(lat2 * p) * 
                             (1 - c((lon2 - lon1) * p))/2;
                    
                     return Math.round(12742 * Math.asin(Math.sqrt(a))); // 2 * R; R = 6371 km
                    }
                    
                    function deg2rad(deg) {
                     return deg * (Math.PI/180)
                    }
                    
                    async function sendtext(myText,theSprit) {
                    
                       sendTo(telegramInstanz, {
                    
                           text: myText,
                           parse_mode:"HTML",
                           disable_notification:   true
                    
                           });
                       await wait(1000);
                       var messageid=getState(telegramInstanz+".communicate.botSendMessageId").val;
                       var chatid=getState(telegramInstanz+".communicate.botSendChatId").val;
                       await wait(2000);//log("sendtext")
                       setState('0_userdata.0.FUELPRICEMONITOR.'+theSprit+'telegram_messageid', String(messageid));
                       setState('0_userdata.0.FUELPRICEMONITOR.'+theSprit+'telegram_chatid', String(chatid));
                    
                    }
                    
                    async function updatetext(myText,theSprit) {
                    
                       let mid=getState('0_userdata.0.FUELPRICEMONITOR.'+theSprit+'telegram_messageid').val
                       let mch=getState('0_userdata.0.FUELPRICEMONITOR.'+theSprit+'telegram_chatid').val
                       //log(mid+'  -  '+mch+"  -  update")
                       
                    
                       sendTo(telegramInstanz, {
                          text: myText,
                          parse_mode:"HTML",
                           editMessageText: {
                               options: {
                                   disable_notification:   true,
                                   parse_mode:"HTML",
                                   chat_id: mch,
                                   message_id: mid,
                                         }
                           }
                       });
                    
                    }
                    
                    async function deletetext(theSpritDel) {
                         // await wait(2000);
                         // log(theSpritDel);
                          sendTo(telegramInstanz, {
                            deleteMessage: {
                               options: {
                                   disable_notification:   true,
                                   chat_id: getState('0_userdata.0.FUELPRICEMONITOR.'+theSpritDel+'telegram_chatid').val,
                                   message_id: getState('0_userdata.0.FUELPRICEMONITOR.'+theSpritDel+'telegram_messageid').val
                               }
                           }
                    });
                    }
                    
                    async function sendMail(inst,htmlText,toUser,type){
                    sendTo(inst, "send", {
                                        html: htmlText,
                                        to: toUser,
                                        subject: 'FuelPriceMonitor - Update - '+type
                    });
                    }
                    
                    
                    let timeout = setTimeout(async function () { mainFunc();
                    }, 3000);
                    
                    
                    
                    
                    

                    um die runden bilder zu bekommen, das folgende in den css tab im vis editor einfügen

                    .runde_bilder_inventwo img{
                       border-radius: 50px;
                    }
                    

                    NegaleinN Offline
                    NegaleinN Offline
                    Negalein
                    Global Moderator
                    wrote on last edited by Negalein
                    #67

                    @liv-in-sky

                    Servus

                    Bin erst jetzt (komplett übersehn) auf dein Script gestossen.

                    Du verwendest hier cheapest overall.

                    Ist es möglich, stattdessen fuelpricemonitor.0.0_Home_Diesel zu verwenden?

                    40fa0161-2154-4c9d-adbb-d57c4fd7315d-image.png

                    ° Node.js & System Update ---> sudo apt update, iob stop, sudo apt full-upgrade
                    ° Node.js Fixer ---> iob nodejs-update
                    ° Fixer ---> iob fix

                    liv-in-skyL 2 Replies Last reply
                    0
                    • NegaleinN Negalein

                      @liv-in-sky

                      Servus

                      Bin erst jetzt (komplett übersehn) auf dein Script gestossen.

                      Du verwendest hier cheapest overall.

                      Ist es möglich, stattdessen fuelpricemonitor.0.0_Home_Diesel zu verwenden?

                      40fa0161-2154-4c9d-adbb-d57c4fd7315d-image.png

                      liv-in-skyL Offline
                      liv-in-skyL Offline
                      liv-in-sky
                      wrote on last edited by
                      #68

                      @negalein

                      habe im moment wenig zeit - muss mir das nochmal ansehen - evtl am WE

                      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                      1 Reply Last reply
                      1
                      • NegaleinN Negalein

                        @liv-in-sky

                        Servus

                        Bin erst jetzt (komplett übersehn) auf dein Script gestossen.

                        Du verwendest hier cheapest overall.

                        Ist es möglich, stattdessen fuelpricemonitor.0.0_Home_Diesel zu verwenden?

                        40fa0161-2154-4c9d-adbb-d57c4fd7315d-image.png

                        liv-in-skyL Offline
                        liv-in-skyL Offline
                        liv-in-sky
                        wrote on last edited by liv-in-sky
                        #69

                        @negalein

                        habe nochmal darüber geschaut - das umzustellen ist zu aufwendig - die frage ist aber ob das sinnvoll ist

                        du bekommst die tankstellen deiner umgebung (abhängig von deinen koordinaten) zusätzlich kannst du weitere tankst. eingeben. in overall ist dann eine liste nach preis.

                        wenn du in der instanz alle zusätzlichen tankstellen rausnimmst, sollte eigentlich in 0_home-diesel das selbe stehen, wie in cheapestall-diesel - das was du eigentlich möchtest

                        musst du testen

                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                        1 Reply Last reply
                        0
                        • A Offline
                          A Offline
                          australien
                          wrote on last edited by australien
                          #70

                          @liv-in-sky
                          kann man das für die VIS-2 auch verwenden?

                          bei mir werden keine logos dargestellt, nur der Pfad, welcher richtig ist.
                          44fe7273-92a6-42bd-a268-29acd86a59d0-grafik.png

                          liv-in-skyL 1 Reply Last reply
                          0
                          • A australien

                            @liv-in-sky
                            kann man das für die VIS-2 auch verwenden?

                            bei mir werden keine logos dargestellt, nur der Pfad, welcher richtig ist.
                            44fe7273-92a6-42bd-a268-29acd86a59d0-grafik.png

                            liv-in-skyL Offline
                            liv-in-skyL Offline
                            liv-in-sky
                            wrote on last edited by
                            #71

                            @australien hi, schau mal im widget selbst, ob es für die spalte mit dem pfad eine einstellung gibt für "bild"

                            nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                            A 1 Reply Last reply
                            0
                            • liv-in-skyL liv-in-sky

                              @australien hi, schau mal im widget selbst, ob es für die spalte mit dem pfad eine einstellung gibt für "bild"

                              A Offline
                              A Offline
                              australien
                              wrote on last edited by
                              #72

                              @liv-in-sky ich kann dazu leider im basic und inventwo nicht finden.
                              welches verwendest du?

                              liv-in-skyL 1 Reply Last reply
                              0
                              • A australien

                                @liv-in-sky ich kann dazu leider im basic und inventwo nicht finden.
                                welches verwendest du?

                                liv-in-skyL Offline
                                liv-in-skyL Offline
                                liv-in-sky
                                wrote on last edited by
                                #73

                                @australien

                                ich nutze das nicht - wohne nicht in AUT

                                du kannst dafür nur das json inventwo widget nutzen - ich habe kein vis 2, daher kenne ich das widget darin nicht - ich kann mich aber erinnbern, daß in vis 1 man die spalte als bild definieren muss, sonst wird halt nur der pfad angezeigt

                                nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                A 1 Reply Last reply
                                0
                                • liv-in-skyL liv-in-sky

                                  @australien

                                  ich nutze das nicht - wohne nicht in AUT

                                  du kannst dafür nur das json inventwo widget nutzen - ich habe kein vis 2, daher kenne ich das widget darin nicht - ich kann mich aber erinnbern, daß in vis 1 man die spalte als bild definieren muss, sonst wird halt nur der pfad angezeigt

                                  A Offline
                                  A Offline
                                  australien
                                  wrote on last edited by australien
                                  #74

                                  @liv-in-sky ich habe mir nun in einen script eine html Ausgabe erstellen lassen, passt soweit.

                                  // Dieses Skript liest zwei JSON-Datenpunkte (für Diesel & Super) aus
                                  // und erstellt daraus zwei separate HTML-Tabellen für VIS-2.
                                  //
                                  // ✅ Quellen:
                                  //   - 0_userdata.0.FUELPRICEMONITOR.DIEJsonAnzeige  → enthält Feld "DIE" für Logo
                                  //   - 0_userdata.0.FUELPRICEMONITOR.SUPJsonAnzeige  → enthält Feld "SUP" für Logo
                                  //
                                  // ✅ Ziel-Datenpunkte (HTML für VIS-2):
                                  //   - 0_userdata.0.FUELPRICEMONITOR.DIETankstellen_HTML
                                  //   - 0_userdata.0.FUELPRICEMONITOR.SUPTankstellen_HTML
                                  //
                                  // Logos werden anhand des jeweiligen Feldes (SUP oder DIE) oder – falls leer – anhand des Firmennamens automatisch zugeordnet.
                                  
                                  // ------------------------- EINSTELLUNGEN -------------------------
                                  const srcDIE = '0_userdata.0.FUELPRICEMONITOR.DIEJsonAnzeige';
                                  const srcSUP = '0_userdata.0.FUELPRICEMONITOR.SUPJsonAnzeige';
                                  const dpDIE  = '0_userdata.0.FUELPRICEMONITOR.DIETankstellen_HTML';
                                  const dpSUP  = '0_userdata.0.FUELPRICEMONITOR.SUPTankstellen_HTML';
                                  // -----------------------------------------------------------------
                                  
                                  // Liste aller Tankstellen-Logos
                                  const logoList = [
                                    { firma: "BP", pic: "/vis-2.0/doki/Tankstellen/bp.png" },
                                    { firma: "Genol", pic: "/vis-2.0/doki/Tankstellen/genol.png" },
                                    { firma: "eni", pic: "/vis-2.0/doki/Tankstellen/eni.png" },
                                    { firma: "Turmöl", pic: "/vis-2.0/doki/Tankstellen/turmoel.png" },
                                    { firma: "paradies", pic: "/vis-2.0/doki/Tankstellen/treibstoffparadies.png" },
                                    { firma: "Lohberger", pic: "/vis-2.0/doki/Tankstellen/lohberger.png" },
                                    { firma: "SB-Tankstelle", pic: "/vis-2.0/doki/Tankstellen/sb.jpg" },
                                    { firma: "Diskont", pic: "/vis-2.0/doki/Tankstellen/hofer.png" },
                                    { firma: "AVIA", pic: "/vis-2.0/doki/Tankstellen/avia.png" },
                                    { firma: "AVANTI", pic: "/vis-2.0/doki/Tankstellen/avanti.png" },
                                    { firma: "Shell", pic: "/vis-2.0/doki/Tankstellen/shell.png" },
                                    { firma: "Aral", pic: "/vis-2.0/doki/Tankstellen/aral.png" },
                                    { firma: "JET", pic: "/vis-2.0/doki/Tankstellen/jet.png" },
                                    { firma: "Ultsch", pic: "/vis-2.0/doki/Tankstellen/ultsch.png" },
                                    { firma: "IQ", pic: "/vis-2.0/doki/Tankstellen/iq.jpg" },
                                    { firma: "SOCAR", pic: "/vis-2.0/doki/Tankstellen/socar.png" },
                                    { firma: "OIL!", pic: "/vis-2.0/doki/Tankstellen/oil.png" },
                                    { firma: "bft", pic: "/vis-2.0/doki/Tankstellen/bft.png" },
                                    { firma: "default", pic: "/vis-2.0/doki/Tankstellen/default.png" }
                                  ];
                                  
                                  // Funktion: passendes Logo anhand des Namens ermitteln
                                  function getLogoByName(name) {
                                    if (!name) return "/vis-2.0/doki/Tankstellen/default.png";
                                    const lower = name.toLowerCase();
                                    for (let entry of logoList) {
                                      if (lower.includes(entry.firma.toLowerCase())) {
                                        return entry.pic;
                                      }
                                    }
                                    return "/vis-2.0/doki/Tankstellen/default.png";
                                  }
                                  
                                  // Funktion zur Erstellung der HTML-Tabelle
                                  function createTankstellenHTML(tankstellen, titel, type) {
                                    let html = `
                                    <style>
                                      table.tankstellen {
                                        width: 100%;
                                        border-collapse: collapse;
                                        font-family: Arial, sans-serif;
                                        font-size: 14px;
                                      }
                                      table.tankstellen th {
                                        background-color: #ddd;
                                        padding: 8px;
                                        text-align: left;
                                      }
                                      table.tankstellen td {
                                        padding: 8px;
                                        border-bottom: 1px solid #ccc;
                                      }
                                      table.tankstellen img {
                                        width: 50px;
                                        height: auto;
                                      }
                                      h3.titel {
                                        font-family: Arial, sans-serif;
                                        margin-bottom: 8px;
                                        margin-top: 10px;
                                      }
                                    </style>
                                  
                                    <h3 class="titel">${titel}</h3>
                                    <table class="tankstellen">
                                      <tr>
                                        <th>Logo</th>
                                        <th>Name</th>
                                        <th>Adresse</th>
                                        <th>Preis (€)</th>
                                      </tr>`;
                                  
                                    for (let t of tankstellen) {
                                      // Logo-Feld je nach Typ
                                      let logo = type === 'DIE' ? t.DIE : t.SUP;
                                  
                                      // Wenn leer → anhand des Namens bestimmen
                                      if (!logo || logo.trim() === '') {
                                        logo = getLogoByName(t.Name);
                                      }
                                  
                                      html += `
                                      <tr>
                                        <td style="text-align:center;"><img src="${logo}" alt="Logo"></td>
                                        <td>${t.Name || '-'}</td>
                                        <td>${t.Adresse || '-'}</td>
                                        <td>${t.Preis ? t.Preis.toFixed(3) : '-'}</td>
                                      </tr>`;
                                    }
                                  
                                    html += `</table>`;
                                    return html;
                                  }
                                  
                                  // Ziel-Datenpunkte anlegen, falls nicht vorhanden
                                  if (!existsState(dpDIE)) {
                                    createState(dpDIE, { name: 'DIE Tankstellen HTML', type: 'string', role: 'html', read: true, write: true });
                                  }
                                  if (!existsState(dpSUP)) {
                                    createState(dpSUP, { name: 'SUP Tankstellen HTML', type: 'string', role: 'html', read: true, write: true });
                                  }
                                  
                                  // Hauptfunktion zum Aktualisieren der Tabellen
                                  async function updateTankstellen() {
                                    try {
                                      // Diesel
                                      const rawDIE = getState(srcDIE)?.val;
                                      if (rawDIE) {
                                        const dieselData = JSON.parse(rawDIE);
                                        const htmlDIE = createTankstellenHTML(dieselData, 'Diesel – Tankstellen', 'DIE');
                                        setState(dpDIE, htmlDIE, true);
                                        log(`✅ Diesel-Tabelle aktualisiert (${dieselData.length} Einträge).`);
                                      } else {
                                        log(`⚠️ Keine Daten in ${srcDIE}`, 'warn');
                                      }
                                  
                                      // Super
                                      const rawSUP = getState(srcSUP)?.val;
                                      if (rawSUP) {
                                        const superData = JSON.parse(rawSUP);
                                        const htmlSUP = createTankstellenHTML(superData, 'Super – Tankstellen', 'SUP');
                                        setState(dpSUP, htmlSUP, true);
                                        log(`✅ Super-Tabelle aktualisiert (${superData.length} Einträge).`);
                                      } else {
                                        log(`⚠️ Keine Daten in ${srcSUP}`, 'warn');
                                      }
                                  
                                    } catch (err) {
                                      log('❌ Fehler beim Erstellen der Tankstellen-Tabellen: ' + err, 'error');
                                    }
                                  }
                                  
                                  // Trigger bei Änderungen an den JSON-Datenpunkten
                                  on({ id: srcDIE, change: 'any' }, updateTankstellen);
                                  on({ id: srcSUP, change: 'any' }, updateTankstellen);
                                  
                                  // Beim Start sofort ausführen
                                  updateTankstellen();
                                  
                                  

                                  Gibt es noch eine Möglichkeit die fuelpricemonitor.0.0_Home_Diesel und nicht die fuelpricemonitor.0.cheapestOverAll_DIE für die Erstellung der jsonAusgabe zu verwenden? vv Super

                                  1 Reply Last reply
                                  0
                                  • liv-in-skyL Offline
                                    liv-in-skyL Offline
                                    liv-in-sky
                                    wrote on last edited by
                                    #75

                                    @australien das Script ist nicht von mir, du musst den erstellen fragen

                                    nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                    A 1 Reply Last reply
                                    0
                                    • liv-in-skyL liv-in-sky

                                      @australien das Script ist nicht von mir, du musst den erstellen fragen

                                      A Offline
                                      A Offline
                                      australien
                                      wrote on last edited by
                                      #76

                                      @liv-in-sky ok, dachte ist von dir, das dein username vermerkt ist.

                                      @mrfloppy
                                      @Chaot
                                      @Negalein

                                      liv-in-skyL 1 Reply Last reply
                                      0
                                      • A australien

                                        @liv-in-sky ok, dachte ist von dir, das dein username vermerkt ist.

                                        @mrfloppy
                                        @Chaot
                                        @Negalein

                                        liv-in-skyL Offline
                                        liv-in-skyL Offline
                                        liv-in-sky
                                        wrote on last edited by
                                        #77

                                        @australien

                                        im ersten post dieses threads ist mein script - was du gepostet hast, kenn ich nicht - evtl hat es jmd weiterntwickelt ? wie erwähnt - ich nutze das ja nicht und bin somit nicht auf dem laufenden :-(

                                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                        1 Reply Last reply
                                        0
                                        Reply
                                        • Reply as topic
                                        Log in to reply
                                        • Oldest to Newest
                                        • Newest to Oldest
                                        • Most Votes


                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        737

                                        Online

                                        32.6k

                                        Users

                                        82.3k

                                        Topics

                                        1.3m

                                        Posts
                                        Community
                                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                        ioBroker Community 2014-2025
                                        logo
                                        • Login

                                        • Don't have an account? Register

                                        • Login or register to search.
                                        • First post
                                          Last post
                                        0
                                        • Home
                                        • Recent
                                        • Tags
                                        • Unread 0
                                        • Categories
                                        • Unreplied
                                        • Popular
                                        • GitHub
                                        • Docu
                                        • Hilfe