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
    15
    1
    2.6k

Alexa Shopping List mit Bring synchronisieren

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
164 Beiträge 27 Kommentatoren 33.5k Aufrufe 29 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.
  • DickenD Dicken

    Nun haben sich die Listen bei mir auch verabschiedet im Objektbaum. :cry:

    Ro75R Offline
    Ro75R Offline
    Ro75
    schrieb am zuletzt editiert von Ro75
    #107

    @dicken zeige mal bitte ALLE Alexa2-Adapter Einstellungen und den Objektbaum.

    Hast du irgendwelche Adapter aktualisiert? Admin, JS-Adapter? STABLE oder BETA unterwegs?

    Wie oft wurden die Daten "synchronisiert"? Aller x Minuten oder via Trigger (wie oft da)?

    Ro75.

    SERVER = Beelink U59 16GB DDR4 RAM 512GB SSD, FB 7490, FritzDect 200+301+440, ConBee II, Zigbee Aqara Sensoren + NOUS A1Z, NOUS A1T, Philips Hue ** ioBroker, REDIS, influxdb2, Grafana, PiHole, Plex-Mediaserver, paperless-ngx (Docker), MariaDB + phpmyadmin *** VIS-Runtime = Intel NUC 8GB RAM 128GB SSD + 24" Touchscreen

    1 Antwort Letzte Antwort
    0
    • DickenD Dicken

      Nun haben sich die Listen bei mir auch verabschiedet im Objektbaum. :cry:

      HeimwehH Offline
      HeimwehH Offline
      Heimweh
      schrieb am zuletzt editiert von
      #108

      @dicken - Also bei mir geht alles wie gehabt.... Listen sind noch da und werden aktualisiert

      1 Antwort Letzte Antwort
      0
      • DickenD Offline
        DickenD Offline
        Dicken
        schrieb am zuletzt editiert von
        #109

        Moin zusammen,

        also ich bin im Stable unterwegs und mache die Updates immer recht zügig nach erscheinen. Habe gestern erst wieder geupdatet (auch Admin und den JS-Adapter), das Problem war aber davor auch schon da.

        Die Synchronisierungszeiten sieht man ja im Screenshot der Einstellungen, die hab ich (soweit ich mich erinnern kann) aber nie angepackt und auf standard gelassen.

        Ach ja, vllt auch nicht ganz unwichtig: Script welches ich zum syncen der Einkaufslisten nutze, greift nur auf meinen Datenpunkt zu und stellt keine zusätzlichen anfragen an Amazon.

        Hier nun die Screenshots vom aktuellen Objektbaum und den Einstellungen:

        alexa2_objektbaum.png

        alexa2_einstellungen.png

        Ro75R 1 Antwort Letzte Antwort
        0
        • DickenD Dicken

          Moin zusammen,

          also ich bin im Stable unterwegs und mache die Updates immer recht zügig nach erscheinen. Habe gestern erst wieder geupdatet (auch Admin und den JS-Adapter), das Problem war aber davor auch schon da.

          Die Synchronisierungszeiten sieht man ja im Screenshot der Einstellungen, die hab ich (soweit ich mich erinnern kann) aber nie angepackt und auf standard gelassen.

          Ach ja, vllt auch nicht ganz unwichtig: Script welches ich zum syncen der Einkaufslisten nutze, greift nur auf meinen Datenpunkt zu und stellt keine zusätzlichen anfragen an Amazon.

          Hier nun die Screenshots vom aktuellen Objektbaum und den Einstellungen:

          alexa2_objektbaum.png

          alexa2_einstellungen.png

          Ro75R Offline
          Ro75R Offline
          Ro75
          schrieb am zuletzt editiert von
          #110

          @dicken von wann sind die Cookies?

          39b00699-2dbd-4dad-9b2d-088897aa0ac3-image.png

          Das sind meine und die Listen werden aktualisiert. Wie sieht denn die Liste in der Alexa-App aus? (Das bitte vor dem nächsten Schritt (P.S.)) prüfen.

          P.S. Dann deaktiviere doch mal das Sync-Skript, übernehme mal meine Werte und lasse danach (sollte ja nach Änderung der Werte) den Adapter mal neu starten und warte 1 Minute.

          Ro75.

          SERVER = Beelink U59 16GB DDR4 RAM 512GB SSD, FB 7490, FritzDect 200+301+440, ConBee II, Zigbee Aqara Sensoren + NOUS A1Z, NOUS A1T, Philips Hue ** ioBroker, REDIS, influxdb2, Grafana, PiHole, Plex-Mediaserver, paperless-ngx (Docker), MariaDB + phpmyadmin *** VIS-Runtime = Intel NUC 8GB RAM 128GB SSD + 24" Touchscreen

          DickenD 1 Antwort Letzte Antwort
          0
          • Ro75R Ro75

            @dicken von wann sind die Cookies?

            39b00699-2dbd-4dad-9b2d-088897aa0ac3-image.png

            Das sind meine und die Listen werden aktualisiert. Wie sieht denn die Liste in der Alexa-App aus? (Das bitte vor dem nächsten Schritt (P.S.)) prüfen.

            P.S. Dann deaktiviere doch mal das Sync-Skript, übernehme mal meine Werte und lasse danach (sollte ja nach Änderung der Werte) den Adapter mal neu starten und warte 1 Minute.

            Ro75.

            DickenD Offline
            DickenD Offline
            Dicken
            schrieb am zuletzt editiert von
            #111

            @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

            von wann sind die Cookies?

            Steht doch im Screenshot ganz oben :) 08.10.2024

            Achja zur Info: Hatte den Adapter gestern schon mehrmals neugestartet und zu sehen ob die Datenpunkte wieder reinkommen.

            @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

            Wie sieht denn die Liste in der Alexa-App aus?

            Na da stehen halt im Moment 8 Dinge drauf, die wir einkaufen wollen :D

            @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

            P.S. Dann deaktiviere doch mal das Sync-Skript,

            Das ist sowieso aus, da es mir die Logs vollgehauen hat, da es ja den Datenpunkt der Liste nicht gefunden hat.

            @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

            übernehme mal meine Werte und lasse danach (sollte ja nach Änderung der Werte) den Adapter mal neu starten und warte 1 Minute.

            Gesagt getan, nun hab ich Cookies von Heute, warum die gestern nach dem Neustart nicht aktualisiert wurden, weiß der Geier....

            Dennoch erscheinen keine Datenpunkte für die Liste, auch nicht nach 5 Minuten. Hab dann mal etwas auf die Liste gesetzt und nochmal 5 Minuten gewartet, trotzdem keine Datenpunkte.

            PhantomkommanderP 1 Antwort Letzte Antwort
            0
            • icastillo15I icastillo15

              Hallo zusammen,

              ich habe mein Script nochmal aktualisiert. Es werden in Alexa nun automatisch alle Duplikate sofort wieder gelöscht. Außerdem wird nun erzwungen, dass Artikel mit einem Großbuchstaben beginnen.

              Viel Spaß damit und gerne wieder testen :-)

              Kleiner Nachtrag: wenn ich über Alexa Dinge hinzufüge und dann in Bring als erledigt markiere, dann werden diese bei mir in Alexa nicht mehr gelöscht. Das muss ich mir nochmal ansehen - könnte an den Zeitstempeln liegen.

              Nachtrag 2: ging doch - mein Adapter war nur offline 😎

              const bringBaseId = 'bring.0.0f0c420c-3298-4911-91f5-7ed0fbbfd36e';
              const alexa2BaseId = 'alexa2.0.Lists.SHOPPING_LIST';
              
              const bringListId = bringBaseId + '.content';
              const bringListCompletedId = bringBaseId + '.recentContent';
              const bringAddToList = bringBaseId + '.saveItem';
              const bringCompleteItem = bringBaseId + '.moveToRecentContent';
              const alexaAddToList = alexa2BaseId + '.#New';
              const alexaListId = alexa2BaseId + '.json';
              
              //switch off to silence:
              const printDebug = true;
              
              function debug(msg) {
                  if (printDebug) {
                      log(msg)
                  }
              }
              
              const TodoItemStatus = {
                  NeedsAction: 'needs_action',
                  Completed: 'completed',
              };
              
              /**
               * @typedef bringItem
               * @type {object}
               * @property {string} specification
               * @property {string} name
               * @property {string} status
               * @property {boolean} [found] - keep track if found or not.
               */
              
              /**
               * @typedef alexaItem
               * @type {object}
               * @property {string} value
               * @property {string} id
               * @property {boolean} completed
               * @property {number} updatedDateTime
               * @property {boolean} [found] - keep track if found or not.
               */
              
              /**
               * Compare alexaItem complete and bringItem status -> returns true if same status.
               * @param {Array<alexaItem>} alexaList
               * @param {Array<bringItem>} list
               * @returns {boolean} true if same status.
              */
              function compareCompleted(alexaItem, bringItem) {
                  if (alexaItem.completed && bringItem.status !== TodoItemStatus.Completed) {
                      return false;
                  }
                  if (!alexaItem.completed && bringItem.status !== TodoItemStatus.NeedsAction) {
                      return false;
                  }
                  return true;
              }
              
              function ListCleaner(Eintrag='') {
                  const arr = Eintrag.split(' ');
                  for (let i = 0; i < arr.length; i++) {
                      arr[i] = arr[i].charAt(0).toUpperCase() + arr[i].slice(1);
                  }
                  return arr.join(' ');
              }
              
              /**
               * sync lists
               * @param {Array<alexaItem>} alexaList
               * @param {Array<bringItem>} list
               * @param {number} timestampBring
               * @param {string} msource
               * @param {Array<bringItem>} recentList
               * @returns {Array<bringItem>} new bring List
               */
              function syncLists(alexaList, list, timestampBring, msource, recentList) {
                  const newBringList = [];
                  var empty = true;
                  for (const alexaItem of alexaList) {
              
                      for (const bringItem of list) {
                          empty = false;
              
                          if (bringItem.name === alexaItem.value) {
                              alexaItem.found = true;
                              bringItem.found = true;
              
              
                              //found item. Update completed state from 'newer' list: 
                              bringItem.status = TodoItemStatus.NeedsAction;
                              if (alexaItem.updatedDateTime > timestampBring) {
                                  if (alexaItem.value !== bringItem.name || !compareCompleted(alexaItem, bringItem)) {
              
                                      if (msource === 'Alexa') {
                                         debug('Updating Bring item: ' + bringItem.name + ' from Alexa');
                                         setState(bringCompleteItem, ListCleaner(bringItem.name));
                                      }                   
                                  }
                              
                              } else {
                                  //keep bring:
              
                                  //update alexa:
                                  if (!compareCompleted(alexaItem, bringItem)) {
                                      if (msource === 'Bring') {
                                          bringItem.status = TodoItemStatus.Completed;
                                          debug('Update  Alexa item: ' + alexaItem.value + ' to ' + (bringItem.status === TodoItemStatus.Completed ? 'done' : 'undone') + ' from Bring.');
                                          setState(`${alexa2BaseId}.items.${alexaItem.id}.completed`, bringItem.status === TodoItemStatus.Completed);
                                      } 
                                  }
                              }
                          }
                      }
              
                      for (const bringItemCompleted of recentList) {
                          if (bringItemCompleted.name === alexaItem.value) {
                              alexaItem.found = true;
                              bringItemCompleted.found = true;
              
                              //found item. Update completed state from 'newer' list: 
                              bringItemCompleted.status = TodoItemStatus.Completed;
                              if (alexaItem.updatedDateTime > timestampBring) {
                                  if (alexaItem.value !== bringItemCompleted.name || !compareCompleted(alexaItem, bringItemCompleted)) {
              
                                      if (msource === 'Alexa') {
                                         debug('Adding Bring item: ' + bringItemCompleted.name + ' from Alexa');
                                         setState(bringAddToList, ListCleaner(bringItemCompleted.name));
                                      }                   
                                  }
                              
                              } else {
                                  //keep bring:
              
                                  //update alexa:
                                  if (!compareCompleted(alexaItem, bringItemCompleted)) {
                                      bringItemCompleted.status = TodoItemStatus.Completed;
                                      if (msource === 'Bring') {
                                          debug('Delete  Alexa item: ' + alexaItem.value + ' from Bring.');
                                          //setState(`${alexa2BaseId}.items.${alexaItem.id}.completed`, bringItemCompleted.status === TodoItemStatus.Completed);
                                          setState(`${alexa2BaseId}.items.${alexaItem.id}.#delete`, true);
                                      } 
                                  }
                              }
                          }
                      }
              
              
                      if (!alexaItem.found) {
                          //alexa item not found:
                          if (alexaItem.completed) {
                              debug('Delete ' + alexaItem.value + ' because done and not in Bring list.');
                              setState(`${alexa2BaseId}.items.${alexaItem.id}.#delete`, true);
                          } else {
                              if (msource === 'Alexa') {
                                  debug('Adding ' + alexaItem.value + ' to Bring list');
                                  setState(bringAddToList, ListCleaner(alexaItem.value));
                              }
                          }
                      }
              
                      if (empty === true) {
                          if (alexaItem.updatedDateTime < timestampBring) {
                              debug('Delete ' + alexaItem.value + ' from Alexa list because Bring list is all done.');
                              setState(`${alexa2BaseId}.items.${alexaItem.id}.#delete`, true);
                          }
                      }
                  
                  }
              
                  for (const bringItem of list) {
                      if (!bringItem.found) {
                          if (bringItem.status === TodoItemStatus.Completed) {
                              //debug('Remove from bring item:  ' + bringItem.name + ' because done and not on alexa list');
                              //Not executed since I want to keep the recent items inside bring app
                          } else {
                              if (msource === 'Bring') {
                                  debug('Adding ' + bringItem.name + ' to Alexa list.');
                                  setState(alexaAddToList, ListCleaner(bringItem.name));
                              }
                          }
                      }
                  }
              
                  return newBringList;
              }
              
              
              function doSync(source) {
                  eliminateDuplicated();
                  const alexaList = JSON.parse(getState(alexaListId).val);
                  const state = getState(bringListId);
                  const bringList = JSON.parse(state.val);
                  const state2 = getState(bringListCompletedId);
                  const bringListCompleted = JSON.parse(state2.val);
              
                  syncLists(alexaList, bringList, state.ts, source, bringListCompleted);
              }
              
              function eliminateDuplicated() {
                  var myAlexaList = JSON.parse(getState(alexaListId).val);
                  var arrayWithDuplicates = [];
              
                  for(var alexaItem of myAlexaList) {
                      var obj = {};
                      obj["value"] = ListCleaner(alexaItem.value);
                      obj["id"] = alexaItem.id;
                      arrayWithDuplicates.push(obj);       
                  }
              
                  const lookup = arrayWithDuplicates.reduce((a, e) => {
                  a[e.value] = ++a[e.value] || 0;
                  return a;
                  }, {});
              
                  const
                      getKey = o => keys.map(k => o[k]).join('|'),
                      keys = ['value'],
                      myarray = arrayWithDuplicates.filter(e => lookup[e.value]),
                      hash = Object.create(null),
                      duplicates = myarray.filter(o =>
                          (k => (hash[k] = (hash[k] || 0) + 1) > 1)
                          (getKey(o))
                      );
              
                  for(var item of duplicates) {
                      debug('Delete  Alexa item: ' + item.value + ' because duplicated.');
                      setState(`${alexa2BaseId}.items.${item.id}.#delete`, true);
                  }
              }
              
              on({id: bringListId, change: 'any'}, e => {
                  debug('Update triggered from Bring');
                  doSync('Bring');
              });
              
              on({id: alexaListId, change: 'any'}, e => {
                  debug('Update triggered from Alexa');
                  doSync('Alexa');
              });
              
              doSync();
              
              
              Christoph1337C Offline
              Christoph1337C Offline
              Christoph1337
              schrieb am zuletzt editiert von
              #112

              @icastillo15, ich finde dein Skript großartig! Allerdings habe ich das Problem, dass einige Einträge, nachdem sie in Bring abgehakt wurden, immer wieder aus der Alexa-Liste hinzugefügt werden. Hast du eine Idee, wie man das beheben kann?

              1 Antwort Letzte Antwort
              0
              • DickenD Dicken

                @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                von wann sind die Cookies?

                Steht doch im Screenshot ganz oben :) 08.10.2024

                Achja zur Info: Hatte den Adapter gestern schon mehrmals neugestartet und zu sehen ob die Datenpunkte wieder reinkommen.

                @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                Wie sieht denn die Liste in der Alexa-App aus?

                Na da stehen halt im Moment 8 Dinge drauf, die wir einkaufen wollen :D

                @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                P.S. Dann deaktiviere doch mal das Sync-Skript,

                Das ist sowieso aus, da es mir die Logs vollgehauen hat, da es ja den Datenpunkt der Liste nicht gefunden hat.

                @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                übernehme mal meine Werte und lasse danach (sollte ja nach Änderung der Werte) den Adapter mal neu starten und warte 1 Minute.

                Gesagt getan, nun hab ich Cookies von Heute, warum die gestern nach dem Neustart nicht aktualisiert wurden, weiß der Geier....

                Dennoch erscheinen keine Datenpunkte für die Liste, auch nicht nach 5 Minuten. Hab dann mal etwas auf die Liste gesetzt und nochmal 5 Minuten gewartet, trotzdem keine Datenpunkte.

                PhantomkommanderP Offline
                PhantomkommanderP Offline
                Phantomkommander
                schrieb am zuletzt editiert von
                #113

                @dicken sagte in Alexa Shopping List mit Bring synchronisieren:

                @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                von wann sind die Cookies?

                Steht doch im Screenshot ganz oben :) 08.10.2024

                Achja zur Info: Hatte den Adapter gestern schon mehrmals neugestartet und zu sehen ob die Datenpunkte wieder reinkommen.

                @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                Wie sieht denn die Liste in der Alexa-App aus?

                Na da stehen halt im Moment 8 Dinge drauf, die wir einkaufen wollen :D

                @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                P.S. Dann deaktiviere doch mal das Sync-Skript,

                Das ist sowieso aus, da es mir die Logs vollgehauen hat, da es ja den Datenpunkt der Liste nicht gefunden hat.

                @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                übernehme mal meine Werte und lasse danach (sollte ja nach Änderung der Werte) den Adapter mal neu starten und warte 1 Minute.

                Gesagt getan, nun hab ich Cookies von Heute, warum die gestern nach dem Neustart nicht aktualisiert wurden, weiß der Geier....

                Dennoch erscheinen keine Datenpunkte für die Liste, auch nicht nach 5 Minuten. Hab dann mal etwas auf die Liste gesetzt und nochmal 5 Minuten gewartet, trotzdem keine Datenpunkte.

                Hi @Dicken hast du deine liste wieder hinbekommen? ich habe seit gestern das gleiche Problem, nach einem Update was mit angeboten wurde (stable) habe ich das gleiche problem

                DickenD 1 Antwort Letzte Antwort
                0
                • PhantomkommanderP Phantomkommander

                  @dicken sagte in Alexa Shopping List mit Bring synchronisieren:

                  @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                  von wann sind die Cookies?

                  Steht doch im Screenshot ganz oben :) 08.10.2024

                  Achja zur Info: Hatte den Adapter gestern schon mehrmals neugestartet und zu sehen ob die Datenpunkte wieder reinkommen.

                  @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                  Wie sieht denn die Liste in der Alexa-App aus?

                  Na da stehen halt im Moment 8 Dinge drauf, die wir einkaufen wollen :D

                  @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                  P.S. Dann deaktiviere doch mal das Sync-Skript,

                  Das ist sowieso aus, da es mir die Logs vollgehauen hat, da es ja den Datenpunkt der Liste nicht gefunden hat.

                  @ro75 sagte in Alexa Shopping List mit Bring synchronisieren:

                  übernehme mal meine Werte und lasse danach (sollte ja nach Änderung der Werte) den Adapter mal neu starten und warte 1 Minute.

                  Gesagt getan, nun hab ich Cookies von Heute, warum die gestern nach dem Neustart nicht aktualisiert wurden, weiß der Geier....

                  Dennoch erscheinen keine Datenpunkte für die Liste, auch nicht nach 5 Minuten. Hab dann mal etwas auf die Liste gesetzt und nochmal 5 Minuten gewartet, trotzdem keine Datenpunkte.

                  Hi @Dicken hast du deine liste wieder hinbekommen? ich habe seit gestern das gleiche Problem, nach einem Update was mit angeboten wurde (stable) habe ich das gleiche problem

                  DickenD Offline
                  DickenD Offline
                  Dicken
                  schrieb am zuletzt editiert von
                  #114

                  @phantomkommander leider nein, nach wie vor keine Liste vorhanden.

                  PhantomkommanderP 1 Antwort Letzte Antwort
                  0
                  • DickenD Dicken

                    @phantomkommander leider nein, nach wie vor keine Liste vorhanden.

                    PhantomkommanderP Offline
                    PhantomkommanderP Offline
                    Phantomkommander
                    schrieb am zuletzt editiert von
                    #115

                    @dicken
                    habe bei mir gerade den fehler gefunden.

                    DickenD OreiderO 2 Antworten Letzte Antwort
                    0
                    • PhantomkommanderP Phantomkommander

                      @dicken
                      habe bei mir gerade den fehler gefunden.

                      DickenD Offline
                      DickenD Offline
                      Dicken
                      schrieb am zuletzt editiert von
                      #116

                      @phantomkommander und der wäre? :D

                      1 Antwort Letzte Antwort
                      0
                      • PhantomkommanderP Phantomkommander

                        @dicken
                        habe bei mir gerade den fehler gefunden.

                        OreiderO Offline
                        OreiderO Offline
                        Oreider
                        schrieb am zuletzt editiert von
                        #117

                        @phantomkommander

                        Wäre schön wenn du uns kurz deine Lösung erzählst.
                        Vielleicht hilft das auch anderen um die Listen wieder zu bekommen.

                        Habe leider das Problem noch immer...

                        Danke dir!

                        1 Antwort Letzte Antwort
                        0
                        • HeimwehH Heimweh

                          @Juergen-Sußner - hier ist der Script "ALEXA -> Todoist" mit der Erweiterung, das in Todoist erledigte Punkte in der Alexa auch abgehakt werden wenn erledigt. Eine volle zwei Richtung Synchronisierung ist es zwar nicht, aber mir reicht es so um nicht alles doppelt einzukaufen oder die hälfte zu vergessen....

                          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.Testliste.json', change: 'any' }, function (obj) {    // Hier die entsprechende Liste eintragen
                              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.Testliste.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.Testliste.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.`);
                                          }
                                      });
                                  }
                              });
                          }
                          
                          
                          UllulakiU Offline
                          UllulakiU Offline
                          Ullulaki
                          schrieb am zuletzt editiert von
                          #118

                          @heimweh
                          Sehr geil, so etwas habe ich gesucht und funktioniert super... danke dir dafür! :+1: :+1:

                          1 Antwort Letzte Antwort
                          0
                          • OreiderO Oreider

                            Egal was ich bisher versucht habe, die Listen tauchen nicht wieder auf bei mir. Das ganze hat aber schon mal funktioniert...

                            HeimwehH Offline
                            HeimwehH Offline
                            Heimweh
                            schrieb am zuletzt editiert von
                            #119

                            @oreider - freut mich sehr :)

                            1 Antwort Letzte Antwort
                            0
                            • I Offline
                              I Offline
                              IOMax
                              schrieb am zuletzt editiert von
                              #120

                              Bei mir ist im alexa2 Baum unter Lists nichts mehr vorhanden. In der Alexa App sehe ich aber meine Einkaufliste noch. Hat noch jemand das Problem ?

                              mcBirneM 1 Antwort Letzte Antwort
                              0
                              • I IOMax

                                Bei mir ist im alexa2 Baum unter Lists nichts mehr vorhanden. In der Alexa App sehe ich aber meine Einkaufliste noch. Hat noch jemand das Problem ?

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

                                @iomax ich habe das gleiche Problem

                                1 Antwort Letzte Antwort
                                0
                                • DickenD Dicken

                                  @mriceg Die Eintragungen werden automatisch auf die Todoist App gesetzt. Aber wenn du sie dort als erledigt markierst, bleiben sie halt in der alexa einkaufsliste. Was mir aber relativ egal is, guck ich ja eh nicht drauf.

                                  Marc BeckmannM Offline
                                  Marc BeckmannM Offline
                                  Marc Beckmann
                                  schrieb am zuletzt editiert von
                                  #122

                                  @dicken Das gleiche Problem habe ich auch... :-(

                                  1 Antwort Letzte Antwort
                                  0
                                  • Ro75R Offline
                                    Ro75R Offline
                                    Ro75
                                    schrieb am zuletzt editiert von
                                    #123

                                    Schaut doch erstmal beim primären Adapter.

                                    https://github.com/Apollon77/ioBroker.alexa2/issues/1223

                                    Ro75.

                                    SERVER = Beelink U59 16GB DDR4 RAM 512GB SSD, FB 7490, FritzDect 200+301+440, ConBee II, Zigbee Aqara Sensoren + NOUS A1Z, NOUS A1T, Philips Hue ** ioBroker, REDIS, influxdb2, Grafana, PiHole, Plex-Mediaserver, paperless-ngx (Docker), MariaDB + phpmyadmin *** VIS-Runtime = Intel NUC 8GB RAM 128GB SSD + 24" Touchscreen

                                    1 Antwort Letzte Antwort
                                    0
                                    • HeimwehH Offline
                                      HeimwehH Offline
                                      Heimweh
                                      schrieb am zuletzt editiert von Heimweh
                                      #124

                                      Mit dem Datenpunkt "Summary" hab ich hier einen Script der es wieder ermöglicht mit TODOIST zu synchronisieren. Allerdings nur noch in eine Richtung - die Punkte bleiben alle in den Alexa Listen bestehen....

                                      Was macht das Skript?

                                      Dieses ioBroker-Skript überwacht den Alexa-Datenpunkt alexa2.0.History.summary und erkennt Sätze wie:

                                      „Setze Milch auf die Einkaufsliste“

                                      „Setze zwei Packungen Nudeln auf meine Einkaufsliste“

                                      „Setze Wasser holen auf die To-do Liste“

                                      „Setze fünf hundert Gramm Hackfleisch auf die Einkaufsliste“

                                      „Setze 1 x Tomaten auf die Einkaufsliste“

                                      Erkannte Aufgaben werden automatisch als neue Todoist-Tasks erstellt – entweder:

                                      ✅ in deiner Einkaufsliste (Todoist-Projekt-ID wird angegeben)

                                      ✅ oder in der Inbox (wenn „To-do-Liste“ erkannt wird)

                                      const axios = require('axios');
                                      
                                      // Konfiguration
                                      const todoistShoppingListId = 'XXXXXXXXXXX';
                                      const todoistToken = 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX';
                                      
                                      on({ id: 'alexa2.0.History.summary', change: 'any' }, function (obj) {
                                          const inputRaw = obj.state.val;
                                      
                                          if (typeof inputRaw !== 'string') {
                                              console.warn('⚠️ Kein String erkannt in alexa2.0.History.summary:', inputRaw);
                                              return;
                                          }
                                      
                                          const input = inputRaw.trim();
                                          console.log(`🔁 Neue Alexa-Eingabe erkannt: "${input}"`);
                                      
                                          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);
                                      
                                              console.log(`🧠 Erkannt: Aufgabe = "${aufgabe}", Ziel = "${ziel}"`);
                                      
                                              let projektId = null;
                                              if (ziel === 'einkaufsliste') {
                                                  projektId = todoistShoppingListId;
                                              }
                                      
                                              addTaskToTodoist(aufgabe, projektId);
                                          } else {
                                              console.log('👂 Kein Todoist-Befehl erkannt. Erwartet: "Setze xyz auf [meine/die] Einkaufsliste" oder "To-do-Liste".');
                                          }
                                      });
                                      
                                      function addTaskToTodoist(text, projectId = null) {
                                          const todoistData = { content: text };
                                          if (projectId) todoistData.project_id = projectId;
                                      
                                          console.log(`📤 Sende an Todoist: "${text}" → ${projectId ? `Projekt-ID ${projectId}` : 'Inbox'}`);
                                      
                                          axios.post('https://api.todoist.com/rest/v2/tasks', todoistData, {
                                              headers: {
                                                  'Content-Type': 'application/json',
                                                  'Authorization': `Bearer ${todoistToken}`
                                              }
                                          })
                                          .then(() => {
                                              console.log(`✅ Aufgabe "${text}" erfolgreich zu Todoist hinzugefügt.`);
                                          })
                                          .catch(error => {
                                              console.error('❌ 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);
                                      }
                                      
                                      // Zahlworte + Nach-Zahl-Großschreibung + Multiplikatoren
                                      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];
                                      
                                              // Fall: Zahlwort + "und" + Zehner
                                              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;
                                                  }
                                      
                                                  // Fall: Zahlwort + "hundert"/"tausend"
                                                  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(' ');
                                      }
                                      
                                      

                                      Auch ich hinterfrage den Sinn meiner 10 Echos täglich. Außer Lichter / Geräte damit schalten wird es immer weniger.

                                      M 1 Antwort Letzte Antwort
                                      0
                                      • HeimwehH Heimweh

                                        Mit dem Datenpunkt "Summary" hab ich hier einen Script der es wieder ermöglicht mit TODOIST zu synchronisieren. Allerdings nur noch in eine Richtung - die Punkte bleiben alle in den Alexa Listen bestehen....

                                        Was macht das Skript?

                                        Dieses ioBroker-Skript überwacht den Alexa-Datenpunkt alexa2.0.History.summary und erkennt Sätze wie:

                                        „Setze Milch auf die Einkaufsliste“

                                        „Setze zwei Packungen Nudeln auf meine Einkaufsliste“

                                        „Setze Wasser holen auf die To-do Liste“

                                        „Setze fünf hundert Gramm Hackfleisch auf die Einkaufsliste“

                                        „Setze 1 x Tomaten auf die Einkaufsliste“

                                        Erkannte Aufgaben werden automatisch als neue Todoist-Tasks erstellt – entweder:

                                        ✅ in deiner Einkaufsliste (Todoist-Projekt-ID wird angegeben)

                                        ✅ oder in der Inbox (wenn „To-do-Liste“ erkannt wird)

                                        const axios = require('axios');
                                        
                                        // Konfiguration
                                        const todoistShoppingListId = 'XXXXXXXXXXX';
                                        const todoistToken = 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX';
                                        
                                        on({ id: 'alexa2.0.History.summary', change: 'any' }, function (obj) {
                                            const inputRaw = obj.state.val;
                                        
                                            if (typeof inputRaw !== 'string') {
                                                console.warn('⚠️ Kein String erkannt in alexa2.0.History.summary:', inputRaw);
                                                return;
                                            }
                                        
                                            const input = inputRaw.trim();
                                            console.log(`🔁 Neue Alexa-Eingabe erkannt: "${input}"`);
                                        
                                            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);
                                        
                                                console.log(`🧠 Erkannt: Aufgabe = "${aufgabe}", Ziel = "${ziel}"`);
                                        
                                                let projektId = null;
                                                if (ziel === 'einkaufsliste') {
                                                    projektId = todoistShoppingListId;
                                                }
                                        
                                                addTaskToTodoist(aufgabe, projektId);
                                            } else {
                                                console.log('👂 Kein Todoist-Befehl erkannt. Erwartet: "Setze xyz auf [meine/die] Einkaufsliste" oder "To-do-Liste".');
                                            }
                                        });
                                        
                                        function addTaskToTodoist(text, projectId = null) {
                                            const todoistData = { content: text };
                                            if (projectId) todoistData.project_id = projectId;
                                        
                                            console.log(`📤 Sende an Todoist: "${text}" → ${projectId ? `Projekt-ID ${projectId}` : 'Inbox'}`);
                                        
                                            axios.post('https://api.todoist.com/rest/v2/tasks', todoistData, {
                                                headers: {
                                                    'Content-Type': 'application/json',
                                                    'Authorization': `Bearer ${todoistToken}`
                                                }
                                            })
                                            .then(() => {
                                                console.log(`✅ Aufgabe "${text}" erfolgreich zu Todoist hinzugefügt.`);
                                            })
                                            .catch(error => {
                                                console.error('❌ 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);
                                        }
                                        
                                        // Zahlworte + Nach-Zahl-Großschreibung + Multiplikatoren
                                        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];
                                        
                                                // Fall: Zahlwort + "und" + Zehner
                                                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;
                                                    }
                                        
                                                    // Fall: Zahlwort + "hundert"/"tausend"
                                                    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(' ');
                                        }
                                        
                                        

                                        Auch ich hinterfrage den Sinn meiner 10 Echos täglich. Außer Lichter / Geräte damit schalten wird es immer weniger.

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

                                        @heimweh Danke für das Teilen deines Scripts. Ich habe es mit übernommen, in Zeile 4 und 5 meine Daten ergänzt, bekomme allerdings folgenden Fehler:

                                        javascript.0	09:51:07.115	error	script.js.common.ToDoist.Einkaufsliste_Alexa_Todoist compile failed: at script.js.common.ToDoist.Einkaufsliste_Alexa_Todoist:12
                                        

                                        Woran kann das liegen? Zeilen sind exakt wie in deinem Script.

                                        Im Log:
                                        2b0553d1-1f18-4873-9ac0-a799fcde2bc7-image.png
                                        Danke für die Hilfe!
                                        VG Martin

                                        HeimwehH 1 Antwort Letzte Antwort
                                        0
                                        • M martin_olw

                                          @heimweh Danke für das Teilen deines Scripts. Ich habe es mit übernommen, in Zeile 4 und 5 meine Daten ergänzt, bekomme allerdings folgenden Fehler:

                                          javascript.0	09:51:07.115	error	script.js.common.ToDoist.Einkaufsliste_Alexa_Todoist compile failed: at script.js.common.ToDoist.Einkaufsliste_Alexa_Todoist:12
                                          

                                          Woran kann das liegen? Zeilen sind exakt wie in deinem Script.

                                          Im Log:
                                          2b0553d1-1f18-4873-9ac0-a799fcde2bc7-image.png
                                          Danke für die Hilfe!
                                          VG Martin

                                          HeimwehH Offline
                                          HeimwehH Offline
                                          Heimweh
                                          schrieb am zuletzt editiert von
                                          #126

                                          @martin_olw ist auf Deinem System Axios installiert?

                                          M 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

                                          500

                                          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