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. [Vorlage] todoist.com To-Do-Listen Script für VIS

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    324

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.5k

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

[Vorlage] todoist.com To-Do-Listen Script für VIS

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
130 Beiträge 28 Kommentatoren 24.5k Aufrufe 19 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.
  • T Offline
    T Offline
    tempestas
    schrieb am zuletzt editiert von
    #69

    Skript 1:

    //  Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
    //  Scriptversion: v0.2
    //  Ergänzungen tempestas, Stand 17.3.2018
    //  https://forum.iobroker.net/viewtopic.php?f=21&t=12563
    //  https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205
    
    //Erforderliche Angaben:
    var APItoken = ""; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
    var debug = false;
    
    
    //Weitere Parameter ggf. anpassen:
    var instanz = 'javascript.0';  instanz = instanz + '.';     // Instanz fuer die Datenpunkte definieren
    var pfad =   'Todoist.';                    // Pfad definieren
    var regexTrigger = /^javascript\.0\.Einkaufsliste\.Items\..*$/;   // Trigger analog der manuellen Einkaufsliste
    
    schedule("*/1 * * * *", checkTODOIST);  // Abfragezeit: jede Minute
    
    
    // *********************************************************
    // Scriptbeginn - Ab hier nichts mehr ändern!
    // *********************************************************
    
    function checkTODOIST() {
        
        var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
        var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
        var request = require("request");
        var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
        var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
        
        request(APIprojectsURL, function (error, response, body) {
            try{
                var projects_json = JSON.parse(body);
                for (k = 0; k < projects_json.length; k++) {
                    var projects = parseInt(projects_json[k].id);
                    var projects_name = JSON.stringify(projects_json[k].name);
                    projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                    ToDoListen[ToDoListen.length] = projects;
                    ToDoListen_names[ToDoListen_names.length] = projects_name;
                    createState(instanz + pfad + ToDoListen_names[k], {def: 'false',type: 'string',role: 'html', name: ToDoListen_names[k]+' HTML String'});
                    if(debug) log("Datenpunkt "+ToDoListen_names[k]+" erstellt.", "info");
                    createState(instanz + pfad + ToDoListen_names[k]+'.TaskID', {def: 'false',type: 'string',role: 'string', name: ToDoListen_names[k]+' Task IDs'});
                    if(debug) log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
                }
            }
            catch(err) {log (err.message)}
        });
        
        setTimeout(function() {
            try{
                request(APItaskURL, function (error, response, body) {
                    var json = JSON.parse(body);
                    for (j = 0; j < ToDoListen.length; j++) {
                        var HTMLstring = "";
                        setState(instanz + pfad + ToDoListen_names[j], "leer");
                        for (i = 0; i < json.length; i++) {
                            var Liste = parseInt(json[i].project_id);
                            var content = JSON.stringify(json[i].content);
                            content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                            content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                            var taskurl = JSON.stringify(json[i].url);
                            taskurl = taskurl.replace(/\"/g, "");
                            if (Liste == ToDoListen[j])
                            {
                                if(debug) log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                HTMLstring = HTMLstring+content+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                                setState(instanz + pfad + ToDoListen_names[j], HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                            }
                        }
                    }
                });
            }
            catch(err) {log(err.message)}
        }, 1000);
        
            setTimeout(function() {                                                 // legt IDs der einzelnen Tasks in Unterordnern an
            request(APItaskURL, function (error, response, body) {
                
                var json = JSON.parse(body);
                
                for (j = 0; j < ToDoListen.length; j++) {
                    
                    var HTMLstring = "";
                    
                    setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
                    for (i = 0; i < json.length; i++) {
                        var Liste = parseInt(json[i].project_id);
                        var taskid = JSON.stringify(json[i].id);
                        if (Liste == ToDoListen[j])
                        {
                            if(debug) log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                            HTMLstring = HTMLstring+taskid+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                            setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                        }
                    }
                }
        
             });
        }, 1000);
    }
    
    
    
    // ***********************************************
    // TRIGGER
    // ***********************************************
    
    on({    id:regexTrigger, 
            change: 'ne'}, 
            function() {                          // regex trigger, löst immer aus sobald etwas in der manuellen Liste an- oder abgewählt wird
    
                checkTODOIST();              
            });
    

    Skript2 zum löschen:

    //Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget: 
    // LÖSCHEN FUNKTION
    //Scriptversion: v0.1
    //https://forum.iobroker.net/viewtopic.php?f=21&t=12563
    // https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205
    
    //Erforderliche Angaben:
    var APItoken = ""; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
    var idEinkaufsliste = "javascript.0.Todoist.Alexa-Einkaufsliste.TaskID"/*Alexa-Einkaufsliste HTML String*/;
    var debug = false;
    var instanz = 'javascript.0';  instanz = instanz + '.';     // Instanz fuer die Datenpunkte definieren
    var pfad =   'Todoist.';                    // Pfad definieren
    
    
    // Scriptbeginn - Ab hier nichts mehr ändern!
    
    createState(instanz + pfad +'clearBtn', false, force, {               // löschen Button, damit man nicht alles manuell abwählen muss
                name: 'Clear Liste',
                desc: 'Löscht die Liste',
                type: 'boolean',
                role: 'state',
                unit: ''
    });
    
    var idClear = instanz + pfad + 'clearBtn';
    
    
    var request = require("request");
    
        
    function deleteTask(){
    
        var idListArray =[];
        var idList;
        
        idList = getState(idEinkaufsliste).val;
        if(debug)log(idList);
        idListArray = idList.split("<br>");
        idListArray.pop();                                      // aufgrund meiner uneleganten Änderungen steht als letztes immer "<br>" in der Liste. Damit würde ein Element zuviel ausgegeben werden (leer). Pop kürzt den array ums letzte Element
        
        if(debug)log("idList Array ist " +idListArray);
        if(debug)log("idList Array Länge ist "+idListArray.length);
        
        
        
        for (i = 0; i< idListArray.length; i++){
            
            if(debug) log("Durchgang "+i);
            
            var deleteURL = "https://beta.todoist.com/API/v8/tasks/"+idListArray[i]+"?token="+APItoken;
            if(debug) log("Delete URL ist "+deleteURL);
     
            request({
                uri: deleteURL,
                method: "DELETE",
                timeout: 5000,
                }, 
                    function(error, response, body) {
                    if(debug) console.log(body);
                });    
            }
    }    
    
    
    
    // Löschen der Liste
    
    on(idClear, function(obj){                      // trigger fürs Löschen
        if(obj.state.val === true){
            deleteTask();
        }
    });
    
    
    
    

    Skript 3:

    // SKRIPT FÜGT DER ALEXA EINKAUFSLISTE BEI TODOIST EINEN GEGENSTAND HINZU; WENN DIESER IN DER MANUELLEN EINKAUFSLISTE HINZUGEFÜGT WIRD
    
    var debug = true; 
    
    var APItoken = ""; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
    var idProject = 123; // Projekt-ID der Alexa-Einkaufsliste aus todoist
    var idEinkaufsIDS = "javascript.0.Todoist.Alexa-Einkaufsliste.TaskID";        // hier stehen die Task IDs
    var idEinkaufsItems = "javascript.0.Todoist.Alexa-Einkaufsliste"/*Alexa-Einkaufsliste HTML String*/;
    
    var regexTrigger = /^javascript\.0\.Einkaufsliste\.Items\..*$/;   // Trigger analog der manuellen Einkaufsliste
    
    // **************************************************************
    // Scriptbeginn - Ab hier nichts mehr ändern!
    // **************************************************************
    
    var request = require("request");
    var uuid;
    var purchItem;
    
    // **************************************************************
    // uuid erstellen
    // **************************************************************
    
    function createUUID(){
        var dt = new Date().getTime();
        uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
            var r = (dt + Math.random()*16)%16 | 0;
            dt = Math.floor(dt/16);
            return (c=='x' ? r :(r&0x3|0x8)).toString(16);
        });
        return uuid;
    }
    
    // ********************************************************************
    // "Aufgabe" bzw Einkaufsgegenstand zur todoist Alexa Liste hinzufügen
    // ********************************************************************
    
    function addTask(){
    
            createUUID();
            log(uuid);
    
            var options = { method: 'POST',
              url: 'https://beta.todoist.com/API/v8/tasks',
              headers: 
               { 'Cache-Control': 'no-cache',
                 Authorization: 'Bearer ' +APItoken,
                 'X-Request-Id': uuid,
                 'Content-Type': 'application/json' },
              body: 
               { content: purchItem,
                 project_id: +idProject,
                 },
              json: true };
            
            request(options, function (error, response, body) {
              if (error) throw new Error(error);
            
              if(debug) console.log(JSON.stringify(body));
            });
    }
    
    
    // ********************************************************************
    // "Aufgabe" bzw Einkaufsgegenstand von todoist entfernen
    // ********************************************************************
    
    function deleteTask(){
    
        // Array der IDs aufbereiten
        
        var idListIDsArray =[];
        var idListIDs;
        
        idListIDs = getState(idEinkaufsIDS).val;
        if(debug)log(idListIDs);
        idListIDsArray = idListIDs.split("<br>");
        idListIDsArray.pop();                                      // aufgrund meiner uneleganten Änderungen steht als letztes immer "<br>" in der Liste. Damit würde ein Element zuviel ausgegeben werden (leer). Pop kürzt den array ums letzte Element
    
        // Array der Items aufbereiten
    
        var idListArray =[];
        var idList;
        
        idList = getState(idEinkaufsItems).val;
        if(debug)log(idList);
        idListArray = idList.split("<br>");
        idListArray.pop();       
    
        // Bestimmen der ID Position im Array
        
        var arrayPosition = idListArray.indexOf(purchItem);
        
        // Den Gegenstand über die gefundene ID löschen
    
            var deleteURL = "https://beta.todoist.com/API/v8/tasks/"+idListIDsArray[arrayPosition]+"?token="+APItoken;
            if(debug) log("Delete URL ist "+deleteURL);
     
            request({
                uri: deleteURL,
                method: "DELETE",
                timeout: 5000,
                }, 
                    function(error, response, body) {
                    if(debug) console.log(body);
                });    
    }    
    
    
    // **************************************************************
    // Trigger und Wertübergabe
    // **************************************************************
    
    on({    id:regexTrigger,   change: 'ne'},                           // regex trigger, löst immer aus sobald etwas an- oder abgewählt wird
                function(data) {
                    var temporary;
                    temporary = data.id;
                    purchItem = temporary.substring(33);                // Pfad bis zum Item ist 33 Stellen lang
                    
                    if(data.state.val) {                                // wenn das item auf der manuellen Liste hinzugefügt wurde (state ist true) dann...
                        if (debug) log("Es wird hinzugefügt: "+purchItem);
                        setTimeout(addTask, 500); }
                    else {                                              // sonst wenn wenn das item auf der manuellen Liste entfernt wurde dann...
                        if (debug) log("Es wird entfernt: "+purchItem);
                        setTimeout(deleteTask, 500); 
                    }    
            });
    
    
    

    Ob das alles noch funktioniert weiß ich nicht, ich nutze es nicht. Habs damals nur von exTreme mal zum rumspielen genutzt.

    <size="85">ioBroker | 21 Adapter | Ubuntu Server | intel NUC | Homematic CCU2 | Hue | Osram Lightify| Sonos | 2x Instar Cam | Samsung Tab A 2016 im Holzrahmen| 3x Echo dot | 1x Echo | Neato Botvac D5</size>

    B tobetobeT 2 Antworten Letzte Antwort
    0
    • T tempestas

      Skript 1:

      //  Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
      //  Scriptversion: v0.2
      //  Ergänzungen tempestas, Stand 17.3.2018
      //  https://forum.iobroker.net/viewtopic.php?f=21&t=12563
      //  https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205
      
      //Erforderliche Angaben:
      var APItoken = ""; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
      var debug = false;
      
      
      //Weitere Parameter ggf. anpassen:
      var instanz = 'javascript.0';  instanz = instanz + '.';     // Instanz fuer die Datenpunkte definieren
      var pfad =   'Todoist.';                    // Pfad definieren
      var regexTrigger = /^javascript\.0\.Einkaufsliste\.Items\..*$/;   // Trigger analog der manuellen Einkaufsliste
      
      schedule("*/1 * * * *", checkTODOIST);  // Abfragezeit: jede Minute
      
      
      // *********************************************************
      // Scriptbeginn - Ab hier nichts mehr ändern!
      // *********************************************************
      
      function checkTODOIST() {
          
          var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
          var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
          var request = require("request");
          var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
          var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
          
          request(APIprojectsURL, function (error, response, body) {
              try{
                  var projects_json = JSON.parse(body);
                  for (k = 0; k < projects_json.length; k++) {
                      var projects = parseInt(projects_json[k].id);
                      var projects_name = JSON.stringify(projects_json[k].name);
                      projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                      ToDoListen[ToDoListen.length] = projects;
                      ToDoListen_names[ToDoListen_names.length] = projects_name;
                      createState(instanz + pfad + ToDoListen_names[k], {def: 'false',type: 'string',role: 'html', name: ToDoListen_names[k]+' HTML String'});
                      if(debug) log("Datenpunkt "+ToDoListen_names[k]+" erstellt.", "info");
                      createState(instanz + pfad + ToDoListen_names[k]+'.TaskID', {def: 'false',type: 'string',role: 'string', name: ToDoListen_names[k]+' Task IDs'});
                      if(debug) log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
                  }
              }
              catch(err) {log (err.message)}
          });
          
          setTimeout(function() {
              try{
                  request(APItaskURL, function (error, response, body) {
                      var json = JSON.parse(body);
                      for (j = 0; j < ToDoListen.length; j++) {
                          var HTMLstring = "";
                          setState(instanz + pfad + ToDoListen_names[j], "leer");
                          for (i = 0; i < json.length; i++) {
                              var Liste = parseInt(json[i].project_id);
                              var content = JSON.stringify(json[i].content);
                              content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                              content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                              var taskurl = JSON.stringify(json[i].url);
                              taskurl = taskurl.replace(/\"/g, "");
                              if (Liste == ToDoListen[j])
                              {
                                  if(debug) log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                  HTMLstring = HTMLstring+content+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                                  setState(instanz + pfad + ToDoListen_names[j], HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                              }
                          }
                      }
                  });
              }
              catch(err) {log(err.message)}
          }, 1000);
          
              setTimeout(function() {                                                 // legt IDs der einzelnen Tasks in Unterordnern an
              request(APItaskURL, function (error, response, body) {
                  
                  var json = JSON.parse(body);
                  
                  for (j = 0; j < ToDoListen.length; j++) {
                      
                      var HTMLstring = "";
                      
                      setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
                      for (i = 0; i < json.length; i++) {
                          var Liste = parseInt(json[i].project_id);
                          var taskid = JSON.stringify(json[i].id);
                          if (Liste == ToDoListen[j])
                          {
                              if(debug) log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                              HTMLstring = HTMLstring+taskid+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                              setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                          }
                      }
                  }
          
               });
          }, 1000);
      }
      
      
      
      // ***********************************************
      // TRIGGER
      // ***********************************************
      
      on({    id:regexTrigger, 
              change: 'ne'}, 
              function() {                          // regex trigger, löst immer aus sobald etwas in der manuellen Liste an- oder abgewählt wird
      
                  checkTODOIST();              
              });
      

      Skript2 zum löschen:

      //Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget: 
      // LÖSCHEN FUNKTION
      //Scriptversion: v0.1
      //https://forum.iobroker.net/viewtopic.php?f=21&t=12563
      // https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205
      
      //Erforderliche Angaben:
      var APItoken = ""; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
      var idEinkaufsliste = "javascript.0.Todoist.Alexa-Einkaufsliste.TaskID"/*Alexa-Einkaufsliste HTML String*/;
      var debug = false;
      var instanz = 'javascript.0';  instanz = instanz + '.';     // Instanz fuer die Datenpunkte definieren
      var pfad =   'Todoist.';                    // Pfad definieren
      
      
      // Scriptbeginn - Ab hier nichts mehr ändern!
      
      createState(instanz + pfad +'clearBtn', false, force, {               // löschen Button, damit man nicht alles manuell abwählen muss
                  name: 'Clear Liste',
                  desc: 'Löscht die Liste',
                  type: 'boolean',
                  role: 'state',
                  unit: ''
      });
      
      var idClear = instanz + pfad + 'clearBtn';
      
      
      var request = require("request");
      
          
      function deleteTask(){
      
          var idListArray =[];
          var idList;
          
          idList = getState(idEinkaufsliste).val;
          if(debug)log(idList);
          idListArray = idList.split("<br>");
          idListArray.pop();                                      // aufgrund meiner uneleganten Änderungen steht als letztes immer "<br>" in der Liste. Damit würde ein Element zuviel ausgegeben werden (leer). Pop kürzt den array ums letzte Element
          
          if(debug)log("idList Array ist " +idListArray);
          if(debug)log("idList Array Länge ist "+idListArray.length);
          
          
          
          for (i = 0; i< idListArray.length; i++){
              
              if(debug) log("Durchgang "+i);
              
              var deleteURL = "https://beta.todoist.com/API/v8/tasks/"+idListArray[i]+"?token="+APItoken;
              if(debug) log("Delete URL ist "+deleteURL);
       
              request({
                  uri: deleteURL,
                  method: "DELETE",
                  timeout: 5000,
                  }, 
                      function(error, response, body) {
                      if(debug) console.log(body);
                  });    
              }
      }    
      
      
      
      // Löschen der Liste
      
      on(idClear, function(obj){                      // trigger fürs Löschen
          if(obj.state.val === true){
              deleteTask();
          }
      });
      
      
      
      

      Skript 3:

      // SKRIPT FÜGT DER ALEXA EINKAUFSLISTE BEI TODOIST EINEN GEGENSTAND HINZU; WENN DIESER IN DER MANUELLEN EINKAUFSLISTE HINZUGEFÜGT WIRD
      
      var debug = true; 
      
      var APItoken = ""; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
      var idProject = 123; // Projekt-ID der Alexa-Einkaufsliste aus todoist
      var idEinkaufsIDS = "javascript.0.Todoist.Alexa-Einkaufsliste.TaskID";        // hier stehen die Task IDs
      var idEinkaufsItems = "javascript.0.Todoist.Alexa-Einkaufsliste"/*Alexa-Einkaufsliste HTML String*/;
      
      var regexTrigger = /^javascript\.0\.Einkaufsliste\.Items\..*$/;   // Trigger analog der manuellen Einkaufsliste
      
      // **************************************************************
      // Scriptbeginn - Ab hier nichts mehr ändern!
      // **************************************************************
      
      var request = require("request");
      var uuid;
      var purchItem;
      
      // **************************************************************
      // uuid erstellen
      // **************************************************************
      
      function createUUID(){
          var dt = new Date().getTime();
          uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
              var r = (dt + Math.random()*16)%16 | 0;
              dt = Math.floor(dt/16);
              return (c=='x' ? r :(r&0x3|0x8)).toString(16);
          });
          return uuid;
      }
      
      // ********************************************************************
      // "Aufgabe" bzw Einkaufsgegenstand zur todoist Alexa Liste hinzufügen
      // ********************************************************************
      
      function addTask(){
      
              createUUID();
              log(uuid);
      
              var options = { method: 'POST',
                url: 'https://beta.todoist.com/API/v8/tasks',
                headers: 
                 { 'Cache-Control': 'no-cache',
                   Authorization: 'Bearer ' +APItoken,
                   'X-Request-Id': uuid,
                   'Content-Type': 'application/json' },
                body: 
                 { content: purchItem,
                   project_id: +idProject,
                   },
                json: true };
              
              request(options, function (error, response, body) {
                if (error) throw new Error(error);
              
                if(debug) console.log(JSON.stringify(body));
              });
      }
      
      
      // ********************************************************************
      // "Aufgabe" bzw Einkaufsgegenstand von todoist entfernen
      // ********************************************************************
      
      function deleteTask(){
      
          // Array der IDs aufbereiten
          
          var idListIDsArray =[];
          var idListIDs;
          
          idListIDs = getState(idEinkaufsIDS).val;
          if(debug)log(idListIDs);
          idListIDsArray = idListIDs.split("<br>");
          idListIDsArray.pop();                                      // aufgrund meiner uneleganten Änderungen steht als letztes immer "<br>" in der Liste. Damit würde ein Element zuviel ausgegeben werden (leer). Pop kürzt den array ums letzte Element
      
          // Array der Items aufbereiten
      
          var idListArray =[];
          var idList;
          
          idList = getState(idEinkaufsItems).val;
          if(debug)log(idList);
          idListArray = idList.split("<br>");
          idListArray.pop();       
      
          // Bestimmen der ID Position im Array
          
          var arrayPosition = idListArray.indexOf(purchItem);
          
          // Den Gegenstand über die gefundene ID löschen
      
              var deleteURL = "https://beta.todoist.com/API/v8/tasks/"+idListIDsArray[arrayPosition]+"?token="+APItoken;
              if(debug) log("Delete URL ist "+deleteURL);
       
              request({
                  uri: deleteURL,
                  method: "DELETE",
                  timeout: 5000,
                  }, 
                      function(error, response, body) {
                      if(debug) console.log(body);
                  });    
      }    
      
      
      // **************************************************************
      // Trigger und Wertübergabe
      // **************************************************************
      
      on({    id:regexTrigger,   change: 'ne'},                           // regex trigger, löst immer aus sobald etwas an- oder abgewählt wird
                  function(data) {
                      var temporary;
                      temporary = data.id;
                      purchItem = temporary.substring(33);                // Pfad bis zum Item ist 33 Stellen lang
                      
                      if(data.state.val) {                                // wenn das item auf der manuellen Liste hinzugefügt wurde (state ist true) dann...
                          if (debug) log("Es wird hinzugefügt: "+purchItem);
                          setTimeout(addTask, 500); }
                      else {                                              // sonst wenn wenn das item auf der manuellen Liste entfernt wurde dann...
                          if (debug) log("Es wird entfernt: "+purchItem);
                          setTimeout(deleteTask, 500); 
                      }    
              });
      
      
      

      Ob das alles noch funktioniert weiß ich nicht, ich nutze es nicht. Habs damals nur von exTreme mal zum rumspielen genutzt.

      B Offline
      B Offline
      bdasch
      schrieb am zuletzt editiert von
      #70

      @tempestas leider habe ich bei dem Script immer wieder eine Fehlermeldung:
      52338407_2305089526370910_7126201624329977856_o.jpg

      Kann mir jemand helfen?

      G 1 Antwort Letzte Antwort
      0
      • B bdasch

        @tempestas leider habe ich bei dem Script immer wieder eine Fehlermeldung:
        52338407_2305089526370910_7126201624329977856_o.jpg

        Kann mir jemand helfen?

        G Offline
        G Offline
        Golf GTI
        schrieb am zuletzt editiert von
        #71

        Script 1

        // Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget

        // Scriptversion: v0.2

        // Ergänzungen tempestas, Stand 17.3.2018

        // https://forum.iobroker.net/viewtopic.php?f=21&t=12563

        // https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205

        //Erforderliche Angaben:

        var APItoken = "API Eintragen"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden

        var debug = false;

        //Weitere Parameter ggf. anpassen:

        var instanz = 'javascript.0'; instanz = instanz + '.'; // Instanz fuer die Datenpunkte definieren

        var pfad = 'Todoist.'; // Pfad definieren

        var regexTrigger = /^javascript.0.Einkaufsliste.Items..*$/; // Trigger analog der manuellen Einkaufsliste

        schedule("* * * * *", checkTODOIST); // Abfragezeit: jede Minute

        // *********************************************************

        // Scriptbeginn - Ab hier nichts mehr ändern!

        // *********************************************************

        function checkTODOIST() {

        var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
        
        var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
        
        var request = require("request");
        
        var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
        
        var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
        
        
        
        request(APIprojectsURL, function (error, response, body) {
        
            try{
        
                var projects_json = JSON.parse(body);
        
                for (k = 0; k < projects_json.length; k++) {
        
                    var projects = parseInt(projects_json[k].id);
        
                    var projects_name = JSON.stringify(projects_json[k].name);
        
                    projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
        
                    ToDoListen[ToDoListen.length] = projects;
        
                    ToDoListen_names[ToDoListen_names.length] = projects_name;
        
                    createState(instanz + pfad + ToDoListen_names[k], {def: 'false',type: 'string',role: 'html', name: ToDoListen_names[k]+' HTML String'});
        
                    if(debug) log("Datenpunkt "+ToDoListen_names[k]+" erstellt.", "info");
        
                    createState(instanz + pfad + ToDoListen_names[k]+'.TaskID', {def: 'false',type: 'string',role: 'string', name: ToDoListen_names[k]+' Task IDs'});
        
                    if(debug) log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
        
                }
        
            }
        
            catch(err) {log (err.message)}
        
        });
        
        
        
        setTimeout(function() {
        
            try{
        
                request(APItaskURL, function (error, response, body) {
        
                    var json = JSON.parse(body);
        
                    for (j = 0; j < ToDoListen.length; j++) {
        
                        var HTMLstring = "";
        
                        setState(instanz + pfad + ToDoListen_names[j], "leer");
        
                        for (i = 0; i < json.length; i++) {
        
                            var Liste = parseInt(json[i].project_id);
        
                            var content = JSON.stringify(json[i].content);
        
                            content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
        
                            content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
        
                            var taskurl = JSON.stringify(json[i].url);
        
                            taskurl = taskurl.replace(/\"/g, "");
        
                            if (Liste == ToDoListen[j])
        
                            {
        
                                if(debug) log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
        
                                HTMLstring = HTMLstring+content+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
        
                                setState(instanz + pfad + ToDoListen_names[j], HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
        
                            }
        
                        }
        
                    }
        
                });
        
            }
        
            catch(err) {log(err.message)}
        
        }, 1000);
        
        
        
            setTimeout(function() {                                                 // legt IDs der einzelnen Tasks in Unterordnern an
        
            request(APItaskURL, function (error, response, body) {
        
                
        
                var json = JSON.parse(body);
        
                
        
                for (j = 0; j < ToDoListen.length; j++) {
        
                    
        
                    var HTMLstring = "";
        
                    
        
                    setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
        
                    for (i = 0; i < json.length; i++) {
        
                        var Liste = parseInt(json[i].project_id);
        
                        var taskid = JSON.stringify(json[i].id);
        
                        if (Liste == ToDoListen[j])
        
                        {
        
                            if(debug) log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
        
                            HTMLstring = HTMLstring+taskid+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
        
                            setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
        
                        }
        
                    }
        
                }
        
        
        
             });
        
        }, 1000);
        

        }

        // ***********************************************

        // TRIGGER

        // ***********************************************

        on({ id:regexTrigger,

            change: 'ne'}, 
        
            function() {                          // regex trigger, löst immer aus sobald etwas in der manuellen Liste an- oder abgewählt wird
        
        
        
                checkTODOIST();              
        
            });
        
        1 Antwort Letzte Antwort
        0
        • G Offline
          G Offline
          Golf GTI
          schrieb am zuletzt editiert von
          #72

          Bei mir bekomme ich immer Im Log eine fehlermeldung woran diese liegt weiß ich nicht
          **

          • javascript.0 warn State "[object Object]" not found**
            kenne mich nicht mit javascript aus
            ansonsten leuft es
          B 2 Antworten Letzte Antwort
          0
          • G Golf GTI

            Bei mir bekomme ich immer Im Log eine fehlermeldung woran diese liegt weiß ich nicht
            **

            • javascript.0 warn State "[object Object]" not found**
              kenne mich nicht mit javascript aus
              ansonsten leuft es
            B Offline
            B Offline
            bdasch
            schrieb am zuletzt editiert von
            #73

            @Golf-GTI coole Sache, bisher läuft es, ich werde es mal testen.

            1 Antwort Letzte Antwort
            0
            • G Golf GTI

              Bei mir bekomme ich immer Im Log eine fehlermeldung woran diese liegt weiß ich nicht
              **

              • javascript.0 warn State "[object Object]" not found**
                kenne mich nicht mit javascript aus
                ansonsten leuft es
              B Offline
              B Offline
              bdasch
              schrieb am zuletzt editiert von
              #74

              @Golf-GTI hast du auch ein Script zur Telegramübertragung?

              G 1 Antwort Letzte Antwort
              0
              • G Offline
                G Offline
                Golf GTI
                schrieb am zuletzt editiert von
                #75

                super ja teste mal ob bei dir auch die fehlermeldung kommt

                javascript.0 warn State "[object Object]" not found*

                B 1 Antwort Letzte Antwort
                0
                • B bdasch

                  @Golf-GTI hast du auch ein Script zur Telegramübertragung?

                  G Offline
                  G Offline
                  Golf GTI
                  schrieb am zuletzt editiert von
                  #76

                  @bdasch sagte in [Vorlage] todoist.com To-Do-Listen Script für VIS:

                  Script zur Telegramübertragung

                  Nein hab ich nicht es soll erstmal so laufen

                  B 1 Antwort Letzte Antwort
                  0
                  • G Golf GTI

                    @bdasch sagte in [Vorlage] todoist.com To-Do-Listen Script für VIS:

                    Script zur Telegramübertragung

                    Nein hab ich nicht es soll erstmal so laufen

                    B Offline
                    B Offline
                    bdasch
                    schrieb am zuletzt editiert von
                    #77

                    @Golf-GTI Alles klar danke.

                    1 Antwort Letzte Antwort
                    0
                    • G Golf GTI

                      super ja teste mal ob bei dir auch die fehlermeldung kommt

                      javascript.0 warn State "[object Object]" not found*

                      B Offline
                      B Offline
                      bdasch
                      schrieb am zuletzt editiert von
                      #78

                      @Golf-GTI bei mir kommt leider die gleiche Fehlermeldung wie oben gepostet???????

                      G 1 Antwort Letzte Antwort
                      0
                      • B bdasch

                        @Golf-GTI bei mir kommt leider die gleiche Fehlermeldung wie oben gepostet???????

                        G Offline
                        G Offline
                        Golf GTI
                        schrieb am zuletzt editiert von
                        #79

                        // Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget

                        // Scriptversion: v0.2

                        // Ergänzungen tempestas, Stand 17.3.2018

                        // https://forum.iobroker.net/viewtopic.php?f=21&t=12563

                        // https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205

                        //Erforderliche Angaben:

                        var APItoken = "Token Eintragen"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden

                        var debug = true;

                        //Weitere Parameter ggf. anpassen:

                        var instanz = 'javascript.0'; // Instanz fuer die Datenpunkte definieren

                        var pfad = 'Todoist.'; // Pfad definieren

                        var regexTrigger = /^javascript.0.Einkaufsliste.Items..*$/; // Trigger analog der manuellen Einkaufsliste

                        schedule("*/1 * * * *", checkTODOIST); // Abfragezeit: jede Minute

                        // *********************************************************

                        // Scriptbeginn - Ab hier nichts mehr ändern!

                        // *********************************************************

                        function checkTODOIST() {

                        var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
                        
                        var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
                        
                        var request = require("request");
                        
                        var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
                        
                        var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
                        
                        
                        
                        request(APIprojectsURL, function (error, response, body) {
                        
                            try{
                        
                                var projects_json = JSON.parse(body);
                        
                                for (k = 0; k < projects_json.length; k++) {
                        
                                    var projects = parseInt(projects_json[k].id);
                        
                                    var projects_name = JSON.stringify(projects_json[k].name);
                        
                                    projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                        
                                    ToDoListen[ToDoListen.length] = projects;
                        
                                    ToDoListen_names[ToDoListen_names.length] = projects_name;
                        
                                    createState(instanz + pfad + ToDoListen_names[k], {def: 'false',type: 'string',role: 'html', name: ToDoListen_names[k]+' HTML String'});
                        
                                    if(debug) log("Datenpunkt "+ToDoListen_names[k]+" erstellt.", "info");
                        
                                    createState(instanz + pfad + ToDoListen_names[k]+'.TaskID', {def: 'false',type: 'string',role: 'string', name: ToDoListen_names[k]+' Task IDs'});
                        
                                    if(debug) log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
                        
                                }
                        
                            }
                        
                            catch(err) {log (err.message)}
                        
                        });
                        
                        
                        
                        setTimeout(function() {
                        
                            try{
                        
                                request(APItaskURL, function (error, response, body) {
                        
                                    var json = JSON.parse(body);
                        
                                    for (j = 0; j < ToDoListen.length; j++) {
                        
                                        var HTMLstring = "";
                        
                                        setState(instanz + pfad + ToDoListen_names[j], "leer");
                        
                                        for (i = 0; i < json.length; i++) {
                        
                                            var Liste = parseInt(json[i].project_id);
                        
                                            var content = JSON.stringify(json[i].content);
                        
                                            content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                        
                                            content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                        
                                            var taskurl = JSON.stringify(json[i].url);
                        
                                            taskurl = taskurl.replace(/\"/g, "");
                        
                                            if (Liste == ToDoListen[j])
                        
                                            {
                        
                                                if(debug) log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                        
                                                HTMLstring = HTMLstring+content+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                        
                                                setState(instanz + pfad + ToDoListen_names[j], HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                        
                                            }
                        
                                        }
                        
                                    }
                        
                                });
                        
                            }
                        
                            catch(err) {log(err.message)}
                        
                        }, 1000);
                        
                        
                        
                            setTimeout(function() {                                                 // legt IDs der einzelnen Tasks in Unterordnern an
                        
                            request(APItaskURL, function (error, response, body) {
                        
                                
                        
                                var json = JSON.parse(body);
                        
                                
                        
                                for (j = 0; j < ToDoListen.length; j++) {
                        
                                    
                        
                                    var HTMLstring = "";
                        
                                    
                        
                                    setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
                        
                                    for (i = 0; i < json.length; i++) {
                        
                                        var Liste = parseInt(json[i].project_id);
                        
                                        var taskid = JSON.stringify(json[i].id);
                        
                                        if (Liste == ToDoListen[j])
                        
                                        {
                        
                                            if(debug) log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                        
                                            HTMLstring = HTMLstring+taskid+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                        
                                            setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                        
                                        }
                        
                                    }
                        
                                }
                        
                        
                        
                             });
                        
                        }, 1000);
                        

                        }

                        // ***********************************************

                        // TRIGGER

                        // ***********************************************

                        on({ id:regexTrigger,

                            change: 'ne'}, 
                        
                            function() {                          // regex trigger, löst immer aus sobald etwas in der manuellen Liste an- oder abgewählt wird
                        
                        
                        
                                checkTODOIST();              
                        
                            });
                        
                        B 1 Antwort Letzte Antwort
                        0
                        • G Golf GTI

                          // Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget

                          // Scriptversion: v0.2

                          // Ergänzungen tempestas, Stand 17.3.2018

                          // https://forum.iobroker.net/viewtopic.php?f=21&t=12563

                          // https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205

                          //Erforderliche Angaben:

                          var APItoken = "Token Eintragen"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden

                          var debug = true;

                          //Weitere Parameter ggf. anpassen:

                          var instanz = 'javascript.0'; // Instanz fuer die Datenpunkte definieren

                          var pfad = 'Todoist.'; // Pfad definieren

                          var regexTrigger = /^javascript.0.Einkaufsliste.Items..*$/; // Trigger analog der manuellen Einkaufsliste

                          schedule("*/1 * * * *", checkTODOIST); // Abfragezeit: jede Minute

                          // *********************************************************

                          // Scriptbeginn - Ab hier nichts mehr ändern!

                          // *********************************************************

                          function checkTODOIST() {

                          var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
                          
                          var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
                          
                          var request = require("request");
                          
                          var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
                          
                          var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
                          
                          
                          
                          request(APIprojectsURL, function (error, response, body) {
                          
                              try{
                          
                                  var projects_json = JSON.parse(body);
                          
                                  for (k = 0; k < projects_json.length; k++) {
                          
                                      var projects = parseInt(projects_json[k].id);
                          
                                      var projects_name = JSON.stringify(projects_json[k].name);
                          
                                      projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                          
                                      ToDoListen[ToDoListen.length] = projects;
                          
                                      ToDoListen_names[ToDoListen_names.length] = projects_name;
                          
                                      createState(instanz + pfad + ToDoListen_names[k], {def: 'false',type: 'string',role: 'html', name: ToDoListen_names[k]+' HTML String'});
                          
                                      if(debug) log("Datenpunkt "+ToDoListen_names[k]+" erstellt.", "info");
                          
                                      createState(instanz + pfad + ToDoListen_names[k]+'.TaskID', {def: 'false',type: 'string',role: 'string', name: ToDoListen_names[k]+' Task IDs'});
                          
                                      if(debug) log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
                          
                                  }
                          
                              }
                          
                              catch(err) {log (err.message)}
                          
                          });
                          
                          
                          
                          setTimeout(function() {
                          
                              try{
                          
                                  request(APItaskURL, function (error, response, body) {
                          
                                      var json = JSON.parse(body);
                          
                                      for (j = 0; j < ToDoListen.length; j++) {
                          
                                          var HTMLstring = "";
                          
                                          setState(instanz + pfad + ToDoListen_names[j], "leer");
                          
                                          for (i = 0; i < json.length; i++) {
                          
                                              var Liste = parseInt(json[i].project_id);
                          
                                              var content = JSON.stringify(json[i].content);
                          
                                              content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                          
                                              content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                          
                                              var taskurl = JSON.stringify(json[i].url);
                          
                                              taskurl = taskurl.replace(/\"/g, "");
                          
                                              if (Liste == ToDoListen[j])
                          
                                              {
                          
                                                  if(debug) log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                          
                                                  HTMLstring = HTMLstring+content+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                          
                                                  setState(instanz + pfad + ToDoListen_names[j], HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                          
                                              }
                          
                                          }
                          
                                      }
                          
                                  });
                          
                              }
                          
                              catch(err) {log(err.message)}
                          
                          }, 1000);
                          
                          
                          
                              setTimeout(function() {                                                 // legt IDs der einzelnen Tasks in Unterordnern an
                          
                              request(APItaskURL, function (error, response, body) {
                          
                                  
                          
                                  var json = JSON.parse(body);
                          
                                  
                          
                                  for (j = 0; j < ToDoListen.length; j++) {
                          
                                      
                          
                                      var HTMLstring = "";
                          
                                      
                          
                                      setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
                          
                                      for (i = 0; i < json.length; i++) {
                          
                                          var Liste = parseInt(json[i].project_id);
                          
                                          var taskid = JSON.stringify(json[i].id);
                          
                                          if (Liste == ToDoListen[j])
                          
                                          {
                          
                                              if(debug) log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                          
                                              HTMLstring = HTMLstring+taskid+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                          
                                              setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                          
                                          }
                          
                                      }
                          
                                  }
                          
                          
                          
                               });
                          
                          }, 1000);
                          

                          }

                          // ***********************************************

                          // TRIGGER

                          // ***********************************************

                          on({ id:regexTrigger,

                              change: 'ne'}, 
                          
                              function() {                          // regex trigger, löst immer aus sobald etwas in der manuellen Liste an- oder abgewählt wird
                          
                          
                          
                                  checkTODOIST();              
                          
                              });
                          
                          B Offline
                          B Offline
                          bdasch
                          schrieb am zuletzt editiert von
                          #80

                          @Golf-GTI leider die gleiche Fehlermeldung, keine Ahnung was da schief läuft.

                          1 Antwort Letzte Antwort
                          0
                          • M Offline
                            M Offline
                            Matze89
                            schrieb am zuletzt editiert von
                            #81

                            Bei mir selbe fehlermeldung im log.
                            Scheint so als ob diese kommt wenn sich bei der liste etwas manuell ändert oder diese erneut abgefragt wird.
                            Kann hier jemand mit mehr java kenntnissen unterstützen?

                            Danke schon mal!

                            T 1 Antwort Letzte Antwort
                            0
                            • M Matze89

                              Bei mir selbe fehlermeldung im log.
                              Scheint so als ob diese kommt wenn sich bei der liste etwas manuell ändert oder diese erneut abgefragt wird.
                              Kann hier jemand mit mehr java kenntnissen unterstützen?

                              Danke schon mal!

                              T Offline
                              T Offline
                              tempestas
                              schrieb am zuletzt editiert von tempestas
                              #82

                              @Matze89
                              Daran liegt es nicht. Woran es liegt bleibt unklar.

                              Probiert mal diese Version bitte. Nur ein zusätzliches try-catch eingebaut

                              //  Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
                              //  Scriptversion: v0.21
                              //  Ergänzungen tempestas, Stand 27.3.2019
                              //  https://forum.iobroker.net/viewtopic.php?f=21&t=12563
                              //  https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205
                              
                              //Erforderliche Angaben:
                              var APItoken = ""; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
                              var debug = false;
                              
                              
                              //Weitere Parameter ggf. anpassen:
                              var instanz = 'javascript.0';  instanz = instanz + '.';     // Instanz fuer die Datenpunkte definieren
                              var pfad =   'Todoist.';                    // Pfad definieren
                              var regexTrigger = /^javascript\.0\.Einkaufsliste\.Items\..*$/;   // Trigger analog der manuellen Einkaufsliste
                              
                              schedule("*/1 * * * *", checkTODOIST);  // Abfragezeit: jede Minute
                              
                              
                              // *********************************************************
                              // Scriptbeginn - Ab hier nichts mehr ändern!
                              // *********************************************************
                              
                              function checkTODOIST() {
                                  
                                  var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
                                  var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
                                  var request = require("request");
                                  var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
                                  var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
                                  
                                  request(APIprojectsURL, function (error, response, body) {
                                      try{
                                          var projects_json = JSON.parse(body);
                                          for (k = 0; k < projects_json.length; k++) {
                                              var projects = parseInt(projects_json[k].id);
                                              var projects_name = JSON.stringify(projects_json[k].name);
                                              projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                                              ToDoListen[ToDoListen.length] = projects;
                                              ToDoListen_names[ToDoListen_names.length] = projects_name;
                                              createState(instanz + pfad + ToDoListen_names[k], {def: 'false',type: 'string',role: 'html', name: ToDoListen_names[k]+' HTML String'});
                                              if(debug) log("Datenpunkt "+ToDoListen_names[k]+" erstellt.", "info");
                                              createState(instanz + pfad + ToDoListen_names[k]+'.TaskID', {def: 'false',type: 'string',role: 'string', name: ToDoListen_names[k]+' Task IDs'});
                                              if(debug) log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
                                          }
                                      }
                                      catch(err) {log (err.message)}
                                  });
                                  
                                  setTimeout(function() {
                                      try{
                                          request(APItaskURL, function (error, response, body) {
                                              var json = JSON.parse(body);
                                              for (j = 0; j < ToDoListen.length; j++) {
                                                  var HTMLstring = "";
                                                  setState(instanz + pfad + ToDoListen_names[j], "leer");
                                                  for (i = 0; i < json.length; i++) {
                                                      var Liste = parseInt(json[i].project_id);
                                                      var content = JSON.stringify(json[i].content);
                                                      content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                                                      content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                                                      var taskurl = JSON.stringify(json[i].url);
                                                      taskurl = taskurl.replace(/\"/g, "");
                                                      if (Liste == ToDoListen[j])
                                                      {
                                                          if(debug) log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                                          HTMLstring = HTMLstring+content+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                                                          setState(instanz + pfad + ToDoListen_names[j], HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                                                      }
                                                  }
                                              }
                                          });
                                      }
                                      catch(err) {log(err.message)}
                                  }, 1000);
                                  
                                  setTimeout(function() {                                                 // legt IDs der einzelnen Tasks in Unterordnern an
                                      try{        
                                          request(APItaskURL, function (error, response, body) {
                                              
                                              var json = JSON.parse(body);
                                              
                                              for (j = 0; j < ToDoListen.length; j++) {
                                                  
                                                  var HTMLstring = "";
                                                  
                                                  setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
                                                  for (i = 0; i < json.length; i++) {
                                                      var Liste = parseInt(json[i].project_id);
                                                      var taskid = JSON.stringify(json[i].id);
                                                      if (Liste == ToDoListen[j])
                                                      {
                                                          if(debug) log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                                          HTMLstring = HTMLstring+taskid+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                                                          setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                                                      }
                                                  }
                                              }
                                      
                                           });
                                      }
                                      catch(err) {log(err.message)}
                                  }, 1000);
                              }
                              
                              
                              
                              // ***********************************************
                              // TRIGGER
                              // ***********************************************
                              
                              on({    id:regexTrigger, 
                                      change: 'ne'}, 
                                      function() {                          // regex trigger, löst immer aus sobald etwas in der manuellen Liste an- oder abgewählt wird
                              
                                          checkTODOIST();              
                                      });
                              

                              <size="85">ioBroker | 21 Adapter | Ubuntu Server | intel NUC | Homematic CCU2 | Hue | Osram Lightify| Sonos | 2x Instar Cam | Samsung Tab A 2016 im Holzrahmen| 3x Echo dot | 1x Echo | Neato Botvac D5</size>

                              M 1 Antwort Letzte Antwort
                              0
                              • T tempestas

                                @Matze89
                                Daran liegt es nicht. Woran es liegt bleibt unklar.

                                Probiert mal diese Version bitte. Nur ein zusätzliches try-catch eingebaut

                                //  Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
                                //  Scriptversion: v0.21
                                //  Ergänzungen tempestas, Stand 27.3.2019
                                //  https://forum.iobroker.net/viewtopic.php?f=21&t=12563
                                //  https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205
                                
                                //Erforderliche Angaben:
                                var APItoken = ""; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
                                var debug = false;
                                
                                
                                //Weitere Parameter ggf. anpassen:
                                var instanz = 'javascript.0';  instanz = instanz + '.';     // Instanz fuer die Datenpunkte definieren
                                var pfad =   'Todoist.';                    // Pfad definieren
                                var regexTrigger = /^javascript\.0\.Einkaufsliste\.Items\..*$/;   // Trigger analog der manuellen Einkaufsliste
                                
                                schedule("*/1 * * * *", checkTODOIST);  // Abfragezeit: jede Minute
                                
                                
                                // *********************************************************
                                // Scriptbeginn - Ab hier nichts mehr ändern!
                                // *********************************************************
                                
                                function checkTODOIST() {
                                    
                                    var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
                                    var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
                                    var request = require("request");
                                    var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
                                    var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
                                    
                                    request(APIprojectsURL, function (error, response, body) {
                                        try{
                                            var projects_json = JSON.parse(body);
                                            for (k = 0; k < projects_json.length; k++) {
                                                var projects = parseInt(projects_json[k].id);
                                                var projects_name = JSON.stringify(projects_json[k].name);
                                                projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                                                ToDoListen[ToDoListen.length] = projects;
                                                ToDoListen_names[ToDoListen_names.length] = projects_name;
                                                createState(instanz + pfad + ToDoListen_names[k], {def: 'false',type: 'string',role: 'html', name: ToDoListen_names[k]+' HTML String'});
                                                if(debug) log("Datenpunkt "+ToDoListen_names[k]+" erstellt.", "info");
                                                createState(instanz + pfad + ToDoListen_names[k]+'.TaskID', {def: 'false',type: 'string',role: 'string', name: ToDoListen_names[k]+' Task IDs'});
                                                if(debug) log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
                                            }
                                        }
                                        catch(err) {log (err.message)}
                                    });
                                    
                                    setTimeout(function() {
                                        try{
                                            request(APItaskURL, function (error, response, body) {
                                                var json = JSON.parse(body);
                                                for (j = 0; j < ToDoListen.length; j++) {
                                                    var HTMLstring = "";
                                                    setState(instanz + pfad + ToDoListen_names[j], "leer");
                                                    for (i = 0; i < json.length; i++) {
                                                        var Liste = parseInt(json[i].project_id);
                                                        var content = JSON.stringify(json[i].content);
                                                        content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                                                        content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                                                        var taskurl = JSON.stringify(json[i].url);
                                                        taskurl = taskurl.replace(/\"/g, "");
                                                        if (Liste == ToDoListen[j])
                                                        {
                                                            if(debug) log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                                            HTMLstring = HTMLstring+content+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                                                            setState(instanz + pfad + ToDoListen_names[j], HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                                                        }
                                                    }
                                                }
                                            });
                                        }
                                        catch(err) {log(err.message)}
                                    }, 1000);
                                    
                                    setTimeout(function() {                                                 // legt IDs der einzelnen Tasks in Unterordnern an
                                        try{        
                                            request(APItaskURL, function (error, response, body) {
                                                
                                                var json = JSON.parse(body);
                                                
                                                for (j = 0; j < ToDoListen.length; j++) {
                                                    
                                                    var HTMLstring = "";
                                                    
                                                    setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
                                                    for (i = 0; i < json.length; i++) {
                                                        var Liste = parseInt(json[i].project_id);
                                                        var taskid = JSON.stringify(json[i].id);
                                                        if (Liste == ToDoListen[j])
                                                        {
                                                            if(debug) log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                                            HTMLstring = HTMLstring+taskid+"<br>";  // mit Link: HTMLstring = HTMLstring+"<tr><td><li><a href=\""+taskurl+"\" target=\"_blank\">"+content+"</a></li></td></tr>";
                                                            setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);   // "<table><>"+HTMLstring+"</ul></table>");
                                                        }
                                                    }
                                                }
                                        
                                             });
                                        }
                                        catch(err) {log(err.message)}
                                    }, 1000);
                                }
                                
                                
                                
                                // ***********************************************
                                // TRIGGER
                                // ***********************************************
                                
                                on({    id:regexTrigger, 
                                        change: 'ne'}, 
                                        function() {                          // regex trigger, löst immer aus sobald etwas in der manuellen Liste an- oder abgewählt wird
                                
                                            checkTODOIST();              
                                        });
                                
                                M Offline
                                M Offline
                                Matze89
                                schrieb am zuletzt editiert von
                                #83

                                @tempestas
                                hab mal dein neues Skript seid gestern am Laufen.
                                Leider immernoch fehler im log obwohl es funktioniert.
                                Trotzdem Danke :)

                                Hat jemand noch eine andere Idee?

                                host.debian 2019-03-28 18:04:01.473 error instance system.adapter.javascript.0 terminated with code 0 (OK)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at Object.onceWrapper (events.js:313:30)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at IncomingMessage.<anonymous> (/opt/iobroker/node_modules/request/request.js:1083:12)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request.emit (events.js:211:7)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at emitOne (events.js:116:13)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request.<anonymous> (/opt/iobroker/node_modules/request/request.js:1161:10)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request.emit (events.js:214:7)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at emitTwo (events.js:126:13)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request.self.callback (/opt/iobroker/node_modules/request/request.js:185:22)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request._callback (script.js.Einkaufsliste.Einkaufslisteneutest:105:33)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: at JSON.parse (<anonymous>:null:null)
                                Caught 2019-03-28 18:04:01.473 error by controller[0]: SyntaxError: Unexpected token I in JSON at position 0

                                T 1 Antwort Letzte Antwort
                                0
                                • M Matze89

                                  @tempestas
                                  hab mal dein neues Skript seid gestern am Laufen.
                                  Leider immernoch fehler im log obwohl es funktioniert.
                                  Trotzdem Danke :)

                                  Hat jemand noch eine andere Idee?

                                  host.debian 2019-03-28 18:04:01.473 error instance system.adapter.javascript.0 terminated with code 0 (OK)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at Object.onceWrapper (events.js:313:30)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at IncomingMessage.<anonymous> (/opt/iobroker/node_modules/request/request.js:1083:12)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request.emit (events.js:211:7)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at emitOne (events.js:116:13)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request.<anonymous> (/opt/iobroker/node_modules/request/request.js:1161:10)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request.emit (events.js:214:7)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at emitTwo (events.js:126:13)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request.self.callback (/opt/iobroker/node_modules/request/request.js:185:22)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at Request._callback (script.js.Einkaufsliste.Einkaufslisteneutest:105:33)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: at JSON.parse (<anonymous>:null:null)
                                  Caught 2019-03-28 18:04:01.473 error by controller[0]: SyntaxError: Unexpected token I in JSON at position 0

                                  T Offline
                                  T Offline
                                  tempestas
                                  schrieb am zuletzt editiert von
                                  #84

                                  @Matze89

                                  kannst du mir mal sagen, was bei dir in Zeile 105 steht? Welcher Code Abschnitt?

                                  <size="85">ioBroker | 21 Adapter | Ubuntu Server | intel NUC | Homematic CCU2 | Hue | Osram Lightify| Sonos | 2x Instar Cam | Samsung Tab A 2016 im Holzrahmen| 3x Echo dot | 1x Echo | Neato Botvac D5</size>

                                  M haselchenH 2 Antworten Letzte Antwort
                                  0
                                  • T tempestas

                                    @Matze89

                                    kannst du mir mal sagen, was bei dir in Zeile 105 steht? Welcher Code Abschnitt?

                                    M Offline
                                    M Offline
                                    Matze89
                                    schrieb am zuletzt editiert von
                                    #85

                                    @tempestas

                                    zeile 105 ist:

                                                var json = JSON.parse(body);
                                    
                                    1 Antwort Letzte Antwort
                                    0
                                    • E Offline
                                      E Offline
                                      ettaner
                                      schrieb am zuletzt editiert von
                                      #86

                                      Hi,

                                      das Script läuft super bei mir, vielen Dank dafür.
                                      Leider zeigt es auch Termine in der Zukunft mit an, kann man das ändern? Ich habe viele Serienaufgaben mit drin, z.B. alle 8 Wochen Rasen düngen. Siehe Screenshot. Ich hätte in meiner Liste gerne nur die derzeit gültigen Aufgaben drin. Also nicht die gelb markierten. aufgaben.png Geht das irgendwie? In Vis sind leider alle drin:
                                      vis.png

                                      1 Antwort Letzte Antwort
                                      0
                                      • T tempestas

                                        @Matze89

                                        kannst du mir mal sagen, was bei dir in Zeile 105 steht? Welcher Code Abschnitt?

                                        haselchenH Offline
                                        haselchenH Offline
                                        haselchen
                                        Most Active
                                        schrieb am zuletzt editiert von haselchen
                                        #87

                                        @tempestas

                                        Ich brauche bitte dringend Deine Hilfe.
                                        Aus dem Nichts erscheint im Log : Unexpected token P in JSON at Position 0.
                                        Einkaufsliste wird nicht mehr aktualisiert.
                                        Ich habe nichts geändert.
                                        Vor 3 Tagen um 2 Uhr morgens ist das passiert. Hab es im Logfile lesen können. Da war auch nichts außergewöhnliches.

                                        Synology DS218+ & 2 x Fujitsu Esprimo (VM/Container) + FritzBox7590 + 2 AVM 3000 Repeater & Homematic & HUE & Osram & Xiaomi, NPM 10.9.4, Nodejs 22.21.0 ,JS Controller 7.0.7 ,Admin 7.7.19

                                        T 1 Antwort Letzte Antwort
                                        0
                                        • haselchenH haselchen

                                          @tempestas

                                          Ich brauche bitte dringend Deine Hilfe.
                                          Aus dem Nichts erscheint im Log : Unexpected token P in JSON at Position 0.
                                          Einkaufsliste wird nicht mehr aktualisiert.
                                          Ich habe nichts geändert.
                                          Vor 3 Tagen um 2 Uhr morgens ist das passiert. Hab es im Logfile lesen können. Da war auch nichts außergewöhnliches.

                                          T Offline
                                          T Offline
                                          tempestas
                                          schrieb am zuletzt editiert von
                                          #88

                                          @haselchen

                                          Hallo,

                                          das Problem gibt es schon länger, meistens mit "unexpected Token I"... bislang keine Lösung, sorry

                                          <size="85">ioBroker | 21 Adapter | Ubuntu Server | intel NUC | Homematic CCU2 | Hue | Osram Lightify| Sonos | 2x Instar Cam | Samsung Tab A 2016 im Holzrahmen| 3x Echo dot | 1x Echo | Neato Botvac D5</size>

                                          haselchenH 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

                                          579

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          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