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. Einfügen von JS-Klassen aus eigenem NPM-Modul

NEWS

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

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

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

Einfügen von JS-Klassen aus eigenem NPM-Modul

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
51 Beiträge 4 Kommentatoren 5.4k Aufrufe 3 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 ticaki

    @uwe72
    Mit TS bin ich nicht weiter ABER :)

    Bildschirmfoto 2023-11-11 um 20.11.08.png

    Bildschirmfoto 2023-11-11 um 20.11.32.png

    Bildschirmfoto 2023-11-11 um 20.12.36.png

    F Offline
    F Offline
    fastfoot
    schrieb am zuletzt editiert von
    #18

    @ticaki wo ist da jetzt der Unterschied zu meinem Beispiel?

    was TS angeht, so kann die importierende Datei natürlich auch TS sein. Was den import angeht, so muss die zu importierende Datei immer zuerst zu JS transpiliert werden wenn es sich auch um TS handelt, das ist ja in einer 'normalen' node application auch nicht anders, da wird immer JS importiert. Das jedoch im JS-Adapter zu vereinen wird wohl nicht möglich sein da sich da alles im Memory abspielt. Deshalb lib in TS schreiben, mit tsc zu JS(als common js!) compilieren und wie gezeigt nutzen

    iobroker läuft unter Docker auf QNAP TS-451+
    SkriptRecovery: https://forum.iobroker.net/post/930558

    T U 2 Antworten Letzte Antwort
    0
    • F fastfoot

      @ticaki wo ist da jetzt der Unterschied zu meinem Beispiel?

      was TS angeht, so kann die importierende Datei natürlich auch TS sein. Was den import angeht, so muss die zu importierende Datei immer zuerst zu JS transpiliert werden wenn es sich auch um TS handelt, das ist ja in einer 'normalen' node application auch nicht anders, da wird immer JS importiert. Das jedoch im JS-Adapter zu vereinen wird wohl nicht möglich sein da sich da alles im Memory abspielt. Deshalb lib in TS schreiben, mit tsc zu JS(als common js!) compilieren und wie gezeigt nutzen

      T Offline
      T Offline
      ticaki
      schrieb am zuletzt editiert von ticaki
      #19

      @fastfoot sagte in Einfügen von JS-Klassen aus eigenem NPM-Modul:

      @ticaki wo ist da jetzt der Unterschied zu meinem Beispiel?

      Der Unterschied ist, das alles im Javascript-Adapter ist. Falls das für dich nichts besonders ist ok, nur hat hier jeder immer geschrieben, das libs nicht gehen. Daher ist das für mich was bemerkenswertes.

      Zu TS:

      hab ich mir gedacht, daher funktioniert die "alles im Adapter" Methode nicht mit TS. Danke, erspart mir das suchen, ob es nicht doch geht.

      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

      Spenden

      1 Antwort Letzte Antwort
      0
      • F fastfoot

        @ticaki wo ist da jetzt der Unterschied zu meinem Beispiel?

        was TS angeht, so kann die importierende Datei natürlich auch TS sein. Was den import angeht, so muss die zu importierende Datei immer zuerst zu JS transpiliert werden wenn es sich auch um TS handelt, das ist ja in einer 'normalen' node application auch nicht anders, da wird immer JS importiert. Das jedoch im JS-Adapter zu vereinen wird wohl nicht möglich sein da sich da alles im Memory abspielt. Deshalb lib in TS schreiben, mit tsc zu JS(als common js!) compilieren und wie gezeigt nutzen

        U Offline
        U Offline
        uwe72
        schrieb am zuletzt editiert von
        #20

        @fastfoot

        Sorry, nun hatte ich erst dein Beispiel verstanden. Das funktioniert auch und schon mal viel besser als meine Lösung über das eigene NPM Module.

        /home/uwe72/clement/docker/my-datas/iobroker/iobrokerdata/my_scripts/main.js

        class Person {
            constructor(vorname, nachname, alter) {
              this._vorname = vorname;
              this._nachname = nachname;
              this._alter = alter;
            }
          
            information() {
              return (`Mein Name ist ${this._vorname} ${this._nachname} und ich bin ${this._alter} Jahre alt!!!!1`);
            }
          }
        
        module.exports = { Person};
        

        iobroker-Script:

        const { Person } = require('/opt/iobroker/my_scripts/main.js');
        const joe = new Person("Joe", "Müller", 32);
        log(joe.information());
        

        Log:

        Mein Name ist Joe Müller und ich bin 32 Jahre alt!!!!1
        
        1 Antwort Letzte Antwort
        0
        • T ticaki

          @uwe72
          Mit TS bin ich nicht weiter ABER :)

          Bildschirmfoto 2023-11-11 um 20.11.08.png

          Bildschirmfoto 2023-11-11 um 20.11.32.png

          Bildschirmfoto 2023-11-11 um 20.12.36.png

          U Offline
          U Offline
          uwe72
          schrieb am zuletzt editiert von uwe72
          #21

          @ticaki Danke. Habe deinen vorletzten Post noch nicht ganz verstanden. Schaue ich mir aber nun im Detail an! Wenn es innerhalb von iobroker wäre, wäre dies natürlich eine Stufe besser.

          T 1 Antwort Letzte Antwort
          0
          • U uwe72

            @ticaki Danke. Habe deinen vorletzten Post noch nicht ganz verstanden. Schaue ich mir aber nun im Detail an! Wenn es innerhalb von iobroker wäre, wäre dies natürlich eine Stufe besser.

            T Offline
            T Offline
            ticaki
            schrieb am zuletzt editiert von ticaki
            #22

            bin gerade verwirrt.

            Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

            Spenden

            U 2 Antworten Letzte Antwort
            0
            • T ticaki

              bin gerade verwirrt.

              U Offline
              U Offline
              uwe72
              schrieb am zuletzt editiert von
              #23

              @ticaki said in Einfügen von JS-Klassen aus eigenem NPM-Modul:

              @uwe72
              ISt das selbe wie von fastfood, was ich dann scheinbar auch nicht verstanden habe. :D

              OK.

              Was machen wir nun mit unserem TS? :-)

              T 1 Antwort Letzte Antwort
              0
              • T ticaki

                bin gerade verwirrt.

                U Offline
                U Offline
                uwe72
                schrieb am zuletzt editiert von
                #24

                @ticaki Ich hätte dich zuerst so verstanden, dass Du eine JS-Lösung hast wo alles in iobroker abläuft. Bei @fastfoot liegt das Script ja außerhalb von iobroker.

                F 1 Antwort Letzte Antwort
                0
                • U uwe72

                  @ticaki said in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                  @uwe72
                  ISt das selbe wie von fastfood, was ich dann scheinbar auch nicht verstanden habe. :D

                  OK.

                  Was machen wir nun mit unserem TS? :-)

                  T Offline
                  T Offline
                  ticaki
                  schrieb am zuletzt editiert von ticaki
                  #25

                  @uwe72 sagte in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                  @ticaki said in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                  @uwe72
                  ISt das selbe wie von fastfood, was ich dann scheinbar auch nicht verstanden habe. :D

                  OK.

                  Was machen wir nun mit unserem TS? :-)

                  Wie geschrieben ich bin gerade verwirrt. Der Aufbau meines Beispiels ist der selbe wie von Fastfood, nur das ich getestet habe ob man das nicht komplett im Javascript-Adapter machen kann und das geht.

                  TS geht nur wenn du das Skript extern in JS transpilierst.
                  Dir ist klar das du auch in einem TS Skript, die JS lib importieren kannst?

                  20:44:12.627	info	javascript.0 (57320) script.js.Test.Skript_type_1: compiling TypeScript source...
                  20:44:12.802	info	javascript.0 (57320) script.js.Test.Skript_type_1: TypeScript compilation successful
                  20:44:12.811	info	javascript.0 (57320) script.js.Test.Skript_type_1: Mein Name ist Joe Müller und ich bin 31 Jahre alt!
                  20:44:12.812	info	javascript.0 (57320) script.js.Test.Skript_type_1: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                  

                  Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                  Spenden

                  U 1 Antwort Letzte Antwort
                  0
                  • U uwe72

                    @ticaki Ich hätte dich zuerst so verstanden, dass Du eine JS-Lösung hast wo alles in iobroker abläuft. Bei @fastfoot liegt das Script ja außerhalb von iobroker.

                    F Offline
                    F Offline
                    fastfoot
                    schrieb am zuletzt editiert von
                    #26

                    @uwe72 sagte in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                    @ticaki Ich hätte dich zuerst so verstanden, dass Du eine JS-Lösung hast wo alles in iobroker abläuft. Bei @fastfoot liegt das Script ja außerhalb von iobroker.

                    wo das script(die lib) liegt ist letztlich doch egal. Ich hatte den Kniff mit der Spiegelung deshalb nicht genutzt weil es dir ja um TS geht und da willst(kannst!) du den Source halt nicht im Editor haben. Also, lib in TS schreiben(die ändert sich ja nicht so oft) und mit tsc compilieren. Dann im Editor ganz normal mit require die js-datei importieren. Wichtig bei tsc ist die Option zu nutzen welche dir die lib als common js schreibt da der Adapter keine esm Module supported. Einfach mal probieren,evtl.funktioniert das schon im Standard so(tsc lib.ts)

                    iobroker läuft unter Docker auf QNAP TS-451+
                    SkriptRecovery: https://forum.iobroker.net/post/930558

                    U 2 Antworten Letzte Antwort
                    2
                    • F fastfoot

                      @uwe72 sagte in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                      @ticaki Ich hätte dich zuerst so verstanden, dass Du eine JS-Lösung hast wo alles in iobroker abläuft. Bei @fastfoot liegt das Script ja außerhalb von iobroker.

                      wo das script(die lib) liegt ist letztlich doch egal. Ich hatte den Kniff mit der Spiegelung deshalb nicht genutzt weil es dir ja um TS geht und da willst(kannst!) du den Source halt nicht im Editor haben. Also, lib in TS schreiben(die ändert sich ja nicht so oft) und mit tsc compilieren. Dann im Editor ganz normal mit require die js-datei importieren. Wichtig bei tsc ist die Option zu nutzen welche dir die lib als common js schreibt da der Adapter keine esm Module supported. Einfach mal probieren,evtl.funktioniert das schon im Standard so(tsc lib.ts)

                      U Offline
                      U Offline
                      uwe72
                      schrieb am zuletzt editiert von
                      #27

                      @fastfoot said in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                      @uwe72 sagte in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                      @ticaki Ich hätte dich zuerst so verstanden, dass Du eine JS-Lösung hast wo alles in iobroker abläuft. Bei @fastfoot liegt das Script ja außerhalb von iobroker.

                      wo das script(die lib) liegt ist letztlich doch egal. Ich hatte den Kniff mit der Spiegelung deshalb nicht genutzt weil es dir ja um TS geht und da willst(kannst!) du den Source halt nicht im Editor haben. Also, lib in TS schreiben(die ändert sich ja nicht so oft) und mit tsc compilieren. Dann im Editor ganz normal mit require die js-datei importieren. Wichtig bei tsc ist die Option zu nutzen welche dir die lib als common js schreibt da der Adapter keine esm Module supported. Einfach mal probieren,evtl.funktioniert das schon im Standard so(tsc lib.ts)

                      Ich werde dies nun ausprobieren! Danke!

                      1 Antwort Letzte Antwort
                      0
                      • T ticaki

                        @uwe72 sagte in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                        @ticaki said in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                        @uwe72
                        ISt das selbe wie von fastfood, was ich dann scheinbar auch nicht verstanden habe. :D

                        OK.

                        Was machen wir nun mit unserem TS? :-)

                        Wie geschrieben ich bin gerade verwirrt. Der Aufbau meines Beispiels ist der selbe wie von Fastfood, nur das ich getestet habe ob man das nicht komplett im Javascript-Adapter machen kann und das geht.

                        TS geht nur wenn du das Skript extern in JS transpilierst.
                        Dir ist klar das du auch in einem TS Skript, die JS lib importieren kannst?

                        20:44:12.627	info	javascript.0 (57320) script.js.Test.Skript_type_1: compiling TypeScript source...
                        20:44:12.802	info	javascript.0 (57320) script.js.Test.Skript_type_1: TypeScript compilation successful
                        20:44:12.811	info	javascript.0 (57320) script.js.Test.Skript_type_1: Mein Name ist Joe Müller und ich bin 31 Jahre alt!
                        20:44:12.812	info	javascript.0 (57320) script.js.Test.Skript_type_1: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                        
                        U Offline
                        U Offline
                        uwe72
                        schrieb am zuletzt editiert von
                        #28

                        @ticaki Habe nicht alles verstanden was Du schriebst. Hast Du nun bereits das Ganze in TS?

                        T 1 Antwort Letzte Antwort
                        0
                        • U uwe72

                          @ticaki Habe nicht alles verstanden was Du schriebst. Hast Du nun bereits das Ganze in TS?

                          T Offline
                          T Offline
                          ticaki
                          schrieb am zuletzt editiert von
                          #29

                          @uwe72
                          Ich bin wohl zu müde :)

                          Nein, ich habe das nicht in TS.

                          Wenn ich die Ausführungen von @fastfoot richtig verstehe, muß man TS erst in Javascript transpilieren, was alle Typenanmerkungen entfernt und kann sie dann importieren.

                          In dem Fall kann man diese auch gleich in JS schreiben und in die TS Scripte importieren.

                          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                          Spenden

                          1 Antwort Letzte Antwort
                          0
                          • F fastfoot

                            @uwe72 sagte in Einfügen von JS-Klassen aus eigenem NPM-Modul:

                            @ticaki Ich hätte dich zuerst so verstanden, dass Du eine JS-Lösung hast wo alles in iobroker abläuft. Bei @fastfoot liegt das Script ja außerhalb von iobroker.

                            wo das script(die lib) liegt ist letztlich doch egal. Ich hatte den Kniff mit der Spiegelung deshalb nicht genutzt weil es dir ja um TS geht und da willst(kannst!) du den Source halt nicht im Editor haben. Also, lib in TS schreiben(die ändert sich ja nicht so oft) und mit tsc compilieren. Dann im Editor ganz normal mit require die js-datei importieren. Wichtig bei tsc ist die Option zu nutzen welche dir die lib als common js schreibt da der Adapter keine esm Module supported. Einfach mal probieren,evtl.funktioniert das schon im Standard so(tsc lib.ts)

                            U Offline
                            U Offline
                            uwe72
                            schrieb am zuletzt editiert von uwe72
                            #30

                            @fastfoot @ticaki

                            TS-Lösung funktioniert!

                            Wie von @ticaki vorgeschlagen funktioniert. D.h. TS-Script liegt extern und muss transpilierst werden.

                            /home/uwe72/clement/docker/my-datas/iobroker/iobrokerdata/my_scripts/buch.ts

                            class Buch  {
                            
                                public getCurrentWeekdayAsString() : string {
                                    var now = new Date();
                                    let weekday = now.getDay();
                                    return this.getWeekdayAsString(weekday);
                                }
                            
                                private getWeekdayAsString(weekday: number) : string {
                                    let weekdayAsString;
                                    if (weekday == 1) {
                                        weekdayAsString = "Montag";
                                    } else if (weekday == 2) {
                                        weekdayAsString = "Dienstag";
                                    } else if (weekday == 3) {
                                        weekdayAsString = "Mittwoch";
                                    } else if (weekday == 4) {
                                        weekdayAsString = "Donnerstag";
                                    } else if (weekday == 5) {
                                        weekdayAsString = "Freitag";
                                    } else if (weekday == 6) {
                                        weekdayAsString = "Samstag";
                                    } else if (weekday == 7) {
                                        weekdayAsString = "Sonntag";
                                    } else if (weekday == 0) {
                                        weekdayAsString = "Sonntag";
                                    }
                                    return weekdayAsString;
                                }  
                            }
                            
                            module.exports = { Buch};
                            

                            Dann in der Konsole folgendes eingeben (habe ich noch nicht im Detail verstanden):

                            npx tsc buch.ts
                            

                            --> Es entsteht die Datei buch.js

                            ioBroker-Script (TypeScript!)

                            const { Buch } = require('/opt/iobroker/my_scripts/buch.js');
                            const myBook = new Buch();
                            log("Heute ist: " + myBook.getCurrentWeekdayAsString());
                            

                            Logausgabe:

                            21:03:04.274	info	javascript.1 (65633) script.js.common.TEST_IMPORT_TS: Heute ist: Samstag
                            

                            Bin jetzt super glücklich! DANKE EUCH BEIDEN für das tolle und konstruktive Miteinander!

                            @ticaki
                            In dem Fall kann man diese auch gleich in JS schreiben und in die TS Scripte importieren.
                            Erst jetzt kapiert. Ja in der Tat! Wobei in meinem Fall ich schon alle Scripte in TS habe.

                            U 1 Antwort Letzte Antwort
                            1
                            • U uwe72

                              @fastfoot @ticaki

                              TS-Lösung funktioniert!

                              Wie von @ticaki vorgeschlagen funktioniert. D.h. TS-Script liegt extern und muss transpilierst werden.

                              /home/uwe72/clement/docker/my-datas/iobroker/iobrokerdata/my_scripts/buch.ts

                              class Buch  {
                              
                                  public getCurrentWeekdayAsString() : string {
                                      var now = new Date();
                                      let weekday = now.getDay();
                                      return this.getWeekdayAsString(weekday);
                                  }
                              
                                  private getWeekdayAsString(weekday: number) : string {
                                      let weekdayAsString;
                                      if (weekday == 1) {
                                          weekdayAsString = "Montag";
                                      } else if (weekday == 2) {
                                          weekdayAsString = "Dienstag";
                                      } else if (weekday == 3) {
                                          weekdayAsString = "Mittwoch";
                                      } else if (weekday == 4) {
                                          weekdayAsString = "Donnerstag";
                                      } else if (weekday == 5) {
                                          weekdayAsString = "Freitag";
                                      } else if (weekday == 6) {
                                          weekdayAsString = "Samstag";
                                      } else if (weekday == 7) {
                                          weekdayAsString = "Sonntag";
                                      } else if (weekday == 0) {
                                          weekdayAsString = "Sonntag";
                                      }
                                      return weekdayAsString;
                                  }  
                              }
                              
                              module.exports = { Buch};
                              

                              Dann in der Konsole folgendes eingeben (habe ich noch nicht im Detail verstanden):

                              npx tsc buch.ts
                              

                              --> Es entsteht die Datei buch.js

                              ioBroker-Script (TypeScript!)

                              const { Buch } = require('/opt/iobroker/my_scripts/buch.js');
                              const myBook = new Buch();
                              log("Heute ist: " + myBook.getCurrentWeekdayAsString());
                              

                              Logausgabe:

                              21:03:04.274	info	javascript.1 (65633) script.js.common.TEST_IMPORT_TS: Heute ist: Samstag
                              

                              Bin jetzt super glücklich! DANKE EUCH BEIDEN für das tolle und konstruktive Miteinander!

                              @ticaki
                              In dem Fall kann man diese auch gleich in JS schreiben und in die TS Scripte importieren.
                              Erst jetzt kapiert. Ja in der Tat! Wobei in meinem Fall ich schon alle Scripte in TS habe.

                              U Offline
                              U Offline
                              uwe72
                              schrieb am zuletzt editiert von uwe72
                              #31

                              @fastfoot

                              Noch eine Nachfrage für ein blödes Beispiel:

                              Möchte besipielsweise so was verwenden in meinen Scripten:

                              sendTo('telegram.0', "TEST");
                              

                              /home/uwe72/clement/docker/my-datas/iobroker/iobrokerdata/my_scripts/buch.ts

                              class Buch  {
                              
                                  public getCurrentWeekdayAsString() : string {
                                      var now = new Date();
                                      let weekday = now.getDay();
                                      sendTo('telegram.0', "TEST"); // <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
                                      return this.getWeekdayAsString(weekday);
                                  }
                              
                                  private getWeekdayAsString(weekday: number) : string {
                                      let weekdayAsString;
                                      if (weekday == 1) {
                                          weekdayAsString = "Montag";
                                      } else if (weekday == 2) {
                                          weekdayAsString = "Dienstag";
                                      } else if (weekday == 3) {
                                          weekdayAsString = "Mittwoch";
                                      } else if (weekday == 4) {
                                          weekdayAsString = "Donnerstag";
                                      } else if (weekday == 5) {
                                          weekdayAsString = "Freitag";
                                      } else if (weekday == 6) {
                                          weekdayAsString = "Samstag";
                                      } else if (weekday == 7) {
                                          weekdayAsString = "Sonntag";
                                      } else if (weekday == 0) {
                                          weekdayAsString = "Sonntag";
                                      }
                                      return weekdayAsString;
                                  }  
                              }
                              
                              module.exports = { Buch};
                              

                              Transpilieren:

                              npx tsc buch.ts
                              

                              Fehlermeldung:

                              root@iobroker:/opt/iobroker/my_scripts# npx tsc buch.ts
                              buch.ts:2:5 - error TS2304: Cannot find name 'sendTo'.
                              
                                    sendTo('telegram.0', "TEST");
                                    ~~~~~~
                              
                              
                              Found 1 error in buch.ts
                              

                              Vermutlich fehlt hier ein "Import-Statement" von den ganzen "Allgemeinen-Sachen"?

                              T 1 Antwort Letzte Antwort
                              0
                              • U uwe72

                                @fastfoot

                                Noch eine Nachfrage für ein blödes Beispiel:

                                Möchte besipielsweise so was verwenden in meinen Scripten:

                                sendTo('telegram.0', "TEST");
                                

                                /home/uwe72/clement/docker/my-datas/iobroker/iobrokerdata/my_scripts/buch.ts

                                class Buch  {
                                
                                    public getCurrentWeekdayAsString() : string {
                                        var now = new Date();
                                        let weekday = now.getDay();
                                        sendTo('telegram.0', "TEST"); // <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
                                        return this.getWeekdayAsString(weekday);
                                    }
                                
                                    private getWeekdayAsString(weekday: number) : string {
                                        let weekdayAsString;
                                        if (weekday == 1) {
                                            weekdayAsString = "Montag";
                                        } else if (weekday == 2) {
                                            weekdayAsString = "Dienstag";
                                        } else if (weekday == 3) {
                                            weekdayAsString = "Mittwoch";
                                        } else if (weekday == 4) {
                                            weekdayAsString = "Donnerstag";
                                        } else if (weekday == 5) {
                                            weekdayAsString = "Freitag";
                                        } else if (weekday == 6) {
                                            weekdayAsString = "Samstag";
                                        } else if (weekday == 7) {
                                            weekdayAsString = "Sonntag";
                                        } else if (weekday == 0) {
                                            weekdayAsString = "Sonntag";
                                        }
                                        return weekdayAsString;
                                    }  
                                }
                                
                                module.exports = { Buch};
                                

                                Transpilieren:

                                npx tsc buch.ts
                                

                                Fehlermeldung:

                                root@iobroker:/opt/iobroker/my_scripts# npx tsc buch.ts
                                buch.ts:2:5 - error TS2304: Cannot find name 'sendTo'.
                                
                                      sendTo('telegram.0', "TEST");
                                      ~~~~~~
                                
                                
                                Found 1 error in buch.ts
                                

                                Vermutlich fehlt hier ein "Import-Statement" von den ganzen "Allgemeinen-Sachen"?

                                T Offline
                                T Offline
                                ticaki
                                schrieb am zuletzt editiert von ticaki
                                #32

                                @uwe72

                                https://github.com/ioBroker/ioBroker.javascript/blob/master/lib/javascript.d.ts

                                tsconfig.json

                                {
                                  "compileOnSave": true,
                                  "compilerOptions": {
                                    "noEmit": true,
                                    "allowJs": true,
                                    "checkJs": true,
                                    "module": "commonjs",
                                    "moduleResolution": "node",
                                    "esModuleInterop": true,
                                    "resolveJsonModule": true,
                                    "strict": true,
                                    "noImplicitAny": false,
                                    "target": "es2018",
                                    "typeRoots": [
                                      ".iobroker/types",
                                      "node_modules/@types"
                                    ]
                                  },
                                  "include": [
                                    "**/*.js",
                                    "**/*.ts",
                                    ".iobroker/types/javascript.d.ts"
                                  ],
                                  "exclude": [
                                    "node_modules/**"
                                  ]
                                }
                                

                                Wenn du VS Code benutzt kannst du dir mit der iobrokererweiterungen, das auch angucken wie das da gelöst ist, weiß aber natürlich nicht ob das compilieren geht. Wird in vs dann aber nicht als Fehler angezeigt.

                                Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                Spenden

                                U 1 Antwort Letzte Antwort
                                1
                                • T ticaki

                                  @uwe72

                                  https://github.com/ioBroker/ioBroker.javascript/blob/master/lib/javascript.d.ts

                                  tsconfig.json

                                  {
                                    "compileOnSave": true,
                                    "compilerOptions": {
                                      "noEmit": true,
                                      "allowJs": true,
                                      "checkJs": true,
                                      "module": "commonjs",
                                      "moduleResolution": "node",
                                      "esModuleInterop": true,
                                      "resolveJsonModule": true,
                                      "strict": true,
                                      "noImplicitAny": false,
                                      "target": "es2018",
                                      "typeRoots": [
                                        ".iobroker/types",
                                        "node_modules/@types"
                                      ]
                                    },
                                    "include": [
                                      "**/*.js",
                                      "**/*.ts",
                                      ".iobroker/types/javascript.d.ts"
                                    ],
                                    "exclude": [
                                      "node_modules/**"
                                    ]
                                  }
                                  

                                  Wenn du VS Code benutzt kannst du dir mit der iobrokererweiterungen, das auch angucken wie das da gelöst ist, weiß aber natürlich nicht ob das compilieren geht. Wird in vs dann aber nicht als Fehler angezeigt.

                                  U Offline
                                  U Offline
                                  uwe72
                                  schrieb am zuletzt editiert von uwe72
                                  #33

                                  @ticaki Nun bin ich zu müde. Komme da nicht weiter, habe keine Ahnung und leider fehlen mir hier (Grund-) kenntnisse.

                                  {
                                    "compileOnSave": true,
                                    "compilerOptions": {
                                      "noEmit": true,
                                      "allowJs": true,
                                      "checkJs": true,
                                      "module": "commonjs",
                                      "moduleResolution": "node",
                                      "esModuleInterop": true,
                                      "resolveJsonModule": true,
                                      "strict": true,
                                      "noImplicitAny": false,
                                      "target": "es2018",
                                      "typeRoots": [
                                        ".iobroker/types",
                                        "node_modules/@types"
                                      ]
                                    },
                                    "include": [
                                      "buch.ts",
                                      "/opt/iobroker/node_modules/iobroker.javascript/lib/javascript.d.ts"
                                    ],
                                    "exclude": [
                                    ]
                                  }
                                  

                                  Habe ein tsconfig.json File und transpiliere dies

                                  npx tsc --build tsconfig.json
                                  

                                  --> Nur Fehlermeldungen. Habe keine Ahnung wie ich "javascript.d.ts" einbinde

                                  b606e419-3efa-4001-a6cd-66ddb90c04d6-image.png

                                  T 1 Antwort Letzte Antwort
                                  0
                                  • U uwe72

                                    @ticaki Nun bin ich zu müde. Komme da nicht weiter, habe keine Ahnung und leider fehlen mir hier (Grund-) kenntnisse.

                                    {
                                      "compileOnSave": true,
                                      "compilerOptions": {
                                        "noEmit": true,
                                        "allowJs": true,
                                        "checkJs": true,
                                        "module": "commonjs",
                                        "moduleResolution": "node",
                                        "esModuleInterop": true,
                                        "resolveJsonModule": true,
                                        "strict": true,
                                        "noImplicitAny": false,
                                        "target": "es2018",
                                        "typeRoots": [
                                          ".iobroker/types",
                                          "node_modules/@types"
                                        ]
                                      },
                                      "include": [
                                        "buch.ts",
                                        "/opt/iobroker/node_modules/iobroker.javascript/lib/javascript.d.ts"
                                      ],
                                      "exclude": [
                                      ]
                                    }
                                    

                                    Habe ein tsconfig.json File und transpiliere dies

                                    npx tsc --build tsconfig.json
                                    

                                    --> Nur Fehlermeldungen. Habe keine Ahnung wie ich "javascript.d.ts" einbinde

                                    b606e419-3efa-4001-a6cd-66ddb90c04d6-image.png

                                    T Offline
                                    T Offline
                                    ticaki
                                    schrieb am zuletzt editiert von
                                    #34

                                    @uwe72
                                    Morgen kann ich das mal ausprobieren, aber ich bin schon vor 2h müde gewesen. :)

                                    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                    Spenden

                                    U 2 Antworten Letzte Antwort
                                    0
                                    • T ticaki

                                      @uwe72
                                      Morgen kann ich das mal ausprobieren, aber ich bin schon vor 2h müde gewesen. :)

                                      U Offline
                                      U Offline
                                      uwe72
                                      schrieb am zuletzt editiert von
                                      #35

                                      @ticaki Danke dir!! :-)

                                      1 Antwort Letzte Antwort
                                      0
                                      • T ticaki

                                        @uwe72
                                        Morgen kann ich das mal ausprobieren, aber ich bin schon vor 2h müde gewesen. :)

                                        U Offline
                                        U Offline
                                        uwe72
                                        schrieb am zuletzt editiert von
                                        #36

                                        @ticaki @fastfoot

                                        Anbei nochmals das nicht funktionierende Beispiel und den aktuellen Stand in übersichtlicher Form:

                                        Hier mein externes TS-File.

                                        class Buch  {
                                        
                                            public getCurrentWeekdayAsString() : string {
                                                var now = new Date();
                                                let weekday = now.getDay();
                                        
                                                            sendTo("email.0", {
                                                                from:    "uwe.clement@gmail.com",                                                                
                                                                to:      "uwe.clement@gmail.com",
                                                                subject: "Test1",
                                                                html: "test2"
                                                            });	
                                        
                                        
                                                return this.getWeekdayAsString(weekday);
                                            }
                                        
                                            public getWeekdayAsString(weekday: number) : string {
                                                let weekdayAsString;
                                                if (weekday == 1) {
                                                    weekdayAsString = "Montag";
                                                } else if (weekday == 2) {
                                                    weekdayAsString = "Dienstag";
                                                } else if (weekday == 3) {
                                                    weekdayAsString = "Mittwoch";
                                                } else if (weekday == 4) {
                                                    weekdayAsString = "Donnerstag";
                                                } else if (weekday == 5) {
                                                    weekdayAsString = "Freitag";
                                                } else if (weekday == 6) {
                                                    weekdayAsString = "Samstag";
                                                } else if (weekday == 7) {
                                                    weekdayAsString = "Sonntag";
                                                } else if (weekday == 0) {
                                                    weekdayAsString = "Sonntag";
                                                }
                                                return weekdayAsString;
                                            }  
                                        
                                        }
                                        
                                        module.exports = { Buch};
                                        

                                        Ohne das "sendTo" funktionierte es. Mit eben nicht.

                                        Habe im gleichen Verzeichnis diese Datei tsconfig.json:

                                        {
                                          "compileOnSave": true,
                                          "compilerOptions": {
                                            "noEmit": true,
                                            "allowJs": true,
                                            "checkJs": true,
                                            "module": "commonjs",
                                            "moduleResolution": "node",
                                            "esModuleInterop": true,
                                            "resolveJsonModule": true,
                                            "strict": true,
                                            "noImplicitAny": false,
                                            "target": "es2018",
                                            "typeRoots": [
                                              ".iobroker/types",
                                              "node_modules/@types"
                                            ]
                                          },
                                          "include": [
                                            "**/*.js",
                                            "**/*.ts",
                                            ".iobroker/types/javascript.d.ts"
                                          ],
                                          "exclude": [
                                            "node_modules/**"
                                          ]
                                        }
                                        

                                        Auf der Konsole gebe ich folgendes ein:

                                        npx tsc --build tsconfig.json
                                        

                                        Führt zu diesen Fehlern:

                                        buch.ts:7:21 - error TS2304: Cannot find name 'sendTo'.
                                        
                                        7                     sendTo("email.0", {
                                                              ~~~~~~
                                        
                                        buch.ts:42:1 - error TS2580: Cannot find name 'module'. Do you need to install type definitions for node? Try `npm i --save-dev @types/node`.
                                        
                                        42 module.exports = { Buch};
                                           ~~~~~~
                                        
                                        
                                        Found 2 errors.
                                        

                                        Beide Dateien liegen im gleichen Verzeichnis, in dem ich auch den Befehl "npx tsc --build tsconfig.json" eingebe:
                                        4ccda497-e58f-4019-8f71-ac27a25da5e7-image.png

                                        T 2 Antworten Letzte Antwort
                                        0
                                        • U uwe72

                                          @ticaki @fastfoot

                                          Anbei nochmals das nicht funktionierende Beispiel und den aktuellen Stand in übersichtlicher Form:

                                          Hier mein externes TS-File.

                                          class Buch  {
                                          
                                              public getCurrentWeekdayAsString() : string {
                                                  var now = new Date();
                                                  let weekday = now.getDay();
                                          
                                                              sendTo("email.0", {
                                                                  from:    "uwe.clement@gmail.com",                                                                
                                                                  to:      "uwe.clement@gmail.com",
                                                                  subject: "Test1",
                                                                  html: "test2"
                                                              });	
                                          
                                          
                                                  return this.getWeekdayAsString(weekday);
                                              }
                                          
                                              public getWeekdayAsString(weekday: number) : string {
                                                  let weekdayAsString;
                                                  if (weekday == 1) {
                                                      weekdayAsString = "Montag";
                                                  } else if (weekday == 2) {
                                                      weekdayAsString = "Dienstag";
                                                  } else if (weekday == 3) {
                                                      weekdayAsString = "Mittwoch";
                                                  } else if (weekday == 4) {
                                                      weekdayAsString = "Donnerstag";
                                                  } else if (weekday == 5) {
                                                      weekdayAsString = "Freitag";
                                                  } else if (weekday == 6) {
                                                      weekdayAsString = "Samstag";
                                                  } else if (weekday == 7) {
                                                      weekdayAsString = "Sonntag";
                                                  } else if (weekday == 0) {
                                                      weekdayAsString = "Sonntag";
                                                  }
                                                  return weekdayAsString;
                                              }  
                                          
                                          }
                                          
                                          module.exports = { Buch};
                                          

                                          Ohne das "sendTo" funktionierte es. Mit eben nicht.

                                          Habe im gleichen Verzeichnis diese Datei tsconfig.json:

                                          {
                                            "compileOnSave": true,
                                            "compilerOptions": {
                                              "noEmit": true,
                                              "allowJs": true,
                                              "checkJs": true,
                                              "module": "commonjs",
                                              "moduleResolution": "node",
                                              "esModuleInterop": true,
                                              "resolveJsonModule": true,
                                              "strict": true,
                                              "noImplicitAny": false,
                                              "target": "es2018",
                                              "typeRoots": [
                                                ".iobroker/types",
                                                "node_modules/@types"
                                              ]
                                            },
                                            "include": [
                                              "**/*.js",
                                              "**/*.ts",
                                              ".iobroker/types/javascript.d.ts"
                                            ],
                                            "exclude": [
                                              "node_modules/**"
                                            ]
                                          }
                                          

                                          Auf der Konsole gebe ich folgendes ein:

                                          npx tsc --build tsconfig.json
                                          

                                          Führt zu diesen Fehlern:

                                          buch.ts:7:21 - error TS2304: Cannot find name 'sendTo'.
                                          
                                          7                     sendTo("email.0", {
                                                                ~~~~~~
                                          
                                          buch.ts:42:1 - error TS2580: Cannot find name 'module'. Do you need to install type definitions for node? Try `npm i --save-dev @types/node`.
                                          
                                          42 module.exports = { Buch};
                                             ~~~~~~
                                          
                                          
                                          Found 2 errors.
                                          

                                          Beide Dateien liegen im gleichen Verzeichnis, in dem ich auch den Befehl "npx tsc --build tsconfig.json" eingebe:
                                          4ccda497-e58f-4019-8f71-ac27a25da5e7-image.png

                                          T Offline
                                          T Offline
                                          ticaki
                                          schrieb am zuletzt editiert von ticaki
                                          #37

                                          @uwe72

                                          "include": [
                                              "**/*.js",
                                              "**/*.ts",
                                              ".iobroker/types/javascript.d.ts"
                                            ],
                                          

                                          da muß die javascript.d.ts datei sein. Kannst das natürlich anpassen.

                                          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                          Spenden

                                          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

                                          639

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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