Benachrichtigungen
Alles löschen

[Gelöst] Rückgabe aus einer Aktion für das Dashboard aufbereiten...

16 Beiträge
2 Benutzer
2 Reactions
87 Ansichten
0
Themenstarter

Hallo,

 

mit der neuen Version 2025.05 hat sich die Intergration "17Track" (Dokumentation) geändert.

Leider wurde die Doku nicht angepasst (siehe auch).

Ich habe zuvor meine Pakete wie unter "Examples/Dashboard summary card" beschrieben, in meinem Dashboard angezeigt.

Jetzt gibt es nur noch die Aktion "seventeentrack.get_packages"

Diese gibt folgendes Zurück:

packages:
  - destination_country: Germany
    origin_country: Poland
    package_type: Registered Parcel
    tracking_info_language: Unknown
    tracking_number: 1ZXXXXXXXXXXXXX
    location: Ort, DE
    status: In Transit
    info_text: Arrived at Facility
    friendly_name: Lieferung
    timestamp: "2025-05-10T04:36:00+00:00"

oder als Template:

{% set action_response = {"packages":[{"destination_country":"Germany","origin_country":"Poland","package_type":"Registered Parcel","tracking_info_language":"Unknown","tracking_number":"1ZXXXXXXXXXXXXX","location":"Ort, DE","status":"In Transit","info_text":"Arrived at Facility","friendly_name":"Lieferung","timestamp":"2025-05-10T04:36:00+00:00"}]} %}

 

Wie kann ich diese Rückgabe so aufbereiten, so das ich diese in meinem Dashboard anzeigen kann?

Viele Grüße
Gunter

8 Antworten
1

Erstelle eine Template-Sensor, die wie folgt aussehen kann:

- trigger:
    - platform: time_pattern
      minutes: "/15"
  action:
    - action: seventeentrack.get_packages
      data:
        config_entry_id: DEINE_ID_AUS_ENTWICKLERWERKZEUGEN
      response_variable: tmp_packages
  sensor:
    - name: Paketlieferungen
      unique_id: my_packages
      state: "{{ now().isoformat() }}"
      icon: mdi:calendar-range
      attributes:
        packages: "{{ tmp_packages.packages }}"

 

Die config_entry_id kannst du in den Entwicklerwerkzeugen auslesen, wenn du die Aktion ausführst und in den YAML-Modus wechselst. Der Template-Sensor wird alle 15 Minuten die Aktion ausführen und deine Daten aktualisieren.

Als Ergebnis bekommst du einen neuen Sensor sensor.paketlieferungen, der alle gem. Aktion definierten Pakete (in meinem Beispiel keine Einschränkungen) enthält:

image

Über die Aktion kannst du bei Bedarf noch definieren, welche Stati in dem Sensor enthalten sein sollen.

Über die Attribute kann man dann iterieren, bspw. auch in einer Markdown-Card. Hierfür könnte der Code wie folgt aussehen:

{% for package in states.sensor.paketlieferungen.attributes.packages %}
{{ package.friendly_name }} ({{ package.tracking_number }}): {{ package.info_text }}
{% endfor %}

Und das Ergebnis ist dann:

{1FF8F7A5 588B 48AB 96D0 CEA20AB2C03F}
1
Themenstarter

Hallo Olli,

Danke für deine Hilfe ich habe nun wieder die "alte" Funktionaltität.

Falls das jemand auch nachbauen muss bzw. will, stelle ich hier meine Arbeit Online:

So sieht das Dasboard dafür aus:

Screenshot 2025 05 11 143124

Dazu habe ich vier Template-Sensoren erstellt die alle fünf Minuten den Zustand abfragen:

  - trigger:
      - platform: time_pattern
        minutes: "/5"
    action:
      - action: seventeentrack.get_packages
        data:
          config_entry_id: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
          package_state:
            - in_transit
        response_variable: pakete_unterwegs
    sensor:
      - name: SevTrackPaketeUnterwegs
        unique_id: seventeentrack_packages_in_transit
        state: "{{ now().isoformat() }}"
        icon: mdi:truck-delivery-outline
        attributes:
          packages: "{{ pakete_unterwegs.packages }}"
          
  - trigger:
      - platform: time_pattern
        minutes: "/5"
    action:
      - action: seventeentrack.get_packages
        data:
          config_entry_id: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
          package_state:
            - not_found
        response_variable: pakete_not_found
    sensor:
      - name: SevTrackPaketeNichtgefunden
        unique_id: seventeentrack_packages_not_found
        state: "{{ now().isoformat() }}"
        icon: mdi:package-variant-closed
        attributes:
          packages: "{{ pakete_not_found.packages }}"

  - trigger:
      - platform: time_pattern
        minutes: "/5"
    action:
      - action: seventeentrack.get_packages
        data:
          config_entry_id: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
          package_state:
            - delivered
        response_variable: pakete_geliefert
    sensor:
      - name: SevTrackPaketeGeliefert
        unique_id: seventeentrack_packages_delivered
        state: "{{ now().isoformat() }}"
        icon: mdi:checkbox-marked-circle-outline
        attributes:
          packages: "{{ pakete_geliefert.packages }}"

  - trigger:
      - platform: time_pattern
        minutes: "/5"
    action:
      - action: seventeentrack.get_packages
        data:
          config_entry_id: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
          package_state:
            - ready_to_be_picked_up
        response_variable: pakete_pickup
    sensor:
      - name: SevTrackPaketeBereitzurAbholung
        unique_id: seventeentrack_packages_pickup
        state: "{{ now().isoformat() }}"
        icon: mdi:package-variant-closed
        attributes:
          packages: "{{ pakete_pickup.packages }}"
		  

 

