mirror of
https://github.com/home-assistant/frontend.git
synced 2026-04-07 03:14:00 +00:00
Don't use ha-automation-row-selected to know if the item was selected (#26812)
This commit is contained in:
committed by
Bram Kragten
parent
cd294ba619
commit
9845f0b47c
@@ -15,21 +15,16 @@ declare global {
|
||||
"item-added": {
|
||||
index: number;
|
||||
data: any;
|
||||
item: any;
|
||||
};
|
||||
"item-removed": {
|
||||
index: number;
|
||||
};
|
||||
"drag-start": undefined;
|
||||
"drag-end": undefined;
|
||||
"item-cloned": HaSortableClonedEventData;
|
||||
}
|
||||
}
|
||||
|
||||
export interface HaSortableClonedEventData {
|
||||
item: any;
|
||||
clone: any;
|
||||
}
|
||||
|
||||
export type HaSortableOptions = Omit<
|
||||
SortableInstance.SortableOptions,
|
||||
"onStart" | "onChoose" | "onEnd" | "onUpdate" | "onAdd" | "onRemove"
|
||||
@@ -154,7 +149,6 @@ export class HaSortable extends LitElement {
|
||||
onUpdate: this._handleUpdate,
|
||||
onAdd: this._handleAdd,
|
||||
onRemove: this._handleRemove,
|
||||
onClone: this._handleClone,
|
||||
};
|
||||
|
||||
if (this.draggableSelector) {
|
||||
@@ -187,6 +181,7 @@ export class HaSortable extends LitElement {
|
||||
fireEvent(this, "item-added", {
|
||||
index: evt.newIndex,
|
||||
data: evt.item.sortableData,
|
||||
item: evt.item,
|
||||
});
|
||||
};
|
||||
|
||||
@@ -194,10 +189,6 @@ export class HaSortable extends LitElement {
|
||||
fireEvent(this, "item-removed", { index: evt.oldIndex });
|
||||
};
|
||||
|
||||
private _handleClone = (evt) => {
|
||||
fireEvent(this, "item-cloned", evt);
|
||||
};
|
||||
|
||||
private _handleEnd = async (evt) => {
|
||||
fireEvent(this, "drag-end");
|
||||
// put back in original location
|
||||
|
||||
@@ -9,7 +9,6 @@ import { fireEvent } from "../../../../common/dom/fire_event";
|
||||
import { nextRender } from "../../../../common/util/render-status";
|
||||
import "../../../../components/ha-button";
|
||||
import "../../../../components/ha-sortable";
|
||||
import type { HaSortableClonedEventData } from "../../../../components/ha-sortable";
|
||||
import "../../../../components/ha-svg-icon";
|
||||
import {
|
||||
ACTION_BUILDING_BLOCKS,
|
||||
@@ -76,7 +75,6 @@ export default class HaAutomationAction extends LitElement {
|
||||
@item-moved=${this._actionMoved}
|
||||
@item-added=${this._actionAdded}
|
||||
@item-removed=${this._actionRemoved}
|
||||
@item-cloned=${this._actionCloned}
|
||||
>
|
||||
<div class="rows ${!this.optionsInSidebar ? "no-sidebar" : ""}">
|
||||
${repeat(
|
||||
@@ -301,11 +299,8 @@ export default class HaAutomationAction extends LitElement {
|
||||
private async _actionAdded(ev: CustomEvent): Promise<void> {
|
||||
ev.stopPropagation();
|
||||
const { index, data } = ev.detail;
|
||||
let selected = false;
|
||||
if (data?.["ha-automation-row-selected"]) {
|
||||
selected = true;
|
||||
delete data["ha-automation-row-selected"];
|
||||
}
|
||||
const item = ev.detail.item as HaAutomationActionRow;
|
||||
const selected = item.isSelected();
|
||||
|
||||
let actions = [
|
||||
...this.actions.slice(0, index),
|
||||
@@ -363,12 +358,6 @@ export default class HaAutomationAction extends LitElement {
|
||||
fireEvent(this, "value-changed", { value: actions });
|
||||
}
|
||||
|
||||
private _actionCloned(ev: CustomEvent<HaSortableClonedEventData>) {
|
||||
if (ev.detail.item.action && ev.detail.item.isSelected()) {
|
||||
ev.detail.item.action["ha-automation-row-selected"] = true;
|
||||
}
|
||||
}
|
||||
|
||||
private _duplicateAction(ev: CustomEvent) {
|
||||
ev.stopPropagation();
|
||||
const index = (ev.target as any).index;
|
||||
|
||||
@@ -10,7 +10,6 @@ import { nextRender } from "../../../../common/util/render-status";
|
||||
import "../../../../components/ha-button";
|
||||
import "../../../../components/ha-button-menu";
|
||||
import "../../../../components/ha-sortable";
|
||||
import type { HaSortableClonedEventData } from "../../../../components/ha-sortable";
|
||||
import "../../../../components/ha-svg-icon";
|
||||
import type {
|
||||
AutomationClipboard,
|
||||
@@ -153,7 +152,6 @@ export default class HaAutomationCondition extends LitElement {
|
||||
@item-moved=${this._conditionMoved}
|
||||
@item-added=${this._conditionAdded}
|
||||
@item-removed=${this._conditionRemoved}
|
||||
@item-cloned=${this._conditionCloned}
|
||||
>
|
||||
<div class="rows ${!this.optionsInSidebar ? "no-sidebar" : ""}">
|
||||
${repeat(
|
||||
@@ -319,11 +317,8 @@ export default class HaAutomationCondition extends LitElement {
|
||||
private async _conditionAdded(ev: CustomEvent): Promise<void> {
|
||||
ev.stopPropagation();
|
||||
const { index, data } = ev.detail;
|
||||
let selected = false;
|
||||
if (data?.["ha-automation-row-selected"]) {
|
||||
selected = true;
|
||||
delete data["ha-automation-row-selected"];
|
||||
}
|
||||
const item = ev.detail.item as HaAutomationConditionRow;
|
||||
const selected = item.isSelected();
|
||||
let conditions = [
|
||||
...this.conditions.slice(0, index),
|
||||
data,
|
||||
@@ -361,12 +356,6 @@ export default class HaAutomationCondition extends LitElement {
|
||||
fireEvent(this, "value-changed", { value: conditions });
|
||||
}
|
||||
|
||||
private _conditionCloned(ev: CustomEvent<HaSortableClonedEventData>) {
|
||||
if (ev.detail.item.isSelected()) {
|
||||
ev.detail.item.condition["ha-automation-row-selected"] = true;
|
||||
}
|
||||
}
|
||||
|
||||
private _conditionChanged(ev: CustomEvent) {
|
||||
ev.stopPropagation();
|
||||
const conditions = [...this.conditions];
|
||||
|
||||
@@ -9,7 +9,6 @@ import { fireEvent } from "../../../../common/dom/fire_event";
|
||||
import { nextRender } from "../../../../common/util/render-status";
|
||||
import "../../../../components/ha-button";
|
||||
import "../../../../components/ha-sortable";
|
||||
import type { HaSortableClonedEventData } from "../../../../components/ha-sortable";
|
||||
import "../../../../components/ha-svg-icon";
|
||||
import type { AutomationClipboard } from "../../../../data/automation";
|
||||
import type { Option } from "../../../../data/script";
|
||||
@@ -65,7 +64,6 @@ export default class HaAutomationOption extends LitElement {
|
||||
@item-moved=${this._optionMoved}
|
||||
@item-added=${this._optionAdded}
|
||||
@item-removed=${this._optionRemoved}
|
||||
@item-cloned=${this._optionCloned}
|
||||
>
|
||||
<div class="rows ${!this.optionsInSidebar ? "no-sidebar" : ""}">
|
||||
${repeat(
|
||||
@@ -241,11 +239,8 @@ export default class HaAutomationOption extends LitElement {
|
||||
private async _optionAdded(ev: CustomEvent): Promise<void> {
|
||||
ev.stopPropagation();
|
||||
const { index, data } = ev.detail;
|
||||
let selected = false;
|
||||
if (data?.["ha-automation-row-selected"]) {
|
||||
selected = true;
|
||||
delete data["ha-automation-row-selected"];
|
||||
}
|
||||
const item = ev.detail.item as HaAutomationOptionRow;
|
||||
const selected = item.isSelected();
|
||||
|
||||
const options = [
|
||||
...this.options.slice(0, index),
|
||||
@@ -273,12 +268,6 @@ export default class HaAutomationOption extends LitElement {
|
||||
fireEvent(this, "value-changed", { value: options });
|
||||
}
|
||||
|
||||
private _optionCloned(ev: CustomEvent<HaSortableClonedEventData>) {
|
||||
if (ev.detail.item.isSelected()) {
|
||||
ev.detail.item.option["ha-automation-row-selected"] = true;
|
||||
}
|
||||
}
|
||||
|
||||
private _optionChanged(ev: CustomEvent) {
|
||||
ev.stopPropagation();
|
||||
const options = [...this.options];
|
||||
|
||||
@@ -10,7 +10,6 @@ import { nextRender } from "../../../../common/util/render-status";
|
||||
import "../../../../components/ha-button";
|
||||
import "../../../../components/ha-button-menu";
|
||||
import "../../../../components/ha-sortable";
|
||||
import type { HaSortableClonedEventData } from "../../../../components/ha-sortable";
|
||||
import "../../../../components/ha-svg-icon";
|
||||
import type {
|
||||
AutomationClipboard,
|
||||
@@ -72,7 +71,6 @@ export default class HaAutomationTrigger extends LitElement {
|
||||
@item-moved=${this._triggerMoved}
|
||||
@item-added=${this._triggerAdded}
|
||||
@item-removed=${this._triggerRemoved}
|
||||
@item-cloned=${this._triggerCloned}
|
||||
>
|
||||
<div class="rows ${!this.optionsInSidebar ? "no-sidebar" : ""}">
|
||||
${repeat(
|
||||
@@ -260,11 +258,8 @@ export default class HaAutomationTrigger extends LitElement {
|
||||
private async _triggerAdded(ev: CustomEvent): Promise<void> {
|
||||
ev.stopPropagation();
|
||||
const { index, data } = ev.detail;
|
||||
let selected = false;
|
||||
if (data?.["ha-automation-row-selected"]) {
|
||||
selected = true;
|
||||
delete data["ha-automation-row-selected"];
|
||||
}
|
||||
const item = ev.detail.item as HaAutomationTriggerRow;
|
||||
const selected = item.isSelected();
|
||||
|
||||
let triggers = [
|
||||
...this.triggers.slice(0, index),
|
||||
@@ -303,12 +298,6 @@ export default class HaAutomationTrigger extends LitElement {
|
||||
fireEvent(this, "value-changed", { value: triggers });
|
||||
}
|
||||
|
||||
private _triggerCloned(ev: CustomEvent<HaSortableClonedEventData>) {
|
||||
if (ev.detail.item.isSelected()) {
|
||||
ev.detail.item.trigger["ha-automation-row-selected"] = true;
|
||||
}
|
||||
}
|
||||
|
||||
private _triggerChanged(ev: CustomEvent) {
|
||||
ev.stopPropagation();
|
||||
const triggers = [...this.triggers];
|
||||
|
||||
Reference in New Issue
Block a user