mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-12-02 12:54:18 +01:00
75 lines
2.3 KiB
TypeScript
75 lines
2.3 KiB
TypeScript
|
import {html, LitElement} from "lit";
|
||
|
import {Et2Widget} from "../Et2Widget/Et2Widget";
|
||
|
import {FileInfo} from "./Et2VfsSelect";
|
||
|
import {property} from "lit/decorators/property.js";
|
||
|
import {state} from "lit/decorators/state.js";
|
||
|
import {classMap} from "lit/directives/class-map.js";
|
||
|
import shoelace from "../Styles/shoelace";
|
||
|
import styles from "./Et2VfsSelectRow.styles";
|
||
|
|
||
|
export class Et2VfsSelectRow extends Et2Widget(LitElement)
|
||
|
{
|
||
|
static get styles()
|
||
|
{
|
||
|
return [
|
||
|
shoelace,
|
||
|
...super.styles,
|
||
|
styles
|
||
|
];
|
||
|
}
|
||
|
|
||
|
@property({type: Object}) value : FileInfo;
|
||
|
|
||
|
/** Draws the file in a disabled state, preventing selection. */
|
||
|
@property({type: Boolean, reflect: true}) disabled = false;
|
||
|
|
||
|
@state() current = false; // the user has keyed into the file, but hasn't selected it yet (shows a highlight)
|
||
|
@state() selected = false; // the file is selected and has aria-selected="true"
|
||
|
@state() hasHover = false; // we need this because Safari doesn't honor :hover styles while dragging
|
||
|
|
||
|
connectedCallback()
|
||
|
{
|
||
|
super.connectedCallback();
|
||
|
this.setAttribute('role', 'option');
|
||
|
this.setAttribute('aria-selected', 'false');
|
||
|
}
|
||
|
|
||
|
private handleMouseEnter()
|
||
|
{
|
||
|
this.hasHover = true;
|
||
|
this.requestUpdate("hasHover", false);
|
||
|
}
|
||
|
|
||
|
private handleMouseLeave()
|
||
|
{
|
||
|
this.hasHover = false;
|
||
|
this.requestUpdate("hasHover", true);
|
||
|
}
|
||
|
|
||
|
render()
|
||
|
{
|
||
|
return html`
|
||
|
<div
|
||
|
part="base"
|
||
|
class=${classMap({
|
||
|
file: true,
|
||
|
'file--current': this.current,
|
||
|
'file--disabled': this.disabled,
|
||
|
'file--selected': this.selected,
|
||
|
'file--hover': this.hasHover
|
||
|
})}
|
||
|
@mouseenter=${this.handleMouseEnter}
|
||
|
@mouseleave=${this.handleMouseLeave}
|
||
|
>
|
||
|
<sl-icon part="checked-icon" class="file__check" name="check" library="system"
|
||
|
aria-hidden="true"></sl-icon>
|
||
|
<slot part="prefix" name="prefix" class="file__prefix"></slot>
|
||
|
<et2-vfs-mime .value=${this.value}></et2-vfs-mime>
|
||
|
${this.value.name}
|
||
|
<slot part="suffix" name="suffix" class="file__suffix"></slot>
|
||
|
</div>
|
||
|
`;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
customElements.define("et2-vfs-select-row", Et2VfsSelectRow);
|