Weiter zum Inhalt

JavaScript

2.5k Themen 49.5k Beiträge

Hilfe für Skripterstellung mit JavaScript

NEWS

  • Kontakte (Cards)

    javascript multimedia template
    4
    1
    2 Stimmen
    4 Beiträge
    80 Aufrufe
    Ro75R
    Habe den Code im Eingangspost aktualisiert. Da fehlte eine Funktion. Ro75.
  • POST in JSON an WLED absenden

    8
    1
    0 Stimmen
    8 Beiträge
    262 Aufrufe
    M
    @Matthias-Jakob Bitte das Endergebnis für andere hier posten.
  • Zendure zenSDK Lokal API, SmartMode, SolarFlow AC 800 Pro 2

    291
    9 Stimmen
    291 Beiträge
    25k Aufrufe
    maxclaudiM
    update 21.05.26 22:05h auto_in_out_Limit Bitte "Wichtiger Hinweis zum Flash-Speicher" beachten: Beschreibung Update 24.05.26 00:15h globale Typsicherung Viel Spaß!
  • Error aus Kostal Piko 5.5 schiesst Script ab

    4
    0 Stimmen
    4 Beiträge
    91 Aufrufe
    paul53P
    @Homoran [sagte]: Dann bau ich das mal für zukünftige Fälle ein. Version, die nur ein komplettes Objekt erstellt, wenn der Code nicht gefunden wurde: var msg = msgs.find(item => item.code==code); if(!msg) msg = { code: code, type: 'unbekannt', description: 'n.v.', action: 'n.v.' }; msg.date=date;
  • ioBroker Prozess- & Gesundheitsmonitor + Grafana + HTML

    javascript monitoring
    90
    5
    5 Stimmen
    90 Beiträge
    3k Aufrufe
    crunchipC
    @emil70 du schreibst nen falschen DP in die Influx 0_userdata.0.Systeminfos.ioBroker.Prozesse.LogErrorHistory gehört da nicht hin Im ersten Beitrag unter Punkt 4 ist ein Screen mit allen DP`s die in die InfluxDB kommen
  • E3DC Hauskraftwerk steuern

    4k
    1
    3 Stimmen
    4k Beiträge
    2m Aufrufe
    A
    @Dave69-CH Ok, normalerweise sollten die Werte wieder ausgelesen und aktualisiert werden, selbst wenn diese mal gelöscht werden. Eventuell mal ein Issue hier eröffnen: e3dc-rscp Adapter
  • getobject und rooms

    2
    0 Stimmen
    2 Beiträge
    51 Aufrufe
    paul53P
    @bob79999 [sagte]: enumNames, sie können im Script nur nicht angesprochen werden. Meiner Erfahrung nach funktioniert dieser Ansatz (mehrfach getestet): let room = getObject(id, 'rooms').enumNames[0]; if(typeof room == 'object') room = room.de; Als (globale) Funktion: function roomName(id) { const room = getObject(id, 'rooms').enumNames[0]; if(typeof room == 'object') return room.de; return room; } @bob79999 sagte: Compiler wirft wie bekannt und oft im Forum adressiert ein "property enumNames does not exist" aus. Das ist nicht der Compiler, sondern die Typescript-Prüfung im Editor. Vom rot unterkringelten enumNames sollte man sich nicht verrückt machen lassen.
  • ioBroker Forum Widget – Forum-Daten direkt in Visu

    18
    2
    0 Stimmen
    18 Beiträge
    301 Aufrufe
    M
    Es gibt eine Möglichkeit im Profil [image: 1778956764291-1565b73c-02ac-4b1c-aa71-82d8311947d5-image.jpeg]
  • Todoist Script Lösung

    11
    1
    1 Stimmen
    11 Beiträge
    301 Aufrufe
    haselchenH
    Update: Mit diesem Befehl in einer Konsole kann man seine Projekte auflisten lassen (aus der App). Das ist wichtig für die Projekt ID im Skript. curl -i https://api.todoist.com/api/v1/projects -H "Authorization: Bearer XXXXXXXX" (für die XXXX muss euer Token eingesetzt werden) Die Ausgabe sähe als Beispiel so aus: { "results": [ { "id": "XXXXXX", "can_assign_tasks": false, "can_comment": true, "child_order": 0, "is_collapsed": false, "color": "grey", "creator_uid": "", "created_at": "", "is_archived": false, "is_deleted": false, "is_favorite": false, "is_frozen": false, "name": "Inbox", "is_shared": false, "updated_at": "", "view_style": "list", "default_order": 0, "description": "", "public_access": false, "public_key": "", "access": { "visibility": "restricted", "configuration": {} }, "role": "CREATOR", "goal_ids": [], "parent_id": null, "inbox_project": true }, { "id": "XXXXXX", "can_assign_tasks": false, "can_comment": true, "child_order": 1, "is_collapsed": false, "color": "sky_blue", "creator_uid": "", "created_at": "", "is_archived": false, "is_deleted": false, "is_favorite": false, "is_frozen": false, "name": "Alexa-Einkaufsliste", "is_shared": false, "updated_at": "", "view_style": "list", "default_order": 0, "description": "", "public_access": false, "public_key": "", "access": { "visibility": "restricted", "configuration": {} }, "role": "CREATOR", "goal_ids": [], "parent_id": null, "inbox_project": false }, { "id": "XXXXXX", "can_assign_tasks": false, "can_comment": true, "child_order": 2, "is_collapsed": false, "color": "orange", "creator_uid": "", "created_at": "", "is_archived": false, "is_deleted": false, "is_favorite": false, "is_frozen": false, "name": "Alexa To-Do Liste", "is_shared": false, "updated_at": "", "view_style": "list", "default_order": 0, "description": "", "public_access": false, "public_key": "", "access": { "visibility": "restricted", "configuration": {} }, "role": "CREATOR", "goal_ids": [], "parent_id": null, "inbox_project": false } ], "next_cursor": null Nehmen wir den Block , wo Alexa-Einkaufsliste steht. Darüber gibt es das Feld "id". Diese ID nehmt ihr für euer Skript. Das könnt ihr für jedes Projekt , was ihr in der App angelegt habt, machen. Ich habe ne ToDo Liste noch mit Aufgaben, die ich mir zukünftig so vorgenommen habe. Ein HTML Widget und sie werden mir in der VIS angezeigt. Immer wenns mir in den Kopp kommt, trage ich ne Aufgabe oder was für den Einkauf in der ToDoIst App ein und je nach Update Intervall im Skript, erscheint es dann in der VIS. [image: 1778806962575-4af9418b-b376-4f21-8e11-192aec03c340-image.jpeg] Token und Project ID vervollständigen und die beiden Datenpunkte anlegen 0_userdata.0.todoist.aufgaben.html 0_userdata.0.todoist.aufgaben.count const TOKEN = "XXXXXX"; // 🔴 Kann numerisch sein (muss nicht) const PROJECT_ID = "XXXXXX"; const DP_HTML = "0_userdata.0.todoist.aufgaben.html"; const DP_COUNT = "0_userdata.0.todoist.aufgaben.count"; // Cache let lastHTML = "Keine Daten"; let lastCount = 0; // ===================== // LOG INFO TEIL (SEPARAT & CLEAN) // ===================== function logInfo(msg) { log("[TODOIST] " + msg, "info"); } function logError(msg) { log("[TODOIST ERROR] " + msg, "info"); // kein warn/error → keine Stacktraces } // ===================== // START // ===================== schedule("*/5 * * * *", loadTasks); loadTasks(); // ===================== // MAIN // ===================== function loadTasks() { logInfo("Lade Tasks..."); httpPost("https://api.todoist.com/api/v1/sync", "sync_token=*&resource_types=" + encodeURIComponent('["items"]'), { headers: { "Authorization": "Bearer " + TOKEN, "Content-Type": "application/x-www-form-urlencoded" }, timeout: 10000 }, (err, res) => { if (err) { logError("HTTP Fehler"); setState(DP_HTML, lastHTML, true); setState(DP_COUNT, lastCount, true); return; } let data; try { data = JSON.parse(res.data); } catch (e) { logError("JSON Fehler"); return; } const items = data.items || []; if (!Array.isArray(items)) return; const filtered = items.filter(t => t.project_id == PROJECT_ID ); const html = filtered.length ? filtered.map(t => { let text = escapeHtml(t.content || ""); // entfernt führende "-" oder "•" falls sie im Task stehen text = text.replace(/^(\s*[-•]\s*)+/, ""); return "&#8226; " + text; }).join("<br>") : "Keine Einträge vorhanden"; setState(DP_HTML, html, true); setState(DP_COUNT, filtered.length, true); lastHTML = html; lastCount = filtered.length; logInfo("OK: " + filtered.length + " Items"); } ); } // ===================== // HTML SAFE // ===================== function escapeHtml(str) { return (str || "") .replace(/&/g, "&amp;") .replace(/</g, "&lt;") .replace(/>/g, "&gt;"); }
  • Werte in ein Register Schreiben

    48
    0 Stimmen
    48 Beiträge
    848 Aufrufe
    T
    Oha, das es so einfach ist hätte ich jetzt nicht gedacht. Da habe ich ja diese Woche eine Menge gelernt
  • HowTo: Zusatz-Programme fuer jarvis v3

    javascript
    899
    4 Stimmen
    899 Beiträge
    254k Aufrufe
    D
    @MCU geiler Scheiss. Danke funktioniert! 👍🏻
  • SQL-Abfrage aus Script an MariaDB

    9
    0 Stimmen
    9 Beiträge
    363 Aufrufe
    Uwe-KU
    @Norwegen60 Das hier funktioniert jetzt incl. zurück holen des Wertes in Datapoint let sSQL0 = "SELECT ioBroker.fn_energy('" + Mode + "', " + ID + ", " + Offset + ") AS energy"; sendTo('sql.0', 'query', sSQL0, function (result) { let energy = result.result[0].energy; setState(DataPoint, {val: Number(energy), ack: true}); log('GetEnergy: ' + energy + ' -> ' + DataPoint, 'info'); }); Danke für die Unterstützung Hast du das als reines Java Script realisiert oder es irgendwie in den Send_to Blockly Block integriert ? Ich würde es am liebsten rein im Blockly umsetzen, SQL Basic kann ich, aber Java Script ist nicht mein Metier. Ich habe schon Stunden zugebracht nach einem Blockly Beispiel, aber ich habe nichts gefunden, welches mir Werte zurückliefert die ich dann weiterverarbeiten kann.
  • Rauchmelder Skript

    javascript security
    53
    1 Stimmen
    53 Beiträge
    7k Aufrufe
    Kanzler1959K
    Ich wollte mich nur bedanken - auch wenn die Beiträge alle schon ein wenig alt sind. Das Script am Anfang hat mit geholfen eine Abfrage über meine RM zu machen. Diese sind alle im Gewerk "Sicherheit". Ich habe PushOver durch Telegram ersetzt und und auch eine 'daily' Meldung (um 22:22) eingebaut. Wenn jemand Interesse hat einfach fragen, dann poste ich das hier. Ist aber im Grunde das Script von ganz oben. Nachtrag: Man kann es testen, in dem man den Status 'editiert' (false -> true (Auslöser) -> false)
  • [TypeSkript] Wetter.com Forecast/Vorhersage

    69
    4 Stimmen
    69 Beiträge
    4k Aufrufe
    P
    @Schimi sagte: habe mal ne neue version erstellt, weil ich auch wieder ins Limit gelaufen bin... > Danke fürs fixen. Vom ersten Eindruck passt das so. Ich bin vor 2 Tagen auch ans Limit gelaufen, obwohl der Monatszähler bestimmt unter 50 war. Den Zähler zu reseten hat nichts gebracht. Ging dann nur mit einem neuen API-Key.
  • Tandoor zu Bring

    1
    0 Stimmen
    1 Beiträge
    60 Aufrufe
    Niemand hat geantwortet
  • [Vorlage] Script: JSON-->Datenpunkte mit sync

    Verschoben javascript monitoring
    11
    2 Stimmen
    11 Beiträge
    2k Aufrufe
    C
    @Ahnungsbefreit Kein Problem, ich habe das Thema für mich lösen können.
  • HTTP PATCH

    5
    1
    0 Stimmen
    5 Beiträge
    183 Aufrufe
    m1k3f15hM
    Super danke @codierknecht für den Tipp mit Axios Haut super hin :) function renameCam() { var temp = getState("alias.0.au.ga.xxxxxxxxx").val axios.patch('https://192.168.xxx.xxx/proxy/protect/integration/v1/cameras/xxxxxxxxxxxxxxxxxx', { name: 'xxxxx' + temp + '°C' }, { httpsAgent: agent, headers: { 'X-API-KEY': 'xxxxxxxxxxxxxxxxxxxxxxxxx', 'Accept': 'application/json' } }) // .then(function(response) { // log("Response: " + JSON.stringify(response.data)) // }) .catch(function(error) { log("Error: " + error, error) }) }; Mike
  • Homepilot Rolladensteuerung per Telegram

    javascript
    1
    0 Stimmen
    1 Beiträge
    65 Aufrufe
    Niemand hat geantwortet
  • JavaScript Exec Problem

    9
    0 Stimmen
    9 Beiträge
    229 Aufrufe
    R
    @Thomas-Braun Super, Danke hat funktioniert !!!!!!!
  • Klipper --> Telegram --> Snapshot

    1
    0 Stimmen
    1 Beiträge
    70 Aufrufe
    Niemand hat geantwortet

465

Online

32.9k

Benutzer

83.0k

Themen

1.3m

Beiträge