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. Skripten / Logik
  4. Alexa Shopping List mit Bring synchronisieren

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.5k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.0k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    2.7k

Alexa Shopping List mit Bring synchronisieren

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
166 Beiträge 29 Kommentatoren 33.6k Aufrufe 30 Watching
  • Ä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.
  • Der-JetiD Offline
    Der-JetiD Offline
    Der-Jeti
    schrieb am zuletzt editiert von
    #145

    Mit der neuen Version vom Alexa Adapter 3.27.0 und dem Script funktioniert das Synchronisieren auf beiden Seiten wieder.

    const bringBaseId = 'bring.0.xxxxxxxx-xxx-xxxx-xxxx-xxxxxxxxxxxx';
    const alexa2BaseId = 'alexa2.0.Lists.SHOP';
    
    const bringListId = bringBaseId + '.content';
    const bringListCompletedId = bringBaseId + '.recentContent';
    const bringAddToList = bringBaseId + '.saveItem';
    const bringCompleteItem = bringBaseId + '.moveToRecentContent';
    const alexaAddToList = alexa2BaseId + '.#New';
    const alexaListId = alexa2BaseId + '.json';
    
    const printDebug = true;
    function debug(msg) {
        if (printDebug) log(msg);
    }
    
    const TodoItemStatus = {
        NeedsAction: 'needs_action',
        Completed: 'completed',
    };
    
    function ListCleaner(Eintrag = '') {
        return Eintrag
            .split(' ')
            .map(w => w.charAt(0).toUpperCase() + w.slice(1))
            .join(' ');
    }
    
    function compareCompleted(alexaItem, bringItem) {
        return (
            (alexaItem.completed && bringItem.status === TodoItemStatus.Completed) ||
            (!alexaItem.completed && bringItem.status === TodoItemStatus.NeedsAction)
        );
    }
    
    function eliminateDuplicated() {
        const raw = getState(alexaListId).val;
        if (!raw) return;
        const list = JSON.parse(raw);
        const seen = {};
        for (const item of list) {
            const cleaned = ListCleaner(item.value);
            if (seen[cleaned]) {
                debug(`Delete duplicate Alexa item: ${item.value}`);
                setState(`${alexa2BaseId}.items.${item.id}.#delete`, true);
            } else {
                seen[cleaned] = true;
            }
        }
    }
    
    function syncLists(alexaList, bringList, timestampBring, source, recentList) {
        for (const alexaItem of alexaList) {
            const cleanedName = ListCleaner(alexaItem.value);
            alexaItem.found = false;
    
            // Suche im aktiven Bring-Einträgen
            for (const bringItem of bringList) {
                if (ListCleaner(bringItem.name) === cleanedName) {
                    alexaItem.found = true;
                    bringItem.found = true;
    
                    if (alexaItem.updatedDateTime > timestampBring) {
                        if (!compareCompleted(alexaItem, bringItem)) {
                            if (source === 'Alexa' && alexaItem.completed) {
                                debug(`Markiere "${bringItem.name}" als erledigt in Bring (von Alexa)`);
                                setState(bringCompleteItem, cleanedName);
                            }
                        }
                    } else {
                        if (!compareCompleted(alexaItem, bringItem)) {
                            if (source === 'Bring') {
                                debug(`Aktualisiere "${alexaItem.value}" in Alexa (von Bring)`);
                                setState(`${alexa2BaseId}.items.${alexaItem.id}.completed`, bringItem.status === TodoItemStatus.Completed);
                            }
                        }
                    }
                }
            }
    
            // Suche im "recentContent" von Bring
            for (const bringItem of recentList) {
                if (ListCleaner(bringItem.name) === cleanedName) {
                    alexaItem.found = true;
                    bringItem.found = true;
    
                    if (alexaItem.updatedDateTime > timestampBring) {
                        if (source === 'Alexa' && !compareCompleted(alexaItem, bringItem)) {
                            debug(`Füge "${bringItem.name}" erneut zu Bring hinzu (von Alexa)`);
                            setState(bringAddToList, cleanedName);
                        }
                    } else {
                        if (!compareCompleted(alexaItem, bringItem)) {
                            if (source === 'Bring') {
                                debug(`Lösche Alexa-Eintrag "${alexaItem.value}" (von Bring)`);
                                setState(`${alexa2BaseId}.items.${alexaItem.id}.#delete`, true);
                            }
                        }
                    }
                }
            }
    
            // Alexa-Item nicht gefunden in Bring
            if (!alexaItem.found) {
                if (alexaItem.completed) {
                    debug(`Lösche erledigten Alexa-Eintrag "${alexaItem.value}", nicht in Bring gefunden.`);
                    setState(`${alexa2BaseId}.items.${alexaItem.id}.#delete`, true);
                } else if (source === 'Alexa') {
                    debug(`Füge neuen Alexa-Eintrag "${alexaItem.value}" zu Bring hinzu`);
                    setState(bringAddToList, cleanedName);
                }
            }
        }
    
        // Bring-Einträge, die nicht in Alexa sind
        for (const bringItem of bringList) {
            if (!bringItem.found && bringItem.status !== TodoItemStatus.Completed && source === 'Bring') {
                debug(`Füge Bring-Eintrag "${bringItem.name}" zu Alexa hinzu`);
                setState(alexaAddToList, ListCleaner(bringItem.name));
            }
        }
    }
    
    function doSync(source) {
        eliminateDuplicated();
    
        const rawAlexa = getState(alexaListId).val;
        const rawBring = getState(bringListId).val;
        const rawCompleted = getState(bringListCompletedId).val;
    
        if (!rawAlexa || !rawBring || !rawCompleted) {
            debug('Datenpunkte unvollständig');
            return;
        }
    
        const alexaList = JSON.parse(rawAlexa);
        const bringList = JSON.parse(rawBring);
        const bringCompleted = JSON.parse(rawCompleted);
        const timestamp = getState(bringListId).ts;
    
        syncLists(alexaList, bringList, timestamp, source, bringCompleted);
    }
    
    on({ id: bringListId, change: 'any' }, () => {
        debug('Änderung durch Bring erkannt');
        doSync('Bring');
    });
    
    on({ id: alexaListId, change: 'any' }, () => {
        debug('Änderung durch Alexa erkannt');
        doSync('Alexa');
    });
    
    // Initial Sync beim Start
    doSync('Startup');
    
    
    M 1 Antwort Letzte Antwort
    0
    • Der-JetiD Der-Jeti

      Mit der neuen Version vom Alexa Adapter 3.27.0 und dem Script funktioniert das Synchronisieren auf beiden Seiten wieder.

      const bringBaseId = 'bring.0.xxxxxxxx-xxx-xxxx-xxxx-xxxxxxxxxxxx';
      const alexa2BaseId = 'alexa2.0.Lists.SHOP';
      
      const bringListId = bringBaseId + '.content';
      const bringListCompletedId = bringBaseId + '.recentContent';
      const bringAddToList = bringBaseId + '.saveItem';
      const bringCompleteItem = bringBaseId + '.moveToRecentContent';
      const alexaAddToList = alexa2BaseId + '.#New';
      const alexaListId = alexa2BaseId + '.json';
      
      const printDebug = true;
      function debug(msg) {
          if (printDebug) log(msg);
      }
      
      const TodoItemStatus = {
          NeedsAction: 'needs_action',
          Completed: 'completed',
      };
      
      function ListCleaner(Eintrag = '') {
          return Eintrag
              .split(' ')
              .map(w => w.charAt(0).toUpperCase() + w.slice(1))
              .join(' ');
      }
      
      function compareCompleted(alexaItem, bringItem) {
          return (
              (alexaItem.completed && bringItem.status === TodoItemStatus.Completed) ||
              (!alexaItem.completed && bringItem.status === TodoItemStatus.NeedsAction)
          );
      }
      
      function eliminateDuplicated() {
          const raw = getState(alexaListId).val;
          if (!raw) return;
          const list = JSON.parse(raw);
          const seen = {};
          for (const item of list) {
              const cleaned = ListCleaner(item.value);
              if (seen[cleaned]) {
                  debug(`Delete duplicate Alexa item: ${item.value}`);
                  setState(`${alexa2BaseId}.items.${item.id}.#delete`, true);
              } else {
                  seen[cleaned] = true;
              }
          }
      }
      
      function syncLists(alexaList, bringList, timestampBring, source, recentList) {
          for (const alexaItem of alexaList) {
              const cleanedName = ListCleaner(alexaItem.value);
              alexaItem.found = false;
      
              // Suche im aktiven Bring-Einträgen
              for (const bringItem of bringList) {
                  if (ListCleaner(bringItem.name) === cleanedName) {
                      alexaItem.found = true;
                      bringItem.found = true;
      
                      if (alexaItem.updatedDateTime > timestampBring) {
                          if (!compareCompleted(alexaItem, bringItem)) {
                              if (source === 'Alexa' && alexaItem.completed) {
                                  debug(`Markiere "${bringItem.name}" als erledigt in Bring (von Alexa)`);
                                  setState(bringCompleteItem, cleanedName);
                              }
                          }
                      } else {
                          if (!compareCompleted(alexaItem, bringItem)) {
                              if (source === 'Bring') {
                                  debug(`Aktualisiere "${alexaItem.value}" in Alexa (von Bring)`);
                                  setState(`${alexa2BaseId}.items.${alexaItem.id}.completed`, bringItem.status === TodoItemStatus.Completed);
                              }
                          }
                      }
                  }
              }
      
              // Suche im "recentContent" von Bring
              for (const bringItem of recentList) {
                  if (ListCleaner(bringItem.name) === cleanedName) {
                      alexaItem.found = true;
                      bringItem.found = true;
      
                      if (alexaItem.updatedDateTime > timestampBring) {
                          if (source === 'Alexa' && !compareCompleted(alexaItem, bringItem)) {
                              debug(`Füge "${bringItem.name}" erneut zu Bring hinzu (von Alexa)`);
                              setState(bringAddToList, cleanedName);
                          }
                      } else {
                          if (!compareCompleted(alexaItem, bringItem)) {
                              if (source === 'Bring') {
                                  debug(`Lösche Alexa-Eintrag "${alexaItem.value}" (von Bring)`);
                                  setState(`${alexa2BaseId}.items.${alexaItem.id}.#delete`, true);
                              }
                          }
                      }
                  }
              }
      
              // Alexa-Item nicht gefunden in Bring
              if (!alexaItem.found) {
                  if (alexaItem.completed) {
                      debug(`Lösche erledigten Alexa-Eintrag "${alexaItem.value}", nicht in Bring gefunden.`);
                      setState(`${alexa2BaseId}.items.${alexaItem.id}.#delete`, true);
                  } else if (source === 'Alexa') {
                      debug(`Füge neuen Alexa-Eintrag "${alexaItem.value}" zu Bring hinzu`);
                      setState(bringAddToList, cleanedName);
                  }
              }
          }
      
          // Bring-Einträge, die nicht in Alexa sind
          for (const bringItem of bringList) {
              if (!bringItem.found && bringItem.status !== TodoItemStatus.Completed && source === 'Bring') {
                  debug(`Füge Bring-Eintrag "${bringItem.name}" zu Alexa hinzu`);
                  setState(alexaAddToList, ListCleaner(bringItem.name));
              }
          }
      }
      
      function doSync(source) {
          eliminateDuplicated();
      
          const rawAlexa = getState(alexaListId).val;
          const rawBring = getState(bringListId).val;
          const rawCompleted = getState(bringListCompletedId).val;
      
          if (!rawAlexa || !rawBring || !rawCompleted) {
              debug('Datenpunkte unvollständig');
              return;
          }
      
          const alexaList = JSON.parse(rawAlexa);
          const bringList = JSON.parse(rawBring);
          const bringCompleted = JSON.parse(rawCompleted);
          const timestamp = getState(bringListId).ts;
      
          syncLists(alexaList, bringList, timestamp, source, bringCompleted);
      }
      
      on({ id: bringListId, change: 'any' }, () => {
          debug('Änderung durch Bring erkannt');
          doSync('Bring');
      });
      
      on({ id: alexaListId, change: 'any' }, () => {
          debug('Änderung durch Alexa erkannt');
          doSync('Alexa');
      });
      
      // Initial Sync beim Start
      doSync('Startup');
      
      
      M Online
      M Online
      MCU
      schrieb am zuletzt editiert von MCU
      #146

      @der-jeti 3.27.0 gibt es nicht
      5a708cda-cfe8-4011-a13e-69b8288ea640-image.png
      EDIT: anscheinend doch
      "version": "3.27.0",

      NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
      Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

      T mcBirneM 2 Antworten Letzte Antwort
      0
      • M MCU

        @der-jeti 3.27.0 gibt es nicht
        5a708cda-cfe8-4011-a13e-69b8288ea640-image.png
        EDIT: anscheinend doch
        "version": "3.27.0",

        T Offline
        T Offline
        thorschtn
        schrieb am zuletzt editiert von
        #147

        @mcu Funktioniert einwandfrei. Lediglich die noch nicht offiziell releaste 3.27.0 laden und im Javascript die const alexa2BaseId ändern.

        1 Antwort Letzte Antwort
        0
        • M MCU

          @der-jeti 3.27.0 gibt es nicht
          5a708cda-cfe8-4011-a13e-69b8288ea640-image.png
          EDIT: anscheinend doch
          "version": "3.27.0",

          mcBirneM Offline
          mcBirneM Offline
          mcBirne
          schrieb am zuletzt editiert von
          #148

          @mcu Wo findest du die v3.27.0? Ich finde nur die v3.26.7

          Der-JetiD M 2 Antworten Letzte Antwort
          0
          • mcBirneM mcBirne

            @mcu Wo findest du die v3.27.0? Ich finde nur die v3.26.7

            Der-JetiD Offline
            Der-JetiD Offline
            Der-Jeti
            schrieb am zuletzt editiert von
            #149

            @mcbirne mit der Katze von github laden.

            1 Antwort Letzte Antwort
            1
            • mcBirneM mcBirne

              @mcu Wo findest du die v3.27.0? Ich finde nur die v3.26.7

              M Online
              M Online
              MCU
              schrieb am zuletzt editiert von
              #150

              @mcbirne
              https://github.com/Apollon77/ioBroker.alexa2/blob/9baece37d4796b88d8debb7af9cbfef50cfc92c8/io-package.json#L4

              NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
              Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

              M 1 Antwort Letzte Antwort
              1
              • M MCU

                @mcbirne
                https://github.com/Apollon77/ioBroker.alexa2/blob/9baece37d4796b88d8debb7af9cbfef50cfc92c8/io-package.json#L4

                M Offline
                M Offline
                martin_olw
                schrieb am zuletzt editiert von
                #151

                @Heimweh - kann mit der neuen Version vom Alexa Adapter 3.27.x über die Datenpunkte in alexa2.0.Lists.SHOP mit TODOIST gesycnt oder zuverlässig nach TODOIST geschrieben werden? Aktuell klappt das bei mir mit deinem Skript nur in 30 % der Fälle.
                Danke!
                VG Martin

                HeimwehH 3 Antworten Letzte Antwort
                0
                • M martin_olw

                  @Heimweh - kann mit der neuen Version vom Alexa Adapter 3.27.x über die Datenpunkte in alexa2.0.Lists.SHOP mit TODOIST gesycnt oder zuverlässig nach TODOIST geschrieben werden? Aktuell klappt das bei mir mit deinem Skript nur in 30 % der Fälle.
                  Danke!
                  VG Martin

                  HeimwehH Online
                  HeimwehH Online
                  Heimweh
                  schrieb am zuletzt editiert von Heimweh
                  #152

                  @martin_olw bei mir hat das zu 100% funktioniert. Ich habe mir zuletzt einen eigenen Alexa Skill gebastelt für Einkaufs und Todoliste mit Todoist. Es hat auch geklappt allerdings blöd zum aufrufen. Bsp.: Alexa sag meinen Projekten, ich muss Fenster putzen. - bei dem Script den ich online gestellt hatte war bei mir öfters das Problem der summary Datenpunkt der zeitweise nicht funktioniert. Ich kann Dir derzeit nicht helfen weil ich noch 3 Wochen im Urlaub bin, habe aber interessiert hier mitgelesen und wollte mir das nach Rückkehr mal anschauen..... Ich denke schon dass man das wieder verknüpfen kann so das es mit Todoist läuft

                  aruttkampA 1 Antwort Letzte Antwort
                  0
                  • HeimwehH Heimweh

                    @martin_olw bei mir hat das zu 100% funktioniert. Ich habe mir zuletzt einen eigenen Alexa Skill gebastelt für Einkaufs und Todoliste mit Todoist. Es hat auch geklappt allerdings blöd zum aufrufen. Bsp.: Alexa sag meinen Projekten, ich muss Fenster putzen. - bei dem Script den ich online gestellt hatte war bei mir öfters das Problem der summary Datenpunkt der zeitweise nicht funktioniert. Ich kann Dir derzeit nicht helfen weil ich noch 3 Wochen im Urlaub bin, habe aber interessiert hier mitgelesen und wollte mir das nach Rückkehr mal anschauen..... Ich denke schon dass man das wieder verknüpfen kann so das es mit Todoist läuft

                    aruttkampA Offline
                    aruttkampA Offline
                    aruttkamp
                    schrieb am zuletzt editiert von
                    #153

                    Das läuft jetzt wieder wie geschmiert !
                    Danke an alle beteiligten !

                    aruttkampA 1 Antwort Letzte Antwort
                    0
                    • aruttkampA aruttkamp

                      Das läuft jetzt wieder wie geschmiert !
                      Danke an alle beteiligten !

                      aruttkampA Offline
                      aruttkampA Offline
                      aruttkamp
                      schrieb am zuletzt editiert von aruttkamp
                      #154

                      @Heimweh
                      Mir ist aufgefallen, dass das Skript jede Minute eine Änderung durch Bring! erkennt.
                      Dabei ist es egal ob etwas geändert wurde oder nicht. Hat das schon mal jemand beleuchtet warum dies passiert und wie das evtl. unterbunden werden kann ?

                      HeimwehH 1 Antwort Letzte Antwort
                      0
                      • aruttkampA aruttkamp

                        @Heimweh
                        Mir ist aufgefallen, dass das Skript jede Minute eine Änderung durch Bring! erkennt.
                        Dabei ist es egal ob etwas geändert wurde oder nicht. Hat das schon mal jemand beleuchtet warum dies passiert und wie das evtl. unterbunden werden kann ?

                        HeimwehH Online
                        HeimwehH Online
                        Heimweh
                        schrieb am zuletzt editiert von
                        #155

                        @aruttkamp - Du meinst Todoist? Kannst Du mir näher beschreiben was Du genau meinst? Vielleicht wird er Summary Datenpunkt minütlich abgefragt? Aber das dürfte nicht relevant sein solange sich der Wert nicht ändert? Bei mir läuft der Skript seit Erstellung problemlos.... Habe mich daher auch nicht mehr damit befasst.....

                        aruttkampA 1 Antwort Letzte Antwort
                        0
                        • HeimwehH Heimweh

                          @aruttkamp - Du meinst Todoist? Kannst Du mir näher beschreiben was Du genau meinst? Vielleicht wird er Summary Datenpunkt minütlich abgefragt? Aber das dürfte nicht relevant sein solange sich der Wert nicht ändert? Bei mir läuft der Skript seit Erstellung problemlos.... Habe mich daher auch nicht mehr damit befasst.....

                          aruttkampA Offline
                          aruttkampA Offline
                          aruttkamp
                          schrieb am zuletzt editiert von
                          #156

                          @heimweh
                          ich meine Diese Protokolleinträge :
                          c808b55c-11f1-45cf-851a-c6ce0d66fe54-image.png

                          ja, es sind nur infos und ich kann sie abstellen. aber es passiert ja doch ein permanentes schreiben Rtg. Alexa. ich bin nicht sicher ob das nicht zu viel traffic dort führt und die uns das irgendwann übel nehmen ;-)

                          HeimwehH mcBirneM 2 Antworten Letzte Antwort
                          0
                          • aruttkampA aruttkamp

                            @heimweh
                            ich meine Diese Protokolleinträge :
                            c808b55c-11f1-45cf-851a-c6ce0d66fe54-image.png

                            ja, es sind nur infos und ich kann sie abstellen. aber es passiert ja doch ein permanentes schreiben Rtg. Alexa. ich bin nicht sicher ob das nicht zu viel traffic dort führt und die uns das irgendwann übel nehmen ;-)

                            HeimwehH Online
                            HeimwehH Online
                            Heimweh
                            schrieb am zuletzt editiert von
                            #157

                            @aruttkamp bei mir ist das nicht so. Hast Du den Bring Teil in meinen Script reingebastelt? Was ich mir gerade noch überlege - der Listen Teil soll ja wieder funktionieren (s.o.) - hat es damit evtl zu tun?

                            1 Antwort Letzte Antwort
                            0
                            • aruttkampA aruttkamp

                              @heimweh
                              ich meine Diese Protokolleinträge :
                              c808b55c-11f1-45cf-851a-c6ce0d66fe54-image.png

                              ja, es sind nur infos und ich kann sie abstellen. aber es passiert ja doch ein permanentes schreiben Rtg. Alexa. ich bin nicht sicher ob das nicht zu viel traffic dort führt und die uns das irgendwann übel nehmen ;-)

                              mcBirneM Offline
                              mcBirneM Offline
                              mcBirne
                              schrieb am zuletzt editiert von
                              #158

                              @aruttkamp
                              Bei mir funktioniert es seit heute nicht mehr. Allerdings werden auch keine Alexa IOT Befehle erkannt oder die Alexa Summary aktualisiert. Auch Ankündigungen sind nicht mehr möglich. Hat das noch jemand? Hat Amazon da ein Problem?

                              HeimwehH aruttkampA 2 Antworten Letzte Antwort
                              0
                              • mcBirneM mcBirne

                                @aruttkamp
                                Bei mir funktioniert es seit heute nicht mehr. Allerdings werden auch keine Alexa IOT Befehle erkannt oder die Alexa Summary aktualisiert. Auch Ankündigungen sind nicht mehr möglich. Hat das noch jemand? Hat Amazon da ein Problem?

                                HeimwehH Online
                                HeimwehH Online
                                Heimweh
                                schrieb am zuletzt editiert von
                                #159

                                @mcbirne ist bei mir auch so. bzw. IOT Geräte lassen sich steuern aber summary und die Listen gehen nicht mehr

                                1 Antwort Letzte Antwort
                                1
                                • mcBirneM mcBirne

                                  @aruttkamp
                                  Bei mir funktioniert es seit heute nicht mehr. Allerdings werden auch keine Alexa IOT Befehle erkannt oder die Alexa Summary aktualisiert. Auch Ankündigungen sind nicht mehr möglich. Hat das noch jemand? Hat Amazon da ein Problem?

                                  aruttkampA Offline
                                  aruttkampA Offline
                                  aruttkamp
                                  schrieb am zuletzt editiert von aruttkamp
                                  #160

                                  @Heimweh
                                  Nein. Dein Scrikt ist das von hier - 1:1 kopiert und nur oben im Kopf die entspr. ID´s geändert

                                  HeimwehH 1 Antwort Letzte Antwort
                                  0
                                  • aruttkampA aruttkamp

                                    @Heimweh
                                    Nein. Dein Scrikt ist das von hier - 1:1 kopiert und nur oben im Kopf die entspr. ID´s geändert

                                    HeimwehH Online
                                    HeimwehH Online
                                    Heimweh
                                    schrieb am zuletzt editiert von Heimweh
                                    #161

                                    @aruttkamp ich habe gar kein Bring sondern Todoist. Hoffe Du hast jetzt nichts gemischt. Der Todoist Script mit viel weniger Logeinträgen wäre der hier (bitte selber testen - hab leider keine Zeit gefunden):

                                    const axios = require('axios');
                                    
                                    // Konfiguration
                                    const todoistShoppingListId = 'XXXXXXXXXXX'; // <- Deine Projekt-ID
                                    const todoistToken = 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'; // <- Dein API-Token
                                    
                                    on({ id: 'alexa2.0.History.summary', change: 'any' }, function (obj) {
                                        const inputRaw = obj.state.val;
                                    
                                        if (typeof inputRaw !== 'string') {
                                            console.warn('[ToDoist] ⚠️ Kein String erkannt in alexa2.0.History.summary:', inputRaw);
                                            return;
                                        }
                                    
                                        const input = inputRaw.trim();
                                    
                                        const match = input.match(/^setze (.+) auf (?:meine|die) (einkaufsliste|todo[\s-]?liste)/i);
                                    
                                        if (match && match.length >= 3) {
                                            const rohAufgabe = match[1];
                                            const ziel = match[2].replace(/\s|-/g, '').toLowerCase();
                                    
                                            const mitZiffern = wordsToNumbersSmart(rohAufgabe);
                                            const aufgabe = capitalizeFirst(mitZiffern);
                                    
                                            let projektId = null;
                                            if (ziel === 'einkaufsliste') {
                                                projektId = todoistShoppingListId;
                                            }
                                    
                                            console.log(`[ToDoist] 🧠 Alexa erkannt → "${aufgabe}" für Projekt: ${ziel}`);
                                            addTaskToTodoist(aufgabe, projektId);
                                        }
                                    });
                                    
                                    function addTaskToTodoist(text, projectId = null) {
                                        const todoistData = { content: text };
                                        if (projectId) todoistData.project_id = projectId;
                                    
                                        axios.post('https://api.todoist.com/rest/v2/tasks', todoistData, {
                                            headers: {
                                                'Content-Type': 'application/json',
                                                'Authorization': `Bearer ${todoistToken}`
                                            }
                                        })
                                        .then(() => {
                                            console.log(`[ToDoist] ✅ Aufgabe "${text}" erfolgreich zu Todoist hinzugefügt.`);
                                        })
                                        .catch(error => {
                                            console.error('[ToDoist] ❌ Fehler beim Hinzufügen zu Todoist:', error.message || error.response?.data || error);
                                        });
                                    }
                                    
                                    function capitalizeFirst(text) {
                                        if (!text || typeof text !== 'string') return '';
                                        return text.charAt(0).toUpperCase() + text.slice(1);
                                    }
                                    
                                    function wordsToNumbersSmart(text) {
                                        const ones = {
                                            'null': 0, 'eins': 1, 'eine': 1, 'einen': 1,
                                            'zwei': 2, 'drei': 3, 'vier': 4, 'fünf': 5,
                                            'sechs': 6, 'sieben': 7, 'acht': 8, 'neun': 9,
                                            'zehn': 10, 'elf': 11, 'zwölf': 12, 'dreizehn': 13,
                                            'vierzehn': 14, 'fünfzehn': 15, 'sechzehn': 16,
                                            'siebzehn': 17, 'achtzehn': 18, 'neunzehn': 19
                                        };
                                    
                                        const tens = {
                                            'zwanzig': 20, 'dreißig': 30, 'vierzig': 40,
                                            'fünfzig': 50, 'sechzig': 60, 'siebzig': 70,
                                            'achtzig': 80, 'neunzig': 90
                                        };
                                    
                                        const multipliers = {
                                            'hundert': 100,
                                            'tausend': 1000
                                        };
                                    
                                        const skipWords = ['und', 'oder', 'mit', 'für', 'pro'];
                                    
                                        const words = text.toLowerCase().split(/\s+/);
                                        const finalText = [];
                                        let i = 0;
                                        let capitalizeNext = 0;
                                    
                                        while (i < words.length) {
                                            const word = words[i];
                                    
                                            if (ones[word] !== undefined) {
                                                if (i + 2 < words.length && words[i + 1] === 'und' && tens[words[i + 2]]) {
                                                    const value = ones[word] + tens[words[i + 2]];
                                                    finalText.push(value.toString());
                                                    capitalizeNext = 2;
                                                    i += 3;
                                                    continue;
                                                }
                                    
                                                if (i + 1 < words.length && multipliers[words[i + 1]]) {
                                                    const value = ones[word] * multipliers[words[i + 1]];
                                                    finalText.push(value.toString());
                                                    capitalizeNext = 2;
                                                    i += 2;
                                                    continue;
                                                }
                                    
                                                finalText.push(ones[word].toString());
                                                capitalizeNext = 2;
                                                i++;
                                            } else if (tens[word] !== undefined) {
                                                finalText.push(tens[word].toString());
                                                capitalizeNext = 2;
                                                i++;
                                            } else if (!isNaN(word)) {
                                                finalText.push(word);
                                                capitalizeNext = 2;
                                                i++;
                                            } else {
                                                if (capitalizeNext > 0 && !skipWords.includes(word)) {
                                                    finalText.push(word.charAt(0).toUpperCase() + word.slice(1));
                                                    capitalizeNext--;
                                                } else {
                                                    finalText.push(word);
                                                }
                                                i++;
                                            }
                                        }
                                    
                                        return finalText.join(' ');
                                    }
                                    
                                    
                                    1 Antwort Letzte Antwort
                                    0
                                    • M martin_olw

                                      @Heimweh - kann mit der neuen Version vom Alexa Adapter 3.27.x über die Datenpunkte in alexa2.0.Lists.SHOP mit TODOIST gesycnt oder zuverlässig nach TODOIST geschrieben werden? Aktuell klappt das bei mir mit deinem Skript nur in 30 % der Fälle.
                                      Danke!
                                      VG Martin

                                      HeimwehH Online
                                      HeimwehH Online
                                      Heimweh
                                      schrieb am zuletzt editiert von
                                      #162

                                      @martin_olw sorry das ich mir so lange Zeit gelassen habe. Wenn ich das jetzt richtig gesehen habe - funktioniert mit der neuen Adapter Version der Datenpunkt alexa2.0.Lists.SHOP.json wieder - dann wäre ja alles wieder beim alten und mein erster Script den ich zum Thema Todoist reingestellt habe, müsste wieder funktionieren wie "früher" - ich hab jetzt den Script von damals nochmal korrigiert (er hat auf eine Testliste verwiesen) aber nicht getestet (mir fehlt die Zeit)

                                      const axios = require('axios');
                                      
                                      // Todoist API-Konfiguration
                                      const todoistProjectId = '12345678'; // Todoist-Projekt-ID
                                      const todoistToken = 'xXxXxXxXxXxXxXxXxXxXxXxX'; // Todoist-API-Token
                                      
                                      let previousList = [];
                                      
                                      // 1. Überwachen der Änderungen in der Alexa-Liste
                                      on({ id: 'alexa2.0.Lists.SHOP.json', change: 'any' }, function (obj) {
                                          try {
                                              console.log('Änderung in der Alexa Liste erkannt.');
                                      
                                              // Alexa-Liste als JSON parsen
                                              const currentList = JSON.parse(obj.state.val);
                                              console.log('Alexa-Liste erfolgreich geparst.');
                                      
                                              if (currentList && currentList.length > 0) {
                                                  console.log(`Alexa-Liste enthält ${currentList.length} Einträge.`);
                                      
                                                  // Neues Item zur Todoist-Liste hinzufügen, wenn die Liste gewachsen ist
                                                  if (previousList.length < currentList.length) {
                                                      const newItem = currentList.find(item => !previousList.some(prevItem => prevItem.id === item.id));
                                                      if (newItem) {
                                                          console.log(`Neues Item erkannt: "${newItem.value}" mit ID: ${newItem.id}`);
                                                          addTaskToTodoist(newItem.value);
                                                      }
                                                  }
                                      
                                                  // Aktualisiere die vorherige Liste
                                                  previousList = currentList;
                                              } else {
                                                  console.log('Alexa-Liste ist leer oder nicht verfügbar.');
                                              }
                                          } catch (e) {
                                              console.error('Fehler beim Parsen der Alexa-Liste:', e.message || e);
                                          }
                                      });
                                      
                                      // 2. Periodische Synchronisierung mit Todoist (alle 1 Minute)
                                      schedule('*/1 * * * *', function () {
                                          console.log("Todoist-Aufgaben werden abgefragt...");
                                      
                                          // Abrufen der aktiven Todoist-Aufgaben
                                          axios.get(`https://api.todoist.com/rest/v2/tasks`, {
                                              headers: {
                                                  'Authorization': `Bearer ${todoistToken}`
                                              }
                                          })
                                          .then(response => {
                                              const activeTasks = response.data.map(task => task.content); // Extrahiere die Inhalte der aktiven Aufgaben
                                              console.log('Aktive Todoist-Aufgaben erfolgreich abgerufen.');
                                      
                                              // Vergleich der aktiven Todoist-Aufgaben mit der Alexa-Liste
                                              syncAlexaWithTodoist(activeTasks);
                                          })
                                          .catch(error => {
                                              console.error('Fehler beim Abrufen der Todoist-Aufgaben:', error.message || error.response.data);
                                          });
                                      });
                                      
                                      // 3. Hilfsfunktion zum Hinzufügen von Aufgaben zu Todoist
                                      function addTaskToTodoist(itemValue) {
                                          const todoistData = {
                                              content: itemValue,
                                              project_id: todoistProjectId
                                          };
                                      
                                          axios.post('https://api.todoist.com/rest/v2/tasks', todoistData, {
                                              headers: {
                                                  'Content-Type': 'application/json',
                                                  'Authorization': `Bearer ${todoistToken}`
                                              }
                                          })
                                          .then(response => {
                                              console.log(`Item "${itemValue}" erfolgreich zu Todoist hinzugefügt.`);
                                          })
                                          .catch(error => {
                                              console.error('Fehler beim Hinzufügen zu Todoist:', error.message || error);
                                          });
                                      }
                                      
                                      // 4. Hilfsfunktion zur Synchronisierung der Alexa-Liste mit Todoist
                                      function syncAlexaWithTodoist(activeTasks) {
                                          const alexaList = JSON.parse(getState('alexa2.0.Lists.SHOP.json').val);
                                      
                                          alexaList.forEach(item => {
                                              if (!activeTasks.includes(item.value)) {
                                                  // Markiere das Item in Alexa als "completed", wenn es nicht mehr in Todoist aktiv ist
                                                  const completeState = `alexa2.0.Lists.SHOP.items.${item.id}.completed`;
                                                  setState(completeState, true, function(err) {
                                                      if (err) {
                                                          console.error(`Fehler beim Setzen von "completed" für "${item.value}" in Alexa:`, err.message || err);
                                                      } else {
                                                          console.log(`Item "${item.value}" in Alexa erfolgreich als "completed" markiert.`);
                                                      }
                                                  });
                                              }
                                          });
                                      }
                                      
                                      
                                      1 Antwort Letzte Antwort
                                      1
                                      • M martin_olw

                                        @Heimweh - kann mit der neuen Version vom Alexa Adapter 3.27.x über die Datenpunkte in alexa2.0.Lists.SHOP mit TODOIST gesycnt oder zuverlässig nach TODOIST geschrieben werden? Aktuell klappt das bei mir mit deinem Skript nur in 30 % der Fälle.
                                        Danke!
                                        VG Martin

                                        HeimwehH Online
                                        HeimwehH Online
                                        Heimweh
                                        schrieb am zuletzt editiert von
                                        #163

                                        @martin_olw Ich hab es jetzt doch getestet und noch was geändert:

                                        Hier die Beschreibung:

                                        Der Skript überwacht den Datenpunkt alexa2.0.Lists.SHOP.json.

                                        Sobald Alexa z. B. sagt:

                                        „Alexa, setze vier Äpfel auf die Einkaufsliste“
                                        wird das als neuer Eintrag in dieser Liste erkannt.

                                        Zahlwort-Umwandlung:

                                        Aus „vier Äpfel“ wird „4 Äpfel“.

                                        Auch zusammengesetzte Zahlen wie „fünfzehn“ oder „dreiundzwanzig“ werden korrekt erkannt.

                                        Das erste Wort nach der Zahl wird großgeschrieben: z. B. „4 Äpfel“ statt „4 äpfel“.

                                        Todoist-Eintrag:

                                        Der bereinigte und umgewandelte Eintrag wird direkt über die REST-API an Todoist gesendet und dort im definierten Projekt als Aufgabe eingetragen.

                                        Automatisches Entfernen in Alexa:

                                        Nach 60 Sekunden wird der passende Alexa-Listeneintrag automatisch als „abgehakt“ markiert.

                                        Es muss nur die ListID und der Token eingesetzt werden.

                                        const axios = require('axios');
                                        
                                        // Todoist API-Konfiguration
                                        const todoistProjectId = 'XXXXXXXX'; // Deine Projekt-ID
                                        const todoistToken = 'XXXXXXXXXXXXXXXXXXXXXXX'; // Dein Token
                                        
                                        let previousList = [];
                                        
                                        // 1. Alexa-Änderungen überwachen
                                        on({ id: 'alexa2.0.Lists.SHOP.json', change: 'any' }, function (obj) {
                                            try {
                                                const currentList = JSON.parse(obj.state.val);
                                        
                                                if (currentList && currentList.length > 0) {
                                                    if (previousList.length < currentList.length) {
                                                        const newItem = currentList.find(item =>
                                                            !previousList.some(prevItem => prevItem.id === item.id)
                                                        );
                                        
                                                        if (newItem) {
                                                            const umgewandelt = wordsToNumbersSmart(newItem.value);
                                                            const aufgabe = capitalizeFirst(umgewandelt);
                                                            addTaskToTodoist(aufgabe);
                                        
                                                            // Nach 60 Sekunden Alexa-Eintrag auf "completed" setzen
                                                            setTimeout(() => {
                                                                const alexaList = JSON.parse(getState('alexa2.0.Lists.SHOP.json').val);
                                        
                                                                const matchingItem = alexaList.find(item => {
                                                                    const itemText = wordsToNumbersSmart(item.value).trim().toLowerCase();
                                                                    return itemText === aufgabe.trim().toLowerCase();
                                                                });
                                        
                                                                if (matchingItem) {
                                                                    const completeState = `alexa2.0.Lists.SHOP.items.${matchingItem.id}.completed`;
                                                                    setState(completeState, true);
                                                                } else {
                                                                    console.warn(`⚠️ Kein passender Alexa-Eintrag zu "${aufgabe}" gefunden.`);
                                                                }
                                                            }, 60 * 1000); // 60 Sekunden
                                                        }
                                                    }
                                        
                                                    previousList = currentList;
                                                }
                                            } catch (e) {
                                                console.error('Fehler beim Parsen der Alexa-Liste:', e.message || e);
                                            }
                                        });
                                        
                                        // 2. Aufgaben an Todoist senden
                                        function addTaskToTodoist(itemValue) {
                                            const todoistData = {
                                                content: itemValue,
                                                project_id: todoistProjectId
                                            };
                                        
                                            axios.post('https://api.todoist.com/rest/v2/tasks', todoistData, {
                                                headers: {
                                                    'Content-Type': 'application/json',
                                                    'Authorization': `Bearer ${todoistToken}`
                                                }
                                            })
                                            .then(() => {
                                                console.log(`✅ "${itemValue}" zu Todoist hinzugefügt.`);
                                            })
                                            .catch(error => {
                                                console.error('Fehler beim Hinzufügen zu Todoist:', error.message || error);
                                            });
                                        }
                                        
                                        // 3. Erstes Wort groß
                                        function capitalizeFirst(text) {
                                            if (!text || typeof text !== 'string') return '';
                                            return text.charAt(0).toUpperCase() + text.slice(1);
                                        }
                                        
                                        // 4. Wörter → Zahlen (z. B. „vierzehn“ → 14)
                                        function wordsToNumbersSmart(text) {
                                            const ones = {
                                                'null': 0, 'eins': 1, 'eine': 1, 'einen': 1,
                                                'zwei': 2, 'drei': 3, 'vier': 4, 'fünf': 5,
                                                'sechs': 6, 'sieben': 7, 'acht': 8, 'neun': 9,
                                                'zehn': 10, 'elf': 11, 'zwölf': 12, 'dreizehn': 13,
                                                'vierzehn': 14, 'fünfzehn': 15, 'sechzehn': 16,
                                                'siebzehn': 17, 'achtzehn': 18, 'neunzehn': 19
                                            };
                                        
                                            const tens = {
                                                'zwanzig': 20, 'dreißig': 30, 'vierzig': 40,
                                                'fünfzig': 50, 'sechzig': 60, 'siebzig': 70,
                                                'achtzig': 80, 'neunzig': 90
                                            };
                                        
                                            const multipliers = {
                                                'hundert': 100,
                                                'tausend': 1000
                                            };
                                        
                                            const skipWords = ['und', 'oder', 'mit', 'für', 'pro'];
                                            const words = text.toLowerCase().split(/\s+/);
                                            const finalText = [];
                                            let i = 0;
                                            let capitalizeNext = 0;
                                        
                                            while (i < words.length) {
                                                const word = words[i];
                                        
                                                if (ones[word] !== undefined) {
                                                    if (i + 2 < words.length && words[i + 1] === 'und' && tens[words[i + 2]]) {
                                                        const value = ones[word] + tens[words[i + 2]];
                                                        finalText.push(value.toString());
                                                        capitalizeNext = 2;
                                                        i += 3;
                                                        continue;
                                                    }
                                        
                                                    if (i + 1 < words.length && multipliers[words[i + 1]]) {
                                                        const value = ones[word] * multipliers[words[i + 1]];
                                                        finalText.push(value.toString());
                                                        capitalizeNext = 2;
                                                        i += 2;
                                                        continue;
                                                    }
                                        
                                                    finalText.push(ones[word].toString());
                                                    capitalizeNext = 2;
                                                    i++;
                                                } else if (tens[word] !== undefined) {
                                                    finalText.push(tens[word].toString());
                                                    capitalizeNext = 2;
                                                    i++;
                                                } else if (!isNaN(word)) {
                                                    finalText.push(word);
                                                    capitalizeNext = 2;
                                                    i++;
                                                } else {
                                                    if (capitalizeNext > 0 && !skipWords.includes(word)) {
                                                        finalText.push(word.charAt(0).toUpperCase() + word.slice(1));
                                                        capitalizeNext--;
                                                    } else {
                                                        finalText.push(word);
                                                    }
                                                    i++;
                                                }
                                            }
                                        
                                            return finalText.join(' ');
                                        }
                                        
                                        
                                        N 1 Antwort Letzte Antwort
                                        1
                                        • HeimwehH Heimweh

                                          @martin_olw Ich hab es jetzt doch getestet und noch was geändert:

                                          Hier die Beschreibung:

                                          Der Skript überwacht den Datenpunkt alexa2.0.Lists.SHOP.json.

                                          Sobald Alexa z. B. sagt:

                                          „Alexa, setze vier Äpfel auf die Einkaufsliste“
                                          wird das als neuer Eintrag in dieser Liste erkannt.

                                          Zahlwort-Umwandlung:

                                          Aus „vier Äpfel“ wird „4 Äpfel“.

                                          Auch zusammengesetzte Zahlen wie „fünfzehn“ oder „dreiundzwanzig“ werden korrekt erkannt.

                                          Das erste Wort nach der Zahl wird großgeschrieben: z. B. „4 Äpfel“ statt „4 äpfel“.

                                          Todoist-Eintrag:

                                          Der bereinigte und umgewandelte Eintrag wird direkt über die REST-API an Todoist gesendet und dort im definierten Projekt als Aufgabe eingetragen.

                                          Automatisches Entfernen in Alexa:

                                          Nach 60 Sekunden wird der passende Alexa-Listeneintrag automatisch als „abgehakt“ markiert.

                                          Es muss nur die ListID und der Token eingesetzt werden.

                                          const axios = require('axios');
                                          
                                          // Todoist API-Konfiguration
                                          const todoistProjectId = 'XXXXXXXX'; // Deine Projekt-ID
                                          const todoistToken = 'XXXXXXXXXXXXXXXXXXXXXXX'; // Dein Token
                                          
                                          let previousList = [];
                                          
                                          // 1. Alexa-Änderungen überwachen
                                          on({ id: 'alexa2.0.Lists.SHOP.json', change: 'any' }, function (obj) {
                                              try {
                                                  const currentList = JSON.parse(obj.state.val);
                                          
                                                  if (currentList && currentList.length > 0) {
                                                      if (previousList.length < currentList.length) {
                                                          const newItem = currentList.find(item =>
                                                              !previousList.some(prevItem => prevItem.id === item.id)
                                                          );
                                          
                                                          if (newItem) {
                                                              const umgewandelt = wordsToNumbersSmart(newItem.value);
                                                              const aufgabe = capitalizeFirst(umgewandelt);
                                                              addTaskToTodoist(aufgabe);
                                          
                                                              // Nach 60 Sekunden Alexa-Eintrag auf "completed" setzen
                                                              setTimeout(() => {
                                                                  const alexaList = JSON.parse(getState('alexa2.0.Lists.SHOP.json').val);
                                          
                                                                  const matchingItem = alexaList.find(item => {
                                                                      const itemText = wordsToNumbersSmart(item.value).trim().toLowerCase();
                                                                      return itemText === aufgabe.trim().toLowerCase();
                                                                  });
                                          
                                                                  if (matchingItem) {
                                                                      const completeState = `alexa2.0.Lists.SHOP.items.${matchingItem.id}.completed`;
                                                                      setState(completeState, true);
                                                                  } else {
                                                                      console.warn(`⚠️ Kein passender Alexa-Eintrag zu "${aufgabe}" gefunden.`);
                                                                  }
                                                              }, 60 * 1000); // 60 Sekunden
                                                          }
                                                      }
                                          
                                                      previousList = currentList;
                                                  }
                                              } catch (e) {
                                                  console.error('Fehler beim Parsen der Alexa-Liste:', e.message || e);
                                              }
                                          });
                                          
                                          // 2. Aufgaben an Todoist senden
                                          function addTaskToTodoist(itemValue) {
                                              const todoistData = {
                                                  content: itemValue,
                                                  project_id: todoistProjectId
                                              };
                                          
                                              axios.post('https://api.todoist.com/rest/v2/tasks', todoistData, {
                                                  headers: {
                                                      'Content-Type': 'application/json',
                                                      'Authorization': `Bearer ${todoistToken}`
                                                  }
                                              })
                                              .then(() => {
                                                  console.log(`✅ "${itemValue}" zu Todoist hinzugefügt.`);
                                              })
                                              .catch(error => {
                                                  console.error('Fehler beim Hinzufügen zu Todoist:', error.message || error);
                                              });
                                          }
                                          
                                          // 3. Erstes Wort groß
                                          function capitalizeFirst(text) {
                                              if (!text || typeof text !== 'string') return '';
                                              return text.charAt(0).toUpperCase() + text.slice(1);
                                          }
                                          
                                          // 4. Wörter → Zahlen (z. B. „vierzehn“ → 14)
                                          function wordsToNumbersSmart(text) {
                                              const ones = {
                                                  'null': 0, 'eins': 1, 'eine': 1, 'einen': 1,
                                                  'zwei': 2, 'drei': 3, 'vier': 4, 'fünf': 5,
                                                  'sechs': 6, 'sieben': 7, 'acht': 8, 'neun': 9,
                                                  'zehn': 10, 'elf': 11, 'zwölf': 12, 'dreizehn': 13,
                                                  'vierzehn': 14, 'fünfzehn': 15, 'sechzehn': 16,
                                                  'siebzehn': 17, 'achtzehn': 18, 'neunzehn': 19
                                              };
                                          
                                              const tens = {
                                                  'zwanzig': 20, 'dreißig': 30, 'vierzig': 40,
                                                  'fünfzig': 50, 'sechzig': 60, 'siebzig': 70,
                                                  'achtzig': 80, 'neunzig': 90
                                              };
                                          
                                              const multipliers = {
                                                  'hundert': 100,
                                                  'tausend': 1000
                                              };
                                          
                                              const skipWords = ['und', 'oder', 'mit', 'für', 'pro'];
                                              const words = text.toLowerCase().split(/\s+/);
                                              const finalText = [];
                                              let i = 0;
                                              let capitalizeNext = 0;
                                          
                                              while (i < words.length) {
                                                  const word = words[i];
                                          
                                                  if (ones[word] !== undefined) {
                                                      if (i + 2 < words.length && words[i + 1] === 'und' && tens[words[i + 2]]) {
                                                          const value = ones[word] + tens[words[i + 2]];
                                                          finalText.push(value.toString());
                                                          capitalizeNext = 2;
                                                          i += 3;
                                                          continue;
                                                      }
                                          
                                                      if (i + 1 < words.length && multipliers[words[i + 1]]) {
                                                          const value = ones[word] * multipliers[words[i + 1]];
                                                          finalText.push(value.toString());
                                                          capitalizeNext = 2;
                                                          i += 2;
                                                          continue;
                                                      }
                                          
                                                      finalText.push(ones[word].toString());
                                                      capitalizeNext = 2;
                                                      i++;
                                                  } else if (tens[word] !== undefined) {
                                                      finalText.push(tens[word].toString());
                                                      capitalizeNext = 2;
                                                      i++;
                                                  } else if (!isNaN(word)) {
                                                      finalText.push(word);
                                                      capitalizeNext = 2;
                                                      i++;
                                                  } else {
                                                      if (capitalizeNext > 0 && !skipWords.includes(word)) {
                                                          finalText.push(word.charAt(0).toUpperCase() + word.slice(1));
                                                          capitalizeNext--;
                                                      } else {
                                                          finalText.push(word);
                                                      }
                                                      i++;
                                                  }
                                              }
                                          
                                              return finalText.join(' ');
                                          }
                                          
                                          
                                          N Offline
                                          N Offline
                                          no6mis
                                          schrieb am zuletzt editiert von
                                          #164

                                          @heimweh, danke für das Script, endlich kann man die Einkaufsliste in Alexa wieder benutzen.

                                          previousList = currentList;
                                          

                                          sollte allerdings außerhalb des if-Zweigs gesetzt werden, ansonsten gibt es ein Problem, wenn man die Liste in der Alexa-App leert. Dann wird beim nächsten Aufruf die previousList mehr Inhalte haben als die currentList und die folgenden Einträge bis zum Neustart des Scripts oder bis die aktuelle Liste wieder einen Eintrag mehr hat als die vorherige Liste nicht mehr hinzugefügt.

                                          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

                                          816

                                          Online

                                          32.4k

                                          Benutzer

                                          81.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