Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Entwicklung
  4. Erweiterung des vis-jqui-mfd

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.5k

Erweiterung des vis-jqui-mfd

Geplant Angeheftet Gesperrt Verschoben Entwicklung
2 Beiträge 1 Kommentatoren 347 Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • ZaphodZ Offline
    ZaphodZ Offline
    Zaphod
    schrieb am zuletzt editiert von
    #1

    Hallo,

    ... für meine Dimmer-Steuerung hätte ich gerne ein widget, welches den Zustand des DImmers anzeigt und bei Betätigung dieser Anzeige ein Fenster öffnet, in dem ich den neuen Dimmerwert aus eine Liste von Dimmerwerten auswählen kann.
    Bei vis-jqui-widget bin ich mit dem "Dimmer + jqui Dialog"-Template (tplMfdLightDialog) fündig geworden.

    Allerdings:
    Dort sind die möglichen Werte hartcodiert (und auch ein paar "Nicklichkeiten" drinnen - z.B. wird der Dimmerwert immer angezeigt)

    Ich hab' mich also an die Widget-Programmierung gemacht.
    Nicht ganz leicht, VIS zu überzeugen, eine neue Version zu verwenden und zu debuggen ...

    ... ich hab' also, statt der hartcodierten 5 Werte (_off, 25%, 50%, 75%, 100%) zunächst 6 Werte hartcodiert (_off, 20%, ..., 100%):

                    <input type="radio" id="<%= WidId %>_radio0" name="<%= this.data.attr('wid') %>_radio" value="<%= min %>" checked="checked"/>
                    <label for="<%= WidId %>_radio0"><%= _('off') %></label>
                    <input type="radio" id="<%= WidId %>_radio1" name="<%= this.data.attr('wid') %>_radio" value="<%= min + (max - min) * 0.2 %>" checked="checked"/>
                    <label for="<%= WidId %>_radio1">20</label>
                    <input type="radio" id="<%= WidId %>_radio2" name="<%= this.data.attr('wid') %>_radio" value="<%= min + (max - min) * 0.4 %>" checked="checked"/>
                    <label for="<%= WidId %>_radio2">40</label>
                    <input type="radio" id="<%= WidId %>_radio3" name="<%= this.data.attr('wid') %>_radio" value="<%= min + (max - min) * 0.6 %>" checked="checked"/>
                    <label for="<%= WidId %>_radio3">60</label>
                    <input type="radio" id="<%= WidId %>_radio4" name="<%= this.data.attr('wid') %>_radio" value="<%= min + (max - min) * 0.8 %>" checked="checked"/>
                    <label for="<%= WidId %>_radio4">80</label>
                    <input type="radio" id="<%= WidId %>_radio5" name="<%= this.data.attr('wid') %>_radio" value="<%= max %>"/>
                    <label for="<%= WidId %>_radio5">100</label>
    

    nun das Ganze als Schleife (mit EJS):

    let count = 5;
                    <input type="radio" id="<%= WidId %>_radio0" name="<%= WidId %>_radio" value="<%= min %>" checked="checked"/>
                    <label for="<%= WidId %>_radio0"><%= _('off') %></label>
                    <%
                    for (let i=1; i <= count; i++) {
                        let percent =  ( (min+(max-min)) / count ) * i;
                        console.log ("percent: " + percent);
                    %>
                        <input type="radio" id="<%= WidId %>_radio<% i %>" name="<%= WidId %>_radio" value="<%= percent %>" checked="checked"/>
                        <label for="<%= WidId %>_radio<% i %>"><%= percent %></label>
                    <% } %>
    

    Das Ergebnis ist allerdings nicht wie erwartet:

    ![Dialog](Dialog.jpg image url)

    ... ich hab's tausendmal debugged - irgendwie generiert mir VIS da ganz merkwürdige <spans> hinein:

    ![spans](labels.jpg image url)

    ???

    1 Antwort Letzte Antwort
    0
    • ZaphodZ Offline
      ZaphodZ Offline
      Zaphod
      schrieb am zuletzt editiert von
      #2

      ... fragt mich nicht, wo der Unterschied ist. So läuft's

      <%
                      for (let i=1; i <= count; i++) {
                          let percent =  ( (min+(max-min)) / count ) * i;
                          let id = WidId + '_radio' + i;
                      %>
                          <input type="radio" id="<%= id %>" name="<%= WidId %>_radio" value="<%= percent %>" checked="checked"/>
                          <label for="<%= id %>"><%= percent %></label>
                          <% console.log ("percent: " + percent + "; i: " + i + "; id: " + id); %>
                      <% } %>
      

      d.h., ich hab' die id zusammengebaut und erst dann im HTML verwendet.

      1 Antwort Letzte Antwort
      0
      Antworten
      • In einem neuen Thema antworten
      Anmelden zum Antworten
      • Älteste zuerst
      • Neuste zuerst
      • Meiste Stimmen


      Support us

      ioBroker
      Community Adapters
      Donate

      604

      Online

      32.7k

      Benutzer

      82.4k

      Themen

      1.3m

      Beiträge
      Community
      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
      ioBroker Community 2014-2025
      logo
      • Anmelden

      • Du hast noch kein Konto? Registrieren

      • Anmelden oder registrieren, um zu suchen
      • Erster Beitrag
        Letzter Beitrag
      0
      • Home
      • Aktuell
      • Tags
      • Ungelesen 0
      • Kategorien
      • Unreplied
      • Beliebt
      • GitHub
      • Docu
      • Hilfe