feat(dees-table): improve inline cell editors with integrated input styling and auto-open dropdowns
This commit is contained in:
@@ -2023,6 +2023,10 @@ export class DeesTable<T> extends DeesElement {
|
||||
'.editingCell dees-input-tags'
|
||||
) as any;
|
||||
el?.focus?.();
|
||||
// Dropdown editors should auto-open so the user can pick immediately.
|
||||
if (el?.tagName === 'DEES-INPUT-DROPDOWN') {
|
||||
el.updateComplete?.then(() => el.toggleSelectionBox?.());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@@ -2090,8 +2094,13 @@ export class DeesTable<T> extends DeesElement {
|
||||
case 'dropdown': {
|
||||
const options = (col.editorOptions?.options as any[]) ?? [];
|
||||
const selected =
|
||||
options.find((o: any) => (o?.option ?? o?.key ?? o) === value) ?? null;
|
||||
options.find((o: any) => {
|
||||
if (o == null) return false;
|
||||
if (typeof o === 'string') return o === raw;
|
||||
return o.key === raw || o.option === raw;
|
||||
}) ?? null;
|
||||
return html`<dees-input-dropdown
|
||||
.vintegrated=${true}
|
||||
.options=${options}
|
||||
.selectedOption=${selected}
|
||||
@selectedOption=${(e: CustomEvent<any>) => {
|
||||
@@ -2121,6 +2130,7 @@ export class DeesTable<T> extends DeesElement {
|
||||
case 'text':
|
||||
default:
|
||||
return html`<dees-input-text
|
||||
.vintegrated=${true}
|
||||
.value=${value == null ? '' : String(value)}
|
||||
@focusout=${(e: any) => onTextCommit(e.target)}
|
||||
@keydown=${(e: KeyboardEvent) => this.__handleEditorKey(e, item, col)}
|
||||
|
||||
@@ -386,6 +386,11 @@ export const tableStyles: CSSResult[] = [
|
||||
}
|
||||
td.editingCell {
|
||||
padding: 0;
|
||||
outline: 2px solid ${cssManager.bdTheme(
|
||||
'hsl(222.2 47.4% 51.2% / 0.6)',
|
||||
'hsl(217.2 91.2% 59.8% / 0.6)'
|
||||
)};
|
||||
outline-offset: -2px;
|
||||
}
|
||||
td.editingCell .innerCellContainer {
|
||||
padding: 0;
|
||||
|
||||
@@ -46,6 +46,12 @@ export class DeesInputDropdown extends DeesInputBase<DeesInputDropdown> {
|
||||
})
|
||||
accessor enableSearch: boolean = true;
|
||||
|
||||
@property({
|
||||
type: Boolean,
|
||||
reflect: true,
|
||||
})
|
||||
accessor vintegrated: boolean = false;
|
||||
|
||||
@state()
|
||||
accessor isOpened = false;
|
||||
|
||||
@@ -126,6 +132,36 @@ export class DeesInputDropdown extends DeesInputBase<DeesInputDropdown> {
|
||||
.selectedBox.open::after {
|
||||
transform: translateY(-50%) rotate(180deg);
|
||||
}
|
||||
|
||||
/* Visually integrated mode: shed chrome to blend into a host component
|
||||
(e.g. a dees-table cell in edit mode). */
|
||||
:host([vintegrated]) dees-label {
|
||||
display: none;
|
||||
}
|
||||
:host([vintegrated]) .maincontainer {
|
||||
height: 40px;
|
||||
}
|
||||
:host([vintegrated]) .selectedBox {
|
||||
height: 40px;
|
||||
line-height: 40px;
|
||||
padding: 0 32px 0 16px;
|
||||
font-size: 13px;
|
||||
border: none;
|
||||
border-radius: 0;
|
||||
background: transparent;
|
||||
box-shadow: none;
|
||||
transition: none;
|
||||
}
|
||||
:host([vintegrated]) .selectedBox:hover:not(.disabled),
|
||||
:host([vintegrated]) .selectedBox:focus-visible {
|
||||
border: none;
|
||||
box-shadow: none;
|
||||
background: transparent;
|
||||
}
|
||||
:host([vintegrated]) .selectedBox::after {
|
||||
right: 12px;
|
||||
opacity: 0.6;
|
||||
}
|
||||
`,
|
||||
];
|
||||
|
||||
|
||||
@@ -57,6 +57,12 @@ export class DeesInputText extends DeesInputBase {
|
||||
@property({})
|
||||
accessor validationFunction!: (value: string) => boolean;
|
||||
|
||||
@property({
|
||||
type: Boolean,
|
||||
reflect: true,
|
||||
})
|
||||
accessor vintegrated: boolean = false;
|
||||
|
||||
public static styles = [
|
||||
themeDefaultStyles,
|
||||
...DeesInputBase.baseStyles,
|
||||
@@ -194,6 +200,36 @@ export class DeesInputText extends DeesInputBase {
|
||||
border-color: ${cssManager.bdTheme('hsl(142.1 76.2% 36.3%)', 'hsl(142.1 70.6% 45.3%)')};
|
||||
box-shadow: 0 0 0 2px ${cssManager.bdTheme('hsl(142.1 76.2% 36.3% / 0.05)', 'hsl(142.1 70.6% 45.3% / 0.05)')};
|
||||
}
|
||||
|
||||
/* Visually integrated mode: shed chrome to blend into a host component
|
||||
(e.g. a dees-table cell in edit mode). */
|
||||
:host([vintegrated]) dees-label,
|
||||
:host([vintegrated]) .validationContainer {
|
||||
display: none;
|
||||
}
|
||||
:host([vintegrated]) .maincontainer {
|
||||
height: 40px;
|
||||
}
|
||||
:host([vintegrated]) input {
|
||||
height: 40px;
|
||||
line-height: 24px;
|
||||
padding: 0 16px;
|
||||
font-size: 13px;
|
||||
border: none;
|
||||
border-radius: 0;
|
||||
background: transparent;
|
||||
box-shadow: none;
|
||||
transition: none;
|
||||
}
|
||||
:host([vintegrated]) input:hover:not(:disabled):not(:focus),
|
||||
:host([vintegrated]) input:focus {
|
||||
border: none;
|
||||
box-shadow: none;
|
||||
background: transparent;
|
||||
}
|
||||
:host([vintegrated]) .showPassword {
|
||||
display: none;
|
||||
}
|
||||
`,
|
||||
];
|
||||
|
||||
|
||||
Reference in New Issue
Block a user