Für das Dashboard habe ich Markups erstellt mit der Prüfung ob Pakete vorhanden sind (>0):

 

type: conditional
conditions:
  - entity: sensor.seventeentrack_packages_in_transit
    state_not: "0"
card:
  type: markdown
  content: >-
    <h1><font color="#f0c216"><ha-icon
    icon="mdi:truck-delivery-outline"></ha-icon> Pakete auf dem Weg

    </font></h1>

    {% for package in
       states.sensor.sevtrackpaketeunterwegs.attributes.packages %}
    ***
      >- **{{ package.friendly_name }} ({{ package.tracking_number }}):** 
        {{ package.info_text }}
        **Stand:** {{ (package.timestamp | as_datetime).strftime('%d.%m.%Y - %H:%M Uhr') }} 
        **Wo ist das Paket derzeit:**
        {{ package.location }}

      {% endfor %}
    ***

type: conditional
conditions:
  - entity: sensor.seventeentrack_packages_ready_to_be_picked_up
    state_not: "0"
card:
  type: markdown
  content: >-
    <h1><font color="#3358ff"><ha-icon
    icon="mdi:package-variant-closed"></ha-icon> Pakete in Zustellung

    </font></h1>



    {% for package in
      states.sensor.sevtrackpaketebereitzurabholung.attributes.packages %}
    ***
      >- **{{ package.friendly_name }} ({{ package.tracking_number }}):** 
        {{ package.info_text }}


      {% endfor %}
    ***


type: conditional
conditions:
  - entity: sensor.seventeentrack_packages_not_found
    state_not: "0"
card:
  type: markdown
  content: >-
    <h1><font color="#800080"><ha-icon
    icon="mdi:package-variant-closed"></ha-icon> Pakete unbekannt

    </font></h1>


    {% for package in
      states.sensor.sevtrackpaketenichtgefunden.attributes.packages %}
      >- **{{ package.friendly_name }}**
         ({{ package.tracking_number }})
    {% endfor %} ***

type: conditional
conditions:
  - entity: sensor.seventeentrack_packages_delivered
    state_not: "0"
card:
  type: markdown
  content: >-
    <h1>

    <h1><font color="#30a414"><ha-icon
    icon="mdi:checkbox-marked-circle-outline"></ha-icon> Pakete geliefert


    </font></h1>

    {% for package in
      states.sensor.sevtrackpaketegeliefert.attributes.packages %}
    ***
      >- **{{ package.friendly_name }} ({{ package.tracking_number }}):** 
           {{ package.info_text }}

      {% endfor %}
    ***

Viele Grüße
Gunter

 

 

0
Themenstarter

... mit zwei Pakten erhalte ich folgende Ausgaben:

packages:
  - destination_country: Unknown
    origin_country: Germany
    package_type: Registered Parcel
    tracking_info_language: Unknown
    tracking_number: "0034043XXXXXX"
    location: ""
    status: Not Found
    info_text: null
    friendly_name: Lieferung 2
  - destination_country: Germany
    origin_country: Poland
    package_type: Registered Parcel
    tracking_info_language: Unknown
    tracking_number: 1ZXXXXXXXXXXXXX
    location: Ort, DE
    status: In Transit
    info_text: Arrived at Facility
    friendly_name: Lieferung
    timestamp: "2025-05-10T04:36:00+00:00"

oder als Template:

