diff --git a/.vscode/settings.json b/.vscode/settings.json
index edb439a..2991c25 100644
--- a/.vscode/settings.json
+++ b/.vscode/settings.json
@@ -4,6 +4,8 @@
"Venu"
],
"files.exclude": {
- "resources-*": true
+ "resources-*": true,
+ "bin": true,
+ "export": true
}
-}
\ No newline at end of file
+}
diff --git a/BackgroundService.md b/BackgroundService.md
index 14e9081..5311867 100644
--- a/BackgroundService.md
+++ b/BackgroundService.md
@@ -1,4 +1,4 @@
-[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
+[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [HTTP Headers](HTTP_Headers.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
# Background Service
diff --git a/HISTORY.md b/HISTORY.md
index 56d341a..106786b 100644
--- a/HISTORY.md
+++ b/HISTORY.md
@@ -1,4 +1,4 @@
-[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
+[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [HTTP Headers](HTTP_Headers.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
# Version History
@@ -46,3 +46,4 @@
| 2.31 | Adding [two new options](./examples/Actions.md#exit-on-tap) to the menu items: 1) The ability to disable a menu item, e.g. temporarily for seasonal changes, 2) The option to exit after a menu item has been select. |
| 2.32 | Bug fix for a breaking change extracting options caused by the need to rearrange function parameters for an [annoying compiler error](https://github.com/house-of-abbey/GarminHomeAssistant/issues/253). |
| 3.0 | First version with the ability to use [Wi-Fi or LTE](Wi-Fi.md) instead of Bluetooth but with limited functionality, thanks to [@vincentezw](https://github.com/vincentezw). |
+| 3.1 | Added the ability for users to provide custom HTTP headers for their Home Assistant server. Improved German language translations. Removed all groups in settings as the SDK is buggy. |
diff --git a/HTTP_Headers.md b/HTTP_Headers.md
new file mode 100644
index 0000000..2e7543e
--- /dev/null
+++ b/HTTP_Headers.md
@@ -0,0 +1,37 @@
+[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [HTTP Headers](HTTP_Headers.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
+
+# User Specified Custom HTTP Headers
+
+Principally for those who use Home Assistant add-on [Cloudflared](https://github.com/brenner-tobias/addon-cloudflared) in order to provide additional security via Cloudflare's Web Application Firewall (WAF). But Garmin does not support certificates in requests. And the solution is generic enough for other use cases.
+
+Please let us know if this solution is found to be useful for other situations.
+
+## Setup
+
+The settings contain two options for users to specify both the HTTP header name and the value as two free form strings.
+
+
+
+If you don't know why you need these, leave them empty and ignore.
+
+### Cloudflare WAF rule example
+
+`(any(http.request.headers["your-header-name"][*] eq "your-header-key"))`
+
+Make the key strong enough!
+
+## Support
+
+**None!**
+
+The authors of the Garmin Home Assistant application do not use, and hence do not know, the [Cloudflared](https://github.com/brenner-tobias/addon-cloudflared) add-on. While we have enabled the HTTP headers to support using this add-on, it does mean _you support yourself_. Please do not raise issues about this functionality unless you are supplying the answers for any required changes too!
+
+## Credits
+
+With thanks to Lars Pöpperl ([@tispokes](https://github.com/tispokes)) for contributing to this solution.
+
+
+## References
+
+* [Using Cloudflare ZeroTrust and mTLS to securely access Home Assistant via the internet](https://kcore.org/2024/06/28/using-cloudflare-zerotrust-and-mtls-with-home-assistant-via-the-internet/)
+* [Home Assistant Add-on: Cloudflared](https://github.com/brenner-tobias/addon-cloudflared)
\ No newline at end of file
diff --git a/README.md b/README.md
index 587501c..a694284 100644
--- a/README.md
+++ b/README.md
@@ -1,4 +1,4 @@
-[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
+[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [HTTP Headers](HTTP_Headers.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
# GarminHomeAssistant
@@ -17,6 +17,8 @@ The application is designed around a simple scrollable menu where menu items hav
> [!IMPORTANT]
> The Garmin SDK allows HTTP requests only to a limited number of domains specified in their app. Therefore, for your Garmin to communicate with your Home Assistant instance, your Home Assistant instance must be accessible via HTTPS (with a public certificate!) or through a local DNS server that overrides one of the whitelisted domains to communicate using HTTP.
>
+>New with version 3.1, you can use [Cloudflared](https://github.com/brenner-tobias/addon-cloudflared) plug-in in combination with a [custom HTTP header](HTTP_Headers.md) and do not need a public certificate for HTTPS.
+>
> To make your Home Assistant instance accessible via HTTPS, you will need a public certificate. You can get one for free from [Let's Encrypt](https://letsencrypt.org/) or you can pay for [Home Assistant cloud](https://www.nabucasa.com/). (You can install a local [Nginx proxy server](https://my.home-assistant.io/redirect/supervisor_addon/?addon=a0d7b954_nginxproxymanager) to manage Let's Encrypt certificates.)
>
> If you use a local DNS server (like [Pi-Hole](https://pi-hole.net/)), you can create a local DNS record for the domain `garmincdn.com` (which is allowed for HTTP in the Garmin SDK) and map it to your Home Assistant instance's IP. "_[About Communication Between Garmin SDK and a Raspberry Pi](https://www.instructables.com/About-Communication-Between-Garmin-SDK-and-a-Raspb/)_" provides additional workarounds for HTTP request restrictions in the Garmin SDK.
@@ -230,7 +232,7 @@ Make sure you can browse to the URL of your JSON file in a standard web browser
## API Key Creation
-Having created your JSON definition for your dashboard, you need to create an API key for your personal account on Home Assistant. You will need a [Long-Lived Access Token](https://developers.home-assistant.io/docs/auth_api/#long-lived-access-token). This is not obvious to find and is bound to your own Home Assistant account. Follow the menu sequence: `HA -> user profile -> Long-lived access tokens`. Make sure you save the generated token before dismissing it.
+Having created your JSON definition for your dashboard, you need to create an API key for your personal account on Home Assistant. You will need a [Long-Lived Access Token](https://developers.home-assistant.io/docs/auth_api/#long-lived-access-token). This is not obvious to find and is bound to your own Home Assistant account. Follow the menu sequence: `HA -> User Profile -> "Security" tab -> Long-lived access tokens`. Make sure you save the generated token before dismissing it.

@@ -339,3 +341,7 @@ The `id` attribute values are taken from the same names used in [`strings.xml`](
8. There is a [bug in Garmin Express so that when you use that software to amend the application's settings](https://github.com/house-of-abbey/GarminHomeAssistant/issues/194), the page appears in a random language not of your choice. I would like to thank user [heviiguy](https://github.com/heviiguy) for his work researching the issue, leading to these references that indicate the authors of Garmin Home Assistant cannot resolve this issue as its a bug in Garmin Express that Garmin are refusing to believe exists! See these pages for details:
- [Garmin Express - Wrong Language](https://forums.garmin.com/developer/connect-iq/i/bug-reports/garmin-express---wrong-language)
- [Incorrect language displayed for custom data fields](https://forums.garmin.com/developer/connect-iq/f/discussion/388137/incorrect-language-displayed-for-custom-data-fields)
+
+# Authors & Contributors
+
+For an up to date list of all authors and contributors, please check the [contributor's page](https://github.com/house-of-abbey/GarminHomeAssistant/graphs/contributors). Thank you all for improving this application.
diff --git a/TroubleShooting.md b/TroubleShooting.md
index 5fab675..f5fd011 100644
--- a/TroubleShooting.md
+++ b/TroubleShooting.md
@@ -1,4 +1,4 @@
-[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
+[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [HTTP Headers](HTTP_Headers.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
# Troubleshooting Guides
diff --git a/Wi-Fi.md b/Wi-Fi.md
index c572360..ef49760 100644
--- a/Wi-Fi.md
+++ b/Wi-Fi.md
@@ -1,4 +1,4 @@
-[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
+[Home](README.md) | [Switches](examples/Switches.md) | [Actions](examples/Actions.md) | [Templates](examples/Templates.md) | [Glance](examples/Glance.md) | [Background Service](BackgroundService.md) | [Wi-Fi](Wi-Fi.md) | [HTTP Headers](HTTP_Headers.md) | [Trouble Shooting](TroubleShooting.md) | [Version History](HISTORY.md)
# Wi-Fi & LTE
@@ -17,14 +17,17 @@ With version 3.0 onwards the application now includes the ability to temporarily
4. Remember that you need to be within range of your watch's configured Wi-Fi access point to utilize this functionality. If supported by your device, LTE offers a longer range, but network charges may apply.
5. On some Garmin devices, the HTTPS handshake is performed using **TLS 1.2**. If your server or proxy enforces a higher minimum (e.g., TLS 1.3), you will encounter an SSL handshake error with the message:
+
```
HTTP request returned error code = 0
```
+
This limitation only affects **Wi-Fi/LTE connections**. When connected over **Bluetooth**, the watch routes requests through the paired phone, which handles the TLS handshake and supports newer TLS versions (such as 1.3) without issue.
To fix this, lower the minimum TLS setting to allow TLS 1.2. For example, if you are using **Cloudflare Tunneling**, go to:
`SSL/TLS → Edge Certificates → Minimum TLS Version`
and set it to **at most TLS 1.2**. _Reducing below TLS 1.2 is not recommended due to security risks._
+
## Video
This video using will hopefully make it obvious how slow it is to use the Wi-Fi option and illustrate the cautionary notes above.
@@ -37,4 +40,4 @@ We emphasize that the Wi-Fi/LTE functionality should be viewed as a 'last resort
## Credits
-With thanks to [@vincentezw](https://github.com/vincentezw) for contributing this solution.
+With thanks to Vincent, [@vincentezw](https://github.com/vincentezw) for contributing this solution, and to Ali Alaei, [@aalaei](https://github.com/aalaei) for the finer details on TLS.
diff --git a/examples/Actions.md b/examples/Actions.md
index aea117c..1df7942 100644
--- a/examples/Actions.md
+++ b/examples/Actions.md
@@ -1,4 +1,4 @@
-[Home](../README.md) | [Switches](Switches.md) | [Actions](Actions.md) | [Templates](Templates.md) | [Glance](Glance.md) | [Background Service](../BackgroundService.md) | [Wi-Fi](../Wi-Fi.md) | [Trouble Shooting](../TroubleShooting.md) | [Version History](../HISTORY.md)
+[Home](../README.md) | [Switches](Switches.md) | [Actions](Actions.md) | [Templates](Templates.md) | [Glance](Glance.md) | [Background Service](../BackgroundService.md) | [Wi-Fi](../Wi-Fi.md) | [HTTP Headers](../HTTP_Headers.md) | [Trouble Shooting](../TroubleShooting.md) | [Version History](../HISTORY.md)
# Actions
diff --git a/examples/Glance.md b/examples/Glance.md
index 601ee29..e48e82b 100644
--- a/examples/Glance.md
+++ b/examples/Glance.md
@@ -1,4 +1,4 @@
-[Home](../README.md) | [Switches](Switches.md) | [Actions](Actions.md) | [Templates](Templates.md) | [Glance](Glance.md) | [Background Service](../BackgroundService.md) | [Wi-Fi](../Wi-Fi.md) | [Trouble Shooting](../TroubleShooting.md) | [Version History](../HISTORY.md)
+[Home](../README.md) | [Switches](Switches.md) | [Actions](Actions.md) | [Templates](Templates.md) | [Glance](Glance.md) | [Background Service](../BackgroundService.md) | [Wi-Fi](../Wi-Fi.md) | [HTTP Headers](../HTTP_Headers.md) | [Trouble Shooting](../TroubleShooting.md) | [Version History](../HISTORY.md)
# Glance
diff --git a/examples/Switches.md b/examples/Switches.md
index 9f1253a..c5834d4 100644
--- a/examples/Switches.md
+++ b/examples/Switches.md
@@ -1,4 +1,4 @@
-[Home](../README.md) | [Switches](Switches.md) | [Actions](Actions.md) | [Templates](Templates.md) | [Glance](Glance.md) | [Background Service](../BackgroundService.md) | [Wi-Fi](../Wi-Fi.md) | [Trouble Shooting](../TroubleShooting.md) | [Version History](../HISTORY.md)
+[Home](../README.md) | [Switches](Switches.md) | [Actions](Actions.md) | [Templates](Templates.md) | [Glance](Glance.md) | [Background Service](../BackgroundService.md) | [Wi-Fi](../Wi-Fi.md) | [HTTP Headers](../HTTP_Headers.md) | [Trouble Shooting](../TroubleShooting.md) | [Version History](../HISTORY.md)
# Switches
diff --git a/examples/Templates.md b/examples/Templates.md
index 48d9e61..b488125 100644
--- a/examples/Templates.md
+++ b/examples/Templates.md
@@ -1,4 +1,4 @@
-[Home](../README.md) | [Switches](Switches.md) | [Actions](Actions.md) | [Templates](Templates.md) | [Glance](Glance.md) | [Background Service](../BackgroundService.md) | [Wi-Fi](../Wi-Fi.md) | [Trouble Shooting](../TroubleShooting.md) | [Version History](../HISTORY.md)
+[Home](../README.md) | [Switches](Switches.md) | [Actions](Actions.md) | [Templates](Templates.md) | [Glance](Glance.md) | [Background Service](../BackgroundService.md) | [Wi-Fi](../Wi-Fi.md) | [HTTP Headers](../HTTP_Headers.md) | [Trouble Shooting](../TroubleShooting.md) | [Version History](../HISTORY.md)
# Templates
diff --git a/images/GarminHomeAssistantSettings.png b/images/GarminHomeAssistantSettings.png
index 3e7d475..328a3ac 100644
Binary files a/images/GarminHomeAssistantSettings.png and b/images/GarminHomeAssistantSettings.png differ
diff --git a/images/http_header_settings.png b/images/http_header_settings.png
new file mode 100644
index 0000000..d8a7bb6
Binary files /dev/null and b/images/http_header_settings.png differ
diff --git a/resources-ara/strings/strings.xml b/resources-ara/strings/strings.xml
index ddbb72b..59eda4f 100644
--- a/resources-ara/strings/strings.xml
+++ b/resources-ara/strings/strings.xml
@@ -62,11 +62,12 @@
عنوان URL لتكوين القائمة (JSON).
هل يجب أن يقوم تطبيق ذاكرة التخزين المؤقت لتكوين القائمة؟
هل يجب على التطبيق مسح ذاكرة التخزين المؤقت الموجودة في المرة القادمة التي يتم فيها بدء تشغيلها؟
+ تمكين تنفيذ الأوامر على Wi-Fi/LTE.
هل يجب أن يقدم التطبيق ملاحظات عبر الاهتزازات؟
مهلة في ثوان. الخروج من التطبيق بعد هذه الفترة من عدم النشاط لحفظ بطارية الجهاز.
تأخير استطلاع إضافي (بالثواني). يضيف تأخيرًا بين تحديث الحالة لجميع عناصر القائمة.
بعد هذا الوقت (بالثواني) ، يتم إغلاق مربع حوار تأكيد لإجراء ما ويتم إلغاء الإجراء. ضبط على 0 لتعطيل المهلة.
- دبوس من 4 أرقام لاستخدامه في جميع الإجراءات التي تتطلب تأكيدًا (0000-9999).
+ دبوس من 4 أرقام لاستخدامه في جميع الإجراءات التي تتطلب ذلك (0000-9999).
يرجى تكوين دبوس رقمي مكون من 4 أرقام بين 0000 و 9999 في إعدادات التطبيق.
اليسار (قبالة) أو محاذاة القائمة اليمنى (ON).
من اليسار إلى اليمين
@@ -74,8 +75,9 @@
(عنصر واجهة المستخدم فقط) ابدأ التطبيق تلقائيًا من عنصر واجهة المستخدم دون انتظار النقر.
قم بتمكين خدمة الخلفية لإرسال مستوى بطارية الجهاز والموقع و (إذا كان مدعومًا) بيانات النشاط إلى مساعد المنزل.
معدل التحديث (في الدقائق) التي يجب أن تكرر خدمة الخلفية إرسال البيانات.
+
+
+
+
(اقرأ فقط) معرف WebHook الذي تم إنشاؤه بواسطة الجهاز لتحديثات خدمة الخلفية. قد تطلب هذا لتصحيح الأخطاء.
- وضع تنفيذ Wi-Fi/LTE.
- تمكين تنفيذ الأوامر على Wi-Fi/LTE.
- يسمح للتطبيق بالبدء بدون اتصال الهاتف (عند تخزين القائمة) ، والمطالبة بتنفيذ الأمر عبر Wi-Fi/LTE.
diff --git a/resources-bul/strings/strings.xml b/resources-bul/strings/strings.xml
index 5bfe003..990e3e1 100644
--- a/resources-bul/strings/strings.xml
+++ b/resources-bul/strings/strings.xml
@@ -44,7 +44,7 @@
Потенциална грешка
секунди
Грешка в шаблона
- URL адресът на API не трябва да има наклонена черта '/'.
+ URL адресът на API не трябва да има закъснение '/'.
Недостъпни
Неуверен
HTTP заявка Върната код за грешка =
@@ -56,17 +56,18 @@
Няма получени данни.
Изберете ...
- Ключ на API за домашни условия.
+ Ключ на API за домашно.
Дълготраен маркер за достъп.
URL за домашен API.
URL за конфигуриране на менюто (JSON).
Трябва ли приложението да кешира конфигурацията на менюто?
Трябва ли приложението да изчисти съществуващия кеш следващия път, когато е стартиран?
+ Активиране на изпълнение на команди над Wi-Fi/LTE.
Трябва ли приложението да предоставя обратна връзка чрез вибрации?
Време за изчакване за секунди. Излезте от приложението след този период на бездействие, за да запазите батерията на устройството.
Допълнително забавяне на анкетата (за секунди). Добавя забавяне между актуализацията на състоянието на всички елементи от менюто.
След това време (за секунди) диалоговият прозорец за потвърждение за действие автоматично се затваря и действието се отменя. Задайте 0, за да деактивирате изчакване.
- 4-цифрен ПИН, който ще се използва за всички действия, които изискват потвърждение (0000-9999).
+ 4-цифрен ПИН, който ще се използва за всички действия, които го изискват (0000-9999).
Моля, конфигурирайте валиден 4-цифрен цифров ПИН между 0000 и 9999 в настройките на приложението.
Наляво (изключено) или вдясно (включено) изравняване на менюто.
Отляво надясно
@@ -74,8 +75,9 @@
(Само при джаджа) Автоматично стартирайте приложението от джаджата, без да чакате докосване.
Активирайте фоновата услуга за изпращане на нивото на батерията на устройството, местоположението и (ако се поддържа) данни за активност на домашен асистент.
Скоростта на опресняване (за минути), при която фоновата услуга трябва да повтори изпращането на данни.
+
+
+
+
(Само прочетете) Идентификационният номер на WebHook, създаден от устройството за актуализации на фоновите услуги. Може да се наложи това за отстраняване на грешки.
- Режим на изпълнение на Wi-Fi/LTE.
- Активиране на изпълнение на команди над Wi-Fi/LTE.
- Позволява на приложението да стартира без телефонна връзка (когато менюто е кеширано) и подкана за изпълнение на команда през Wi-Fi/LTE.
diff --git a/resources-ces/strings/strings.xml b/resources-ces/strings/strings.xml
index c72fcfd..9df656d 100644
--- a/resources-ces/strings/strings.xml
+++ b/resources-ces/strings/strings.xml
@@ -32,12 +32,12 @@
Paměť
Žádný klíč API v nastavení aplikace.
- V nastavení aplikace není žádná URL API.
+ Žádná URL API v nastavení aplikace.
V nastavení aplikace není žádná konfigurační adresa URL.
Žádné připojení k internetu.
Žádný JSON se nevrátil z požadavku HTTP.
Žádné telefonní připojení.
- Žádné telefonní připojení, žádné menu v mezipaměti.
+ Žádné připojení telefonu, žádné menu v mezipaměti.
Žádná odpověď, zkontrolovat připojení k internetu
Požadavek načasovaný
Vstup kolíku uzamčený pro
@@ -60,22 +60,24 @@
Dlouhodobý přístupový token.
URL pro domácí API.
URL pro konfiguraci nabídky (JSON).
- Měla by aplikační mezipaměť konfigurace nabídky?
+ Měla by aplikace ukládat konfiguraci nabídky?
Měla by aplikace vymazat stávající mezipaměť příště, až bude spuštěna?
+ Povolit provádění příkazů přes Wi-Fi/LTE.
Měla by aplikace poskytovat zpětnou vazbu prostřednictvím vibrací?
Timeout během několika sekund. Po tomto období nečinnosti uložte aplikaci k uložení baterie zařízení.
Další zpoždění hlasování (v sekundách). Přidá zpoždění mezi aktualizací stavu všech položek nabídky.
Po této době (v sekundách) je potvrzovací dialog pro akci automaticky uzavřen a akce je zrušena. Nastavit na 0 pro deaktivaci časového limitu.
- 4místný pin, který se má použít pro všechny akce, které vyžadují potvrzení (0000-9999).
+ 4místný pin, který se má použít pro všechny akce, které to vyžadují (0000-9999).
Nakonfigurujte prosím platný čtyřmístný číselný pin mezi 0000 a 9999 v nastavení aplikace.
- Zarovnání nabídky vlevo (vypnuto) nebo vpravo (ON).
+ Vlevo (vypnuto) nebo vpravo (ON) zarovnání nabídky.
Zleva doprava
Vpravo doleva
(Pouze widget) automaticky spusťte aplikaci z widgetu bez čekání na klepnutí.
- Umožněte službě pozadí odesílat úroveň, umístění baterie zařízení a (pokud je podporována) údaje o aktivitě domácímu asistentovi.
- Obnovová frekvence (v minutách), při kterém by měla služba na pozadí opakovat odesílání dat.
+ Umožněte službě pozadí odeslat úroveň baterie, umístění baterie zařízení a (pokud je podporována) údaje o aktivitě domácímu asistentovi.
+ Obnovení frekvence (v minutách), při kterém by měla služba na pozadí opakovat odesílání dat.
+
+
+
+
(Pouze číst) ID Webhook vytvořené zařízením pro aktualizace služby na pozadí. Možná to budete potřebovat pro ladění.
- Režim provádění Wi-Fi/LTE.
- Povolit provádění příkazů přes Wi-Fi/LTE.
- Umožňuje aplikaci začít bez telefonu (když je nabídka v mezipaměti) a výzva k provedení příkazu přes Wi-Fi/LTE.
diff --git a/resources-dan/strings/strings.xml b/resources-dan/strings/strings.xml
index 8105ed0..38d1460 100644
--- a/resources-dan/strings/strings.xml
+++ b/resources-dan/strings/strings.xml
@@ -44,7 +44,7 @@
Potentiel fejl
sekunder
Skabelonfejl
- API URL må ikke have en bageste skråstreg '/'.
+ API -URL må ikke have en bageste skråstreg '/'.
Utilgængelig
Ukonfigureret
HTTP -anmodning returneret fejlkode =
@@ -62,11 +62,12 @@
URL til menukonfiguration (JSON).
Skal applikationscache menuen Konfiguration?
Bør applikationen rydde den eksisterende cache næste gang den startes?
+ Aktivér udførelse af kommandoer over Wi-Fi/LTE.
Bør applikationen give feedback via vibrationer?
Timeout på få sekunder. Afslut applikationen efter denne periode med inaktivitet for at gemme enhedsbatteriet.
Yderligere afstemningsforsinkelse (på få sekunder). Tilføjer en forsinkelse mellem statusopdateringen af alle menupunkter.
Efter denne tid (på få sekunder) lukkes en bekræftelsesdialog for en handling automatisk, og handlingen annulleres. Indstil til 0 for at deaktivere timeout.
- 4-cifret pin, der skal bruges til alle handlinger, der kræver bekræftelse (0000-9999).
+ 4-cifret pin, der skal bruges til alle handlinger, der kræver det (0000-9999).
Konfigurer venligst en gyldig 4-cifret numerisk pin mellem 0000 og 9999 i applikationsindstillingerne.
Venstre (slukket) eller højre (på) menuindretning.
Venstre til højre
@@ -74,8 +75,9 @@
(Kun widget) Start automatisk applikationen fra widgetten uden at vente på et tryk.
Aktivér baggrundstjenesten til at sende enhedsbatteriniveauet, placering og (hvis understøttes) aktivitetsdata til hjemmeassistent.
Opdateringshastigheden (på få minutter), hvor baggrundstjenesten skal gentage afsendelsesdata.
+
+
+
+
(Læs kun) Webhook -ID oprettet af enheden til opdateringer af baggrundstjeneste. Du kræver muligvis dette til fejlsøgning.
- Wi-Fi/LTE-eksekveringstilstand.
- Aktivér udførelse af kommandoer over Wi-Fi/LTE.
- Tillader appen at starte uden telefonforbindelse (når menuen er cache) og beder om at udføre kommando over Wi-Fi/LTE.
diff --git a/resources-deu/strings/corrections.xml b/resources-deu/strings/corrections.xml
index 070d88b..cfd8ae4 100644
--- a/resources-deu/strings/corrections.xml
+++ b/resources-deu/strings/corrections.xml
@@ -26,29 +26,23 @@
Zu viele API-Aufrufe in kurzer Zeit. Bitte verlangsame deine Anfragen.
URL nicht gefunden. Möglicher Fehler in der API-URL in den Einstellungen.
-
OK
gecacht
Prüfe...
URL nicht gefunden. Möglicherweise falsche Konfigurations-URL in den Einstellungen.
-
Speicher
- Kein API-Schlüssel in den App-Einstellungen vorhanden.
- Keine API-URL in den App-Einstellungen vorhanden.
- Keine Konfigurations-URL in den App-Einstellungen vorhanden.
-
+ Kein API-Schlüssel in den App-Einstellungen hinterlegt.
+ Keine API-URL in den App-Einstellungen hinterlegt.
+ Keine Menükonfigurations-URL (JSON) in den App-Einstellungen hinterlegt.
Keine JSON-Datei aus der HTTP-Anfrage zurückbekommen.
-
Keine Telefonverbindung und kein gecachtes Menü.
Keine Antwort, bitte Internetverbindung prüfen.
Anfragezeit überschritten.
PIN-Eingabe gesperrt für
Möglicher Fehler
-
Template konnte nicht gerendert werden
API-URL darf nicht mit einem Schrägstrich '/' enden.
-
Die HTTP-Anfrage gab folgenden Fehlercode zurück =
Webhook-Registrierung fehlgeschlagen.
Falsche PIN.
@@ -65,11 +59,12 @@
URL für die Menükonfiguration (JSON).
Soll die App die Menükonfiguration cachen?
Soll die Anwendung beim nächsten Start den vorhandenen Cache löschen?
+ Befehlsausführung über WLAN/LTE aktivieren.
Soll die App Rückmeldung per Vibration geben?
Timeout in Sekunden. Beendet die App nach dieser Inaktivitätszeit, um Akku zu sparen.
Zusätzliche Abfrageverzögerung (in Sekunden). Fügt zwischen den Status-Updates der Menüeinträge eine Pause ein.
Nach dieser Zeit (in Sekunden) wird ein Bestätigungsdialog automatisch geschlossen und die Aktion abgebrochen. Mit 0 deaktivieren.
- 4-stellige PIN für alle Aktionen, die eine Bestätigung erfordern (0000-9999).
+ 4-stellige PIN für alle Aktionen, die diese erfordern (0000-9999).
Bitte eine gültige 4-stellige numerische PIN in den App Einstellungen eingeben (0000-9999).
Menüausrichtung: Links (aus) oder Rechts (ein).
@@ -77,8 +72,9 @@
(Nur Widget) App automatisch aus dem Widget starten, ohne auf Tippen zu warten.
Hintergrunddienst aktivieren, um Akkustand, Standort und (falls unterstützt) Aktivitätsdaten an Home Assistant zu senden.
Intervall (in Minuten), in dem der Hintergrunddienst die Daten erneut senden soll.
+
+
+
+
(Nur lesen) Die vom Gerät erstellte Webhook-ID für Hintergrund-Updates. Kann zum Debuggen benötigt werden.
- Ausführung über WLAN-/LTE einschalten.
- Befehlsausführung über WLAN/LTE aktivieren.
- Ermöglicht das Starten der App ohne Telefonverbindung (bei zwischengespeichertem Menü) und fragt, ob der Befehl über WLAN/LTE ausgeführt werden soll.
diff --git a/resources-deu/strings/strings.xml b/resources-deu/strings/strings.xml
index f97d1d7..a7582b3 100644
--- a/resources-deu/strings/strings.xml
+++ b/resources-deu/strings/strings.xml
@@ -19,8 +19,8 @@
-->
- API ruft zu schnell an. Bitte verlangsamen Sie Ihre Anfragen.
- URL nicht gefunden. Potenzieller API -URL -Fehler in Einstellungen.
+ Zu viele API-Aufrufe in kurzer Zeit. Bitte verlangsame deine Anfragen.
+ URL nicht gefunden. Möglicher Fehler in der API-URL in den Einstellungen.
HomeAssistant
OK
gecacht
@@ -31,55 +31,53 @@
Bestätigt
Speicher
- Kein API -Schlüssel in den Anwendungseinstellungen.
- Keine API -URL in den Anwendungseinstellungen.
- Keine Konfigurations -URL in den Anwendungseinstellungen.
+ Kein API-Schlüssel in den App-Einstellungen hinterlegt.
+ Keine API-URL in den App-Einstellungen hinterlegt.
+ Keine Menükonfigurations-URL (JSON) in den App-Einstellungen hinterlegt.
Keine Internetverbindung.
- Kein JSON kehrte von der HTTP -Anfrage zurück.
+ Keine JSON-Datei aus der HTTP-Anfrage zurückbekommen.
Keine Telefonverbindung.
- Keine Telefonverbindung, kein zwischengespeichertes Menü.
- Keine Antwort, überprüfen Sie die Internetverbindung
- Zeitlich anfordern
- PIN -Eingang gesperrt für
- Potenzieller Fehler
+ Keine Telefonverbindung und kein gecachtes Menü.
+ Keine Antwort, bitte Internetverbindung prüfen.
+ Anfragezeit überschritten.
+ PIN-Eingabe gesperrt für
+ Möglicher Fehler
Sekunden
Template konnte nicht gerendert werden
- Die API -URL darf keinen nachfolgenden Schrägstrich haben '/'.
+ API-URL darf nicht mit einem Schrägstrich '/' enden.
Nicht verfügbar
Nicht konfiguriert
Die HTTP-Anfrage gab folgenden Fehlercode zurück =
- Nicht registrieren Sie Webhook
- Falscher Stift
- Kein Wi-Fi oder LTE verfügbar
- Über Wi-Fi/LTE ausführen?
- Senden zum Home Assistant.
- Keine Daten erhalten.
+ Webhook-Registrierung fehlgeschlagen.
+ Falsche PIN.
+ Kein WLAN oder LTE verfügbar.
+ Über WLAN/LTE ausführen?
+ Sende an Home Assistant.
+ Keine Daten empfangen.
- Wählen...
- API -Schlüssel für Homasen.
- Langlebiger Zugangstoken.
+ Auswählen...
+ API-Schlüssel für HomeAssistant.
+ Langzeit-Zugangstoken.
URL der HomeAssistant-API.
- URL der Menükonfiguration (JSON).
- Soll die Anwendung die Menükonfiguration cachen?
+ URL für die Menükonfiguration (JSON).
+ Soll die App die Menükonfiguration cachen?
Soll die Anwendung beim nächsten Start den vorhandenen Cache löschen?
- Sollte die Anwendung Feedback über Vibrationen geben?
- Die App wird nach Ablauf der Zeit (in Sekunden) bei Inaktivität beendet, um den Akku
- des Geräts zu schonen.
- Zusätzliche Umfrageverzögerung (in Sekunden). Fügt eine Verzögerung zwischen der Statusaktualisierung aller Menüelemente hinzu.
- Nach dieser Zeit (in Sekunden) wird der Bestätigungsdialog einer Aktion geschlossen und die
- Aktion abgebrochen. Auf 0 setzen, um den Timeout zu deaktivieren.
- 4-stellige PIN für alle Actions mit 'confirm': true (0000-9999).
+ Befehlsausführung über WLAN/LTE aktivieren.
+ Soll die App Rückmeldung per Vibration geben?
+ Timeout in Sekunden. Beendet die App nach dieser Inaktivitätszeit, um Akku zu sparen.
+ Zusätzliche Abfrageverzögerung (in Sekunden). Fügt zwischen den Status-Updates der Menüeinträge eine Pause ein.
+ Nach dieser Zeit (in Sekunden) wird ein Bestätigungsdialog automatisch geschlossen und die Aktion abgebrochen. Mit 0 deaktivieren.
+ 4-stellige PIN für alle Aktionen, die diese erfordern (0000-9999).
Bitte eine gültige 4-stellige numerische PIN in den App Einstellungen eingeben (0000-9999).
- Links (aus) oder rechts (auf) Menüausrichtung.
+ Menüausrichtung: Links (aus) oder Rechts (ein).
Von links nach rechts
- Rechts nach links
- (Nur Widget) Anwendung automatisch über das Widget starten ohne drauftippen zu müssen.
- Hintergrunddienst aktivieren, um den Ladezustand der Batterie an HomeAssistant zu senden.
- Die Aktualisierungsrate (in Minuten) mit der der Ladezustand der Batterie
- an HomeAssistant gesendet wird.
- (Schreibgeschützt) Die von der Uhr erstellte Webhook-ID für Aktualisierungen des Ladezustands der Batterie.
- Möglicherweise wird dies zum Debuggen benötigt.
- Wi-Fi/LTE-Ausführungsmodus.
- Aktivieren Sie die Ausführung von Befehlen über Wi-Fi/LTE.
- Ermöglicht der App, ohne Telefonverbindung zu starten (wenn das Menü zwischengespeichert wird) und fordert auf, den Befehl über Wi-Fi/LTE auszuführen.
+ Von rechts nach links
+ (Nur Widget) App automatisch aus dem Widget starten, ohne auf Tippen zu warten.
+ Hintergrunddienst aktivieren, um Akkustand, Standort und (falls unterstützt) Aktivitätsdaten an Home Assistant zu senden.
+ Intervall (in Minuten), in dem der Hintergrunddienst die Daten erneut senden soll.
+
+
+
+
+ (Nur lesen) Die vom Gerät erstellte Webhook-ID für Hintergrund-Updates. Kann zum Debuggen benötigt werden.
diff --git a/resources-dut/strings/strings.xml b/resources-dut/strings/strings.xml
index 25f9231..d3d04b0 100644
--- a/resources-dut/strings/strings.xml
+++ b/resources-dut/strings/strings.xml
@@ -62,20 +62,22 @@
URL voor menuconfiguratie (JSON).
Moet de toepassingscache de menu -configuratie?
Moet de toepassing de bestaande cache wissen de volgende keer dat deze wordt gestart?
+ Schakel opdrachten uit via Wi-Fi/LTE.
Moet de applicatie feedback geven via trillingen?
Time -out in seconden. Verlaat de toepassing na deze periode van inactiviteit om de apparaatbatterij op te slaan.
Aanvullende peilvertraging (in seconden). Voegt een vertraging toe tussen de statusupdate van alle menu -items.
Na deze tijd (in seconden) wordt een bevestigingsdialoogvenster voor een actie automatisch gesloten en wordt de actie geannuleerd. Ingesteld op 0 om de time -out uit te schakelen.
- 4-cijferige pin die moet worden gebruikt voor alle acties die bevestiging vereisen (0000-9999).
- Configureer een geldige 4-cijferige numerieke pin tussen 0000 en 9999 in de applicatie-instellingen.
+ 4-cijferige pin die moet worden gebruikt voor alle acties die dit vereisen (0000-9999).
+ Configureer een geldige 4-cijferige numerieke pin tussen 0000 en 9999 in de toepassingsinstellingen.
Links (uit) of rechts (AAN) menu -uitlijning.
Van links naar rechts
Van rechts naar links
(Alleen widget) Start de toepassing automatisch vanuit de widget zonder te wachten op een tik.
Schakel de achtergrondservice in om het batterijdniveau van het apparaat, de locatie en (indien ondersteunde) activiteitsgegevens naar Home Assistant te verzenden.
De verversingssnelheid (in minuten) waarbij de achtergrondservice het verzenden van gegevens moet herhalen.
+
+
+
+
(Alleen lezen) De webhook -ID die door het apparaat is gemaakt voor updates van de achtergrondservice. Misschien heeft u dit nodig voor foutopsporing.
- Wi-Fi/LTE-uitvoeringsmodus.
- Schakel opdrachten uit via Wi-Fi/LTE.
- Hiermee kan de app starten zonder telefoonaansluiting (wanneer het menu wordt gecacheerd) en de opdracht uitvoeren via Wi-Fi/LTE uit te voeren.
diff --git a/resources-est/strings/strings.xml b/resources-est/strings/strings.xml
index 1b3f256..c7cf0a6 100644
--- a/resources-est/strings/strings.xml
+++ b/resources-est/strings/strings.xml
@@ -33,12 +33,12 @@
Mälu
Rakenduse seadetes pole API -klahvi.
Rakenduse seadetes pole API URL -i.
- Rakenduse seadetes puudub konfiguratsioon URL.
+ Rakenduse sätetes pole konfiguratsiooni URL -i.
Interneti -ühendust pole.
Ükski JSON ei tulnud http päringult tagasi.
Telefoniühendust pole.
Pole telefoniühendust ega vahemällu salvestatud menüüd.
- Pole vastust, kontrollige Interneti -ühendust
+ Vastust pole, kontrollige Interneti -ühendust
Taotlus on ajastatud
PIN -i sisend lukustatud
Potentsiaalne viga
@@ -62,20 +62,22 @@
URL menüü konfiguratsiooni jaoks (JSON).
Kas rakenduse vahemälu peaks menüü konfiguratsiooni vahemälu vahemälu vahemälu vahemälu vahemälu vahemälu vahemälu vahemälu
Kas rakendus peaks olemasoleva vahemälu järgmine kord alustama?
+ Luba käskude täitmine Wi-Fi/LTE kaudu.
Kas rakendus peaks vibratsiooni kaudu tagasisidet andma?
Aegumine sekunditega. Pärast seda tegevusetuse perioodi seade aku salvestamiseks väljuge rakendusest.
Täiendav küsitluse viivitus (sekundites). Lisab viivituse kõigi menüüelementide olekuvärskenduse vahel.
Pärast seda aega (sekundites) suletakse toimingu kinnitusdialoog automaatselt ja toiming tühistatakse. Määrake aegumistähtaeg 0 -le.
- 4-kohaline tihvt, mida kasutatakse kõigi kinnitamist vajavate toimingute jaoks (0000-9999).
+ 4-kohaline tihvt, mida kasutatakse kõigi seda vajavate toimingute jaoks (0000-9999).
Konfigureerige rakenduse seadetes kehtiv 4-kohaline numbriline nööpnõel vahemikus 0000 kuni 9999.
Vasak (välja lülitatud) või parem (ON) menüü joondamine.
Vasakult paremale
Paremale vasakule
(Ainult vidin) käivitage rakendus vidinast automaatselt ilma kraani ootamata.
- Luba taustteenus, et saata seadme aku tase, asukoht ja (kui see on toetatud) tegevusandmed koduassistendile.
+ Luba taustteenus seadme aku taseme, asukoha ja (kui see on toetatud) tegevusandmete saatmine koduassistendile.
Värskendusmäär (minutites), kus taustteenus peaks andmete saatmist korrata.
+
+
+
+
(Loe ainult) WebHooki ID, mille seade on loonud taustteenuse värskenduste jaoks. Võite seda silumiseks nõuda.
- Wi-Fi/LTE täitmisrežiim.
- Luba käskude täitmine Wi-Fi/LTE kaudu.
- Võimaldab rakendusel käivitada ilma telefoniühenduseta (kui menüü on vahemällu salvestatud) ja vihje käsu käivitamiseks Wi-Fi/LTE kaudu.
diff --git a/resources-fin/strings/strings.xml b/resources-fin/strings/strings.xml
index ddd41e6..ff28604 100644
--- a/resources-fin/strings/strings.xml
+++ b/resources-fin/strings/strings.xml
@@ -62,20 +62,22 @@
Valikkokokoonpanon URL (JSON).
Pitäisikö sovelluksen välimuistiin valikon kokoonpano?
Pitäisikö sovelluksen tyhjentää olemassa oleva välimuisti seuraavalla kerralla?
+ Ota komentojen suorittaminen käyttöön Wi-Fi/LTE: n kautta.
Pitäisikö sovelluksen antaa palautetta värähtelyjen kautta?
Aikakatkaisu sekunneissa. Poistu sovelluksesta tämän toimettomuuden jälkeen laitteen akun tallentamiseksi.
Lisäkyselyviive (sekunneissa). Lisää viive kaikkien valikkokohteiden tilapäivityksen välillä.
Tämän ajan jälkeen (sekunneissa) toiminnan vahvistusvalintaikkuna suljetaan automaattisesti ja toiminto peruutetaan. Aseta arvoon 0 poistamaan aikakatkaisu käytöstä.
- 4-numeroinen PIN-koodi kaikissa toimissa, jotka vaativat vahvistusta (0000-9999).
+ 4-numeroinen PIN-koodi, jota käytetään kaikkiin sitä vaativiin toimiin (0000-9999).
Määritä kelvollinen 4-numeroinen numeerinen PIN-arvo välillä 0000-9999 sovellusasetuksissa.
Vasen (pois päältä) tai oikea (on) valikon kohdistus.
Vasemmalta oikealle
Vasemmalle
- (Vain widget) Käynnistä sovellus automaattisesti widgetistä odottamatta napautta.
+ (Vain widget) Käynnistä sovellus automaattisesti widgetistä odottamatta napautusta.
Ota taustapalvelu käyttöön laitteen akkutason, sijainnin ja (jos tuetun) aktiviteettitietojen lähettämiseksi kodin avustajalle.
Päivitysnopeus (muutamassa minuutissa), jossa taustapalvelun tulisi toistaa tietojen lähettäminen.
+
+
+
+
(Vain lue) laitteen luoma webhook -tunnus taustapalvelupäivityksiin. Saatat tarvita tätä virheenkorjausta varten.
- Wi-Fi/LTE-suoritustila.
- Ota komentojen suorittaminen käyttöön Wi-Fi/LTE: n kautta.
- Mahdollistaa sovelluksen käynnistyksen ilman puhelinyhteyttä (kun valikko on välimuisti) ja kehottaa suorittamaan komento Wi-Fi/LTE: n kautta.
diff --git a/resources-fre/strings/strings.xml b/resources-fre/strings/strings.xml
index 8089266..090b893 100644
--- a/resources-fre/strings/strings.xml
+++ b/resources-fre/strings/strings.xml
@@ -62,11 +62,12 @@
URL pour la configuration du menu (JSON).
L'application devrait-elle mettre en cache la configuration du menu?
L'application devrait-elle effacer le cache existant la prochaine fois qu'il sera démarré?
+ Activer l'exécution des commandes sur Wi-Fi / LTE.
L'application devrait-elle fournir des commentaires via des vibrations?
Timeout en quelques secondes. Quittez l'application après cette période d'inactivité pour enregistrer la batterie de l'appareil.
Délai supplémentaire du scrutin (en secondes). Ajoute un délai entre la mise à jour d'état de tous les éléments de menu.
Après ce temps (en quelques secondes), une boîte de dialogue de confirmation pour une action est automatiquement fermée et l'action est annulée. Réglé sur 0 pour désactiver le délai d'attente.
- PIN à 4 chiffres à utiliser pour toutes les actions qui nécessitent une confirmation (0000-9999).
+ PIN à 4 chiffres à utiliser pour toutes les actions qui l'exigent (0000-9999).
Veuillez configurer une broche numérique à 4 chiffres valide entre 0000 et 9999 dans les paramètres de l'application.
Alignement du menu gauche (off) ou droit (on).
De gauche à droite
@@ -74,8 +75,9 @@
(Widget uniquement) Démarrez automatiquement l'application à partir du widget sans attendre un robinet.
Activez le service d'arrière-plan pour envoyer le niveau de la batterie de l'appareil, l'emplacement et (le cas échéant) les données d'activité à l'assistant à domicile.
Le taux de rafraîchissement (en minutes) auquel le service d'arrière-plan doit répéter l'envoi de données.
+
+
+
+
(Lire uniquement) L'ID Webhook créé par l'appareil pour les mises à jour du service d'arrière-plan. Vous pourriez en avoir besoin pour le débogage.
- Mode d'exécution Wi-Fi / LTE.
- Activer l'exécution des commandes sur Wi-Fi / LTE.
- Permet à l'application de démarrer sans connexion par téléphone (lorsque le menu est mis en cache) et invite à exécuter la commande via Wi-Fi / LTE.
diff --git a/resources-gre/strings/strings.xml b/resources-gre/strings/strings.xml
index cd988cf..aa44e11 100644
--- a/resources-gre/strings/strings.xml
+++ b/resources-gre/strings/strings.xml
@@ -44,29 +44,30 @@
Πιθανό σφάλμα
δευτερόλεπτα
Σφάλμα προτύπου
- Το API URL δεν πρέπει να έχει μια κλίση "/'.
+ Το URL API δεν πρέπει να έχει μια κλίση "/'.
Δυσεύρετος
Αδιευκρίνιστος
- Το αίτημα HTTP επέστρεψε κωδικό σφάλματος =
+ Αίτηση HTTP Επιστρέφεται κωδικός σφάλματος =
Αποτυχία εγγραφής webhook
Λάθος καρφίτσα
- Δεν υπάρχει διαθέσιμο Wi-Fi ή LTE
+ Χωρίς Wi-Fi ή LTE διαθέσιμο
Εκτέλεση μέσω Wi-Fi/LTE;
Αποστολή στον βοηθό στο σπίτι.
Δεν λαμβάνονται δεδομένα.
Επιλέγω...
API κλειδί για το Homeassistant.
- Διακριτικό πρόσβασης σε μακροχρόνια διάρκεια.
+ Διακριτικό πρόσβαση σε μακροχρόνια διάρκεια.
URL για το Homeassistant API.
URL για διαμόρφωση μενού (JSON).
Πρέπει η προσωρινή μνήμη εφαρμογής τη διαμόρφωση μενού;
Πρέπει η εφαρμογή να διαγράψει την υπάρχουσα μνήμη cache την επόμενη φορά που θα ξεκινήσει;
+ Ενεργοποιήστε τις εντολές εκτέλεσης μέσω Wi-Fi/LTE.
Πρέπει η εφαρμογή να παρέχει ανατροφοδότηση μέσω δονήσεων;
Χρονικό όριο σε δευτερόλεπτα. Βγείτε από την εφαρμογή μετά από αυτήν την περίοδο αδράνειας για να αποθηκεύσετε τη μπαταρία της συσκευής.
Πρόσθετη καθυστέρηση δημοσκόπησης (σε δευτερόλεπτα). Προσθέτει μια καθυστέρηση μεταξύ της ενημέρωσης κατάστασης όλων των στοιχείων μενού.
Μετά από αυτό το χρονικό διάστημα (σε δευτερόλεπτα), ένα παράθυρο διαλόγου επιβεβαίωσης για μια ενέργεια κλείνει αυτόματα και η ενέργεια ακυρώνεται. Ρυθμίστε στο 0 για να απενεργοποιήσετε το χρονικό όριο.
- 4 ψηφία PIN για όλες τις ενέργειες που απαιτούν επιβεβαίωση (0000-9999).
+ 4-ψηφία PIN που πρέπει να χρησιμοποιηθεί για όλες τις ενέργειες που το απαιτούν (0000-9999).
Διαμορφώστε έναν έγκυρο τετραψήφιο αριθμητικό πείρο μεταξύ 0000 και 9999 στις ρυθμίσεις εφαρμογής.
Αριστερά (απενεργοποίηση) ή δεξιά (ON) Ευθυγράμμιση μενού.
Από αριστερά προς τα δεξιά
@@ -74,8 +75,9 @@
(Μόνο widget) Ξεκινήστε αυτόματα την εφαρμογή από το widget χωρίς να περιμένετε μια βρύση.
Ενεργοποιήστε την υπηρεσία φόντου για την αποστολή της στάθμης της μπαταρίας της συσκευής, της θέσης και της (αν υποστηριχθεί) δεδομένων δραστηριότητας στον βοηθό στο σπίτι.
Ο ρυθμός ανανέωσης (σε λεπτά) κατά τον οποίο η υπηρεσία φόντου πρέπει να επαναλαμβάνει τα δεδομένα αποστολής.
+
+
+
+
(Μόνο διαβάστε) Το αναγνωριστικό WebHook που δημιουργήθηκε από τη συσκευή για ενημερώσεις υπηρεσιών φόντου. Μπορεί να το χρειαστείτε για εντοπισμό σφαλμάτων.
- Λειτουργία εκτέλεσης Wi-Fi/LTE.
- Ενεργοποιήστε τις εντολές εκτέλεσης μέσω Wi-Fi/LTE.
- Επιτρέπει στην εφαρμογή να ξεκινά χωρίς σύνδεση τηλεφώνου (όταν το μενού αποθηκεύεται) και προτρέπεται να εκτελέσει εντολή μέσω Wi-Fi/LTE.
diff --git a/resources-heb/strings/strings.xml b/resources-heb/strings/strings.xml
index eb78b31..40220d1 100644
--- a/resources-heb/strings/strings.xml
+++ b/resources-heb/strings/strings.xml
@@ -44,7 +44,7 @@
שגיאה פוטנציאלית
שניות
שגיאת תבנית
- אסור לכתובת API להיות סלאש נגרר '/'.
+ כתובת API אסור שיהיה לו סלאש נגרר '/'.
לא זמין
לא מוגדר
בקשת HTTP קוד שגיאה שהוחזר =
@@ -54,19 +54,20 @@
להורג באמצעות Wi-Fi/LTE?
שולח לעוזר הבית.
לא התקבלו נתונים.
-
+
לִבחוֹר...
- מפתח API עבור HomeAsstant.
+ מפתח API עבור HomeAssistant.
אסימון גישה ארוכת שנים.
כתובת URL לממשק API עמדתי.
כתובת אתר לתצורת תפריט (JSON).
האם על היישום למנוע את תצורת התפריט?
האם על היישום לנקות את המטמון הקיים בפעם הבאה שהוא מתחיל?
+ אפשר לבצע פקודות דרך Wi-Fi/LTE.
האם על היישום לספק משוב באמצעות תנודות?
פסק זמן בשניות. צא מהיישום לאחר תקופת חוסר פעילות זו כדי לחסוך את סוללת ההתקן.
עיכוב נוסף בסקר (תוך שניות). מוסיף עיכוב בין עדכון הסטטוס של כל פריטי התפריט.
לאחר זמן זה (תוך שניות), דיאלוג אישור לפעולה נסגר אוטומטית והפעולה מבוטלת. מוגדר ל 0 כדי להשבית את פסק הזמן.
- סיכה 4 ספרות שישמשו לכל הפעולות הדורשות אישור (0000-9999).
+ סיכה עם 4 ספרות שישמשו לכל הפעולות הדורשות אותה (0000-9999).
אנא קבע את התצורה של סיכה מספרית תקפה בת 4 ספרות בין 0000 ל- 9999 בהגדרות היישום.
יישור תפריט משמאל (כבוי) או ימין (ON).
משמאל לימין
@@ -74,8 +75,9 @@
(ווידג'ט בלבד) הפעל אוטומטית את היישום מהווידג'ט מבלי לחכות לברז.
אפשר לשירות הרקע לשלוח את רמת סוללת המכשיר, מיקום ו (אם נתמך) נתוני פעילות לעוזר הבית.
קצב הרענון (בדקות) בו שירות הרקע צריך לחזור על שליחת נתונים.
+
+
+
+
(קרא בלבד) מזהה WebHook שנוצר על ידי המכשיר לעדכוני שירות רקע. אתה עשוי לדרוש זאת לצורך ניפוי באגים.
- מצב ביצוע Wi-Fi/LTE.
- אפשר לבצע פקודות דרך Wi-Fi/LTE.
- מאפשר לאפליקציה להתחיל ללא חיבור טלפון (כאשר התפריט מטמון), ולבקש לבצע פקודה דרך Wi-Fi/LTE.
diff --git a/resources-hrv/strings/strings.xml b/resources-hrv/strings/strings.xml
index 7eaa57e..ef7664d 100644
--- a/resources-hrv/strings/strings.xml
+++ b/resources-hrv/strings/strings.xml
@@ -62,11 +62,12 @@
URL za konfiguraciju izbornika (JSON).
Treba li aplikacija predmemorirati konfiguraciju izbornika?
Treba li aplikacija očistiti postojeću predmemoriju sljedeći put kad se pokrene?
+ Omogući izvršavanje naredbi preko Wi-Fi/LTE.
Treba li aplikacija davati povratne informacije putem vibracija?
Timeout u sekundi. Izađite iz aplikacije nakon ovog razdoblja neaktivnosti kako biste uštedjeli bateriju uređaja.
Dodatno kašnjenje ankete (u sekundi). Dodaje kašnjenje između ažuriranja statusa svih stavki izbornika.
Nakon tog vremena (u sekundi), dijaloški okvir za potvrdu za radnju automatski se zatvara i radnja se otkazuje. Postavite na 0 da onemogućite vremensko ograničenje.
- Četveroznamenkasti pin koji će se koristiti za sve radnje koje zahtijevaju potvrdu (0000-9999).
+ Četveroznamenkasti pin koji će se koristiti za sve radnje koje zahtijevaju (0000-9999).
Konfigurirajte valjani četveroznamenkasti numerički pin između 0000 i 9999 u postavkama aplikacije.
Lijevo (isključeno) ili desno (ON) Poravnavanje izbornika.
Slijeva na desno
@@ -74,8 +75,9 @@
(Samo widget) Automatski pokrenite aplikaciju iz widgeta bez čekanja na dodir.
Omogućite pozadinsku uslugu da pošalje podatke o bateriji uređaja, lokaciji i (ako su podržani) podatke o aktivnostima kod kuće.
Brzina osvježavanja (u minutama) u kojoj bi pozadinska usluga trebala ponoviti slanje podataka.
+
+
+
+
(Samo pročitajte) ID Webhooka stvorio je uređaj za ažuriranja pozadine. Možda će vam to trebati za uklanjanje pogrešaka.
- Wi-Fi/LTE izvedbe.
- Omogući izvršavanje naredbi preko Wi-Fi/LTE.
- Omogućuje aplikaciji da se pokrene bez telefonske veze (kada je izbornik predmemoran) i zatražite izvršavanje naredbe preko Wi-Fi/LTE.
diff --git a/resources-hun/strings/strings.xml b/resources-hun/strings/strings.xml
index b112b8b..f60ba15 100644
--- a/resources-hun/strings/strings.xml
+++ b/resources-hun/strings/strings.xml
@@ -56,26 +56,28 @@
Nincs adat.
Válassza ki ...
- API -kulcs a homeaSsistant -hoz.
+ API kulcs a homeaSsistant -hoz.
Hosszú élettartamú hozzáférési jogkivonó.
URL a Homeassistant API -hoz.
URL a menükonfigurációhoz (JSON).
Az alkalmazásnak gyorsítótáraznia kell a menükonfigurációt?
Az alkalmazásnak törölnie kell -e a meglévő gyorsítótárat a következő indításkor?
+ Engedélyezze a parancsok végrehajtási végrehajtását a Wi-Fi/LTE-n keresztül.
Az alkalmazásnak visszacsatolást kell adnia a rezgések révén?
Időtúllépés másodpercek alatt. Az eszköz akkumulátorának mentése érdekében kilépjen az alkalmazásból az inaktivitás után.
További közvélemény -kutatási késleltetés (másodpercek alatt). Hozzáad egy késleltetést az összes menüelem állapotfrissítése között.
Ezen idő után (másodpercben) egy akció megerősítő párbeszédpanelje automatikusan bezáródik, és a műveletet töröljük. Állítsa 0 -ra az időtúllépés letiltásához.
- 4 számjegyű PIN-kód, amelyet minden olyan művelethez használni kell, amely megerősítést igényel (0000-9999).
+ 4 számjegyű PIN-kódot, amelyet minden szükséges művelethez használni kell (0000-9999).
Kérjük, konfiguráljon egy érvényes négyjegyű numerikus csapot 0000 és 9999 között az alkalmazás beállításaiban.
Balra (ki) vagy jobb (be (be) menü igazítás.
Balról jobbra
Jobbról balra
(Csak widget) automatikusan indítsa el az alkalmazást a widgetről, anélkül, hogy megérintené a csapot.
- Engedélyezze, hogy a háttérszolgáltatás az eszköz akkumulátorának szintjét, helyét és (ha támogatott) tevékenységi adatait elküldi az otthoni asszisztensnek.
+ Engedélyezze, hogy a háttérszolgáltatás az eszköz akkumulátorának szintjét, helyét és (ha támogatott) tevékenységi adatait elküldje az otthoni asszisztensnek.
A háttérszolgáltatásnak a küldési adatokkal kell megismételnie a frissítési arányt (percekben).
+
+
+
+
(Csak olvassa el) Az eszköz által létrehozott webhook azonosító a háttérszolgáltatás frissítéseihez. Lehet, hogy ezt a hibakereséshez szükség lehet.
- Wi-Fi/LTE végrehajtási mód.
- Engedélyezze a parancsok végrehajtási végrehajtását a Wi-Fi/LTE-n keresztül.
- Lehetővé teszi az alkalmazás számára, hogy telefonkapcsolat nélkül induljon (amikor a menü gyorsítótárban van), és kérje a parancs végrehajtását a Wi-Fi/LTE-en keresztül.
diff --git a/resources-ind/strings/strings.xml b/resources-ind/strings/strings.xml
index 849e46d..fd473e7 100644
--- a/resources-ind/strings/strings.xml
+++ b/resources-ind/strings/strings.xml
@@ -46,7 +46,7 @@
Kesalahan template
URL API tidak boleh memiliki tebasan trailing '/'.
Tidak tersedia
- Tidak dikonfigurasi
+ Tidak dikonfigurasikan
Permintaan HTTP Kode kesalahan dikembalikan =
Gagal Mendaftar Webhook
Pin yang salah
@@ -62,11 +62,12 @@
URL untuk Konfigurasi Menu (JSON).
Haruskah Aplikasi Menyimpan Konfigurasi Menu?
Haruskah aplikasi menghapus cache yang ada lain kali dimulai?
+ Aktifkan Perintah yang Mengeksekusi melalui Wi-Fi/LTE.
Haruskah aplikasi memberikan umpan balik melalui getaran?
Batas waktu dalam hitungan detik. Keluar dari aplikasi setelah periode tidak aktif ini untuk menyimpan baterai perangkat.
Penundaan jajak pendapat tambahan (dalam hitungan detik). Menambahkan penundaan antara pembaruan status semua item menu.
Setelah waktu ini (dalam hitungan detik), dialog konfirmasi untuk suatu tindakan ditutup secara otomatis dan tindakan dibatalkan. Diatur ke 0 untuk menonaktifkan batas waktu.
- PIN 4 digit untuk digunakan untuk semua tindakan yang memerlukan konfirmasi (0000-9999).
+ PIN 4 digit untuk digunakan untuk semua tindakan yang memerlukannya (0000-9999).
Harap konfigurasikan pin numerik 4 digit yang valid antara 0000 dan 9999 di pengaturan aplikasi.
Left (off) atau Alignment Menu Left (Off) atau Right (ON).
Kiri ke kanan
@@ -74,8 +75,9 @@
(Hanya widget) secara otomatis memulai aplikasi dari widget tanpa menunggu keran.
Aktifkan layanan latar belakang untuk mengirim data baterai perangkat, lokasi, dan (jika didukung) data ke rumah asisten.
Tingkat refresh (dalam hitungan menit) di mana layanan latar belakang harus mengulang data pengiriman.
+
+
+
+
(Baca saja) ID WebHook yang dibuat oleh perangkat untuk pembaruan layanan latar belakang. Anda mungkin memerlukan ini untuk debugging.
- Mode Eksekusi Wi-Fi/LTE.
- Aktifkan Perintah yang Mengeksekusi melalui Wi-Fi/LTE.
- Memungkinkan aplikasi untuk memulai tanpa koneksi telepon (saat menu di-cache), dan meminta untuk menjalankan perintah melalui Wi-Fi/LTE.
diff --git a/resources-ita/strings/strings.xml b/resources-ita/strings/strings.xml
index aa5e6c2..bc01cae 100644
--- a/resources-ita/strings/strings.xml
+++ b/resources-ita/strings/strings.xml
@@ -62,11 +62,12 @@
URL per la configurazione del menu (JSON).
L'applicazione dovrebbe memorizzare la cache della configurazione del menu?
L'applicazione dovrebbe cancellare la cache esistente la prossima volta che viene avviata?
+ Abilita l'esecuzione dei comandi su Wi-Fi/LTE.
L'applicazione dovrebbe fornire feedback tramite vibrazioni?
Timeout in secondi. Esci dall'applicazione dopo questo periodo di inattività per salvare la batteria del dispositivo.
Ritardo del sondaggio aggiuntivo (in secondi). Aggiunge un ritardo tra l'aggiornamento dello stato di tutte le voci di menu.
Dopo questo periodo (in secondi), una finestra di dialogo di conferma per un'azione viene automaticamente chiusa e l'azione viene annullata. Impostare su 0 per disabilitare il timeout.
- PIN a 4 cifre da utilizzare per tutte le azioni che richiedono conferma (0000-9999).
+ Pin a 4 cifre da utilizzare per tutte le azioni che lo richiedono (0000-9999).
Configurare un pin numerico a 4 cifre valido tra 0000 e 9999 nelle impostazioni dell'applicazione.
Allineamento del menu a sinistra (OFF) o destro (ON).
Da sinistra a destra
@@ -74,8 +75,9 @@
(Solo widget) Avviare automaticamente l'applicazione dal widget senza aspettare un tocco.
Abilita il servizio di fondo per inviare i dati di attività della batteria, posizione e (se supportati) ad Assistente Home Assistant.
La frequenza di aggiornamento (in minuti) in cui il servizio di fondo deve ripetere l'invio di dati.
+
+
+
+
(Solo lettura) L'ID WebHook creato dal dispositivo per gli aggiornamenti del servizio in background. Potresti richiederlo per il debug.
- Modalità di esecuzione Wi-Fi/LTE.
- Abilita l'esecuzione dei comandi su Wi-Fi/LTE.
- Consente all'app di avviare senza connessione telefonica (quando il menu è memorizzato nella cache) e prompt di eseguire il comando tramite Wi-Fi/LTE.
diff --git a/resources-jpn/strings/strings.xml b/resources-jpn/strings/strings.xml
index 4521f7e..f7978e7 100644
--- a/resources-jpn/strings/strings.xml
+++ b/resources-jpn/strings/strings.xml
@@ -62,11 +62,12 @@
メニュー構成用のURL(JSON)。
アプリケーションはメニュー構成をキャッシュする必要がありますか?
次回開始時にアプリケーションが既存のキャッシュをクリアする必要がありますか?
+ Wi-Fi/LTEを介してコマンドを実行できるようにします。
アプリケーションは振動を介してフィードバックを提供する必要がありますか?
数秒でタイムアウト。デバイスバッテリーを保存するために、この不活性期間の後にアプリケーションを終了します。
追加の投票遅延(秒単位)。すべてのメニュー項目のステータス更新間に遅延を追加します。
この時間(秒)の後、アクションの確認ダイアログが自動的に閉じられ、アクションがキャンセルされます。タイムアウトを無効にするために0に設定します。
- 確認が必要なすべてのアクションに使用される4桁のピン(0000-9999)。
+ 4桁のピンは、それを必要とするすべてのアクションに使用されます(0000-9999)。
アプリケーション設定で0000〜9999の間に有効な4桁の数値ピンを構成してください。
左(オフ)または右(オン)メニューアライメント。
左から右
@@ -74,8 +75,9 @@
(ウィジェットのみ)タップを待たずにウィジェットからアプリケーションを自動的に起動します。
バックグラウンドサービスがデバイスのバッテリーレベル、場所、および(サポートされている場合)アクティビティデータをホームアシスタントに送信できるようにします。
バックグラウンドサービスがデータの送信を繰り返す必要があるリフレッシュレート(数分単位)。
+
+
+
+
(読み取り専用)バックグラウンドサービスの更新のためにデバイスによって作成されたWebHook ID。デバッグにこれが必要になる場合があります。
- Wi-Fi/LTE実行モード。
- Wi-Fi/LTEを介してコマンドを実行できるようにします。
- 電話接続なしでアプリを起動することができます(メニューがキャッシュされている場合)、Wi-Fi/LTEを介してコマンドを実行するように求められます。
diff --git a/resources-kor/strings/strings.xml b/resources-kor/strings/strings.xml
index f7485f5..62d9516 100644
--- a/resources-kor/strings/strings.xml
+++ b/resources-kor/strings/strings.xml
@@ -62,11 +62,12 @@
메뉴 구성 (JSON) 용 URL.
응용 프로그램이 메뉴 구성을 캐시해야합니까?
다음에 시작될 때 응용 프로그램이 기존 캐시를 지우려면?
+ Wi-Fi/LTE를 통해 명령을 실행할 수 있습니다.
응용 프로그램이 진동을 통해 피드백을 제공해야합니까?
시간 초과 시간 초과. 장치 배터리를 저장하기 위해이 비활성 기간 후에 응용 프로그램을 종료하십시오.
추가 폴링 지연 (초). 모든 메뉴 항목의 상태 업데이트 사이에 지연이 추가됩니다.
이 시간 (초) 이후 (초) 조치에 대한 확인 대화 상자가 자동으로 닫히고 조치가 취소됩니다. 타임 아웃을 비활성화하려면 0으로 설정하십시오.
- 확인이 필요한 모든 작업에 사용되는 4 자리 핀 (0000-9999).
+ 4 자리 핀이 필요한 모든 작업에 사용됩니다 (0000-9999).
응용 프로그램 설정에서 0000에서 9999 사이의 유효한 4 자리 숫자 핀을 구성하십시오.
왼쪽 (OFF) 또는 오른쪽 (ON) 메뉴 정렬.
왼쪽에서 오른쪽
@@ -74,8 +75,9 @@
(위젯 만) 탭을 기다리지 않고 위젯에서 응용 프로그램을 자동으로 시작합니다.
배경 서비스가 장치 배터리 레벨, 위치 및 (지원되는 경우) 활동 데이터를 홈 비서로 보낼 수 있도록합니다.
백그라운드 서비스가 데이터 전송을 반복 해야하는 새로 고침 비율 (분).
+
+
+
+
(읽기 전용) 배경 서비스 업데이트를 위해 장치에서 만든 WebHook ID. 디버깅을 위해서는이 문제가 필요할 수 있습니다.
- Wi-Fi/LTE 실행 모드.
- Wi-Fi/LTE를 통해 명령을 실행할 수 있습니다.
- 전화 연결없이 앱을 시작할 수 있으며 (메뉴가 캐시 될 때) Wi-Fi/LTE를 통해 명령을 실행하라는 메시지가 표시됩니다.
diff --git a/resources-lav/strings/strings.xml b/resources-lav/strings/strings.xml
index ec5592d..9d6bcd2 100644
--- a/resources-lav/strings/strings.xml
+++ b/resources-lav/strings/strings.xml
@@ -33,7 +33,7 @@
Atmiņa
Lietojumprogrammas iestatījumos nav API atslēgas.
Lietojumprogrammu iestatījumos nav API URL.
- Lietojumprogrammu iestatījumos nav konfigurācijas URL.
+ Lietojumprogrammas iestatījumos nav konfigurācijas URL.
Nav interneta savienojuma.
Neviens JSON neatgriezās no HTTP pieprasījuma.
Nav tālruņa savienojuma.
@@ -54,19 +54,20 @@
Izpildīt pār wi-fi/lte?
Sūtot mājas palīgu.
Dati nav saņemti.
-
+
Atlasiet ...
API atslēga Homeassistant.
Ilgstoša piekļuves marķieris.
URL Homeassistant API.
URL izvēlnes konfigurācijai (JSON).
- Vai lietojumprogrammai vajadzētu kešatmiņā saglabāt izvēlnes konfigurāciju?
+ Vai lietojumprogrammai vajadzētu kešatmiņā izvēlnes konfigurāciju?
Vai lietojumprogrammai vajadzētu notīrīt esošo kešatmiņu nākamreiz, kad tā tiks sākta?
+ Iespējot izpildīt komandas, izmantojot Wi-Fi/LTE.
Vai lietojumprogrammai vajadzētu sniegt atgriezenisko saiti, izmantojot vibrācijas?
Noildze sekundēs. Izejiet no lietojumprogrammas pēc šī bezdarbības perioda, lai saglabātu ierīces akumulatoru.
Papildu aptaujas kavēšanās (sekundēs). Pievieno kavēšanos starp visu izvēlnes vienumu statusa atjauninājumu.
Pēc šī laika (sekundēs) tiek automātiski slēgts apstiprinājuma dialogs darbībai un darbība tiek atcelta. Iestatiet uz 0, lai atspējotu noildzi.
- 4 ciparu tapa, kas jāizmanto visām darbībām, kurām nepieciešams apstiprinājums (0000-9999).
+ 4 ciparu tapa, kas jāizmanto visām darbībām, kurām to nepieciešama (0000-9999).
Lūdzu, lietojumprogrammu iestatījumos konfigurējiet derīgu četrciparu skaitlisko tapu no 0000 līdz 9999.
Kreisais (izslēgts) vai labais (ieslēgts) izvēlnes izlīdzināšana.
No kreisās uz labo pusi
@@ -74,8 +75,9 @@
(Tikai logrīks) Automātiski sāk lietot lietojumprogrammu no logrīka, negaidot pieskārienu.
Iespējojiet fona pakalpojumu, lai mājas asistentam nosūtītu ierīces akumulatora līmeni, atrašanās vietu un (ja tos atbalstītu) aktivitātes datus.
Atsvaidzināšanas ātrums (minūtēs), kurā fona pakalpojumam vajadzētu atkārtot datu nosūtīšanu.
+
+
+
+
(Tikai lasīt) WebHook ID, ko ierīce izveidoja fona pakalpojumu atjauninājumiem. Jūs to varētu pieprasīt atkļūdošanai.
- Wi-Fi/LTE izpildes režīms.
- Iespējot izpildīt komandas, izmantojot Wi-Fi/LTE.
- Ļauj lietotnei sākt bez tālruņa savienojuma (kad izvēlne ir kešatmiņā), un uzvedne izpildīt komandu, izmantojot Wi-Fi/LTE.
diff --git a/resources-lit/strings/strings.xml b/resources-lit/strings/strings.xml
index 80e28e4..844059d 100644
--- a/resources-lit/strings/strings.xml
+++ b/resources-lit/strings/strings.xml
@@ -22,12 +22,12 @@
API skambina per greitai. Prašau sulėtinti savo užklausas.
URL nerastas. Potenciali API URL klaida nustatymuose.
HomeAssistant
- Galima
+ Galimas
Talpykloje
Tikrinimas ...
URL nerastas. Potenciali konfigūracijos URL klaida nustatymuose.
Žinoma?
- Tuščia
+ Tuščias
Patvirtinta
Atmintis
@@ -57,25 +57,27 @@
Pasirinkite ...
API raktas, skirtas homeassistant.
- Ilgalaikis prieigos prieigos raktas.
- URL HOMEASISTUS API.
+ Ilgalaikis prieigos raktas.
+ URL HOMEASISTANT API.
URL meniu konfigūracijai (JSON).
Ar programos talpykla turėtų talpinti meniu konfigūraciją?
Ar programa turėtų išvalyti esamą talpyklą kitą kartą, kai ji bus paleista?
+ Įgalinti komandas vykdant „Wi-Fi“/LTE.
Ar programa turėtų pateikti grįžtamąjį ryšį per vibracijas?
Laikas per kelias sekundes. Išeikite iš programos po šio neveiklumo laikotarpio, kad išsaugotumėte įrenginio akumuliatorių.
Papildomas apklausos vėlavimas (per kelias sekundes). Prideda vėlavimą tarp visų meniu elementų būsenos atnaujinimo.
Po šio laiko (sekundėmis) veiksmo patvirtinimo dialogas automatiškai uždaromas ir veiksmas atšaukiamas. Nustatykite 0, kad išjungtumėte laiką.
- 4 skaitmenų kaištis, naudojamas visiems veiksmams, kuriems reikalingas patvirtinimas (0000–9999).
- Prašome sukonfigūruoti galiojantį 4 skaitmenų skaitinį PIN kodą nuo 0000 iki 9999 programos nustatymuose.
+ 4 skaitmenų kaištis, naudojamas visiems veiksmams, kuriems to reikia (0000–9999).
+ Programos nustatymuose prašome sukonfigūruoti galiojantį 4 skaitmenų skaitinį PIN tarp 0000 ir 9999.
Kairėje (išjungta) arba dešinėje (įjungta) meniu suderinimas.
Iš kairės į dešinę
Į dešinę į kairę
(Tik valdiklis) Automatiškai paleiskite programą iš valdiklio nelaukdamas čiaupo.
Įgalinkite fono paslaugą siųsti įrenginio akumuliatoriaus lygį, vietą ir (jei palaikoma) veiklos duomenis namų asistentui.
Atnaujinimo norma (minutėmis), kuriai fono paslauga turėtų pakartoti siuntimo duomenis.
+
+
+
+
(Skaitykite tik) „WebHook“ ID, kurį įrenginys sukūrė foninių paslaugų atnaujinimams. Jums gali prireikti derinimo.
- „Wi-Fi“/LTE vykdymo režimas.
- Įgalinti komandas per „Wi-Fi/LTE“.
- Leidžia programai paleisti be telefono ryšio (kai meniu yra talpykloje), ir raginkite vykdyti komandą per „Wi-Fi/LTE“.
diff --git a/resources-nob/strings/strings.xml b/resources-nob/strings/strings.xml
index 87d60b8..456c608 100644
--- a/resources-nob/strings/strings.xml
+++ b/resources-nob/strings/strings.xml
@@ -62,11 +62,12 @@
URL for menykonfigurasjon (JSON).
Bør applikasjonsbufferen menykonfigurasjonen?
Bør applikasjonen fjerne den eksisterende cachen neste gang den startes?
+ Aktiver utførende kommandoer over Wi-Fi/LTE.
Bør applikasjonen gi tilbakemelding via vibrasjoner?
Tidsavbrudd på sekunder. Gå ut av applikasjonen etter denne perioden med inaktivitet for å lagre enhetsbatteriet.
Ytterligere avstemningsforsinkelse (på sekunder). Legger til en forsinkelse mellom statusoppdateringen av alle menyelementer.
Etter denne tiden (på sekunder) blir en bekreftelsesdialog for en handling automatisk lukket og handlingen blir kansellert. Sett til 0 for å deaktivere tidsavbruddet.
- 4-sifret PIN-kode som skal brukes til alle handlinger som krever bekreftelse (0000-9999).
+ 4-sifret pinne som skal brukes til alle handlinger som krever det (0000-9999).
Konfigurer en gyldig 4-sifret numerisk pinne mellom 0000 og 9999 i applikasjonsinnstillingene.
Venstre (av) eller høyre (på) menyjustering.
Fra venstre til høyre
@@ -74,8 +75,9 @@
(Bare widget) Start automatisk applikasjonen fra widgeten uten å vente på et trykk.
Aktiver bakgrunnstjenesten å sende enhetens batterinivå, plassering og (hvis støttet) aktivitetsdata til hjemmeassistent.
Oppdateringsfrekvensen (på få minutter) som bakgrunnstjenesten skal gjenta sendingsdata.
+
+
+
+
(Bare les) Webhook -IDen som er opprettet av enheten for oppdateringer av bakgrunnstjenester. Du kan kreve dette for feilsøking.
- Wi-Fi/LTE utførelsesmodus.
- Aktiver utførende kommandoer over Wi-Fi/LTE.
- Lar appen starte uten telefonforbindelse (når menyen er hurtigbufret), og be om å utføre kommando over Wi-Fi/LTE.
diff --git a/resources-pol/strings/strings.xml b/resources-pol/strings/strings.xml
index ebe0bb2..4d44de0 100644
--- a/resources-pol/strings/strings.xml
+++ b/resources-pol/strings/strings.xml
@@ -44,7 +44,7 @@
Potencjalny błąd
towary drugiej jakości
Błąd szablonu
- URL API nie może mieć cięcia „/”.
+ URL API nie może mieć tulokingowego cięcia „/”.
Nie płynny
Niekonfigurowany
Żądanie HTTP Zwracane kod błędu =
@@ -53,7 +53,7 @@
Brak dostępnych Wi-Fi lub LTE
Wykonaj Wi-Fi/LTE?
Wysyłanie do asystenta domowego.
- Nie otrzymano danych.
+ Brak danych.
Wybierać...
Klucz API dla Homeassistant.
@@ -62,11 +62,12 @@
URL dla konfiguracji menu (JSON).
Czy aplikacja powinna buforować konfigurację menu?
Czy aplikacja powinna wyczyścić istniejącą pamięć podręczną następnym razem, gdy zostanie uruchomiona?
+ Włącz wykonywanie poleceń przez Wi-Fi/LTE.
Czy aplikacja powinna przekazywać informacje zwrotne za pośrednictwem wibracji?
Limit czasu w sekundach. Wyjdź z aplikacji po tym okresie bezczynności, aby zapisać akumulator urządzenia.
Dodatkowe opóźnienie ankiety (w sekundach). Dodaje opóźnienie między aktualizacją statusu wszystkich elementów menu.
Po tym czasie (w sekundach) okno dialogowe potwierdzenia akcji jest automatycznie zamknięte, a akcja jest anulowana. Ustaw na 0, aby wyłączyć limit czasu.
- 4-cyfrowy pin do użycia dla wszystkich działań wymagających potwierdzenia (0000-9999).
+ 4-cyfrowy szpilka do użycia do wszystkich działań, które go wymagają (0000-9999).
W ustawieniach aplikacji skonfiguruj prawidłowy 4-cyfrowy pin liczbowy między 0000 a 9999.
Lewy (wyłączony) lub w prawo (na) wyrównanie menu.
Od lewej do prawej
@@ -74,8 +75,9 @@
(Tylko widżet) Automatycznie uruchom aplikację z widżetu bez oczekiwania na dotknięcie.
Włącz usługę w tle wysyłanie poziomu baterii, lokalizacji i (jeśli jest obsługiwane) dane o aktywności do Asystenta Home.
Szybkość odświeżania (w minutach), w której usługa tła powinna powtarzać dane wysyłania.
+
+
+
+
(Tylko odczyt) Identyfikator WebHook utworzony przez urządzenie dla aktualizacji usług w tle. Możesz tego wymagać do debugowania.
- Tryb wykonania Wi-Fi/LTE.
- Włącz wykonywanie poleceń przez Wi-Fi/LTE.
- Umożliwia aplikację uruchamianie bez połączenia telefonicznego (gdy menu jest buforowane) i monit o wykonanie polecenia przez Wi-Fi/LTE.
diff --git a/resources-por/strings/strings.xml b/resources-por/strings/strings.xml
index 066e2c2..36cf839 100644
--- a/resources-por/strings/strings.xml
+++ b/resources-por/strings/strings.xml
@@ -62,11 +62,12 @@
URL para configuração de menu (JSON).
O aplicativo deve cache a configuração do menu?
O aplicativo deve limpar o cache existente na próxima vez que for iniciado?
+ Habilite os comandos de execução sobre Wi-Fi/LTE.
O aplicativo deve fornecer feedback por meio de vibrações?
Tempo limite em segundos. Saia do aplicativo após esse período de inatividade para salvar a bateria do dispositivo.
Atraso adicional da pesquisa (em segundos). Adiciona um atraso entre a atualização de status de todos os itens do menu.
Após esse período (em segundos), uma caixa de diálogo de confirmação para uma ação é fechada automaticamente e a ação é cancelada. Defina como 0 para desativar o tempo limite.
- PIN de 4 dígitos a serem usados para todas as ações que requerem confirmação (0000-9999).
+ PIN de 4 dígitos a ser usado para todas as ações que o exigem (0000-9999).
Configure um pino numérico de 4 dígitos válido entre 0000 e 9999 nas configurações do aplicativo.
Alinhamento do menu esquerdo (desativado) ou direito (on).
Da esquerda para a direita
@@ -74,8 +75,9 @@
(Somente widget) Inicie automaticamente o aplicativo do widget sem esperar por um toque.
Habilite o serviço em segundo plano para enviar o nível da bateria do dispositivo, localização e (se suportado) dados de atividade para o assistente doméstico.
A taxa de atualização (em minutos) na qual o serviço em segundo plano deve repetir os dados de envio.
+
+
+
+
(Somente leitura) O ID do webhook criado pelo dispositivo para atualizações de serviço em segundo plano. Você pode exigir isso para depuração.
- Modo de execução Wi-Fi/LTE.
- Habilite os comandos de execução sobre Wi-Fi/LTE.
- Permite que o aplicativo inicie sem conexão de telefone (quando o menu é armazenado em cache) e solicite a execução do comando sobre Wi-Fi/LTE.
diff --git a/resources-ron/strings/strings.xml b/resources-ron/strings/strings.xml
index 730299b..f50596d 100644
--- a/resources-ron/strings/strings.xml
+++ b/resources-ron/strings/strings.xml
@@ -33,7 +33,7 @@
Memorie
Nici o cheie API în setările aplicației.
Fără URL API în setările aplicației.
- Nici o adresă URL de configurare în setările aplicației.
+ Fără URL de configurare în setările aplicației.
Fără conexiune la internet.
Niciun JSON nu a revenit de la cererea HTTP.
Fără conexiune telefonică.
@@ -62,11 +62,12 @@
URL pentru configurația meniului (JSON).
Aplicația cache ar trebui să fie configurația meniului?
Aplicația ar trebui să șterge cache -ul existent data viitoare când va fi pornită?
+ Activați executarea comenzilor prin Wi-Fi/LTE.
Aplicația ar trebui să ofere feedback prin vibrații?
Timeout în câteva secunde. Ieșiți din aplicație după această perioadă de inactivitate pentru a economisi bateria dispozitivului.
Întârziere suplimentară a sondajului (în secunde). Adăugă o întârziere între actualizarea de stare a tuturor elementelor din meniu.
După acest timp (în câteva secunde), un dialog de confirmare pentru o acțiune este închis automat și acțiunea este anulată. Setați la 0 pentru a dezactiva expirarea.
- Pinul de 4 cifre pentru a fi utilizat pentru toate acțiunile care necesită confirmare (0000-9999).
+ Pinul de 4 cifre pentru a fi utilizat pentru toate acțiunile care îl necesită (0000-9999).
Vă rugăm să configurați un pin numeric valid cu 4 cifre între 0000 și 9999 în setările aplicației.
Alinierea meniului stânga (oprită) sau dreapta (pornită).
De la stânga la dreapta
@@ -74,8 +75,9 @@
(Numai widget) Porniți automat aplicația din widget fără a aștepta o atingere.
Permiteți serviciului de fundal să trimită datele bateriei, locația și (dacă este acceptat) date de activitate către asistentul de acasă.
Rata de actualizare (în câteva minute) la care serviciul de fundal ar trebui să repete date de trimitere.
+
+
+
+
(Numai citiți) ID -ul WebHook creat de dispozitiv pentru actualizări de servicii de fundal. S -ar putea să solicitați acest lucru pentru depanare.
- Modul de execuție Wi-Fi/LTE.
- Activați executarea comenzilor prin Wi-Fi/LTE.
- Permite aplicației să înceapă fără conexiune telefonică (când meniul este în cache) și solicită să execute comanda prin Wi-Fi/LTE.
diff --git a/resources-slo/strings/strings.xml b/resources-slo/strings/strings.xml
index ef82dfb..3f4fbb1 100644
--- a/resources-slo/strings/strings.xml
+++ b/resources-slo/strings/strings.xml
@@ -62,11 +62,12 @@
URL pre konfiguráciu ponuky (JSON).
Mala by sa aplikácia vyrovnávať konfiguráciu ponuky?
Mala by aplikácia vymazať existujúcu vyrovnávaciu pamäť nabudúce, keď sa začne?
+ Povoliť vykonávanie príkazov cez Wi-Fi/LTE.
Mala by aplikácia poskytovať spätnú väzbu prostredníctvom vibrácií?
Časový limit v sekundách. Opustite aplikáciu po tomto období nečinnosti, aby ste uložili batériu zariadenia.
Ďalšie oneskorenie ankety (v sekundách). Pridáva oneskorenie medzi aktualizáciou stavu všetkých položiek ponuky.
Po tomto čase (v sekundách) sa dialógové okno pre akciu automaticky zatvorí a akcia je zrušená. Nastavte na 0, aby ste zakázali časový limit.
- 4-ciferníkový kolík, ktorý sa má použiť pre všetky akcie, ktoré si vyžadujú potvrdenie (0000-9999).
+ 4-ciferníkový kolík, ktorý sa má použiť pre všetky akcie, ktoré to vyžadujú (0000-9999).
V nastaveniach aplikácie nakonfigurujte platný štvorciferný číselný kolík medzi 0000 a 9999.
Zarovnanie ponuky vľavo (vypnuté) alebo doprava.
Zľava doprava
@@ -74,8 +75,9 @@
(Iba widget) Automaticky spustite aplikáciu z miniaplikácie bez čakania na kohútik.
Povoľte službu na pozadí, ktorá bude do Home Assistenta odosielať údaje o stave batérie zariadenia, polohe a (ak je podporované) o aktivite.
Rýchlosť obnovenia (v minútach), pri ktorej by služba pozadia mala opakovať odosielanie údajov.
+
+
+
+
(Iba prečítajte) ID WebHook vytvorené zariadením pre aktualizácie služieb na pozadí. Možno to potrebujete na ladenie.
- Režim vykonávania Wi-Fi/LTE.
- Povoliť vykonávanie príkazov cez Wi-Fi/LTE.
- Umožňuje aplikácii spustiť bez pripojenia telefónu (keď je ponuka ukladaná do vyrovnávacej pamäte) a výzva na vykonanie príkazu cez Wi-Fi/LTE.
diff --git a/resources-slv/strings/strings.xml b/resources-slv/strings/strings.xml
index 2dacc5e..0971790 100644
--- a/resources-slv/strings/strings.xml
+++ b/resources-slv/strings/strings.xml
@@ -62,20 +62,22 @@
URL za konfiguracijo menija (JSON).
Ali naj aplikacija predpomni konfiguracija menija?
Ali bi morala aplikacija očistiti obstoječi predpomnilnik naslednjič, ko se začne?
+ Omogoči izvajanje ukazov prek Wi-Fi/LTE.
Ali bi morala aplikacija posredovati povratne informacije z vibracijami?
Časovna omejitev v nekaj sekundah. Po tem obdobju neaktivnosti zapustite aplikacijo, da shranite baterijo naprave.
Dodatna zamuda ankete (v sekundah). Doda zamudo med posodobitvijo stanja vseh elementov menija.
Po tem času (v sekundah) se potrditveno pogovorno okno za dejanje samodejno zapre in dejanje prekliče. Nastavite na 0, da onemogočite časovno omejitev.
- 4-mestni zatič, ki se uporablja za vsa dejanja, ki zahtevajo potrditev (0000-9999).
+ 4-mestni zatič, ki ga je treba uporabiti za vsa dejanja, ki ga zahtevajo (0000-9999).
V nastavitvah aplikacije konfigurirajte veljaven 4-mestni številčni zatič med 0000 in 9999.
Levo (izklopljeno) ali desno (vklopljeno) poravnavo menija.
Levo proti desni
Desno na levo
(Samo pripomoček) Samodejno zaženite aplikacijo iz pripomočka, ne da bi čakali na pipo.
- Omogočite, da storitve v ozadju pošljete raven baterije naprave, lokacijo in (če so podprte) podatki o dejavnostih domačemu asistentu.
- Hitrost osveževanja (v nekaj minutah), pri kateri naj bo storitev v ozadju ponovila podatke za pošiljanje.
+ Omogočite storitve v ozadju, da pošlje nivo baterije, lokacijo in (če je podprta) podatke o dejavnostih domačemu asistentu.
+ Stopnja osveževanja (v nekaj minutah), pri kateri naj bi storitev v ozadju ponovila podatke za pošiljanje.
+
+
+
+
(Samo preberite) ID spletnega mesta, ki ga je ustvarila naprava za posodobitve storitev v ozadju. To boste morda potrebovali za odpravljanje napak.
- Način izvedbe Wi-Fi/LTE.
- Omogoči izvajanje ukazov prek Wi-Fi/LTE.
- Omogoča, da se aplikacija zažene brez telefonske povezave (ko je meni predpomnjen), in poziva, da izvede ukaz prek Wi-Fi/LTE.
diff --git a/resources-spa/strings/strings.xml b/resources-spa/strings/strings.xml
index 96a308b..d610033 100644
--- a/resources-spa/strings/strings.xml
+++ b/resources-spa/strings/strings.xml
@@ -62,11 +62,12 @@
URL para la configuración del menú (JSON).
¿Debería la aplicación almacenar en caché la configuración del menú?
¿Debería la aplicación borrar el caché existente la próxima vez que se inicie?
+ Habilite la ejecución de comandos sobre Wi-Fi/LTE.
¿Debería la aplicación proporcionar comentarios a través de vibraciones?
Tiempo de espera en segundos. Salga de la aplicación después de este período de inactividad para guardar la batería del dispositivo.
Retraso de encuesta adicional (en segundos). Agrega un retraso entre la actualización de estado de todos los elementos del menú.
Después de este tiempo (en segundos), un diálogo de confirmación para una acción se cierra automáticamente y se cancela la acción. Establecer en 0 para deshabilitar el tiempo de espera.
- Pin de 4 dígitos que se utilizará para todas las acciones que requieren confirmación (0000-9999).
+ Pin de 4 dígitos que se utilizará para todas las acciones que lo requieren (0000-9999).
Configure un PIN numérico válido de 4 dígitos entre 0000 y 9999 en la configuración de la aplicación.
Alineación del menú izquierda (apagada) o derecha (encendida).
De izquierda a derecha
@@ -74,8 +75,9 @@
(Solo widget) Inicie automáticamente la aplicación desde el widget sin esperar un toque.
Habilite el servicio de fondo para enviar el nivel de batería del dispositivo, la ubicación y (si se admiten) datos de actividad al asistente de inicio.
La tasa de actualización (en minutos) en la que el servicio de fondo debe repetir los datos de envío.
+
+
+
+
(Solo lea) la ID de webhook creada por el dispositivo para actualizaciones del servicio de fondo. Es posible que necesite esto para la depuración.
- Modo de ejecución Wi-Fi/LTE.
- Habilite la ejecución de comandos sobre Wi-Fi/LTE.
- Permite que la aplicación comience sin conexión del teléfono (cuando el menú se almacena en caché) y solicite ejecutar el comando a través de Wi-Fi/LTE.
diff --git a/resources-swe/strings/strings.xml b/resources-swe/strings/strings.xml
index d87268f..5bf83bb 100644
--- a/resources-swe/strings/strings.xml
+++ b/resources-swe/strings/strings.xml
@@ -62,20 +62,22 @@
URL för menykonfiguration (JSON).
Bör applikationen cache menykonfigurationen?
Bör applikationen rensa den befintliga cachen nästa gång den startas?
+ Aktivera körkommandon över Wi-Fi/LTE.
Bör applikationen ge feedback via vibrationer?
- Timeout på några sekunder. Avsluta applikationen efter denna inaktivitetsperiod för att spara enhetsbatteriet.
+ Timeout på några sekunder. Exit the application after this period of inactivity to save the device battery.
Ytterligare undersökningsfördröjning (på några sekunder). Lägger till en försening mellan statusuppdateringen av alla menyalternativ.
Efter denna tid (på några sekunder) stängs en bekräftelsedialog för en åtgärd automatiskt och åtgärden avbryts. Ställ in på 0 för att inaktivera timeout.
- 4-siffriga stift som ska användas för alla åtgärder som kräver bekräftelse (0000-9999).
+ 4-siffriga stift som ska användas för alla åtgärder som kräver det (0000-9999).
Konfigurera en giltig fyrsiffrig numerisk stift mellan 0000 och 9999 i applikationsinställningarna.
Vänster (av) eller höger (på) menyinriktning.
Vänster till höger
Höger till vänster
(Endast widget) Starta automatiskt applikationen från widgeten utan att vänta på en kran.
Aktivera bakgrundstjänsten att skicka enhetens batterinivå, plats och (om stödd) aktivitetsdata till hemassistent.
- Uppdateringsfrekvensen (på några minuter) där bakgrundstjänsten ska upprepa skicka data.
+ Uppdateringsfrekvensen (i minuter) där bakgrundstjänsten ska upprepa skicka data.
+
+
+
+
(Endast läs) Webhook -ID som skapats av enheten för uppdateringar av bakgrundstjänster. Du kan behöva detta för felsökning.
- Wi-Fi/LTE exekveringsläge.
- Aktivera körkommandon över Wi-Fi/LTE.
- Tillåter appen att starta utan telefonanslutning (när menyn är cachad) och uppmanas att köra kommando över Wi-Fi/LTE.
diff --git a/resources-tha/strings/strings.xml b/resources-tha/strings/strings.xml
index 1ddbd97..7a560ac 100644
--- a/resources-tha/strings/strings.xml
+++ b/resources-tha/strings/strings.xml
@@ -62,11 +62,12 @@
URL สำหรับการกำหนดค่าเมนู (JSON)
แอปพลิเคชันควรแคชการกำหนดค่าเมนูหรือไม่?
แอปพลิเคชันควรล้างแคชที่มีอยู่ครั้งต่อไปในครั้งต่อไปหรือไม่
+ เปิดใช้งานการดำเนินการคำสั่งผ่าน Wi-Fi/LTE
แอปพลิเคชันควรให้ข้อเสนอแนะผ่านการสั่นสะเทือนหรือไม่?
หมดเวลาในไม่กี่วินาที ออกจากแอปพลิเคชันหลังจากช่วงเวลาที่ไม่มีการใช้งานเพื่อประหยัดแบตเตอรี่อุปกรณ์
ความล่าช้าในการสำรวจเพิ่มเติม (ในไม่กี่วินาที) เพิ่มความล่าช้าระหว่างการอัปเดตสถานะของรายการเมนูทั้งหมด
หลังจากเวลานี้ (ในไม่กี่วินาที) กล่องโต้ตอบยืนยันสำหรับการกระทำจะถูกปิดโดยอัตโนมัติและการดำเนินการจะถูกยกเลิก ตั้งค่าเป็น 0 เพื่อปิดการหมดเวลา
- พิน 4 หลักที่จะใช้สำหรับการกระทำทั้งหมดที่ต้องมีการยืนยัน (0000-9999)
+ พิน 4 หลักที่จะใช้สำหรับการกระทำทั้งหมดที่ต้องการ (0000-9999)
โปรดกำหนดค่าพินตัวเลข 4 หลักที่ถูกต้องระหว่าง 0000 ถึง 9999 ในการตั้งค่าแอปพลิเคชัน
การจัดตำแหน่งเมนูซ้าย (ปิด) หรือขวา (เปิด)
จากซ้ายไปขวา
@@ -74,8 +75,9 @@
(วิดเจ็ตเท่านั้น) เริ่มแอปพลิเคชันจากวิดเจ็ตโดยอัตโนมัติโดยไม่ต้องรอแตะ
เปิดใช้งานบริการพื้นหลังเพื่อส่งระดับแบตเตอรี่ของอุปกรณ์ตำแหน่งและข้อมูลกิจกรรม (ถ้ารองรับ) ไปยังผู้ช่วยที่บ้าน
อัตราการรีเฟรช (ในไม่กี่นาที) ที่บริการพื้นหลังควรส่งข้อมูลซ้ำ
+
+
+
+
(อ่านเท่านั้น) ID WebHook ที่สร้างโดยอุปกรณ์สำหรับการอัปเดตบริการพื้นหลัง คุณอาจต้องการสิ่งนี้สำหรับการดีบัก
- โหมดการดำเนินการ Wi-Fi/LTE
- เปิดใช้งานการดำเนินการคำสั่งผ่าน Wi-Fi/LTE
- อนุญาตให้แอปเริ่มต้นโดยไม่ต้องเชื่อมต่อโทรศัพท์ (เมื่อเมนูถูกแคช) และแจ้งให้เรียกใช้คำสั่งผ่าน Wi-Fi/LTE
diff --git a/resources-tur/strings/strings.xml b/resources-tur/strings/strings.xml
index 0e1ce33..058bcb1 100644
--- a/resources-tur/strings/strings.xml
+++ b/resources-tur/strings/strings.xml
@@ -62,20 +62,22 @@
Menü yapılandırması için URL (JSON).
Uygulama menü yapılandırmasını önbelleğe almalı mı?
Uygulama bir dahaki sefere başladığında mevcut önbelleği temizlemeli mi?
+ Wi-Fi/LTE üzerinden komutların yürütülmesini etkinleştirin.
Uygulama titreşimlerle geri bildirim sağlamalı mı?
Saniyeler içinde zaman aşımı. Cihaz bataryasını kaydetmek için bu hareketsizlik döneminden sonra uygulamadan çıkın.
Ek anket gecikmesi (saniyeler içinde). Tüm menü öğelerinin durum güncellemesi arasında bir gecikme ekler.
Bu süreden sonra (saniye cinsinden), bir eylem için bir onay iletişim kutusu otomatik olarak kapatılır ve eylem iptal edilir. Zaman aşımını devre dışı bırakmak için 0 olarak ayarlayın.
- Onay gerektiren tüm eylemler için kullanılacak 4 haneli pim (0000-9999).
+ 4 basamaklı pim gerektiren tüm eylemler için kullanılacak (0000-9999).
Lütfen uygulama ayarlarında 0000 ve 9999 arasında geçerli bir 4 haneli sayısal pimi yapılandırın.
Sol (kapalı) veya sağ (açık) menü hizalaması.
Soldan sağa
- Sağ sola
+ Sağdan sola
(Yalnızca widget) Bir musluk beklemeden uygulamayı widget'tan otomatik olarak başlatın.
Arka plan hizmetinin aygıt pil seviyesini, konumunu ve (desteklenirse) etkinlik verilerini ev asistanına göndermesini etkinleştirin.
Arka plan hizmetinin veri göndermeyi tekrarlaması gereken yenileme hızı (dakika cinsinden).
+
+
+
+
(Yalnızca okuyun) Arka plan hizmeti güncellemeleri için cihaz tarafından oluşturulan WebHook kimliği. Hata ayıklama için bunu isteyebilirsiniz.
- Wi-Fi/LTE Yürütme Modu.
- Wi-Fi/LTE üzerinden komutların yürütülmesini etkinleştirin.
- Uygulamanın telefon bağlantısı olmadan (menü önbelleğe alındığında) başlamasına izin verir ve Wi-Fi/LTE üzerinden komutu yürütme istemek.
diff --git a/resources-ukr/strings/strings.xml b/resources-ukr/strings/strings.xml
index b28e737..90a1c4d 100644
--- a/resources-ukr/strings/strings.xml
+++ b/resources-ukr/strings/strings.xml
@@ -46,15 +46,15 @@
Помилка шаблону
URL -адреса API не повинна мати кінцеву косою косою '/'.
Недоступний
- Неконфігурований
- Запит HTTP повернувся код помилки =
+ Неінфігурований
+ Запит HTTP Повернувся код помилки =
Не вдалося зареєструвати WebHook
Неправильна шпилька
- Немає Wi-Fi або LTE
+ Відсутність Wi-Fi або LTE
Виконати через Wi-Fi/LTE?
Відправлення домашнього помічника.
- Жодних даних не отримано.
-
+ Не отримані даних.
+
Виберіть ...
Ключ API для домашніх систем.
Довгоживучий маркер доступу.
@@ -62,11 +62,12 @@
URL -адреса для конфігурації меню (JSON).
Чи повинен додатковий кеш конфігурації меню?
Чи повинен програма очистити існуючий кеш наступного разу, коли він буде запущений?
+ Увімкнути виконання команд над Wi-Fi/LTE.
Чи повинен програма надавати зворотній зв'язок через вібрації?
Тайм -аут за лічені секунди. Вийдіть із програми після цього періоду бездіяльності, щоб зберегти акумулятор пристрою.
Додаткова затримка опитування (за лічені секунди). Додає затримку між оновленням статусу всіх пунктів меню.
Після цього часу (за лічені секунди) діалогове вікно підтвердження дії автоматично закривається і дія скасовується. Встановіть 0, щоб відключити тайм -аут.
- 4-значний PIN-код, який буде використовуватися для всіх дій, які потребують підтвердження (0000-9999).
+ 4-значний PIN-код, який слід використовувати для всіх дій, які потребують цього (0000-9999).
Будь ласка, налаштуйте дійсний 4-значний числовий штифт між 0000 та 9999 у налаштуваннях програми.
Зліва (вимкнено) або праворуч (увімкнено) вирівнювання меню.
Зліва направо
@@ -74,8 +75,9 @@
(Тільки віджет) автоматично запустіть програму з віджета, не чекаючи натискання.
Увімкніть фонову службу для надсилання рівня акумулятора пристрою, розташування та (за підтримки) даних активності домашньому помічнику.
Швидкість оновлення (за лічені хвилини), в якій фонова послуга повинна повторити надсилання даних.
+
+
+
+
(Лише читайте) Ідентифікатор WebHook, створений пристроєм для оновлень фонових служб. Вам може знадобитися це для налагодження.
- Режим виконання Wi-Fi/LTE.
- Увімкнути виконання команд над Wi-Fi/LTE.
- Дозволяє додаток починати без підключення до телефону (коли меню кешовано) та підказка виконувати команду через Wi-Fi/LTE.
diff --git a/resources-vie/strings/strings.xml b/resources-vie/strings/strings.xml
index 69d1a43..f2266be 100644
--- a/resources-vie/strings/strings.xml
+++ b/resources-vie/strings/strings.xml
@@ -62,11 +62,12 @@
URL cho cấu hình menu (JSON).
Bộ đệm ứng dụng có nên cấu hình menu không?
Ứng dụng có nên xóa bộ đệm hiện tại vào lần tới khi nó được bắt đầu không?
+ Bật các lệnh thực thi qua Wi-Fi/LTE.
Ứng dụng có nên cung cấp phản hồi thông qua các rung động?
Thời gian chờ trong giây. Thoát khỏi ứng dụng sau khoảng thời gian không hoạt động để lưu pin thiết bị.
Độ trễ thăm dò ý kiến bổ sung (tính bằng giây). Thêm độ trễ giữa bản cập nhật trạng thái của tất cả các mục menu.
Sau thời gian này (tính bằng giây), hộp thoại xác nhận cho một hành động sẽ tự động đóng và hành động bị hủy. Đặt thành 0 để vô hiệu hóa thời gian chờ.
- Pin 4 chữ số được sử dụng cho tất cả các hành động yêu cầu xác nhận (0000-9999).
+ Pin 4 chữ số được sử dụng cho tất cả các hành động yêu cầu nó (0000-9999).
Vui lòng định cấu hình chân số 4 chữ số hợp lệ giữa 0000 đến 9999 trong cài đặt ứng dụng.
Bên trái (tắt) hoặc bên phải (trên) căn chỉnh menu.
Trái sang phải
@@ -74,8 +75,9 @@
(Chỉ Widget) Tự động khởi động ứng dụng từ tiện ích mà không cần chờ vòi.
Cho phép dịch vụ nền để gửi dữ liệu hoạt động, vị trí và (nếu được hỗ trợ) của thiết bị đến trợ lý nhà.
Tốc độ làm mới (tính bằng phút) mà dịch vụ nền sẽ lặp lại gửi dữ liệu.
+
+
+
+
(Chỉ đọc) ID webhook được tạo bởi thiết bị để cập nhật dịch vụ nền. Bạn có thể yêu cầu điều này để gỡ lỗi.
- Chế độ thực hiện Wi-Fi/LTE.
- Bật các lệnh thực thi qua Wi-Fi/LTE.
- Cho phép ứng dụng bắt đầu mà không cần kết nối điện thoại (khi menu được lưu trữ) và nhắc nhở thực thi lệnh qua Wi-Fi/LTE.
diff --git a/resources-zhs/strings/strings.xml b/resources-zhs/strings/strings.xml
index 9789fd9..f02413c 100644
--- a/resources-zhs/strings/strings.xml
+++ b/resources-zhs/strings/strings.xml
@@ -62,11 +62,12 @@
菜单配置的URL(JSON)。
应用程序缓存菜单配置应该缓存吗?
应用程序下次启动时是否应该清除现有的高速缓存?
+ 在Wi-Fi/LTE上启用执行命令。
应用程序是否应该通过振动提供反馈?
超时几秒钟。在此不活动期间退出应用程序以节省设备电池。
额外的民意调查延迟(以秒为单位)。在所有菜单项的状态更新之间添加延迟。
在此时间(以秒为单位)之后,将自动关闭操作的确认对话框,并取消操作。设置为0以禁用超时。
- 4位PIN用于所有需要确认的动作(0000-9999)。
+ 4位PIN用于所有需要它的动作(0000-9999)。
请在应用程序设置中配置有效的4位数字引脚。
左(关闭)或右(ON)菜单对齐。
从左到右
@@ -74,8 +75,9 @@
(仅小部件)自动从小部件启动应用程序,而无需等待点击。
使背景服务能够将设备电池电量,位置以及(如果支持)将活动数据发送给家庭助手。
背景服务应重复发送数据的刷新率(分钟为几分钟)。
+
+
+
+
(仅读)设备创建的Webhook ID用于背景服务更新。您可能需要此次调试。
- Wi-Fi/LTE执行模式。
- 在Wi-Fi/LTE上启用执行命令。
- 允许该应用在没有电话连接的情况下启动(菜单被缓存时),并提示通过Wi-Fi/LTE执行命令。
diff --git a/resources-zht/strings/strings.xml b/resources-zht/strings/strings.xml
index c5ea6b1..8f0a606 100644
--- a/resources-zht/strings/strings.xml
+++ b/resources-zht/strings/strings.xml
@@ -62,11 +62,12 @@
菜單配置的URL(JSON)。
應用程序緩存菜單配置應該緩存嗎?
應用程序下次啟動時是否應該清除現有的高速緩存?
+ 在Wi-Fi/LTE上啟用執行命令。
應用程序是否應該通過振動提供反饋?
超時幾秒鐘。在此不活動期間退出應用程序以節省設備電池。
額外的民意調查延遲(以秒為單位)。在所有菜單項的狀態更新之間添加延遲。
在此時間(以秒為單位)之後,將自動關閉操作的確認對話框,並取消操作。設置為0以禁用超時。
- 4位PIN用於所有需要確認的動作(0000-9999)。
+ 4位PIN用於所有需要它的動作(0000-9999)。
請在應用程序設置中配置有效的4位數字引腳。
左(關閉)或右(ON)菜單對齊。
從左到右
@@ -74,8 +75,9 @@
(僅小部件)自動從小部件啟動應用程序,而無需等待點擊。
使背景服務能夠將設備電池電量,位置以及(如果支持)將活動數據發送給家庭助手。
背景服務應重複發送數據的刷新率(分鐘為幾分鐘)。
+
+
+
+
(僅讀)設備創建的Webhook ID用於背景服務更新。您可能需要此次調試。
- Wi-Fi/LTE執行模式。
- 在Wi-Fi/LTE上啟用執行命令。
- 允許該應用在沒有電話連接的情況下啟動(菜單被緩存時),並提示通過Wi-Fi/LTE執行命令。
diff --git a/resources-zsm/strings/strings.xml b/resources-zsm/strings/strings.xml
index 166e193..635b699 100644
--- a/resources-zsm/strings/strings.xml
+++ b/resources-zsm/strings/strings.xml
@@ -38,7 +38,7 @@
Tiada JSON kembali dari permintaan HTTP.
Tiada sambungan telefon.
Tiada sambungan telefon, tiada menu cache.
- Tiada respons, periksa sambungan internet
+ Tiada Respons, Periksa Sambungan Internet
Meminta tamat masa
Input pin terkunci untuk
Kesalahan yang berpotensi
@@ -62,20 +62,22 @@
URL untuk Konfigurasi Menu (JSON).
Sekiranya aplikasi cache konfigurasi menu?
Sekiranya permohonan membersihkan cache yang sedia ada pada masa akan datang, ia bermula?
+ Dayakan perintah melaksanakan melalui Wi-Fi/LTE.
Sekiranya permohonan memberikan maklum balas melalui getaran?
Tamat masa dalam beberapa saat. Keluar dari permohonan selepas tempoh tidak aktif ini untuk menyimpan bateri peranti.
Kelewatan tinjauan tambahan (dalam saat). Menambah kelewatan antara kemas kini status semua item menu.
Selepas masa ini (dalam saat), dialog pengesahan untuk tindakan ditutup secara automatik dan tindakan dibatalkan. Tetapkan ke 0 untuk melumpuhkan masa tamat.
- PIN 4 digit untuk digunakan untuk semua tindakan yang memerlukan pengesahan (0000-9999).
- Sila konfigurasikan pin angka 4 digit yang sah antara 0000 dan 9999 dalam tetapan aplikasi.
+ Pin 4 digit untuk digunakan untuk semua tindakan yang memerlukannya (0000-9999).
+ Sila konfigurasikan pin angka 4 digit yang sah antara 0000 dan 9999 dalam tetapan permohonan.
Penjajaran menu kiri (off) atau kanan (ON).
Kiri ke kanan
Kanan ke kiri
(Widget sahaja) Secara automatik memulakan aplikasi dari widget tanpa menunggu ketuk.
Dayakan perkhidmatan latar belakang untuk menghantar data aktiviti bateri, lokasi dan (jika disokong) ke Pembantu Rumah.
- Kadar penyegaran (dalam minit) di mana perkhidmatan latar belakang harus mengulangi data menghantar.
+ Kadar penyegaran (dalam minit) di mana perkhidmatan latar belakang harus mengulangi data penghantaran.
+
+
+
+
(Baca sahaja) ID Webhook yang dibuat oleh peranti untuk kemas kini perkhidmatan latar belakang. Anda mungkin memerlukan ini untuk debugging.
- Mod pelaksanaan Wi-Fi/LTE.
- Dayakan perintah melaksanakan melalui Wi-Fi/LTE.
- Membolehkan aplikasi bermula tanpa sambungan telefon (apabila menu di-cache), dan segera untuk melaksanakan perintah melalui Wi-Fi/LTE.
diff --git a/resources/settings/properties.xml b/resources/settings/properties.xml
index d588b4d..4deef67 100644
--- a/resources/settings/properties.xml
+++ b/resources/settings/properties.xml
@@ -94,6 +94,20 @@
-->
15
+
+
+
+
+
+
URL for menu configuration (JSON).
Should the application cache the menu configuration?
Should the application clear the existing cache next time it is started?
+ Enable executing commands over Wi-Fi/LTE.
Should the application provide feedback via vibrations?
Timeout in seconds. Exit the application after this period of inactivity to save the device battery.
Additional poll delay (in seconds). Adds a delay between the status update of all menu items.
After this time (in seconds), a confirmation dialog for an action is automatically closed and the action is cancelled. Set to 0 to disable the timeout.
- 4-digit PIN to be used for all actions that require confirmation (0000-9999).
+ 4-digit PIN to be used for all actions that require it (0000-9999).
Please configure a valid 4-digit numeric PIN between 0000 and 9999 in the application settings.
Left (off) or Right (on) Menu Alignment.
Left to right
@@ -69,8 +70,9 @@
(Widget only) Automatically start the application from the widget without waiting for a tap.
Enable the background service to send the device battery level, location and (if supported) activity data to Home Assistant.
The refresh rate (in minutes) at which the background service should repeat sending data.
+
+
+
+
(Read only) The Webhook ID created by the device for background service updates. You might require this for debugging.
- Wi-Fi/LTE execution mode.
- Enable executing commands over Wi-Fi/LTE.
- Allows the app to start without phone connection (when menu is cached), and prompt to execute command over Wi-Fi/LTE.
diff --git a/source/BackgroundServiceDelegate.mc b/source/BackgroundServiceDelegate.mc
index 71ea4c5..feaa4d4 100644
--- a/source/BackgroundServiceDelegate.mc
+++ b/source/BackgroundServiceDelegate.mc
@@ -158,9 +158,9 @@ class BackgroundServiceDelegate extends System.ServiceDelegate {
},
{
:method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON
- },
+ }),
:responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
},
method(:onReturnDoUpdate)
@@ -244,9 +244,9 @@ class BackgroundServiceDelegate extends System.ServiceDelegate {
},
{
:method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON
- },
+ }),
:responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
},
method(:onReturnDoUpdate)
diff --git a/source/HomeAssistantApp.mc b/source/HomeAssistantApp.mc
index 985241b..1ba112d 100644
--- a/source/HomeAssistantApp.mc
+++ b/source/HomeAssistantApp.mc
@@ -25,8 +25,8 @@ using Toybox.Timer;
//
(:glance, :background)
class HomeAssistantApp extends Application.AppBase {
- private var mApiStatus as Lang.String?;
private var mHasToast as Lang.Boolean = false;
+ private var mApiStatus as Lang.String?;
private var mMenuStatus as Lang.String?;
private var mHaMenu as HomeAssistantView?;
private var mGlanceTemplate as Lang.String? = null;
@@ -36,14 +36,13 @@ class HomeAssistantApp extends Application.AppBase {
private var mUpdateTimer as Timer.Timer?;
// Array initialised by onReturnFetchMenuConfig()
private var mItemsToUpdate as Lang.Array?;
- private var mIsGlance as Lang.Boolean = false;
private var mIsApp as Lang.Boolean = false; // Or Widget
private var mUpdating as Lang.Boolean = false; // Don't start a second chain of updates
private var mTemplates as Lang.Dictionary = {};
private var mNotifiedNoBle as Lang.Boolean = false;
//! Class Constructor
- //
+ //
function initialize() {
AppBase.initialize();
// ATTENTION when adding stuff into this block:
@@ -155,7 +154,6 @@ class HomeAssistantApp extends Application.AppBase {
//! @param responseCode Response code.
//! @param data Response data.
//
- (:glance)
function onReturnFetchMenuConfig(
responseCode as Lang.Number,
data as Null or Lang.Dictionary or Lang.String
@@ -168,35 +166,35 @@ class HomeAssistantApp extends Application.AppBase {
case Communications.BLE_HOST_TIMEOUT:
case Communications.BLE_CONNECTION_UNAVAILABLE:
// System.println("HomeAssistantApp onReturnFetchMenuConfig() Response Code: BLE_HOST_TIMEOUT or BLE_CONNECTION_UNAVAILABLE, Bluetooth connection severed.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoPhone) as Lang.String);
}
break;
case Communications.BLE_QUEUE_FULL:
// System.println("HomeAssistantApp onReturnFetchMenuConfig() Response Code: BLE_QUEUE_FULL, API calls too rapid.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.ApiFlood) as Lang.String);
}
break;
case Communications.NETWORK_REQUEST_TIMED_OUT:
// System.println("HomeAssistantApp onReturnFetchMenuConfig() Response Code: NETWORK_REQUEST_TIMED_OUT, check Internet connection.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoResponse) as Lang.String);
}
break;
case Communications.INVALID_HTTP_BODY_IN_NETWORK_RESPONSE:
// System.println("HomeAssistantApp onReturnFetchMenuConfig() Response Code: INVALID_HTTP_BODY_IN_NETWORK_RESPONSE, check JSON is returned.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoJson) as Lang.String);
}
break;
case 404:
// System.println("HomeAssistantApp onReturnFetchMenuConfig() Response Code: 404, page not found. Check Configuration URL setting.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.ConfigUrlNotFound) as Lang.String);
}
break;
@@ -212,7 +210,7 @@ class HomeAssistantApp extends Application.AppBase {
mMenuStatus = WatchUi.loadResource($.Rez.Strings.Available) as Lang.String;
}
}
- if (mIsGlance) {
+ if (!mIsApp) {
glanceTemplate(data);
} else {
if (data == null) {
@@ -226,7 +224,7 @@ class HomeAssistantApp extends Application.AppBase {
default:
// System.println("HomeAssistantApp onReturnFetchMenuConfig(): Unhandled HTTP response code = " + responseCode);
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.UnhandledHttpErr) as Lang.String + responseCode);
}
break;
@@ -251,7 +249,6 @@ class HomeAssistantApp extends Application.AppBase {
//! @return Return true if the menu came from the cache, otherwise false. This is because fetching
//! the menu when not in the cache is asynchronous and affects how the views are managed.
//
- (:glance)
function fetchMenuConfig() as Lang.Boolean {
// System.println("Menu URL = " + Settings.getConfigUrl());
if (Settings.getConfigUrl().equals("")) {
@@ -275,7 +272,7 @@ class HomeAssistantApp extends Application.AppBase {
errorRez = $.Rez.Strings.Unavailable;
}
// System.println("HomeAssistantApp fetchMenuConfig(): No Phone connection, skipping API call.");
- if (mIsGlance) {
+ if (!mIsApp) {
WatchUi.requestUpdate();
} else {
ErrorView.show(WatchUi.loadResource(errorRez) as Lang.String);
@@ -287,7 +284,8 @@ class HomeAssistantApp extends Application.AppBase {
null,
{
:method => Communications.HTTP_REQUEST_METHOD_GET,
- :responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
+ :responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON,
+ :headers => Settings.augmentHttpHeaders({})
},
method(:onReturnFetchMenuConfig)
);
@@ -295,7 +293,7 @@ class HomeAssistantApp extends Application.AppBase {
} else {
mMenuStatus = WatchUi.loadResource($.Rez.Strings.Cached) as Lang.String;
WatchUi.requestUpdate();
- if (mIsGlance) {
+ if (!mIsApp) {
glanceTemplate(menu);
} else {
buildMenu(menu);
@@ -429,85 +427,87 @@ class HomeAssistantApp extends Application.AppBase {
//! Construct the GET request to update all menu items.
//
function updateMenuItems() as Void {
- var phoneConnected = System.getDeviceSettings().phoneConnected;
- var connectionAvailable = System.getDeviceSettings().connectionAvailable;
+ if (mUpdating) {
+ var phoneConnected = System.getDeviceSettings().phoneConnected;
+ var connectionAvailable = System.getDeviceSettings().connectionAvailable;
- // In Wi-Fi/LTE execution mode, we should not show an error page but use a toast instead.
- if (Settings.getWifiLteExecutionEnabled() && (! phoneConnected || ! connectionAvailable)) {
- // Notify only once per disconnection cycle
- if (!mNotifiedNoBle) {
- var toast = WatchUi.loadResource($.Rez.Strings.NoPhone);
- if (!connectionAvailable) {
- toast = WatchUi.loadResource($.Rez.Strings.NoInternet);
+ // In Wi-Fi/LTE execution mode, we should not show an error page but use a toast instead.
+ if (Settings.getWifiLteExecutionEnabled() && (! phoneConnected || ! connectionAvailable)) {
+ // Notify only once per disconnection cycle
+ if (!mNotifiedNoBle) {
+ var toast = WatchUi.loadResource($.Rez.Strings.NoPhone);
+ if (!connectionAvailable) {
+ toast = WatchUi.loadResource($.Rez.Strings.NoInternet);
+ }
+
+ if (mHasToast) {
+ WatchUi.showToast(toast, null);
+ } else {
+ new Alert({
+ :timeout => Globals.scAlertTimeoutMs,
+ :font => Graphics.FONT_MEDIUM,
+ :text => toast,
+ :fgcolor => Graphics.COLOR_WHITE,
+ :bgcolor => Graphics.COLOR_BLACK
+ }).pushView(WatchUi.SLIDE_IMMEDIATE);
+ }
}
- if (mHasToast) {
- WatchUi.showToast(toast, null);
- } else {
- new Alert({
- :timeout => Globals.scAlertTimeoutMs,
- :font => Graphics.FONT_MEDIUM,
- :text => toast,
- :fgcolor => Graphics.COLOR_WHITE,
- :bgcolor => Graphics.COLOR_BLACK
- }).pushView(WatchUi.SLIDE_IMMEDIATE);
- }
+ mNotifiedNoBle = true;
+ setApiStatus(WatchUi.loadResource($.Rez.Strings.Unavailable) as Lang.String);
+ mUpdateTimer.start(method(:startUpdates), Globals.wifiPollResumeDelayMs, false);
+
+ mUpdating = false;
+ return;
}
- mNotifiedNoBle = true;
- setApiStatus(WatchUi.loadResource($.Rez.Strings.Unavailable) as Lang.String);
- mUpdateTimer.start(method(:startUpdates), Globals.wifiPollResumeDelayMs, false);
+ if (! phoneConnected) {
+ // System.println("HomeAssistantApp updateMenuItems(): No Phone connection, skipping API call.");
+ ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoPhone) as Lang.String);
+ setApiStatus(WatchUi.loadResource($.Rez.Strings.Unavailable) as Lang.String);
+ } else if (! connectionAvailable) {
+ // System.println("HomeAssistantApp updateMenuItems(): No Internet connection, skipping API call.");
+ ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoInternet) as Lang.String);
+ setApiStatus(WatchUi.loadResource($.Rez.Strings.Unavailable) as Lang.String);
+ } else {
+ mNotifiedNoBle = false;
- mUpdating = false;
- return;
- }
-
- if (! phoneConnected) {
- // System.println("HomeAssistantApp updateMenuItems(): No Phone connection, skipping API call.");
- ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoPhone) as Lang.String);
- setApiStatus(WatchUi.loadResource($.Rez.Strings.Unavailable) as Lang.String);
- } else if (! connectionAvailable) {
- // System.println("HomeAssistantApp updateMenuItems(): No Internet connection, skipping API call.");
- ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoInternet) as Lang.String);
- setApiStatus(WatchUi.loadResource($.Rez.Strings.Unavailable) as Lang.String);
- } else {
- mNotifiedNoBle = false;
-
- if (mItemsToUpdate == null or mTemplates == null) {
- mItemsToUpdate = mHaMenu.getItemsToUpdate();
- mTemplates = {};
- for (var i = 0; i < mItemsToUpdate.size(); i++) {
- var item = mItemsToUpdate[i];
- var template = item.getTemplate();
- if (template != null) {
- mTemplates.put(i.toString(), {
- "template" => template
+ if (mItemsToUpdate == null or mTemplates == null) {
+ mItemsToUpdate = mHaMenu.getItemsToUpdate();
+ mTemplates = {};
+ for (var i = 0; i < mItemsToUpdate.size(); i++) {
+ var item = mItemsToUpdate[i];
+ var template = item.getTemplate();
+ if (template != null) {
+ mTemplates.put(i.toString(), {
+ "template" => template
+ });
+ }
+ if (item instanceof HomeAssistantToggleMenuItem) {
+ mTemplates.put(i.toString() + "t", {
+ "template" => (item as HomeAssistantToggleMenuItem).getToggleTemplate()
});
}
- if (item instanceof HomeAssistantToggleMenuItem) {
- mTemplates.put(i.toString() + "t", {
- "template" => (item as HomeAssistantToggleMenuItem).getToggleTemplate()
- });
- }
+ }
}
- }
- // https://developers.home-assistant.io/docs/api/native-app-integration/sending-data/#render-templates
- // System.println("HomeAssistantApp updateMenuItems() URL=" + url + ", Template='" + mTemplate + "'");
- Communications.makeWebRequest(
- Settings.getApiUrl() + "/webhook/" + Settings.getWebhookId(),
- {
- "type" => "render_template",
- "data" => mTemplates
- },
- {
- :method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
- "Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON
+ // https://developers.home-assistant.io/docs/api/native-app-integration/sending-data/#render-templates
+ // System.println("HomeAssistantApp updateMenuItems() URL=" + url + ", Template='" + mTemplate + "'");
+ Communications.makeWebRequest(
+ Settings.getApiUrl() + "/webhook/" + Settings.getWebhookId(),
+ {
+ "type" => "render_template",
+ "data" => mTemplates
},
- :responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
- },
- method(:onReturnUpdateMenuItems)
- );
+ {
+ :method => Communications.HTTP_REQUEST_METHOD_POST,
+ :headers => Settings.augmentHttpHeaders({
+ "Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON
+ }),
+ :responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
+ },
+ method(:onReturnUpdateMenuItems)
+ );
+ }
}
}
@@ -516,7 +516,6 @@ class HomeAssistantApp extends Application.AppBase {
//! @param responseCode Response code.
//! @param data Response data.
//
- (:glance)
function onReturnFetchApiStatus(
responseCode as Lang.Number,
data as Null or Lang.Dictionary or Lang.String
@@ -529,35 +528,35 @@ class HomeAssistantApp extends Application.AppBase {
case Communications.BLE_HOST_TIMEOUT:
case Communications.BLE_CONNECTION_UNAVAILABLE:
// System.println("HomeAssistantApp onReturnFetchApiStatus() Response Code: BLE_HOST_TIMEOUT or BLE_CONNECTION_UNAVAILABLE, Bluetooth connection severed.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoPhone) as Lang.String);
}
break;
case Communications.BLE_QUEUE_FULL:
// System.println("HomeAssistantApp onReturnFetchApiStatus() Response Code: BLE_QUEUE_FULL, API calls too rapid.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.ApiFlood) as Lang.String);
}
break;
case Communications.NETWORK_REQUEST_TIMED_OUT:
// System.println("HomeAssistantApp onReturnFetchApiStatus() Response Code: NETWORK_REQUEST_TIMED_OUT, check Internet connection.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoResponse) as Lang.String);
}
break;
case Communications.INVALID_HTTP_BODY_IN_NETWORK_RESPONSE:
// System.println("HomeAssistantApp onReturnFetchApiStatus() Response Code: INVALID_HTTP_BODY_IN_NETWORK_RESPONSE, check JSON is returned.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoJson) as Lang.String);
}
break;
case 404:
// System.println("HomeAssistantApp onReturnFetchApiStatus() Response Code: 404, page not found. Check Configuration URL setting.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.ConfigUrlNotFound) as Lang.String);
}
break;
@@ -566,7 +565,7 @@ class HomeAssistantApp extends Application.AppBase {
if ((data != null) && data.get("message").equals("API running.")) {
mApiStatus = WatchUi.loadResource($.Rez.Strings.Available) as Lang.String;
} else {
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show("API " + mApiStatus + ".");
}
}
@@ -574,7 +573,7 @@ class HomeAssistantApp extends Application.AppBase {
default:
// System.println("HomeAssistantApp onReturnFetchApiStatus(): Unhandled HTTP response code = " + responseCode);
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.UnhandledHttpErr) as Lang.String + responseCode);
}
}
@@ -583,7 +582,6 @@ class HomeAssistantApp extends Application.AppBase {
//! Construct the GET request to test the API status, is it accessible?
//
- (:glance)
function fetchApiStatus() as Void {
var phoneConnected = System.getDeviceSettings().phoneConnected;
var connectionAvailable = System.getDeviceSettings().connectionAvailable;
@@ -593,13 +591,13 @@ class HomeAssistantApp extends Application.AppBase {
mApiStatus = WatchUi.loadResource($.Rez.Strings.Unconfigured) as Lang.String;
WatchUi.requestUpdate();
} else {
- if (! mIsGlance && Settings.getWifiLteExecutionEnabled() && (! phoneConnected || ! connectionAvailable)) {
+ if ( mIsApp && Settings.getWifiLteExecutionEnabled() && (! phoneConnected || ! connectionAvailable)) {
// System.println("HomeAssistantApp fetchApiStatus(): In-app Wifi mode (No Phone and Internet connection), early return.");
return;
} else if (! phoneConnected) {
// System.println("HomeAssistantApp fetchApiStatus(): No Phone connection, skipping API call.");
mApiStatus = WatchUi.loadResource($.Rez.Strings.Unavailable) as Lang.String;
- if (mIsGlance) {
+ if (!mIsApp) {
WatchUi.requestUpdate();
} else {
System.println("we here");
@@ -608,7 +606,7 @@ class HomeAssistantApp extends Application.AppBase {
} else if (! connectionAvailable) {
// System.println("HomeAssistantApp fetchApiStatus(): No Internet connection, skipping API call.");
mApiStatus = WatchUi.loadResource($.Rez.Strings.Unavailable) as Lang.String;
- if (mIsGlance) {
+ if (!mIsApp) {
WatchUi.requestUpdate();
} else {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoInternet) as Lang.String);
@@ -619,9 +617,9 @@ class HomeAssistantApp extends Application.AppBase {
null,
{
:method => Communications.HTTP_REQUEST_METHOD_GET,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Authorization" => "Bearer " + Settings.getApiKey()
- },
+ }),
:responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
},
method(:onReturnFetchApiStatus)
@@ -636,7 +634,6 @@ class HomeAssistantApp extends Application.AppBase {
//! @param responseCode Response code.
//! @param data Response data.
//
- (:glance)
function onReturnFetchGlanceContent(
responseCode as Lang.Number,
data as Null or Lang.Dictionary or Lang.String
@@ -648,35 +645,35 @@ class HomeAssistantApp extends Application.AppBase {
case Communications.BLE_HOST_TIMEOUT:
case Communications.BLE_CONNECTION_UNAVAILABLE:
// System.println("HomeAssistantApp onReturnFetchGlanceContent() Response Code: BLE_HOST_TIMEOUT or BLE_CONNECTION_UNAVAILABLE, Bluetooth connection severed.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoPhone) as Lang.String);
}
break;
case Communications.BLE_QUEUE_FULL:
// System.println("HomeAssistantApp onReturnFetchGlanceContent() Response Code: BLE_QUEUE_FULL, API calls too rapid.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.ApiFlood) as Lang.String);
}
break;
case Communications.NETWORK_REQUEST_TIMED_OUT:
// System.println("HomeAssistantApp onReturnFetchGlanceContent() Response Code: NETWORK_REQUEST_TIMED_OUT, check Internet connection.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoResponse) as Lang.String);
}
break;
case Communications.INVALID_HTTP_BODY_IN_NETWORK_RESPONSE:
// System.println("HomeAssistantApp onReturnFetchGlanceContent() Response Code: INVALID_HTTP_BODY_IN_NETWORK_RESPONSE, check JSON is returned.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.NoJson) as Lang.String);
}
break;
case 404:
// System.println("HomeAssistantApp onReturnFetchGlanceContent() Response Code: 404, page not found. Check Configuration URL setting.");
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.ConfigUrlNotFound) as Lang.String);
}
break;
@@ -689,7 +686,7 @@ class HomeAssistantApp extends Application.AppBase {
default:
// System.println("HomeAssistantApp onReturnFetchGlanceContent(): Unhandled HTTP response code = " + responseCode);
- if (!mIsGlance) {
+ if (mIsApp) {
ErrorView.show(WatchUi.loadResource($.Rez.Strings.UnhandledHttpErr) as Lang.String + responseCode);
}
}
@@ -698,7 +695,6 @@ class HomeAssistantApp extends Application.AppBase {
//! Construct the GET request to convert the optional glance template to text for display.
//
- (:glance)
function fetchGlanceContent() as Void {
if (mGlanceTemplate != null) {
// https://developers.home-assistant.io/docs/api/native-app-integration/sending-data/#render-templates
@@ -714,9 +710,9 @@ class HomeAssistantApp extends Application.AppBase {
},
{
:method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON
- },
+ }),
:responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
},
method(:onReturnFetchGlanceContent)
@@ -736,7 +732,6 @@ class HomeAssistantApp extends Application.AppBase {
//!
//! @return A string describing the API status
//
- (:glance)
function getApiStatus() as Lang.String {
return mApiStatus;
}
@@ -745,7 +740,6 @@ class HomeAssistantApp extends Application.AppBase {
//!
//! @return A string describing the Menu status
//
- (:glance)
function getMenuStatus() as Lang.String {
return mMenuStatus;
}
@@ -755,7 +749,6 @@ class HomeAssistantApp extends Application.AppBase {
//!
//! @return A string derived from the glance template (or null)
//
- (:glance)
function getGlanceText() as Lang.String? {
return mGlanceText;
}
@@ -799,7 +792,7 @@ class HomeAssistantApp extends Application.AppBase {
//! @return The glance view
//
function getGlanceView() as [ WatchUi.GlanceView ] or [ WatchUi.GlanceView, WatchUi.GlanceViewDelegate ] or Null {
- mIsGlance = true;
+ mIsApp = false; // A bit unnecessary given the default
mApiStatus = WatchUi.loadResource($.Rez.Strings.Checking) as Lang.String;
mMenuStatus = WatchUi.loadResource($.Rez.Strings.Checking) as Lang.String;
Settings.update();
@@ -823,7 +816,9 @@ class HomeAssistantApp extends Application.AppBase {
mGlanceTimer = null;
fetchMenuConfig();
fetchApiStatus();
- fetchGlanceContent();
+ if (Settings.getWebhookId() != null && !Settings.getWebhookId().equals("")) {
+ fetchGlanceContent();
+ }
}
//! Code for when the application settings are updated.
@@ -841,6 +836,8 @@ class HomeAssistantApp extends Application.AppBase {
}
//! Determine is we are a glance or the full application. Glances should be considered to be separate applications.
+ //!
+ //! @return We are an application (if not we're a glance)
//
function getIsApp() as Lang.Boolean {
return mIsApp;
@@ -856,6 +853,8 @@ class HomeAssistantApp extends Application.AppBase {
}
//! Global function to return the application object.
+//!
+//! @return The application object.
//
(:glance, :background)
function getApp() as HomeAssistantApp {
diff --git a/source/HomeAssistantService.mc b/source/HomeAssistantService.mc
index 6e14882..459c189 100644
--- a/source/HomeAssistantService.mc
+++ b/source/HomeAssistantService.mc
@@ -168,10 +168,10 @@ class HomeAssistantService {
data, // Includes {"entity_id": xxxx}
{
:method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON,
"Authorization" => "Bearer " + Settings.getApiKey()
- },
+ }),
:responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON,
:context => {
:entity_id => entity_id,
diff --git a/source/HomeAssistantSyncDelegate.mc b/source/HomeAssistantSyncDelegate.mc
index 81ef1d9..31210aa 100644
--- a/source/HomeAssistantSyncDelegate.mc
+++ b/source/HomeAssistantSyncDelegate.mc
@@ -81,10 +81,10 @@ class HomeAssistantSyncDelegate extends Communications.SyncDelegate {
data, // May include {"entity_id": xxxx} for service calls
{
:method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON,
"Authorization" => "Bearer " + Settings.getApiKey()
- },
+ }),
:responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON,
},
method(:haCallback)
diff --git a/source/HomeAssistantToggleMenuItem.mc b/source/HomeAssistantToggleMenuItem.mc
index a8efdb5..96c04d5 100644
--- a/source/HomeAssistantToggleMenuItem.mc
+++ b/source/HomeAssistantToggleMenuItem.mc
@@ -268,10 +268,10 @@ class HomeAssistantToggleMenuItem extends WatchUi.ToggleMenuItem {
mData,
{
:method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON,
"Authorization" => "Bearer " + Settings.getApiKey()
- },
+ }),
:responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
},
method(:onReturnSetState)
diff --git a/source/Settings.mc b/source/Settings.mc
index c304ee3..17fa85d 100644
--- a/source/Settings.mc
+++ b/source/Settings.mc
@@ -47,6 +47,10 @@ class Settings {
private static var mIsSensorsLevelEnabled as Lang.Boolean = false;
//! minutes
private static var mBatteryRefreshRate as Lang.Number = 15;
+ //! Additional user configurable HTTP header key
+ private static var mUserHeaderName as Lang.String? = null;
+ //! Additional user configurable HTTP header value
+ private static var mUserHeaderValue as Lang.String? = null;
private static var mIsApp as Lang.Boolean = false;
private static var mHasService as Lang.Boolean = false;
//! Must keep the object so it doesn't get garbage collected.
@@ -71,6 +75,8 @@ class Settings {
mMenuAlignment = Properties.getValue("menu_alignment");
mIsSensorsLevelEnabled = Properties.getValue("enable_battery_level");
mBatteryRefreshRate = Properties.getValue("battery_level_refresh_rate");
+ mUserHeaderName = Properties.getValue("user_http_header_name");
+ mUserHeaderValue = Properties.getValue("user_http_header_value");
}
//! A webhook is required for non-privileged API calls.
@@ -284,4 +290,18 @@ class Settings {
}
}
+ //! Augment the HTTP header options passed in with the user configurable HTTP header key and value.
+ //!
+ //! @param options The HTTP header options to augment.
+ //!
+ //! @return The augmented HTTP header options.
+ //
+ static function augmentHttpHeaders(options as Lang.Dictionary) {
+ // Use 'm.length() > 0' here in preference to 'm != ""' or '.equals("")'. They make the App crash on device but not in simulation.
+ if (mUserHeaderName != null && mUserHeaderName.length() > 0 && mUserHeaderValue != null && mUserHeaderValue.length() > 0) {
+ options[mUserHeaderName] = mUserHeaderValue;
+ }
+ return options;
+ }
+
}
diff --git a/source/WebhookManager.mc b/source/WebhookManager.mc
index b6a9a19..5260ce0 100644
--- a/source/WebhookManager.mc
+++ b/source/WebhookManager.mc
@@ -25,7 +25,9 @@ using Toybox.WatchUi;
//!
//! Reference: https://developers.home-assistant.io/docs/api/native-app-integration
//
+(:glance)
class WebhookManager {
+ private var mSensors as Lang.Array = [];
//! Callback for requesting a Webhook ID.
//!
@@ -113,10 +115,10 @@ class WebhookManager {
},
{
:method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON,
"Authorization" => "Bearer " + Settings.getApiKey()
- },
+ }),
:responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
},
method(:onReturnRequestWebhookId)
@@ -130,11 +132,7 @@ class WebhookManager {
//! @param sensors The remaining sensors to be processed. The list of sensors is iterated through
//! until empty. Each POST request creating one sensor on the local Home Assistant.
//
- function onReturnRegisterWebhookSensor(
- responseCode as Lang.Number,
- data as Null or Lang.Dictionary or Lang.String,
- sensors as Lang.Array
- ) as Void {
+ function onReturnRegisterWebhookSensor(responseCode as Lang.Number, data as Null or Lang.Dictionary or Lang.String) as Void {
switch (responseCode) {
case Communications.BLE_HOST_TIMEOUT:
case Communications.BLE_CONNECTION_UNAVAILABLE:
@@ -176,13 +174,14 @@ class WebhookManager {
case 200:
case 201:
if (data instanceof Lang.Dictionary) {
- var d = data as Lang.Dictionary;
+ var d = data as Lang.Dictionary;
var b = d.get("success") as Lang.Boolean?;
if (b != null and b != false) {
- if (sensors.size() == 0) {
+ mSensors = mSensors.slice(1, null);
+ if (mSensors.size() == 0) {
getApp().startUpdates();
} else {
- registerWebhookSensor(sensors);
+ registerWebhookSensor();
}
} else {
// System.println("WebhookManager onReturnRegisterWebhookSensor(): Failure, no 'success'.");
@@ -213,11 +212,10 @@ class WebhookManager {
}
}
- //! Local method to send the POST request to register a number of sensors.
- //!
- //! @param sensors An array of sensors, e.g. As created by `registerWebhookSensors()`.
+ //! Local method to send the POST request to register a number of sensors. The sensors are taken from the class variable
+ //! mSensors created by registerWebhookSensors().
//
- private function registerWebhookSensor(sensors as Lang.Array) {
+ private function registerWebhookSensor() {
var url = Settings.getApiUrl() + "/webhook/" + Settings.getWebhookId();
// System.println("WebhookManager registerWebhookSensor(): Registering webhook sensor: " + sensor.toString());
// System.println("WebhookManager registerWebhookSensor(): URL=" + url);
@@ -226,15 +224,14 @@ class WebhookManager {
url,
{
"type" => "register_sensor",
- "data" => sensors[0]
+ "data" => mSensors[0]
},
{
:method => Communications.HTTP_REQUEST_METHOD_POST,
- :headers => {
+ :headers => Settings.augmentHttpHeaders({
"Content-Type" => Communications.REQUEST_CONTENT_TYPE_JSON
- },
- :responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON,
- :context => sensors.slice(1, null)
+ }),
+ :responseType => Communications.HTTP_RESPONSE_CONTENT_TYPE_JSON
},
method(:onReturnRegisterWebhookSensor)
);
@@ -245,7 +242,7 @@ class WebhookManager {
function registerWebhookSensors() {
var heartRate = Activity.getActivityInfo().currentHeartRate;
- var sensors = [
+ mSensors = [
{
"device_class" => "battery",
"name" => "Battery Level",
@@ -283,7 +280,7 @@ class WebhookManager {
if (Toybox has :ActivityMonitor) {
// System.println("WebhookManager registerWebhookSensors(): has ActivityMonitor class");
var activityInfo = ActivityMonitor.getInfo();
- sensors.add({
+ mSensors.add({
"name" => "Steps today",
"state" => activityInfo.steps == null ? "unknown" : activityInfo.steps,
"type" => "sensor",
@@ -294,7 +291,7 @@ class WebhookManager {
});
if (ActivityMonitor.Info has :floorsClimbed) {
- sensors.add({
+ mSensors.add({
"name" => "Floors climbed today",
"state" => activityInfo.floorsClimbed == null ? "unknown" : activityInfo.floorsClimbed,
"type" => "sensor",
@@ -306,7 +303,7 @@ class WebhookManager {
}
if (ActivityMonitor.Info has :floorsDescended) {
- sensors.add({
+ mSensors.add({
"name" => "Floors descended today",
"state" => activityInfo.floorsDescended == null ? "unknown" : activityInfo.floorsDescended,
"type" => "sensor",
@@ -318,7 +315,7 @@ class WebhookManager {
}
if (ActivityMonitor.Info has :respirationRate) {
- sensors.add({
+ mSensors.add({
"name" => "Respiration rate",
"state" => activityInfo.respirationRate == null ? "unknown" : activityInfo.respirationRate,
"type" => "sensor",
@@ -345,14 +342,14 @@ class WebhookManager {
activity = -1;
sub_activity = -1;
}
- sensors.add({
+ mSensors.add({
"name" => "Activity",
"state" => activity,
"type" => "sensor",
"unique_id" => "activity",
"disabled" => !Settings.isSensorsLevelEnabled()
});
- sensors.add({
+ mSensors.add({
"name" => "Sub-activity",
"state" => sub_activity,
"type" => "sensor",
@@ -361,7 +358,7 @@ class WebhookManager {
});
}
- registerWebhookSensor(sensors);
+ registerWebhookSensor();
}
}
diff --git a/translate.cmd b/translate.cmd
new file mode 100644
index 0000000..78800b2
--- /dev/null
+++ b/translate.cmd
@@ -0,0 +1,24 @@
+@echo off
+rem -----------------------------------------------------------------------------------
+rem
+rem Distributed under MIT Licence
+rem See https://github.com/house-of-abbey/GarminHomeAssistant/blob/main/LICENSE.
+rem
+rem -----------------------------------------------------------------------------------
+rem
+rem GarminHomeAssistant is a Garmin IQ application written in Monkey C and routinely
+rem tested on a Venu 2 device. The source code is provided at:
+rem https://github.com/house-of-abbey/GarminHomeAssistant.
+rem
+rem J D Abbey & P A Abbey, 28 December 2022
+rem
+rem Run the automatic translation script.
+rem
+rem Reference:
+rem * Using Monkey C from the Command Line
+rem https://developer.garmin.com/connect-iq/reference-guides/monkey-c-command-line-setup/
+rem
+rem -----------------------------------------------------------------------------------
+
+python translate.py
+pause
diff --git a/translate.py b/translate.py
index 80282e1..67e3297 100644
--- a/translate.py
+++ b/translate.py
@@ -90,7 +90,7 @@ titleIds: list[str] = []
# the previous strings with the current ones if they exist.
# """
# out = prev.__copy__()
-# for s in curr.find(name="strings").findAll(name="string"):
+# for s in curr.find(name="strings").find_all(name="string"):
# s_prev = out.find(name="string", attrs={"id": s["id"]})
# if s_prev:
# s_prev.string = s.string
@@ -124,7 +124,7 @@ with open("./resources/strings/strings.xml", "r") as f:
translator.translate("Generated by Google Translate from English") + "\n"))
soup.find(name="strings").insert_before("\n\n")
- for s in soup.find(name="strings").findAll(name="string"):
+ for s in soup.find(name="strings").find_all(name="string"):
s.insert_before(" ")
if s["id"] in exceptionIds:
continue
@@ -142,7 +142,7 @@ with open("./resources/strings/strings.xml", "r") as f:
s.string = a.title()
else:
s.string = a
- for s in soup.find(name="strings").findAll(
+ for s in soup.find(name="strings").find_all(
string=lambda text: isinstance(text, Comment)):
s.insert_before(" ")
s.replace_with(Comment(" " + translator.translate(s) + " "))