add german plugin language
This commit is contained in:
parent
721db866ff
commit
cc99ecef0d
@ -117,3 +117,7 @@
|
|||||||
|
|
||||||
## 0.7.2
|
## 0.7.2
|
||||||
* Fixed homebridge crash with multiple robots per account
|
* Fixed homebridge crash with multiple robots per account
|
||||||
|
|
||||||
|
## 0.8.0
|
||||||
|
* Add German plugin language (for example, this gives you a "Sauge Küche" Siri command for a zone called "Küche")
|
||||||
|
* Added possibility to toggle between languages (English/German) in Homebridge UI Plugin Settings
|
10
README.md
10
README.md
@ -27,6 +27,8 @@ The interaction with the Server is handled by the underlying [node-kobold-contro
|
|||||||
- Automatic or periodic refresh of robot state
|
- Automatic or periodic refresh of robot state
|
||||||
- Multiple robots
|
- Multiple robots
|
||||||
|
|
||||||
|
- German or English Language Setting
|
||||||
|
|
||||||
> <b name="change-room">2</b> You can send the robot from one room to another as well. He will return to the base, wait there some seconds and then starts cleaning the next room.
|
> <b name="change-room">2</b> You can send the robot from one room to another as well. He will return to the base, wait there some seconds and then starts cleaning the next room.
|
||||||
|
|
||||||
> <b name="eve">3</b> You need a third party app like eve to access these features.
|
> <b name="eve">3</b> You need a third party app like eve to access these features.
|
||||||
@ -49,7 +51,8 @@ Add the following information to your config file. Change the values for email a
|
|||||||
"platforms": [
|
"platforms": [
|
||||||
{
|
{
|
||||||
"platform": "KoboldVacuumRobot",
|
"platform": "KoboldVacuumRobot",
|
||||||
"token": "YourToken"
|
"token": "YourToken",
|
||||||
|
"language": "de"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
```
|
```
|
||||||
@ -92,6 +95,8 @@ curl -X "POST" "https://mykobold.eu.auth0.com/oauth/token" \
|
|||||||
|
|
||||||
From the output, you want to copy the `id_token` value.
|
From the output, you want to copy the `id_token` value.
|
||||||
|
|
||||||
|
The `language` can be `de` for German, or `en` for English.
|
||||||
|
|
||||||
### Advanced
|
### Advanced
|
||||||
|
|
||||||
Below are explanations for advanced parameters to adjust the plugin to your needs. All parameters are *optional*.
|
Below are explanations for advanced parameters to adjust the plugin to your needs. All parameters are *optional*.
|
||||||
@ -111,7 +116,8 @@ List of plugin features that you don't want to use in homekit (e.g. `dock`, `doc
|
|||||||
"platform": "KoboldVacuumRobot",
|
"platform": "KoboldVacuumRobot",
|
||||||
"token": "YourToken",
|
"token": "YourToken",
|
||||||
"refresh": "120",
|
"refresh": "120",
|
||||||
"hidden": ["dock", "dockstate", "eco", "nogolines", "extracare", "schedule", "find", "spot"]
|
"hidden": ["dock", "dockstate", "eco", "nogolines", "extracare", "schedule", "find", "spot"],
|
||||||
|
"language": "de"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
```
|
```
|
||||||
|
@ -38,6 +38,35 @@ function KoboldVacuumRobotAccessory(platform, robotObject)
|
|||||||
this.spotPlusFeatures = ((typeof robotObject.availableServices.spotCleaning !== 'undefined') && robotObject.availableServices.spotCleaning.includes("basic"));
|
this.spotPlusFeatures = ((typeof robotObject.availableServices.spotCleaning !== 'undefined') && robotObject.availableServices.spotCleaning.includes("basic"));
|
||||||
this.boundary = (typeof robotObject.boundary === 'undefined') ? null : robotObject.boundary;
|
this.boundary = (typeof robotObject.boundary === 'undefined') ? null : robotObject.boundary;
|
||||||
|
|
||||||
|
this.dict = {
|
||||||
|
'en': {
|
||||||
|
"clean": "Clean",
|
||||||
|
"clean the": "Clean the",
|
||||||
|
"goToDock": "Go to Dock",
|
||||||
|
"dockState": "Dock",
|
||||||
|
"eco": "Eco Mode",
|
||||||
|
"noGoLines": "NoGo Lines",
|
||||||
|
"extraCare": "Extra Care",
|
||||||
|
"schedule": "Schedule",
|
||||||
|
"findMe": "Find me",
|
||||||
|
"cleanSpot": "Clean Spot",
|
||||||
|
"battery": "Battery"
|
||||||
|
},
|
||||||
|
'de': {
|
||||||
|
"clean": "Sauge",
|
||||||
|
"clean the": "Sauge",
|
||||||
|
"goToDock": "Zur Basis",
|
||||||
|
"dockState": "In der Basis",
|
||||||
|
"eco": "Eco Modus",
|
||||||
|
"noGoLines": "NoGo Linien",
|
||||||
|
"extraCare": "Extra Care",
|
||||||
|
"schedule": "Zeitplan",
|
||||||
|
"findMe": "Finde mich",
|
||||||
|
"cleanSpot": "Spot Reinigung",
|
||||||
|
"battery": "Batterie"
|
||||||
|
}
|
||||||
|
}[this.platform.language]
|
||||||
|
|
||||||
if (this.boundary == null)
|
if (this.boundary == null)
|
||||||
{
|
{
|
||||||
this.name = this.robot.name;
|
this.name = this.robot.name;
|
||||||
@ -64,20 +93,20 @@ function KoboldVacuumRobotAccessory(platform, robotObject)
|
|||||||
this.name = this.robot.name + ' - ' + this.boundary.name;
|
this.name = this.robot.name + ' - ' + this.boundary.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.batteryService = new Service.BatteryService("Battery", "battery");
|
this.batteryService = new Service.BatteryService(this.dict["battery"], "battery");
|
||||||
|
|
||||||
if (this.boundary == null)
|
if (this.boundary == null)
|
||||||
{
|
{
|
||||||
this.cleanService = new Service.Switch(this.name + " Clean", "clean");
|
this.cleanService = new Service.Switch(this.name + " " + this.dict["clean"], "clean");
|
||||||
this.goToDockService = new Service.Switch(this.name + " Go to Dock", "goToDock");
|
this.goToDockService = new Service.Switch(this.name + " " + this.dict["goToDock"], "goToDock");
|
||||||
this.dockStateService = new Service.OccupancySensor(this.name + " Dock", "dockState");
|
this.dockStateService = new Service.OccupancySensor(this.name + " " + this.dict["dockState"], "dockState");
|
||||||
this.ecoService = new Service.Switch(this.name + " Eco Mode", "eco");
|
this.ecoService = new Service.Switch(this.name + " " + this.dict["eco"], "eco");
|
||||||
this.noGoLinesService = new Service.Switch(this.name + " NoGo Lines", "noGoLines");
|
this.noGoLinesService = new Service.Switch(this.name + " " + this.dict["noGoLines"], "noGoLines");
|
||||||
this.extraCareService = new Service.Switch(this.name + " Extra Care", "extraCare");
|
this.extraCareService = new Service.Switch(this.name + " " + this.dict["extraCare"], "extraCare");
|
||||||
this.scheduleService = new Service.Switch(this.name + " Schedule", "schedule");
|
this.scheduleService = new Service.Switch(this.name + " " + this.dict["schedule"], "schedule");
|
||||||
this.findMeService = new Service.Switch(this.name + " Find Me", "findMe");
|
this.findMeService = new Service.Switch(this.name + " " + this.dict["findMe"], "findMe");
|
||||||
|
|
||||||
this.spotCleanService = new Service.Switch(this.name + " Clean Spot", "cleanSpot");
|
this.spotCleanService = new Service.Switch(this.name + " " + this.dict["cleanSpot"], "cleanSpot");
|
||||||
this.spotCleanService.addCharacteristic(SpotRepeatCharacteristic);
|
this.spotCleanService.addCharacteristic(SpotRepeatCharacteristic);
|
||||||
if (this.spotPlusFeatures)
|
if (this.spotPlusFeatures)
|
||||||
{
|
{
|
||||||
@ -88,10 +117,10 @@ function KoboldVacuumRobotAccessory(platform, robotObject)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
const splitName = this.boundary.name.split(' ');
|
const splitName = this.boundary.name.split(' ');
|
||||||
let serviceName = "Clean the " + this.boundary.name;
|
let serviceName = this.dict["clean the"] + " " + this.boundary.name;
|
||||||
if (splitName.length >= 2 && splitName[splitName.length - 2].match(/[']s$/g))
|
if (splitName.length >= 2 && splitName[splitName.length - 2].match(/[']s$/g))
|
||||||
{
|
{
|
||||||
serviceName = "Clean " + this.boundary.name;
|
serviceName = this.dict["clean"] + " " + this.boundary.name;
|
||||||
}
|
}
|
||||||
this.cleanService = new Service.Switch(serviceName, "cleanBoundary:" + this.boundary.id);
|
this.cleanService = new Service.Switch(serviceName, "cleanBoundary:" + this.boundary.id);
|
||||||
}
|
}
|
||||||
|
@ -10,6 +10,26 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"required": true,
|
"required": true,
|
||||||
"description": "Your Token"
|
"description": "Your Token"
|
||||||
|
},
|
||||||
|
"language": {
|
||||||
|
"title": "language",
|
||||||
|
"type": "string",
|
||||||
|
"default": "en",
|
||||||
|
"oneOf": [
|
||||||
|
{
|
||||||
|
"title": "English",
|
||||||
|
"enum": [
|
||||||
|
"en"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "German",
|
||||||
|
"enum": [
|
||||||
|
"de"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"required": true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
1
index.js
1
index.js
@ -20,6 +20,7 @@ function KoboldVacuumRobotPlatform(log, config)
|
|||||||
this.log = log;
|
this.log = log;
|
||||||
this.serial = "1-3-3-7";
|
this.serial = "1-3-3-7";
|
||||||
this.token = config['token'];
|
this.token = config['token'];
|
||||||
|
this.language = config['language'];
|
||||||
this.hiddenServices = '';
|
this.hiddenServices = '';
|
||||||
this.hiddenServices = ('disabled' in config ? config['disabled'] : this.hiddenServices);
|
this.hiddenServices = ('disabled' in config ? config['disabled'] : this.hiddenServices);
|
||||||
this.hiddenServices = ('hidden' in config ? config['hidden'] : this.hiddenServices);
|
this.hiddenServices = ('hidden' in config ? config['hidden'] : this.hiddenServices);
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "homebridge-kobold",
|
"name": "homebridge-kobold",
|
||||||
"version": "0.7.2",
|
"version": "0.8.0",
|
||||||
"description": "A Vorwerk Kobold vacuum robot plugin for homebridge.",
|
"description": "A Vorwerk Kobold vacuum robot plugin for homebridge.",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
Loading…
Reference in New Issue
Block a user