{% set action_response = {"packages":[{"destination_country":"Unknown","origin_country":"Germany","package_type":"Registered Parcel","tracking_info_language":"Unknown","tracking_number":"0034043XXXXXX","location":"","status":"Not Found","info_text":null,"friendly_name":"Lieferung 1"},{"destination_country":"Germany","origin_country":"Poland","package_type":"Registered Parcel","tracking_info_language":"Unknown","tracking_number":"1ZXXXXXXXXXXXXX","location":"Ort, DE","status":"In Transit","info_text":"Arrived at Facility","friendly_name":"Lieferung 1","timestamp":"2025-05-10T04:36:00+00:00"}]} %}
0

Ich selbst nutze die Integration nicht, aber die Response müsste man zwischenspeichern und dann parsen.

In der 2025.5 Release-Note steht dazu ja folgendes:

image

https://www.home-assistant.io/blog/2025/05/07/release-20255/#backward-incompatible-changes

Das liest sich für mich so, als würde es dedizierte Sensoren nun geben?

0
Themenstarter

Hallo Olli,

leider Nein!
Keine neue Sensoren, nur die Ausgabe über seventeentrack.get_packages

Viele Grüße

Gunter

 

0

Über einen Template-Sensor und die Aktion seventeentrack.get_packages müsste man sich die Response doch aufbereiten können, ähnlich wie bei den Wetterdaten. Dort macht man ja bspw. folgendes:

template:
  - trigger:
      - platform: time_pattern
        hours: "/1"
    action:
      - action: weather.get_forecasts
        target:
          entity_id:
            - weather.forecast_home
        data:
          type: daily
        response_variable: vorhersage
    sensor:
      - name: Wettervorhersage
        unique_id: weather_entity_forecast
        state: "{{ now().isoformat() }}"
        icon: mdi:calendar-range
        attributes:
          forecast: "{{ vorhersage['weather.forecast_home'].forecast }}"

 

Also bspw. alle 15 Minuten das Ding triggern, als action halt seventeentrack.get_packages und die Response in einen neuen Sensor packen und dort die eigentliche Response als Attribute speichern. Weißt du, wie es meine?

Gunni Themenstarter 10/05/2025 9:29 pm

Hallo Olli,

leider nein.

Ich benötige aus den Daten:

tracking_number: 1ZXXXXXXXXXXXXX
location: Ort, DE
status: In Transit
info_text: Arrived at Facility
friendly_name: Lieferung

Diese Daten habe ich zuvor in einem Markup angezeigt.

Viele Grüße
Gunter

Olli 10/05/2025 10:35 pm

Also es gibt doch je Paketzustand einen eigenen Sensor:

Screenshot 20250510 223129

Und sofern ein Sensor >0 ist steht in dem Attribut die Paket-Liste. In einer Markdown-Karte kann man nun prüfen, ob der jeweilige Zustandssensor > 0 ist und wenn ja durch das Attribut iterieren.

Gunni Themenstarter 10/05/2025 10:41 pm

Hallo Olli,

ja, es gibt diese Sensoren, aber nur die Anzahl der Pakete.

 

Screenshot 2025 05 10 223820

Weiteren Datem sind nicht ersichtlich. keine Attribute.

Viele Grüße
Gunter

Olli 10/05/2025 10:58 pm

Doch klar, schau dir die Attribute mal in den Entwicklerwerkzeugen an. Wenn > 0, dann ist das Attribut gefüllt:

Screenshot 20250510 225643
Gunni Themenstarter 10/05/2025 11:02 pm

Hallo Olli,

bei mir nicht.

Screenshot 2025 05 10 223820

Viele Grüße
Gunter

Gunni Themenstarter 10/05/2025 11:03 pm

Core Version: 2025.5.1

Olli 11/05/2025 11:50 am

Ja, mein Fehler... Das war eine Testumgebung mit 2025.4.x - Sorry!

0
Themenstarter

Hallo Olli,

kannst du mir erklären wie ich den Template-Sensor aufbauen muss, z.B. für die Einträge "tracking_number" die von der Rückgabe zurückgegeben werden?

Danke und viele Grüße
Gunter

Olli 11/05/2025 2:41 pm

@gunni Bei meiner Lösung habe ich ergänzt, wie man auf die Attribut-Daten zugreift.

0
Themenstarter

Hallo Olli,

ich habe jetzt mal einen Template Sendor zum Test aufgebaut, ich denke ich komme so mal einen Schritt weiter. Danke.

  - trigger:
      - platform: time_pattern
        minutes: "/1"
    action:
      - action: seventeentrack.get_packages
        data:
          config_entry_id: XXXXXXX
        response_variable: pakete
    sensor:
      - name: 17TrackPakete
        unique_id: seventeentrack_packages
        state: "{{ now().isoformat() }}"
        icon: mdi:package-variant-closed
        attributes:
          rueckgabe: "{{ pakete.packages }}"

 

Viele Grüße
Gunter