Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. TibberLink Adapter

    NEWS

    • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?

    • Monatsrückblick – September 2025

    • Neues Video "KI im Smart Home" - ioBroker plus n8n

    TibberLink Adapter

    This topic has been deleted. Only users with topic management privileges can see it.
    • L
      lesiflo Most Active @ReblausGT last edited by lesiflo

      @reblausgt Hab's mal installiert und getestet, läuft soweit. Allerdings haben die 15 Minuten für mich keinen richtigen Mehrwert. Wenn man einen PV-Speicher hat bügelt der einiges aus. Wäre es möglich einen Schalter einzubauen um zwischen 15 und 60 Minuten zu switchen? Ansonsten klasse Arbeit!

      bf9af0f8-d4c1-461b-82be-4ba4b42d34dc-image.png

      R P 2 Replies Last reply Reply Quote 0
      • R
        ReblausGT Developer @lesiflo last edited by

        @lesiflo said in TibberLink Adapter:

        Wäre es möglich einen Schalter einzubauen um zwischen 15 und 60 Minuten zu switchen?

        Ich hatte befürchtet dass die Frage kommt 😥 😊

        L T 2 Replies Last reply Reply Quote 0
        • L
          lesiflo Most Active @ReblausGT last edited by lesiflo

          @reblausgt Wenn nicht wäre auch nicht schlimm, habe das schon mit meinem Script gelöst. 😉 Allerdings muß ich noch schauen wie das mit den Zeiträumen dann passt.

          P 1 Reply Last reply Reply Quote 0
          • P
            pingo @lesiflo last edited by

            @ReblausGT Vielleicht machst Du einfach zusätzlich Objekte für die Stundenpreise? Sind ja immer nur 4 Objekte zusammengezählt und durch 4 geteilt. So helfe ich mir aktuell.
            Ansonsten funktioniert Version 6.0.0 hier perfekt. Danke

            1 Reply Last reply Reply Quote 0
            • A
              ArnoD last edited by

              Wenn ich die Tibber API Beschreibung richtig verstehe kann man beides abrufen:

              • The Subscription.priceInfo field (i.e. the type PriceInfo) now takes an optional argument resolution that can either be HOURLY or QUARTER_HOURLY.

              Bei Stundenwerten wird von Tibber der Durchschnittspreis angegeben.

              1 Reply Last reply Reply Quote 0
              • L
                lesiflo Most Active last edited by lesiflo

                Moin,
                wäre es möglich noch einen zusätzlichen Rechnerkanal mit einzubauen der die Stunden/Slots anhand des Akkustandes und Verbrauch pro Stunde ermittelt? Beispiel Akku hat noch 4 kWh, Verbrauch 0,4 kWh macht dann 10 Stunden an denen der Akku entladen werden könnte. Vorgaben wären dann Rest Akku und Verbrauch pro Stunde. Eventuell auch noch gesamt Akku um die Gesamtstunden anzuzeigen.

                1 Reply Last reply Reply Quote 0
                • P
                  Peter c @lesiflo last edited by

                  @lesiflo said in TibberLink Adapter:

                  Wenn man einen PV-Speicher hat bügelt der einiges aus.

                  Deine Darstellung der Strompreise sieht sehr übersichtlich aus. Mit was hast Du das erzeugt? Ist das VIS oder was anderes?

                  1 Reply Last reply Reply Quote 0
                  • L
                    lesiflo Most Active last edited by

                    @peter-c Mit vis. Guckst du hier: vis

                    1 Reply Last reply Reply Quote 0
                    • T
                      THELOH @ReblausGT last edited by THELOH

                      Hat sich erledigt, ich habe meine Alias(e) angepasst.

                      @reblausgt Ich hätte die gleiche Bitte.
                      Ich sortiere die Preise um zu den günstigsten Stunden die teuersten Stunden mit dem Speicher zu eliminieren und nutze die Preise sehr oft an verscheidenen Stellen. Ich würde mich jedoch freuen, wenn beides angebiten wird. Alte Strucktur der 1h Datenpunkte ohne Änderungen der Bezeichnungen etc und einmal ein neuer Ordner mit den 15min Werten. So kann sich jeder das schnappen, was er benötigt.
                      Das wäre zauberhaft 🙂

                      1 Reply Last reply Reply Quote 0
                      • H
                        HansJochen last edited by HansJochen

                        Hallo zusammen,

                        die Flexcharts / ECharts Integration in den Tibberlink Adapter ist absolut klasse. Ich habe mir das Standard-Template so angepasst, dass im Diagramm die aktuelle Zeit mit einer vertikalen Linie markiert wird.
                        Sieht dann so aus:
                        Bildschirmfoto_20251102_154501.png

                        Falls das jemand nutzen möchte:

                        {
                        	backgroundColor: "rgb(255, 255, 255)",
                        	title: {
                        		text: "Tibber Preis",
                        		textStyle: {
                        			color: "#ffffff"
                        		}
                        	},
                        	tooltip: {
                        		trigger: "axis",
                        		axisPointer: {
                        			type: "cross"
                        		}
                            },    
                        
                        	grid: { // Randabstände
                        		left: "10%", right: "4%", top: "8%", bottom: "8%"
                        	},
                        	xAxis: {
                        		type: "category",
                        		boundaryGap: false,
                        		data: %%xAxisData%%
                        	},
                        	yAxis: {
                        		type: "value",
                        		axisLabel: {formatter: "{value} €"},
                        		axisPointer: {
                        			snap: true
                        		}
                        	},
                        	visualMap: {
                        		min: 0.2,
                        		max: 0.4,
                        		inRange: {
                        			color: ["green", "yellow", "red"] // Verlauf von grün über gelb nach rot
                        		},
                        		show: false
                        	},
                        	series: [
                        		{
                        			name: "Preis",
                        			type: "line",
                        			step: "end",
                        			symbol: "none",
                        			data: %%yAxisData%%,
                        
                        			markArea: {
                        				itemStyle: {
                        					color: "rgba(120, 200, 120, 0.2)"
                        				},
                        				data: [
                        					%%CalcChannelsData%%
                        				]
                        			},
                        			markLine: {
                                    data: [   
                                    {
                                       name: 'jetzt', xAxis: ("0"+new Date().getDate()).slice(-2)+"."+("0"+(new Date().getMonth()+1)).slice(-2)+"." + "\n" + ("0"+new Date().getHours()).slice(-2)+":"+("0"+(Math.floor(new Date().getMinutes()/15)*15).toString()).slice(-2)}
                                       
                                          ]   
                                    }
                        	    }
                            ]
                        
                        };
                        
                        R 1 Reply Last reply Reply Quote 0
                        • R
                          ReblausGT Developer @HansJochen last edited by

                          @hansjochen said in TibberLink Adapter:

                          Ich habe mir das Standard-Template so angepasst, dass im Diagramm die aktuelle Zeit mit einer vertikalen Linie markiert wird.
                          Falls das jemand nutzen möchte:

                          JA! hier ich!!! Cool, das wollte ich schon die ganze Zeit!! Darf ich das im Adapter als Beispiel veröffentlichen?

                          H 1 Reply Last reply Reply Quote 0
                          • H
                            HansJochen @ReblausGT last edited by

                            Hi @reblausgt ,

                            danke für Dein Feedback.

                            Klar, bau es gerne ein. Ich habe das ja hier gepostet, weil ich dachte, dass es auch für andere praktisch sein kann.

                            R 1 Reply Last reply Reply Quote 0
                            • R
                              ReblausGT Developer @HansJochen last edited by

                              Mal was anderes.... die X-Achse mit Strings war ein Entwurf der 1h Zeitscheiben.... jetzt, mit den 15 Minuten Scheiben überlege ich ob man das doch lieber im category time ändern sollte.... das zerschmeißt dann halt alles was man sich da schon an template gebastelt hatte.... Ist das ne Katastrophe? oder Überwiegen die Vorteile?

                              H 1 Reply Last reply Reply Quote 0
                              • S
                                Schimi last edited by

                                Ich brauche mal ne Erklärung zum "Batterie laden" Kanal nach der 15min Umstellung 🙂

                                a5dfc580-d177-40be-aaad-749936c05b44-image.png

                                Wenn ich die AmountHours auf z.B. "0,5" stelle, schaltet er dann jede verfügbaren 30min Slot, wo der Preis 25% unter dem höchsten Tagespreis ist auf true? (den highest nutze ich nicht)

                                1 Reply Last reply Reply Quote 0
                                • R
                                  ReblausGT Developer last edited by

                                  @schimi said in TibberLink Adapter:

                                  Ich brauche mal ne Erklärung zum "Batterie laden" Kanal nach der 15min Umstellung 🙂

                                  Er sucht die 2 billigsten 15 Minuten und lädt die Batterie. Dann nimmt er den Preis der teuersten Phase = die teuerste Wattstunde im Speicher und rechnet dazu den Wirkungsgradverlust hinzu.... alles was da drunter liegt sperrt er das Entladen, was darüber liegt wird entladen.

                                  1 Reply Last reply Reply Quote 0
                                  • H
                                    HansJochen @ReblausGT last edited by

                                    @reblausgt

                                    Gute Frage. Für mich war das mein erster Berührpunkt mit ECharts. So, wie es jetzt ist, passt es bei mir mit der Skalierung relativ gut. Je nach Fenstergröße auf unterschiedlichen Größen wählt ECharts hier recht vernünftig, welche Punkte auf der Skala weggelassen werden. Beispielsweise sehe ich in dem kleinen Ausschnitt, den ich dem Chart in meiner Visualisierung gönne, die vollen Stunden und wenn ich das Chart alleine im Browser Fullscreen öffne auch die Viertelstunden.

                                    Ich habe mir aber jetzt gerade eine Echart Demo angeschaut (https://echarts.apache.org/examples/en/editor.html?c=area-time-axis), da lässt sich in dem Chart mit dem Mausrad zoomen. Das geht bei uns nicht. Ob die String-Skala der Grund ist, weiß ich nicht. Das könnte ich mir aber vorstellen.

                                    Was wohl in jedem Fall schöner wäre: Es wäre halt der Weg, den ECharts für Zeitserien vorsieht. Das Datum würde nicht ständig wiederholt, sondern nur einmal angezeigt und ansonsten nur die Uhrzeit. Die X-Achse wäre also etwas übersichtlicher.

                                    Mir persönlich wäre die Änderung nicht wichtig, das Template wäre aber leicht anzupassen. Ich kann da bei Bedarf auch gerne unterstützen. Wer sich beispielsweise veränderte Tooltips eingebaut hat, müsste halt selbst noch mal Hand anlegen. Ich würde aber vermuten, wer das hinbekommen hat, wird auch an dem Umbau nicht scheitern.

                                    Übrigens: Ich vermute, dass es einige Nutzer gibt, die mit ECharts keine Berührpunkte hatten und die in ihrer Automatisierung nur für die Tibberpreise benutzen. Dann ist es schon etwas knifflig, die URL für die generierten Charts herauszufinden und die Templates in den Editor zu kopieren könnte auf manche auch etwas abschreckend wirken. Vermutlich benutzen die Meisten eines der Standard Templates ohne Veränderungen.

                                    Da könnte es aus meiner Sicht helfen, wenn die URL im Adapter direkt angezeigt würde und es eine Auswahl der Art "Standard Darstellung", "alternative Darstellung" oder "benutzerdefinierte Darstellung" gäbe und damit der ganze Flexchart Hintergrund samt Erklärungen, Beispielen und Editor nur sichtbar wird, wenn man zuvor "benutzerdefiniert" ausgewählt hat.

                                    1 Reply Last reply Reply Quote 0
                                    • S
                                      Schimi last edited by

                                      ist das was?

                                      {
                                      	backgroundColor: "#ffffff",
                                      
                                      	title: {
                                      		text: "Tibber Preis",
                                      		left: "center",
                                      		textStyle: { color: "#333", fontSize: 16 }
                                      	},
                                      
                                      	tooltip: {
                                      		trigger: "axis",
                                      		axisPointer: { type: "cross" },
                                      		valueFormatter: value => value.toFixed(3) + " €"
                                      	},
                                      
                                      	grid: {
                                      		left: "8%", right: "4%", top: "10%", bottom: "10%"
                                      	},
                                      
                                      	xAxis: {
                                      		type: "time",
                                      		name: "Zeit",
                                      		axisLabel: {
                                      			formatter: value => {
                                      				const date = new Date(value);
                                      				const hours = date.getHours().toString().padStart(2, "0");
                                      				const minutes = date.getMinutes().toString().padStart(2, "0");
                                      				return hours + ":" + minutes;
                                      			}
                                      		},
                                      		splitLine: { show: false }
                                      	},
                                      
                                      	yAxis: {
                                      		type: "value",
                                      		name: "Preis (€)",
                                      		axisLabel: { formatter: "{value} €" },
                                      		splitLine: { show: true }
                                      	},
                                      
                                      	visualMap: {
                                      		show: false,
                                      		min: 0.2,
                                      		max: 0.4,
                                      		inRange: {
                                      			color: ["green", "yellow", "red"]
                                      		}
                                      	},
                                      
                                      	series: [
                                      		{
                                      			name: "Preis",
                                      			type: "line",
                                      			symbol: "none",
                                      			step: "end",
                                      			data: %%yAxisData%%, // Format: [ [timestamp, value], [timestamp, value], ... ]
                                      
                                      			markArea: {
                                      				itemStyle: { color: "rgba(120, 200, 120, 0.2)" },
                                      				data: [ %%CalcChannelsData%% ] // z. B. [[{ xAxis: "2025-11-04T10:00" }, { xAxis: "2025-11-04T14:00" }]]
                                      			},
                                      
                                      			markLine: {
                                      				symbol: "none",
                                      				label: {
                                      					formatter: "Jetzt",
                                      					position: "end",
                                      					color: "#333"
                                      				},
                                      				lineStyle: { color: "red", type: "solid" },
                                      				data: [
                                      					{
                                      						xAxis: new Date().toISOString()
                                      					}
                                      				]
                                      			}
                                      		}
                                      	]
                                      }
                                      
                                      
                                      1 Reply Last reply Reply Quote 0
                                      • First post
                                        Last post

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate
                                      FAQ Cloud / IOT
                                      HowTo: Node.js-Update
                                      HowTo: Backup/Restore
                                      Downloads
                                      BLOG

                                      1.0k
                                      Online

                                      32.4k
                                      Users

                                      81.2k
                                      Topics

                                      1.3m
                                      Posts

                                      85
                                      605
                                      187252
                                      Loading More Posts
                                      • Oldest to Newest
                                      • Newest to Oldest
                                      • Most Votes
                                      Reply
                                      • Reply as topic
                                      Log in to reply
                                      Community
                                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                      The ioBroker Community 2014-2023
                                      logo