Skip to content

Commit

Permalink
Show icons in time slot editor when names are too long
Browse files Browse the repository at this point in the history
Partially fixes #748
  • Loading branch information
tonyroberts committed Nov 8, 2023
1 parent b96a5a3 commit acbcfeb
Showing 1 changed file with 54 additions and 6 deletions.
60 changes: 54 additions & 6 deletions src/components/timeslot-editor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,27 @@ export class TimeslotEditor extends LitElement {
const availableWidth = w * width - leftMargin - rightMargin;
start += w * width;

const content = (() => {
if (actionText && (availableWidth > textWidth / 3 || availableWidth > 50) && availableWidth > 30) {
return html`
<span style="margin-left: ${leftMargin.toFixed(2)}px; margin-right: ${rightMargin.toFixed(2)}px">
${actionText}
</span>
`;
}

const icons = this.computeActionIcons(e);
if (!!icons) {
return html`
<span style="margin-left: auto; margin-right: auto">
${icons.map((icon) => html`<ha-icon icon="${icon}"></ha-icon>`)}
</span>
`;
}

return '';
})();

return html`
<div
class="slot${this.activeSlot == i && this.activeMarker === null ? ' active' : ''} ${w * width < 2
Expand All @@ -150,12 +171,7 @@ export class TimeslotEditor extends LitElement {
`
: ''}
${i > 0 ? this.renderTooltip(i) : ''}
<span style="margin-left: ${leftMargin.toFixed(2)}px; margin-right: ${rightMargin.toFixed(2)}px">
${actionText && (availableWidth > textWidth / 3 || availableWidth > 50) && availableWidth > 30
? actionText
: ''}
</span>
${content}
</div>
`;
});
Expand Down Expand Up @@ -237,6 +253,37 @@ export class TimeslotEditor extends LitElement {
).join(', ');
}

computeActionIcons(entry: Timeslot) {
if (!this.hass) return;
if (!entry.actions) return;

return unique(
entry.actions.map(action => {
const actionConfig = this.actions.find(e => compareActions(e, action, true));
if (!actionConfig) return [];

if (
actionConfig.variables &&
Object.keys(actionConfig.variables).some(field => action.service_data && field in action.service_data)
) {
return Object.entries(actionConfig.variables)
.filter(([field]) => action.service_data && field in action.service_data)
.map(([field, variable]) => {
const value = action.service_data![field];
if (variable.type == EVariableType.List) {
variable = variable as ListVariable;
const listItem = variable.options.find(e => e.value == value);
return listItem?.icon;
} else return undefined;
});
}
return [actionConfig.icon];
})
.reduce((prev, icons) => [...prev, ...icons], [])
.filter((icon) => !!icon)
);
}

@eventOptions({ passive: true })
private _handleTouchStart(ev: MouseEvent | TouchEvent) {
const fullWidth = parseFloat(getComputedStyle(this).getPropertyValue('width'));
Expand Down Expand Up @@ -336,6 +383,7 @@ export class TimeslotEditor extends LitElement {
_selectSlot(ev: Event) {
if (this.isDragging) return;
let el = ev.target as HTMLElement;
if (el.tagName.toLowerCase() == 'ha-icon') el = el.parentElement as HTMLElement;
if (el.tagName.toLowerCase() == 'span') el = el.parentElement as HTMLElement;
if (el.classList.contains('handle')) el = el.parentElement as HTMLElement;
const slot = Number(el.getAttribute('slot'));
Expand Down

0 comments on commit acbcfeb

Please sign in to comment.