NEWS

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


  • Hallo zusammen,

    ich habe ein Javascript gebastelt, welches die To-Do Listen von todoist.com in ioBroker importiert

    Es erstellt Datenpunkte mit HTML Code, welche über das "basic - String (unescaped)" Widget in VIS eingebunden werden können.

    2665_todoscriptobjects.png

    In VIS sieht das dann bei mir z.B. so aus:
    2665_todoistvis.png
    Ein Klick auf ein Listenelement öffnet das Element auf todoist.com.

    Ggf. muss per CSS Code in VIS noch die Linkfarbe und die Link-Text-Decoration entfernt bzw. angepasst werden.

    Ich habe das bei mir so gemacht:

    ! ````
    /* unvisited link /
    a:link {
    color: white;
    text-decoration: none;
    }
    ! /
    visited link /
    a:visited {
    color: white;
    text-decoration: none;
    }
    ! /
    mouse over link /
    a:hover {
    color: white;
    text-decoration: none;
    }
    ! /
    selected link */
    a:active {
    color: white;
    text-decoration: none;
    }

    Hier noch der Code für das Widget
    
    >! ```
    `[{"tpl":"tplValueStringRaw","data":{"oid":"javascript.0.Todoist.Alexa-Einkaufsliste","g_fixed":true,"g_visibility":false,"g_css_font_text":true,"g_css_background":true,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"html_prepend":"**![](\"/vis.0/Eigene)  Einkaufsliste:**` **`","name":"Einkaufsliste"},"style":{"left":"575px","top":"8px","width":"260px","height":"350px","color":"rgba(250,250,250,1)","background":"rgba(150,150,150,0.5)","z-index":"2"},"widgetSet":"basic"}]`
    >! Hier das Javascript. Es muss der API Token eingefügt werden, den findet ihr auf todoist.com in den Einstellungen
    >! ```
    `//Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
    //Scriptversion: v0.1
    //https://forum.iobroker.net/viewtopic.php?f=21&t=12563
    >! //Erforderliche Angaben:
    var APItoken = "xxxxxxxxxxx"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
    >! //Weitere Parameter ggf. anpassen:
    var instanz = 'javascript.0';  instanz = instanz + '.';     // Instanz fuer die Datenpunkte definieren
    var pfad =   'Todoist.';                    // Pfad definieren
    schedule("*/5 * * * *", function () { // Abfragezeit: alle 5 Min
    >! // Scriptbeginn - Ab hier nichts mehr ändern!
    	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) {
            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'});
                log("Datenpunkt "+ToDoListen_names[k]+" erstellt.", "info");
            }
    
        });
        setTimeout(function() {
            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])
                        {
                            log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                            HTMLstring = HTMLstring+"*   ["+content+"](\""+taskurl+"\")";
                            setState(instanz + pfad + ToDoListen_names[j], "
    >! ");
                        }
                    }
                }
    
          	});
        }, 5000);
    });`
    >! Viel Spaß damit![/i][/i][/i]
    ```**
    ```

  • Toll, danke!

  • Most Active

    Ein Mega-Respekt für diese Arbeit. Daumen hoch!

    Und da habe ich gleich 2 Fragen 😄

    Verstehe ich das richtig, wenn ich zu Alexa sage: Packe XXX auf meine Einkaufsliste, dass es dann sofort im .vis auf dem Tablet angezeigt wird?

    Und wenn ja, wie bekomme ich dann NUR die Einkaufsliste ohne die ToDo Liste aufs Tablet (sprich, wie ist dann das Skript?)


  • nach spätestens 5 Minuten wirst du es sehen. Der Schedule ist auf alle 5 Minuten eingestellt. Hängt also davon ab, wann du Alexa ansprichst

    Das Skript liest alle angelegten Listen aus, und erzeugt entsprechende States in ioBroker. Wenn du mehrere Listen hast, nimmst du für VIS halt nur die eine Liste (ein widget, dass du auf die von dir gewünschte Liste referenzierst). Wenn du ohnehin nur eine Liste angelegt hast in todoist, dann bleibts bei nur einer.

  • Most Active

    Mir geht es um die Verknüpfung.

    Mit dem Google Kalender funktioniert das super. Da ist aber auch eine Menüführung zu in der Alexa App.

    Da sage ich einen Termin und es erscheint auf dem Tablet.

    Das gleiche möchte ich nun mit einer Einkaufsliste machen.

    Deshalb frage ich.

    Edit:

    Da warst du schneller mit der Antwort :lol:


  • Wenn man Alexa mit Todoist verknüpft hat dann wird bei „setze auf todo liste“ das element in die Liste „Eingang“ bzw „Inbox“ gepackt. Sagt man Alexa „setze auf die Einkaufsliste“ dann erstellt todoist eine neue Liste namens Alexa-Einkaufsliste und erstellt dort die Elenente.

    Das Script erstellt für alle Listen jeweils einen Datenpunkt mit dem Listeninhalt.

    Den Schedule des Scripts kann man aber auch problemlos auf ein 1 Minuten Intervall umstellen.

    Todoist selbst braucht auch ca eine Minute um sich mit Alexa zu synchronisieren. Kann also manchmal auch 2 Minuten dauern bis die Liste in VIS aktualisiert ist wenn der abfragezyklus in dem moment etwas ungünstig liegt.


  • @eXTreMe:

    Wenn man Alexa mit Todoist verknüpft hat dann wird bei „setze auf todo liste“ das element in die Liste „Eingang“ bzw „Inbox“ gepackt. Sagt man Alexa „setze auf die Einkaufsliste“ dann erstellt todoist eine neue Liste namens Alexa-Einkaufsliste und erstellt dort die Elenente.

    Das Script erstellt für alle Listen jeweils einen Datenpunkt mit dem Listeninhalt.

    Den Schedule des Scripts kann man aber auch problemlos auf ein 1 Minuten Intervall umstellen.

    Todoist selbst braucht auch ca eine Minute um sich mit Alexa zu synchronisieren. Kann also manchmal auch 2 Minuten dauern bis die Kiste in VIS aktualisiert ist wenn der abfragezyklus in dem moment etwas ungünstig liegt. `
    Wenn man IFFFT service benutzt, dann kann man darüber ioBroker triggern und ioBroker wird die Liste ziemlich sofort updaten.

    Es währe cool so ein Video zu haben:

    Alexa setzte auf Einkaufsliste blabla =>

    und dann erscheint sofort das auf vis. 🙂


  • ich überlege gerade, wie ich das Ding mit meiner existierenden Liste verknüpfen kann.

    Zum einen müssten Dopplungen ausgeschlossen werden.

    Dann ist die Frage, wie ich todoist Listen von Extern löschen bzw leeren kann - nur per Sprache?

    Hinzufügen ist auf die Art sehr angenehm, löschen finde ich dagegen anstrengend. Insbesondere, wenn ich z.B. 10 Sachen auf der Liste hatte, aber nur 8 gekauft habe. Dann müsste ich wahrscheinlich via Sprachbefehl 8 Sachen einzeln löschen, oder? Habe mir todoist bis heute noch nicht angesehen und suche gerade, ob man quasi von extern auch Dinge löschen kann


  • @tempestas:

    ich überlege gerade, wie ich das Ding mit meiner existierenden Liste verknüpfen kann.

    Zum einen müssten Dopplungen ausgeschlossen werden.

    Dann ist die Frage, wie ich todoist Listen von Extern löschen bzw leeren kann - nur per Sprache?

    Hinzufügen ist auf die Art sehr angenehm, löschen finde ich dagegen anstrengend. Insbesondere, wenn ich z.B. 10 Sachen auf der Liste hatte, aber nur 8 gekauft habe. Dann müsste ich wahrscheinlich via Sprachbefehl 8 Sachen einzeln löschen, oder? Habe mir todoist bis heute noch nicht angesehen und suche gerade, ob man quasi von extern auch Dinge löschen kann `
    gibt eine REST API, man kann über cURL http POST befehle auch löschen.

    Bin erst totaler Neuling auf dem Gebiet, habe bisher nur GET befehle zum auslesen der tasks verwendet, weiß auch garnicht ob oder wie POST befehle mit javascript gehen, geschweige denn was überhaupt cURL genau ist und wie es funktioniert, bin mich noch am einlesen.

    Hier der Link zur API Doku: https://developer.todoist.com/rest/v8/#delete-a-task

    Wenn du da schlauer bist als ich und das script erweitern möchtest oder eine andere lösung für dein problem hast: nur zu!

    Ich lösche meine Events mit der todoist App auf meinem smartphone. Das script sollte einfach nur eine zusätzliche Darstellung auf VIS ermöglichen.

    Vielleicht kann man über IFTTT Webhooks auch etwas realisieren, Bluefox hatte das ja oben mal in den raum geworfen.


  • @tempestas:

    ich überlege gerade, wie ich das Ding mit meiner existierenden Liste verknüpfen kann.

    Zum einen müssten Dopplungen ausgeschlossen werden.

    Dann ist die Frage, wie ich todoist Listen von Extern löschen bzw leeren kann - nur per Sprache?

    Hinzufügen ist auf die Art sehr angenehm, löschen finde ich dagegen anstrengend. Insbesondere, wenn ich z.B. 10 Sachen auf der Liste hatte, aber nur 8 gekauft habe. Dann müsste ich wahrscheinlich via Sprachbefehl 8 Sachen einzeln löschen, oder? Habe mir todoist bis heute noch nicht angesehen und suche gerade, ob man quasi von extern auch Dinge löschen kann `
    Sollte damit möglich sein.

    https://developer.todoist.com/sync/v7/


  • @eXTreMe:

    habe bisher nur GET befehle zum auslesen der tasks verwendet `
    Wie denn? da braucht man doch auth key?


  • @Bluefox:

    @eXTreMe:

    habe bisher nur GET befehle zum auslesen der tasks verwendet Wie denn? da braucht man doch auth key?
    Den API Key kann man unter todoist.com in den Profileinstellungen unter dem Menüpunkt Integration auslesen (wie oben schon beschrieben). Jeder Useraccount hat einen API Key.

    Und habe damit dann die JSONs für meine Listen und Tasks ausgelesen

    Listen: https://beta.todoist.com/API/v8/project … XXXXXXXXXX

    Tasks: https://beta.todoist.com/API/v8/tasks?token=XXXXXXXXXX

    hier die REST API Doku aus der ich die infos habe: https://developer.todoist.com/rest/v8/#overview


  • Hi,

    nur, damit wir uns da nicht missverstehen: das war keine Kritik und auch kein "mach mal mehr". Ich könnte das gar nicht, was du da gebastelt hast.

    Als BWLer bin ich schon froh, das ich das, was du da gebastelst hast nachvollziehen und "lesen" kann.

    War mehr meine Gedankensammlung zum Thema "was hätte ich gerne noch". Ich schaue mir die Sachen mal an


  • @tempestas:

    Hi,

    nur, damit wir uns da nicht missverstehen: das war keine Kritik und auch kein "mach mal mehr". Ich könnte das gar nicht, was du da gebastelt hast.

    Als BWLer bin ich schon froh, das ich das, was du da gebastelst hast nachvollziehen und "lesen" kann.

    War mehr meine Gedankensammlung zum Thema "was hätte ich gerne noch". Ich schaue mir die Sachen mal an `
    Keine Angst, habe ich nicht so aufgefasst 🙂

    Ich arbeite auch gerade daran das Script in einen Adapter umzuwandeln, so werden es sicher mehr Leute nutzen und wenn darunter der ein oder andere pfiffige Programmierer ist, dann wird es evt auch eher Funktionserweiterungen geben.


  • @eXTreMe:

    @Bluefox:

    @eXTreMe:

    habe bisher nur GET befehle zum auslesen der tasks verwendet Wie denn? da braucht man doch auth key?
    Den API Key kann man unter todoist.com in den Profileinstellungen unter dem Menüpunkt Integration auslesen (wie oben schon beschrieben). Jeder Useraccount hat einen API Key.

    Und habe damit dann die JSONs für meine Listen und Tasks ausgelesen

    Listen: https://beta.todoist.com/API/v8/project … XXXXXXXXXX

    Tasks: https://beta.todoist.com/API/v8/tasks?token=XXXXXXXXXX

    hier die REST API Doku aus der ich die infos habe: https://developer.todoist.com/rest/v8/#overview `

    Die Frage mag total blöd sein, aber ich stelle sie trotzdem:

    wie kommst du aus dieser Doku von diesem Beispiel:

    
        Get tasks
    
    $ curl -X GET \
      https://beta.todoist.com/API/v8/tasks \
      -H "Authorization: Bearer $token”
    
    [
        {
            "id": 123,
            "project_id": 234,
            "content": "Inbox",
            "comment_count": 10,
            "order": 1,
            "indent": 1,
            "priority": 1,
            "url": "https://todoist.com/showTask?id=123"
        },
        ...
    ]
    
    

    auf das hier:

        request( https://beta.todoist.com/API/v8/tasks?token="+APItoken;;  , function (error, response, body) { ..... )
    ````?

  • @eXTreMe:

    Ich arbeite auch gerade daran das Script in einen Adapter umzuwandeln, so werden es sicher mehr Leute nutzen und wenn darunter der ein oder andere pfiffige Programmierer ist, dann wird es evt auch eher Funktionserweiterungen geben. `
    :!: :!: :!:

    Push mal auf github, dann kann ich auch vielleicht helfen.


  • @Bluefox:

    @eXTreMe:

    Ich arbeite auch gerade daran das Script in einen Adapter umzuwandeln, so werden es sicher mehr Leute nutzen und wenn darunter der ein oder andere pfiffige Programmierer ist, dann wird es evt auch eher Funktionserweiterungen geben. `
    :!: :!: :!:

    Push mal auf github, dann kann ich auch vielleicht helfen. `
    Hab es auf github hochgeladen, bekomme den Adapter aber nicht zum laufen. Habe im ioBroker Entwickler Forum einen Beitrag eröffnet.

    Wäre super wenn du mal drüberschauen könntest.

    viewtopic.php?f=24&t=12583


  • @tempestas:

    @eXTreMe:

    @Bluefox:

    Wie denn? da braucht man doch auth key? `
    Den API Key kann man unter todoist.com in den Profileinstellungen unter dem Menüpunkt Integration auslesen (wie oben schon beschrieben). Jeder Useraccount hat einen API Key.

    Und habe damit dann die JSONs für meine Listen und Tasks ausgelesen

    Listen: https://beta.todoist.com/API/v8/project … XXXXXXXXXX

    Tasks: https://beta.todoist.com/API/v8/tasks?token=XXXXXXXXXX

    hier die REST API Doku aus der ich die infos habe: https://developer.todoist.com/rest/v8/#overview `

    Die Frage mag total blöd sein, aber ich stelle sie trotzdem:

    wie kommst du aus dieser Doku von diesem Beispiel:

    
        Get tasks
    
    $ curl -X GET \
      https://beta.todoist.com/API/v8/tasks \
      -H "Authorization: Bearer $token”
    
    [
        {
            "id": 123,
            "project_id": 234,
            "content": "Inbox",
            "comment_count": 10,
            "order": 1,
            "indent": 1,
            "priority": 1,
            "url": "https://todoist.com/showTask?id=123"
        },
        ...
    ]
    
    

    auf das hier:

        request( https://beta.todoist.com/API/v8/tasks?token="+APItoken;;  , function (error, response, body) { ..... )
    ````? `  
    

    Ist eigentlich einfach:

    $ curl -X GET \
      https://beta.todoist.com/API/v8/tasks \
      -H "Authorization: Bearer $token”
    

    Da steht die http-GET URL die du brauchst: https://beta.todoist.com/API/v8/tasks

    und das Attribut welches benötigt wird: $token

    Zusammengesetzt sieht das dann so aus: https://beta.todoist.com/API/v8/tasks?token=XXXX

    Das kannst du mal im Browser eingeben mit deinem Token am Ende, dann sollte soetwas wie oben im Beispiel angegeben rauskommen (ggf. brauchst du noch ein Browser Addon wie "json view" damit es halbwegs schön angezeigt wird):

        {
            "id": 123,
            "project_id": 234,
            "content": "Inbox",
            "comment_count": 10,
            "order": 1,
            "indent": 1,
            "priority": 1,
            "url": "https://todoist.com/showTask?id=123"
        },
    

    mit dem rest von meinem javascript lese ich quasi die einzelnen Elemente aus dem json aus, packe sie in Variablen und verarbeite sie dann zu einem HTML Code für VIS.

    Ich hab mir das auch nur aus anderen Scripten oder Javascript Online-Dokumentationen zusammengesucht und zusammengebastelt. Wirklich 100% verstanden habe ich das selber auch noch nicht im Detail, da ich nie systematisch bei Null angefangen habe Javascript zu lernen.

    Du kannst den Code aus meinem Script quasi für alle möglichen http GET API anfragen (also nur daten auslesen, nicht ändern!) ganz einfach umschreiben wenn du selber etwas realisieren möchtest.


  • Hallo exTreme,

    ich habe dein Skript etwas abgewandelt, damit man nun zumindest via eines Buttons in VIS die GESAMTE Liste löschen kann. Habs gerade getestet, funktioniert.

    In deinem Skript habe ich eine zusätzliche Funktion eingebaut und ein createState, um die IDs der Tasks mit in die jeweilige Liste zu schreiben. Das ist dann fürs Löschen benötigt. Außerden, aber das ist reine Optik, habe ich die Link Funktion rausgenommen, mir reicht ein einfacher HTML Zeilenumbruch.

    Hier das leicht ergänzte Skript:

    ! ```
    `//Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
    //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 = "STRENG GEHEIM"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
    ! //Weitere Parameter ggf. anpassen:
    var instanz = 'javascript.0'; instanz = instanz + '.'; // Instanz fuer die Datenpunkte definieren
    var pfad = 'Todoist.'; // Pfad definieren
    schedule("*/1 * * * *", function () { // Abfragezeit: alle 1 Min
    ! // Scriptbeginn - Ab hier nichts mehr ändern!
    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) {
        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'});
            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'});   // NEU EINGEFÜGT TEMPESTAS
            log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
        }
    
    });
    setTimeout(function() {
        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])
                    {
                        log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                        HTMLstring = HTMLstring+content+"
    

    "; // mit Link: HTMLstring = HTMLstring+"* "+content+"";
    setState(instanz + pfad + ToDoListen_names[j], HTMLstring); // "<>"+HTMLstring+"

    ! ");
    }
    }
    }

         });
    }, 5000);
    
        setTimeout(function() {                                                 // NEU EINGEFÜGT TEMPESTAS: 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])
                    {
                        log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                        HTMLstring = HTMLstring+taskid+"
    

    ";
    setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);
    }
    }
    }

         });
    }, 6000);
    

    });`

    ! und mit diesem Skript kann man dann die Tasks (bzw Einkäufe) löschen. Hier im Beispiel reagiert es noch nicht auf einen VIS Button, aber einen Trigger einzubauen ist ja nun das Einfachste. Den könnte man dann über ioBroker auch via Alexa ansprechen.
    ! >! [spoiler]`[code]
    //Erforderliche Angaben:
    var APItoken = "STRENG GEHEIM"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
    var idEinkaufsliste = "javascript.0.Todoist.Alexa-Einkaufsliste.TaskID"; // hier den Pfad zur Einkaufsliste anlegen, die bei Betätigung gelöscht werden soll
    ! // Scriptbeginn - ab hier nichts mehr ändern
    ! var request = require("request");
    !
    function deleteTask(){
    ! var idListArray =[];
    var idList;

    idList = getState(idEinkaufsliste).val;			
    log(idList);
    idListArray = idList.split("
    

    ");
    idListArray.pop(); // aufgrund meiner uneleganten Änderungen steht als letztes immer "
    " in der Liste. Damit würde ein Element zuviel ausgegeben werden (leer). Pop kürzt den Array ums letzte Element

    log("idList Array ist " +idListArray);
    log("idList Array Länge ist "+idListArray.length);
    
    for (i = 0; i< idListArray.length; i++){
    
        log("Durchgang "+i);
    
        var deleteURL = "https://beta.todoist.com/API/v8/tasks/"+idListArray[i]+"?token="+APItoken;
        log("Delete URL ist "+deleteURL);
    
        request({
            uri: deleteURL,
            method: "DELETE",
            timeout: 5000,
            }, 
                function(error, response, body) {
                console.log(body);
            });    
        }
    

    }

    ! // Bei Start zum Testen
    ! deleteTask();
    ! // Bei Start zum Testen --> Später durch VIS Trigger ersetzen (könnte dann auch über Alexa gesteuert werden)
    ! deleteTask();` [/i][/code][/spoiler][/i][/i][/i][/i][/i]


  • @tempestas:

    Hallo exTreme,

    ich habe dein Skript etwas abgewandelt, damit man nun zumindest via eines Buttons in VIS die GESAMTE Liste löschen kann. Habs gerade getestet, funktioniert. `

    Coole Sache!

    Habs probiert und es funktioniert super!

    Ich wusste nicht, dass es das hier gibt:

    method: "DELETE",
    

    Werde mich damit nochmal befassen., denn damit ergeben sich noch viele neue Möglichkeiten!

    Vielen Dank dafür!

Suggested Topics

874
Online

38.4k
Users

43.9k
Topics

613.2k
Posts