mirror of
https://github.com/home-assistant/frontend.git
synced 2025-07-25 18:26:35 +00:00
Rename service call to action (#21362)
This commit is contained in:
parent
5ead5ed058
commit
d9583582e6
@ -451,7 +451,7 @@ export class HaServiceControl extends LitElement {
|
|||||||
>
|
>
|
||||||
<span slot="description"
|
<span slot="description"
|
||||||
>${this.hass.localize(
|
>${this.hass.localize(
|
||||||
"ui.components.service-control.target_description"
|
"ui.components.service-control.target_secondary"
|
||||||
)}</span
|
)}</span
|
||||||
><ha-selector
|
><ha-selector
|
||||||
.hass=${this.hass}
|
.hass=${this.hass}
|
||||||
@ -478,7 +478,9 @@ export class HaServiceControl extends LitElement {
|
|||||||
${shouldRenderServiceDataYaml
|
${shouldRenderServiceDataYaml
|
||||||
? html`<ha-yaml-editor
|
? html`<ha-yaml-editor
|
||||||
.hass=${this.hass}
|
.hass=${this.hass}
|
||||||
.label=${this.hass.localize("ui.components.service-control.data")}
|
.label=${this.hass.localize(
|
||||||
|
"ui.components.service-control.action_data"
|
||||||
|
)}
|
||||||
.name=${"data"}
|
.name=${"data"}
|
||||||
.readOnly=${this.disabled}
|
.readOnly=${this.disabled}
|
||||||
.defaultValue=${this._value?.data}
|
.defaultValue=${this._value?.data}
|
||||||
|
@ -46,7 +46,7 @@ class HaServicePicker extends LitElement {
|
|||||||
return html`
|
return html`
|
||||||
<ha-combo-box
|
<ha-combo-box
|
||||||
.hass=${this.hass}
|
.hass=${this.hass}
|
||||||
.label=${this.hass.localize("ui.components.service-picker.service")}
|
.label=${this.hass.localize("ui.components.service-picker.action")}
|
||||||
.filteredItems=${this._filteredServices(
|
.filteredItems=${this._filteredServices(
|
||||||
this.hass.localize,
|
this.hass.localize,
|
||||||
this.hass.services,
|
this.hass.services,
|
||||||
|
@ -45,9 +45,12 @@ export class CloudTTSPref extends LitElement {
|
|||||||
header=${this.hass.localize("ui.panel.config.cloud.account.tts.title")}
|
header=${this.hass.localize("ui.panel.config.cloud.account.tts.title")}
|
||||||
>
|
>
|
||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
${this.hass.localize("ui.panel.config.cloud.account.tts.info", {
|
${this.hass.localize(
|
||||||
service: '"tts.cloud_say"',
|
"ui.panel.config.cloud.account.tts.description",
|
||||||
})}
|
{
|
||||||
|
service: '"tts.cloud_say"',
|
||||||
|
}
|
||||||
|
)}
|
||||||
<br /><br />
|
<br /><br />
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<ha-language-picker
|
<ha-language-picker
|
||||||
|
@ -962,7 +962,7 @@ export class EntityRegistrySettingsEditor extends LitElement {
|
|||||||
>
|
>
|
||||||
<span slot="description"
|
<span slot="description"
|
||||||
>${this.hass.localize(
|
>${this.hass.localize(
|
||||||
"ui.dialogs.entity_registry.editor.hidden_description"
|
"ui.dialogs.entity_registry.editor.hidden_explanation"
|
||||||
)}</span
|
)}</span
|
||||||
>
|
>
|
||||||
<ha-switch
|
<ha-switch
|
||||||
|
@ -1177,7 +1177,7 @@ ${
|
|||||||
{ number: this._selected.length }
|
{ number: this._selected.length }
|
||||||
),
|
),
|
||||||
text: this.hass.localize(
|
text: this.hass.localize(
|
||||||
"ui.panel.config.entities.picker.hide_selected.confirm_text"
|
"ui.panel.config.entities.picker.hide_selected.confirm"
|
||||||
),
|
),
|
||||||
confirmText: this.hass.localize("ui.common.hide"),
|
confirmText: this.hass.localize("ui.common.hide"),
|
||||||
dismissText: this.hass.localize("ui.common.cancel"),
|
dismissText: this.hass.localize("ui.common.cancel"),
|
||||||
|
@ -2,7 +2,7 @@ import { mdiHelpCircle } from "@mdi/js";
|
|||||||
import { ERR_CONNECTION_LOST } from "home-assistant-js-websocket";
|
import { ERR_CONNECTION_LOST } from "home-assistant-js-websocket";
|
||||||
import { load } from "js-yaml";
|
import { load } from "js-yaml";
|
||||||
import { css, CSSResultGroup, html, LitElement, nothing } from "lit";
|
import { css, CSSResultGroup, html, LitElement, nothing } from "lit";
|
||||||
import { property, query, state } from "lit/decorators";
|
import { customElement, property, query, state } from "lit/decorators";
|
||||||
import memoizeOne from "memoize-one";
|
import memoizeOne from "memoize-one";
|
||||||
import { storage } from "../../../common/decorators/storage";
|
import { storage } from "../../../common/decorators/storage";
|
||||||
import { computeDomain } from "../../../common/entity/compute_domain";
|
import { computeDomain } from "../../../common/entity/compute_domain";
|
||||||
@ -31,7 +31,8 @@ import { haStyle } from "../../../resources/styles";
|
|||||||
import { HomeAssistant } from "../../../types";
|
import { HomeAssistant } from "../../../types";
|
||||||
import { documentationUrl } from "../../../util/documentation-url";
|
import { documentationUrl } from "../../../util/documentation-url";
|
||||||
|
|
||||||
class HaPanelDevService extends LitElement {
|
@customElement("developer-tools-action")
|
||||||
|
class HaPanelDevAction extends LitElement {
|
||||||
@property({ attribute: false }) public hass!: HomeAssistant;
|
@property({ attribute: false }) public hass!: HomeAssistant;
|
||||||
|
|
||||||
@property({ type: Boolean }) public narrow = false;
|
@property({ type: Boolean }) public narrow = false;
|
||||||
@ -112,7 +113,7 @@ class HaPanelDevService extends LitElement {
|
|||||||
<div class="content">
|
<div class="content">
|
||||||
<p>
|
<p>
|
||||||
${this.hass.localize(
|
${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.description"
|
"ui.panel.developer-tools.tabs.actions.description"
|
||||||
)}
|
)}
|
||||||
</p>
|
</p>
|
||||||
<ha-card>
|
<ha-card>
|
||||||
@ -154,23 +155,23 @@ class HaPanelDevService extends LitElement {
|
|||||||
>
|
>
|
||||||
${this._yamlMode
|
${this._yamlMode
|
||||||
? this.hass.localize(
|
? this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.ui_mode"
|
"ui.panel.developer-tools.tabs.actions.ui_mode"
|
||||||
)
|
)
|
||||||
: this.hass.localize(
|
: this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.yaml_mode"
|
"ui.panel.developer-tools.tabs.actions.yaml_mode"
|
||||||
)}
|
)}
|
||||||
</mwc-button>
|
</mwc-button>
|
||||||
${!this._uiAvailable
|
${!this._uiAvailable
|
||||||
? html`<span class="error"
|
? html`<span class="error"
|
||||||
>${this.hass.localize(
|
>${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.no_template_ui_support"
|
"ui.panel.developer-tools.tabs.actions.no_template_ui_support"
|
||||||
)}</span
|
)}</span
|
||||||
>`
|
>`
|
||||||
: ""}
|
: ""}
|
||||||
</div>
|
</div>
|
||||||
<ha-progress-button raised @click=${this._callService}>
|
<ha-progress-button raised @click=${this._callService}>
|
||||||
${this.hass.localize(
|
${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.call_service"
|
"ui.panel.developer-tools.tabs.actions.call_service"
|
||||||
)}
|
)}
|
||||||
</ha-progress-button>
|
</ha-progress-button>
|
||||||
</div>
|
</div>
|
||||||
@ -179,7 +180,7 @@ class HaPanelDevService extends LitElement {
|
|||||||
? html`<div class="content">
|
? html`<div class="content">
|
||||||
<ha-card
|
<ha-card
|
||||||
.header=${this.hass.localize(
|
.header=${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.response"
|
"ui.panel.developer-tools.tabs.actions.response"
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
@ -199,10 +200,10 @@ class HaPanelDevService extends LitElement {
|
|||||||
<ha-expansion-panel
|
<ha-expansion-panel
|
||||||
.header=${this._yamlMode
|
.header=${this._yamlMode
|
||||||
? this.hass.localize(
|
? this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.all_parameters"
|
"ui.panel.developer-tools.tabs.actions.all_parameters"
|
||||||
)
|
)
|
||||||
: this.hass.localize(
|
: this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.yaml_parameters"
|
"ui.panel.developer-tools.tabs.actions.yaml_parameters"
|
||||||
)}
|
)}
|
||||||
outlined
|
outlined
|
||||||
.expanded=${this._yamlMode}
|
.expanded=${this._yamlMode}
|
||||||
@ -213,7 +214,7 @@ class HaPanelDevService extends LitElement {
|
|||||||
${target
|
${target
|
||||||
? html`
|
? html`
|
||||||
${this.hass.localize(
|
${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.accepts_target"
|
"ui.panel.developer-tools.tabs.actions.accepts_target"
|
||||||
)}
|
)}
|
||||||
`
|
`
|
||||||
: ""}
|
: ""}
|
||||||
@ -244,17 +245,17 @@ class HaPanelDevService extends LitElement {
|
|||||||
<tr>
|
<tr>
|
||||||
<th>
|
<th>
|
||||||
${this.hass.localize(
|
${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.column_parameter"
|
"ui.panel.developer-tools.tabs.actions.column_parameter"
|
||||||
)}
|
)}
|
||||||
</th>
|
</th>
|
||||||
<th>
|
<th>
|
||||||
${this.hass.localize(
|
${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.column_description"
|
"ui.panel.developer-tools.tabs.actions.column_description"
|
||||||
)}
|
)}
|
||||||
</th>
|
</th>
|
||||||
<th>
|
<th>
|
||||||
${this.hass.localize(
|
${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.column_example"
|
"ui.panel.developer-tools.tabs.actions.column_example"
|
||||||
)}
|
)}
|
||||||
</th>
|
</th>
|
||||||
</tr>
|
</tr>
|
||||||
@ -281,7 +282,7 @@ class HaPanelDevService extends LitElement {
|
|||||||
${this._yamlMode
|
${this._yamlMode
|
||||||
? html`<mwc-button @click=${this._fillExampleData}
|
? html`<mwc-button @click=${this._fillExampleData}
|
||||||
>${this.hass.localize(
|
>${this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.fill_example_data"
|
"ui.panel.developer-tools.tabs.actions.fill_example_data"
|
||||||
)}</mwc-button
|
)}</mwc-button
|
||||||
>`
|
>`
|
||||||
: ""}
|
: ""}
|
||||||
@ -305,14 +306,14 @@ class HaPanelDevService extends LitElement {
|
|||||||
const errorCategory = yamlMode ? "yaml" : "ui";
|
const errorCategory = yamlMode ? "yaml" : "ui";
|
||||||
if (!serviceData?.service) {
|
if (!serviceData?.service) {
|
||||||
return localize(
|
return localize(
|
||||||
`ui.panel.developer-tools.tabs.services.errors.${errorCategory}.no_service`
|
`ui.panel.developer-tools.tabs.actions.errors.${errorCategory}.no_service`
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
const domain = computeDomain(serviceData.service);
|
const domain = computeDomain(serviceData.service);
|
||||||
const service = computeObjectId(serviceData.service);
|
const service = computeObjectId(serviceData.service);
|
||||||
if (!domain || !service) {
|
if (!domain || !service) {
|
||||||
return localize(
|
return localize(
|
||||||
`ui.panel.developer-tools.tabs.services.errors.${errorCategory}.invalid_service`
|
`ui.panel.developer-tools.tabs.actions.errors.${errorCategory}.invalid_service`
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (
|
if (
|
||||||
@ -323,7 +324,7 @@ class HaPanelDevService extends LitElement {
|
|||||||
!serviceData.data?.area_id
|
!serviceData.data?.area_id
|
||||||
) {
|
) {
|
||||||
return localize(
|
return localize(
|
||||||
`ui.panel.developer-tools.tabs.services.errors.${errorCategory}.no_target`
|
`ui.panel.developer-tools.tabs.actions.errors.${errorCategory}.no_target`
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
for (const field of fields) {
|
for (const field of fields) {
|
||||||
@ -332,7 +333,7 @@ class HaPanelDevService extends LitElement {
|
|||||||
(!serviceData.data || serviceData.data[field.key] === undefined)
|
(!serviceData.data || serviceData.data[field.key] === undefined)
|
||||||
) {
|
) {
|
||||||
return localize(
|
return localize(
|
||||||
`ui.panel.developer-tools.tabs.services.errors.${errorCategory}.missing_required_field`,
|
`ui.panel.developer-tools.tabs.actions.errors.${errorCategory}.missing_required_field`,
|
||||||
{ key: field.key }
|
{ key: field.key }
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -377,7 +378,7 @@ class HaPanelDevService extends LitElement {
|
|||||||
forwardHaptic("failure");
|
forwardHaptic("failure");
|
||||||
button.actionError();
|
button.actionError();
|
||||||
this._error = this.hass.localize(
|
this._error = this.hass.localize(
|
||||||
"ui.panel.developer-tools.tabs.services.errors.yaml.invalid_yaml"
|
"ui.panel.developer-tools.tabs.actions.errors.yaml.invalid_yaml"
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -439,7 +440,7 @@ class HaPanelDevService extends LitElement {
|
|||||||
}
|
}
|
||||||
this._error =
|
this._error =
|
||||||
localizedErrorMessage ||
|
localizedErrorMessage ||
|
||||||
this.hass.localize("ui.notification_toast.service_call_failed", {
|
this.hass.localize("ui.notification_toast.action_failed", {
|
||||||
service: this._serviceData!.service!,
|
service: this._serviceData!.service!,
|
||||||
}) + ` ${err.message}`;
|
}) + ` ${err.message}`;
|
||||||
return;
|
return;
|
||||||
@ -630,10 +631,8 @@ class HaPanelDevService extends LitElement {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
customElements.define("developer-tools-service", HaPanelDevService);
|
|
||||||
|
|
||||||
declare global {
|
declare global {
|
||||||
interface HTMLElementTagNameMap {
|
interface HTMLElementTagNameMap {
|
||||||
"developer-tools-service": HaPanelDevService;
|
"developer-tools-action": HaPanelDevAction;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -24,9 +24,10 @@ class DeveloperToolsRouter extends HassRouterPage {
|
|||||||
tag: "developer-tools-event",
|
tag: "developer-tools-event",
|
||||||
load: () => import("./event/developer-tools-event"),
|
load: () => import("./event/developer-tools-event"),
|
||||||
},
|
},
|
||||||
service: {
|
service: "action",
|
||||||
tag: "developer-tools-service",
|
action: {
|
||||||
load: () => import("./service/developer-tools-service"),
|
tag: "developer-tools-action",
|
||||||
|
load: () => import("./action/developer-tools-action"),
|
||||||
},
|
},
|
||||||
state: {
|
state: {
|
||||||
tag: "developer-tools-state",
|
tag: "developer-tools-state",
|
||||||
|
@ -62,10 +62,8 @@ class PanelDeveloperTools extends LitElement {
|
|||||||
<paper-tab page-name="state">
|
<paper-tab page-name="state">
|
||||||
${this.hass.localize("ui.panel.developer-tools.tabs.states.title")}
|
${this.hass.localize("ui.panel.developer-tools.tabs.states.title")}
|
||||||
</paper-tab>
|
</paper-tab>
|
||||||
<paper-tab page-name="service">
|
<paper-tab page-name="action">
|
||||||
${this.hass.localize(
|
${this.hass.localize("ui.panel.developer-tools.tabs.actions.title")}
|
||||||
"ui.panel.developer-tools.tabs.services.title"
|
|
||||||
)}
|
|
||||||
</paper-tab>
|
</paper-tab>
|
||||||
<paper-tab page-name="template">
|
<paper-tab page-name="template">
|
||||||
${this.hass.localize(
|
${this.hass.localize(
|
||||||
|
@ -45,7 +45,7 @@ function computeActionTooltip(
|
|||||||
break;
|
break;
|
||||||
case "call-service":
|
case "call-service":
|
||||||
tooltip += `${hass.localize(
|
tooltip += `${hass.localize(
|
||||||
"ui.panel.lovelace.cards.picture-elements.call_service",
|
"ui.panel.lovelace.cards.picture-elements.perform_action",
|
||||||
{ name: config.service }
|
{ name: config.service }
|
||||||
)}`;
|
)}`;
|
||||||
break;
|
break;
|
||||||
|
@ -148,7 +148,7 @@ export const handleAction = async (
|
|||||||
case "call-service": {
|
case "call-service": {
|
||||||
if (!actionConfig.service) {
|
if (!actionConfig.service) {
|
||||||
showToast(node, {
|
showToast(node, {
|
||||||
message: hass.localize("ui.panel.lovelace.cards.actions.no_service"),
|
message: hass.localize("ui.panel.lovelace.cards.actions.no_action"),
|
||||||
});
|
});
|
||||||
forwardHaptic("failure");
|
forwardHaptic("failure");
|
||||||
return;
|
return;
|
||||||
|
@ -407,7 +407,6 @@ export class HuiTileCardEditor
|
|||||||
return this.hass!.localize(
|
return this.hass!.localize(
|
||||||
`ui.panel.lovelace.editor.card.tile.${schema.name}`
|
`ui.panel.lovelace.editor.card.tile.${schema.name}`
|
||||||
);
|
);
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return this.hass!.localize(
|
return this.hass!.localize(
|
||||||
`ui.panel.lovelace.editor.card.generic.${schema.name}`
|
`ui.panel.lovelace.editor.card.generic.${schema.name}`
|
||||||
|
@ -135,7 +135,7 @@ export const connectionMixin = <T extends Constructor<HassBaseEl>>(
|
|||||||
const message =
|
const message =
|
||||||
localizedErrorMessage ||
|
localizedErrorMessage ||
|
||||||
(this as any).hass.localize(
|
(this as any).hass.localize(
|
||||||
"ui.notification_toast.service_call_failed",
|
"ui.notification_toast.action_failed",
|
||||||
"service",
|
"service",
|
||||||
`${domain}/${service}`
|
`${domain}/${service}`
|
||||||
) +
|
) +
|
||||||
|
@ -429,7 +429,7 @@
|
|||||||
"triggered_by": "triggered by",
|
"triggered_by": "triggered by",
|
||||||
"triggered_by_automation": "triggered by automation",
|
"triggered_by_automation": "triggered by automation",
|
||||||
"triggered_by_script": "triggered by script",
|
"triggered_by_script": "triggered by script",
|
||||||
"triggered_by_service": "triggered by service",
|
"triggered_by_action": "triggered by action",
|
||||||
"triggered_by_numeric_state_of": "triggered by numeric state of",
|
"triggered_by_numeric_state_of": "triggered by numeric state of",
|
||||||
"triggered_by_state_of": "triggered by state of",
|
"triggered_by_state_of": "triggered by state of",
|
||||||
"triggered_by_event": "triggered by event",
|
"triggered_by_event": "triggered by event",
|
||||||
@ -773,13 +773,13 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"service-picker": {
|
"service-picker": {
|
||||||
"service": "Service"
|
"action": "Action"
|
||||||
},
|
},
|
||||||
"service-control": {
|
"service-control": {
|
||||||
"required": "This field is required",
|
"required": "This field is required",
|
||||||
"target": "Targets",
|
"target": "Targets",
|
||||||
"target_description": "What should this service use as targeted areas, devices or entities.",
|
"target_secondary": "What should this action use as targeted areas, devices or entities.",
|
||||||
"data": "Service data",
|
"action_data": "Action data",
|
||||||
"integration_doc": "Integration documentation"
|
"integration_doc": "Integration documentation"
|
||||||
},
|
},
|
||||||
"related-items": {
|
"related-items": {
|
||||||
@ -1352,7 +1352,7 @@
|
|||||||
"enabled_description": "Disabled entities will not be added to Home Assistant.",
|
"enabled_description": "Disabled entities will not be added to Home Assistant.",
|
||||||
"enabled_delay_confirm": "The enabled entities will be added to Home Assistant in {delay} seconds",
|
"enabled_delay_confirm": "The enabled entities will be added to Home Assistant in {delay} seconds",
|
||||||
"enabled_restart_confirm": "Restart Home Assistant to finish enabling the entities",
|
"enabled_restart_confirm": "Restart Home Assistant to finish enabling the entities",
|
||||||
"hidden_description": "Hidden entities will not be shown on your dashboard or included when indirectly referenced (ie via an area or device). Their history is still tracked and you can still interact with them with services.",
|
"hidden_explanation": "Hidden entities will not be shown on your dashboard or included when indirectly referenced (ie via an area or device). Their history is still tracked and you can still interact with them with actions.",
|
||||||
"delete": "Delete",
|
"delete": "Delete",
|
||||||
"confirm_delete": "Are you sure you want to delete this entity?",
|
"confirm_delete": "Are you sure you want to delete this entity?",
|
||||||
"update": "Update",
|
"update": "Update",
|
||||||
@ -1603,7 +1603,7 @@
|
|||||||
"view_network": "View network"
|
"view_network": "View network"
|
||||||
},
|
},
|
||||||
"services": {
|
"services": {
|
||||||
"reconfigure": "Reconfigure ZHA device (heal device). Use this if you are having issues with the device. If the device in question is a battery powered device please ensure it is awake and accepting commands when you use this service.",
|
"reconfigure": "Reconfigure ZHA device (heal device). Use this if you are having issues with the device. If the device in question is a battery powered device please ensure it is awake and accepting commands when you use this action.",
|
||||||
"updateDeviceName": "Set a custom name for this device in the device registry.",
|
"updateDeviceName": "Set a custom name for this device in the device registry.",
|
||||||
"remove": "Remove a device from the Zigbee network.",
|
"remove": "Remove a device from the Zigbee network.",
|
||||||
"zigbee_information": "View the Zigbee information for the device."
|
"zigbee_information": "View the Zigbee information for the device."
|
||||||
@ -1732,7 +1732,7 @@
|
|||||||
"step_3": "Tap {link_apps_services} and choose {home_assistant} from the list.",
|
"step_3": "Tap {link_apps_services} and choose {home_assistant} from the list.",
|
||||||
"linked_matter_apps_services": "Linked Matter apps and services",
|
"linked_matter_apps_services": "Linked Matter apps and services",
|
||||||
"link_apps_services": "Link apps & services",
|
"link_apps_services": "Link apps & services",
|
||||||
"no_home_assistant": "I can’t find Home Assistant on the list",
|
"no_home_assistant": "I can''t find Home Assistant on the list",
|
||||||
"redirect": "You are redirected to the Home Assistant app. Please follow the instructions."
|
"redirect": "You are redirected to the Home Assistant app. Please follow the instructions."
|
||||||
},
|
},
|
||||||
"google_home_fallback": {
|
"google_home_fallback": {
|
||||||
@ -1807,7 +1807,7 @@
|
|||||||
"dismiss_all": "Dismiss all"
|
"dismiss_all": "Dismiss all"
|
||||||
},
|
},
|
||||||
"notification_toast": {
|
"notification_toast": {
|
||||||
"service_call_failed": "Failed to call service {service}.",
|
"action_failed": "Failed to perform the action {service}.",
|
||||||
"connection_lost": "Connection lost. Reconnecting…",
|
"connection_lost": "Connection lost. Reconnecting…",
|
||||||
"started": "Home Assistant has started!",
|
"started": "Home Assistant has started!",
|
||||||
"starting": "Home Assistant is starting, not everything will be available until it is finished.",
|
"starting": "Home Assistant is starting, not everything will be available until it is finished.",
|
||||||
@ -2660,7 +2660,7 @@
|
|||||||
"run_text_pipeline": "Run text pipeline",
|
"run_text_pipeline": "Run text pipeline",
|
||||||
"run_audio_pipeline": "Run audio pipeline",
|
"run_audio_pipeline": "Run audio pipeline",
|
||||||
"run_audio_with_wake": "Run audio pipeline with wake word detection",
|
"run_audio_with_wake": "Run audio pipeline with wake word detection",
|
||||||
"response": "[%key:ui::panel::developer-tools::tabs::services::response%]",
|
"response": "[%key:ui::panel::developer-tools::tabs::actions::response%]",
|
||||||
"send": "Send",
|
"send": "Send",
|
||||||
"continue_listening": "Continue listening for wake word",
|
"continue_listening": "Continue listening for wake word",
|
||||||
"continue_talking": "Continue talking",
|
"continue_talking": "Continue talking",
|
||||||
@ -3267,18 +3267,19 @@
|
|||||||
},
|
},
|
||||||
"type": {
|
"type": {
|
||||||
"service": {
|
"service": {
|
||||||
"label": "Call service",
|
"label": "Perform action",
|
||||||
"response_variable": "Response variable",
|
"response_variable": "Response variable",
|
||||||
"has_optional_response": "This service can return a response, if you want to use the response, enter the name of a variable the response will be saved in",
|
"has_optional_response": "This action can return a response, if you want to use the response, enter the name of a variable the response will be saved in",
|
||||||
"has_response": "This service returns a response, enter the name of a variable the response will be saved in",
|
"has_response": "This action returns a response, enter the name of a variable the response will be saved in",
|
||||||
"description": {
|
"description": {
|
||||||
"service_based_on_template": "Call a service based on a template on {targets}",
|
"picker": "Previously known as call service.",
|
||||||
"service_based_on_name": "Call a service ''{name}'' on {targets}",
|
"service_based_on_template": "Perform an action based on a template on {targets}",
|
||||||
|
"service_based_on_name": "Perform action ''{name}'' on {targets}",
|
||||||
"service_name": "{domain} ''{name}'' on {targets}",
|
"service_name": "{domain} ''{name}'' on {targets}",
|
||||||
"service_based_on_template_no_targets": "Call a service based on a template",
|
"service_based_on_template_no_targets": "Perform an action based on a template",
|
||||||
"service_based_on_name_no_targets": "Call a service ''{name}''",
|
"service_based_on_name_no_targets": "Perform action ''{name}''",
|
||||||
"service_name_no_targets": "{domain} ''{name}''",
|
"service_name_no_targets": "{domain} ''{name}''",
|
||||||
"service": "Call a service",
|
"service": "Perform an action",
|
||||||
"target_template": "templated {name}",
|
"target_template": "templated {name}",
|
||||||
"target_unknown_entity": "unknown entity",
|
"target_unknown_entity": "unknown entity",
|
||||||
"target_unknown_device": "unknown device",
|
"target_unknown_device": "unknown device",
|
||||||
@ -3837,7 +3838,7 @@
|
|||||||
"fetching_subscription": "Fetching subscription…",
|
"fetching_subscription": "Fetching subscription…",
|
||||||
"tts": {
|
"tts": {
|
||||||
"title": "Text-to-speech",
|
"title": "Text-to-speech",
|
||||||
"info": "Bring personality to your home by having it speak to you by using our text-to-speech services. You can use this in automations and scripts by using the {service} service.",
|
"description": "Bring personality to your home by having it speak to you by using our text-to-speech services. You can use this in automations and scripts by using the {service} action.",
|
||||||
"default_language": "Default language to use",
|
"default_language": "Default language to use",
|
||||||
"default_voice": "Default voice to use",
|
"default_voice": "Default voice to use",
|
||||||
"try": "Try",
|
"try": "Try",
|
||||||
@ -4122,7 +4123,7 @@
|
|||||||
"hide_selected": {
|
"hide_selected": {
|
||||||
"button": "Hide selected",
|
"button": "Hide selected",
|
||||||
"confirm_title": "Do you want to hide {number} {number, plural,\n one {entity}\n other {entities}\n}?",
|
"confirm_title": "Do you want to hide {number} {number, plural,\n one {entity}\n other {entities}\n}?",
|
||||||
"confirm_text": "Hidden entities will not be shown on your dashboard. Their history is still tracked and you can still interact with them with services."
|
"confirm": "Hidden entities will not be shown on your dashboard. Their history is still tracked and you can still interact with them with actions."
|
||||||
},
|
},
|
||||||
"unhide_selected": {
|
"unhide_selected": {
|
||||||
"button": "Unhide selected"
|
"button": "Unhide selected"
|
||||||
@ -5280,7 +5281,7 @@
|
|||||||
"no_entity_toggle": "No entity provided to toggle",
|
"no_entity_toggle": "No entity provided to toggle",
|
||||||
"no_navigation_path": "No navigation path specified",
|
"no_navigation_path": "No navigation path specified",
|
||||||
"no_url": "No URL to open specified",
|
"no_url": "No URL to open specified",
|
||||||
"no_service": "No service to run specified"
|
"no_action": "No action to run specified"
|
||||||
},
|
},
|
||||||
"empty_state": {
|
"empty_state": {
|
||||||
"title": "Welcome Home",
|
"title": "Welcome Home",
|
||||||
@ -5310,7 +5311,7 @@
|
|||||||
"navigate_to": "Navigate to {location}",
|
"navigate_to": "Navigate to {location}",
|
||||||
"url": "Open window to {url_path}",
|
"url": "Open window to {url_path}",
|
||||||
"toggle": "Toggle {name}",
|
"toggle": "Toggle {name}",
|
||||||
"call_service": "Call service {name}",
|
"perform_action": "Perform action {name}",
|
||||||
"more_info": "Show more info: {name}"
|
"more_info": "Show more info: {name}"
|
||||||
},
|
},
|
||||||
"iframe": {
|
"iframe": {
|
||||||
@ -5625,14 +5626,14 @@
|
|||||||
"start_listening": "Start listening",
|
"start_listening": "Start listening",
|
||||||
"pipeline_id": "Assistant",
|
"pipeline_id": "Assistant",
|
||||||
"actions": {
|
"actions": {
|
||||||
"default_action": "Default action",
|
"default_action": "Default",
|
||||||
"call-service": "Call service",
|
"call-service": "Perform action",
|
||||||
"more-info": "More info",
|
"more-info": "More info",
|
||||||
"toggle": "Toggle",
|
"toggle": "Toggle",
|
||||||
"navigate": "Navigate",
|
"navigate": "Navigate",
|
||||||
"assist": "Assist",
|
"assist": "Assist",
|
||||||
"url": "URL",
|
"url": "URL",
|
||||||
"none": "No action"
|
"none": "Nothing"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"condition-editor": {
|
"condition-editor": {
|
||||||
@ -5740,7 +5741,7 @@
|
|||||||
},
|
},
|
||||||
"entity_row": {
|
"entity_row": {
|
||||||
"divider": "Divider",
|
"divider": "Divider",
|
||||||
"call-service": "Call service",
|
"call-service": "Perform action",
|
||||||
"section": "Section",
|
"section": "Section",
|
||||||
"weblink": "Web link",
|
"weblink": "Web link",
|
||||||
"attribute": "Attribute",
|
"attribute": "Attribute",
|
||||||
@ -5757,7 +5758,7 @@
|
|||||||
"button": {
|
"button": {
|
||||||
"name": "Button",
|
"name": "Button",
|
||||||
"description": "The Button card allows you to add buttons to perform tasks.",
|
"description": "The Button card allows you to add buttons to perform tasks.",
|
||||||
"default_action_help": "The default action depends on the entity's capabilities, it will either be toggled or the more info dialog will be shown."
|
"default_action_help": "The default depends on the entity's capabilities, it will either be toggled or the more info dialog will be shown."
|
||||||
},
|
},
|
||||||
"entity-filter": {
|
"entity-filter": {
|
||||||
"name": "Entity filter",
|
"name": "Entity filter",
|
||||||
@ -5875,10 +5876,10 @@
|
|||||||
"camera_image": "Camera entity",
|
"camera_image": "Camera entity",
|
||||||
"image_entity": "Image entity",
|
"image_entity": "Image entity",
|
||||||
"camera_view": "Camera view",
|
"camera_view": "Camera view",
|
||||||
"double_tap_action": "Double tap action",
|
"double_tap_action": "Double tap behavior",
|
||||||
"entities": "Entities",
|
"entities": "Entities",
|
||||||
"entity": "Entity",
|
"entity": "Entity",
|
||||||
"hold_action": "Hold action",
|
"hold_action": "Hold behavior",
|
||||||
"hours_to_show": "Hours to show",
|
"hours_to_show": "Hours to show",
|
||||||
"days_to_show": "Days to show",
|
"days_to_show": "Days to show",
|
||||||
"icon": "Icon",
|
"icon": "Icon",
|
||||||
@ -5895,7 +5896,7 @@
|
|||||||
"show_icon": "Show icon?",
|
"show_icon": "Show icon?",
|
||||||
"show_name": "Show name?",
|
"show_name": "Show name?",
|
||||||
"show_state": "Show state?",
|
"show_state": "Show state?",
|
||||||
"tap_action": "Tap action",
|
"tap_action": "Tap behavior",
|
||||||
"title": "Title",
|
"title": "Title",
|
||||||
"theme": "Theme",
|
"theme": "Theme",
|
||||||
"unit": "Unit",
|
"unit": "Unit",
|
||||||
@ -5934,7 +5935,7 @@
|
|||||||
},
|
},
|
||||||
"picture": {
|
"picture": {
|
||||||
"name": "Picture",
|
"name": "Picture",
|
||||||
"description": "The Picture card allows you to set an image to use for navigation to various paths in your interface or to call a service."
|
"description": "The Picture card allows you to set an image to use for navigation to various paths in your interface or to perform an action."
|
||||||
},
|
},
|
||||||
"picture-elements": {
|
"picture-elements": {
|
||||||
"name": "Picture elements",
|
"name": "Picture elements",
|
||||||
@ -5946,7 +5947,7 @@
|
|||||||
},
|
},
|
||||||
"picture-glance": {
|
"picture-glance": {
|
||||||
"name": "Picture glance",
|
"name": "Picture glance",
|
||||||
"description": "The Picture card allows you to set an image to use for navigation to various paths in your interface or to call a service.",
|
"description": "The Picture card allows you to set an image to use for navigation to various paths in your interface or to perform an action.",
|
||||||
"state_entity": "State entity"
|
"state_entity": "State entity"
|
||||||
},
|
},
|
||||||
"plant-status": {
|
"plant-status": {
|
||||||
@ -5973,7 +5974,7 @@
|
|||||||
"name": "Tile",
|
"name": "Tile",
|
||||||
"description": "The tile card gives you a quick overview of your entity. The card allow you to toggle the entity, show the more info dialog or custom actions.",
|
"description": "The tile card gives you a quick overview of your entity. The card allow you to toggle the entity, show the more info dialog or custom actions.",
|
||||||
"color": "Color",
|
"color": "Color",
|
||||||
"icon_tap_action": "Icon tap action",
|
"icon_tap_action": "Icon tap behavior",
|
||||||
"actions": "Actions",
|
"actions": "Actions",
|
||||||
"appearance": "Appearance",
|
"appearance": "Appearance",
|
||||||
"default_color": "Default color (state)",
|
"default_color": "Default color (state)",
|
||||||
@ -6690,10 +6691,10 @@
|
|||||||
"alert_event_type": "Event type is a mandatory field",
|
"alert_event_type": "Event type is a mandatory field",
|
||||||
"notification_event_fired": "Event {type} successfully fired!"
|
"notification_event_fired": "Event {type} successfully fired!"
|
||||||
},
|
},
|
||||||
"services": {
|
"actions": {
|
||||||
"title": "Services",
|
"title": "Actions",
|
||||||
"description": "The service dev tool allows you to call any available service in Home Assistant.",
|
"description": "The actions dev tool allows you to perform any action available in Home Assistant.",
|
||||||
"call_service": "Call service",
|
"call_service": "Perform action",
|
||||||
"response": "Response",
|
"response": "Response",
|
||||||
"column_parameter": "Parameter",
|
"column_parameter": "Parameter",
|
||||||
"column_description": "Description",
|
"column_description": "Description",
|
||||||
@ -6703,21 +6704,21 @@
|
|||||||
"ui_mode": "Go to UI mode",
|
"ui_mode": "Go to UI mode",
|
||||||
"yaml_parameters": "Parameters only available in YAML mode",
|
"yaml_parameters": "Parameters only available in YAML mode",
|
||||||
"all_parameters": "All available parameters",
|
"all_parameters": "All available parameters",
|
||||||
"accepts_target": "This service accepts a target, for example: `entity_id: light.bed_light`",
|
"accepts_target": "This action accepts a target, for example: `entity_id: light.bed_light`",
|
||||||
"no_template_ui_support": "The UI does not support templates, you can still use the YAML editor.",
|
"no_template_ui_support": "The UI does not support templates, you can still use the YAML editor.",
|
||||||
"errors": {
|
"errors": {
|
||||||
"ui": {
|
"ui": {
|
||||||
"no_service": "No service selected, please select a service",
|
"no_service": "No action selected, please select an action",
|
||||||
"invalid_service": "Selected service is invalid, please select a valid service",
|
"invalid_service": "Selected action is invalid, please select a valid action",
|
||||||
"no_target": "This service requires a target, please select a target from the picker",
|
"no_target": "This action requires a target, please select a target from the picker",
|
||||||
"missing_required_field": "This service requires field {key}, please enter a valid value for {key}"
|
"missing_required_field": "This action requires field {key}, please enter a valid value for {key}"
|
||||||
},
|
},
|
||||||
"yaml": {
|
"yaml": {
|
||||||
"invalid_yaml": "Service YAML contains syntax errors, please fix the syntax",
|
"invalid_yaml": "Action YAML contains syntax errors, please fix the syntax",
|
||||||
"no_service": "No service defined, please define a service: key",
|
"no_service": "No action defined, please define an action: key",
|
||||||
"invalid_service": "Defined service is invalid, please provide a service in the format domain.service",
|
"invalid_service": "Defined action is invalid, please provide an action in the format domain.action",
|
||||||
"no_target": "This service requires a target, please define a target entity_id, device_id, or area_id under target: or data:",
|
"no_target": "This action requires a target, please define a target entity_id, device_id, or area_id under target: or data:",
|
||||||
"missing_required_field": "This service requires field {key}, which must be provided under data:"
|
"missing_required_field": "This action requires field {key}, which must be provided under data:"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
Loading…
x
Reference in New Issue
Block a user