@omegagrid/grid 0.10.2 → 0.10.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/commands/editingCommands.d.ts +4 -0
- package/dist/commands/editingCommands.d.ts.map +1 -0
- package/dist/commands/editingCommands.js +74 -0
- package/dist/commands/editingCommands.js.map +1 -0
- package/dist/commands/groupCommands.d.ts +8 -0
- package/dist/commands/groupCommands.d.ts.map +1 -0
- package/dist/commands/groupCommands.js +7 -0
- package/dist/commands/groupCommands.js.map +1 -0
- package/dist/commands/index.d.ts +4 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +9 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/navigationCommands.d.ts +5 -0
- package/dist/commands/navigationCommands.d.ts.map +1 -0
- package/dist/commands/navigationCommands.js +117 -0
- package/dist/commands/navigationCommands.js.map +1 -0
- package/dist/constants.d.ts +65 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +8 -0
- package/dist/constants.js.map +1 -0
- package/dist/editors/baseEditor.d.ts +31 -0
- package/dist/editors/baseEditor.d.ts.map +1 -0
- package/dist/editors/baseEditor.js +112 -0
- package/dist/editors/baseEditor.js.map +1 -0
- package/dist/editors/calendarEditor.d.ts +12 -0
- package/dist/editors/calendarEditor.d.ts.map +1 -0
- package/dist/editors/calendarEditor.js +74 -0
- package/dist/editors/calendarEditor.js.map +1 -0
- package/dist/editors/checkboxEditor.d.ts +9 -0
- package/dist/editors/checkboxEditor.d.ts.map +1 -0
- package/dist/editors/checkboxEditor.js +32 -0
- package/dist/editors/checkboxEditor.js.map +1 -0
- package/dist/editors/dateEditor.d.ts +8 -0
- package/dist/editors/dateEditor.d.ts.map +1 -0
- package/dist/editors/dateEditor.js +37 -0
- package/dist/editors/dateEditor.js.map +1 -0
- package/dist/editors/dropdownEditor.d.ts +26 -0
- package/dist/editors/dropdownEditor.d.ts.map +1 -0
- package/dist/editors/dropdownEditor.js +142 -0
- package/dist/editors/dropdownEditor.js.map +1 -0
- package/dist/editors/formulaEditor.d.ts +21 -0
- package/dist/editors/formulaEditor.d.ts.map +1 -0
- package/dist/editors/formulaEditor.js +109 -0
- package/dist/editors/formulaEditor.js.map +1 -0
- package/dist/editors/index.d.ts +8 -0
- package/dist/editors/index.d.ts.map +1 -0
- package/dist/editors/index.js +19 -0
- package/dist/editors/index.js.map +1 -0
- package/dist/editors/numberEditor.d.ts +9 -0
- package/dist/editors/numberEditor.d.ts.map +1 -0
- package/dist/editors/numberEditor.js +37 -0
- package/dist/editors/numberEditor.js.map +1 -0
- package/dist/editors/textEditor.d.ts +15 -0
- package/dist/editors/textEditor.d.ts.map +1 -0
- package/dist/editors/textEditor.js +74 -0
- package/dist/editors/textEditor.js.map +1 -0
- package/dist/filters/NumberFilter.d.ts +8 -0
- package/dist/filters/NumberFilter.d.ts.map +1 -0
- package/dist/filters/NumberFilter.js +13 -0
- package/dist/filters/NumberFilter.js.map +1 -0
- package/dist/filters/baseFilter.d.ts +20 -0
- package/dist/filters/baseFilter.d.ts.map +1 -0
- package/dist/filters/baseFilter.js +47 -0
- package/dist/filters/baseFilter.js.map +1 -0
- package/dist/filters/checkboxFilter.d.ts +12 -0
- package/dist/filters/checkboxFilter.d.ts.map +1 -0
- package/dist/filters/checkboxFilter.js +67 -0
- package/dist/filters/checkboxFilter.js.map +1 -0
- package/dist/filters/dropdownFilter.d.ts +17 -0
- package/dist/filters/dropdownFilter.d.ts.map +1 -0
- package/dist/filters/dropdownFilter.js +116 -0
- package/dist/filters/dropdownFilter.js.map +1 -0
- package/dist/filters/filterFactory.d.ts +4 -0
- package/dist/filters/filterFactory.d.ts.map +1 -0
- package/dist/filters/filterFactory.js +39 -0
- package/dist/filters/filterFactory.js.map +1 -0
- package/dist/filters/index.d.ts +5 -0
- package/dist/filters/index.d.ts.map +1 -0
- package/dist/filters/index.js +5 -0
- package/dist/filters/index.js.map +1 -0
- package/dist/filters/textFilter.d.ts +17 -0
- package/dist/filters/textFilter.d.ts.map +1 -0
- package/dist/filters/textFilter.js +89 -0
- package/dist/filters/textFilter.js.map +1 -0
- package/dist/gridAdapter.d.ts +30 -0
- package/dist/gridAdapter.d.ts.map +1 -0
- package/dist/gridAdapter.js +11 -0
- package/dist/gridAdapter.js.map +1 -0
- package/dist/i18n/en-us.d.ts +4 -0
- package/dist/i18n/en-us.d.ts.map +1 -0
- package/dist/i18n/en-us.js +5 -0
- package/dist/i18n/en-us.js.map +1 -0
- package/dist/i18n/index.d.ts +5 -0
- package/dist/i18n/index.d.ts.map +1 -0
- package/dist/i18n/index.js +8 -0
- package/dist/i18n/index.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/renderers/ActionRenderer.d.ts +3 -0
- package/dist/renderers/ActionRenderer.d.ts.map +1 -0
- package/dist/renderers/ActionRenderer.js +68 -0
- package/dist/renderers/ActionRenderer.js.map +1 -0
- package/dist/renderers/BaseRenderer.d.ts +6 -0
- package/dist/renderers/BaseRenderer.d.ts.map +1 -0
- package/dist/renderers/BaseRenderer.js +56 -0
- package/dist/renderers/BaseRenderer.js.map +1 -0
- package/dist/renderers/CheckboxRenderer.d.ts +4 -0
- package/dist/renderers/CheckboxRenderer.d.ts.map +1 -0
- package/dist/renderers/CheckboxRenderer.js +22 -0
- package/dist/renderers/CheckboxRenderer.js.map +1 -0
- package/dist/renderers/DateTimeRenderer.d.ts +4 -0
- package/dist/renderers/DateTimeRenderer.d.ts.map +1 -0
- package/dist/renderers/DateTimeRenderer.js +21 -0
- package/dist/renderers/DateTimeRenderer.js.map +1 -0
- package/dist/renderers/DropdownRenderer.d.ts +4 -0
- package/dist/renderers/DropdownRenderer.d.ts.map +1 -0
- package/dist/renderers/DropdownRenderer.js +18 -0
- package/dist/renderers/DropdownRenderer.js.map +1 -0
- package/dist/renderers/GeneralRenderer.d.ts +4 -0
- package/dist/renderers/GeneralRenderer.d.ts.map +1 -0
- package/dist/renderers/GeneralRenderer.js +12 -0
- package/dist/renderers/GeneralRenderer.js.map +1 -0
- package/dist/renderers/HtmlRenderer.d.ts +4 -0
- package/dist/renderers/HtmlRenderer.d.ts.map +1 -0
- package/dist/renderers/HtmlRenderer.js +6 -0
- package/dist/renderers/HtmlRenderer.js.map +1 -0
- package/dist/renderers/NumberRenderer.d.ts +4 -0
- package/dist/renderers/NumberRenderer.d.ts.map +1 -0
- package/dist/renderers/NumberRenderer.js +14 -0
- package/dist/renderers/NumberRenderer.js.map +1 -0
- package/dist/renderers/SparklineRenderer.d.ts +3 -0
- package/dist/renderers/SparklineRenderer.d.ts.map +1 -0
- package/dist/renderers/SparklineRenderer.js +8 -0
- package/dist/renderers/SparklineRenderer.js.map +1 -0
- package/dist/renderers/TextRenderer.d.ts +4 -0
- package/dist/renderers/TextRenderer.d.ts.map +1 -0
- package/dist/renderers/TextRenderer.js +38 -0
- package/dist/renderers/TextRenderer.js.map +1 -0
- package/dist/renderers/index.d.ts +12 -0
- package/dist/renderers/index.d.ts.map +1 -0
- package/dist/renderers/index.js +32 -0
- package/dist/renderers/index.js.map +1 -0
- package/dist/types.d.ts +10 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/ui/comment.d.ts +59 -0
- package/dist/ui/comment.d.ts.map +1 -0
- package/dist/ui/comment.js +284 -0
- package/dist/ui/comment.js.map +1 -0
- package/dist/ui/comment.style.d.ts +2 -0
- package/dist/ui/comment.style.d.ts.map +1 -0
- package/dist/ui/comment.style.js +108 -0
- package/dist/ui/comment.style.js.map +1 -0
- package/dist/ui/elementCache.d.ts +15 -0
- package/dist/ui/elementCache.d.ts.map +1 -0
- package/dist/ui/elementCache.js +57 -0
- package/dist/ui/elementCache.js.map +1 -0
- package/dist/ui/filterLabel.d.ts +10 -0
- package/dist/ui/filterLabel.d.ts.map +1 -0
- package/dist/ui/filterLabel.js +76 -0
- package/dist/ui/filterLabel.js.map +1 -0
- package/dist/ui/formulaInput.d.ts +56 -0
- package/dist/ui/formulaInput.d.ts.map +1 -0
- package/dist/ui/formulaInput.js +251 -0
- package/dist/ui/formulaInput.js.map +1 -0
- package/dist/ui/formulaInput.style.d.ts +2 -0
- package/dist/ui/formulaInput.style.d.ts.map +1 -0
- package/dist/ui/formulaInput.style.js +65 -0
- package/dist/ui/formulaInput.style.js.map +1 -0
- package/dist/ui/grid.d.ts +91 -0
- package/dist/ui/grid.d.ts.map +1 -0
- package/dist/ui/grid.editing.d.ts +61 -0
- package/dist/ui/grid.editing.d.ts.map +1 -0
- package/dist/ui/grid.editing.js +439 -0
- package/dist/ui/grid.editing.js.map +1 -0
- package/dist/ui/grid.events.d.ts +97 -0
- package/dist/ui/grid.events.d.ts.map +1 -0
- package/dist/ui/grid.events.js +581 -0
- package/dist/ui/grid.events.js.map +1 -0
- package/dist/ui/grid.filtering.d.ts +23 -0
- package/dist/ui/grid.filtering.d.ts.map +1 -0
- package/dist/ui/grid.filtering.js +68 -0
- package/dist/ui/grid.filtering.js.map +1 -0
- package/dist/ui/grid.js +297 -0
- package/dist/ui/grid.js.map +1 -0
- package/dist/ui/grid.menu.d.ts +43 -0
- package/dist/ui/grid.menu.d.ts.map +1 -0
- package/dist/ui/grid.menu.js +168 -0
- package/dist/ui/grid.menu.js.map +1 -0
- package/dist/ui/grid.objects.d.ts +24 -0
- package/dist/ui/grid.objects.d.ts.map +1 -0
- package/dist/ui/grid.objects.js +69 -0
- package/dist/ui/grid.objects.js.map +1 -0
- package/dist/ui/grid.rendering.d.ts +84 -0
- package/dist/ui/grid.rendering.d.ts.map +1 -0
- package/dist/ui/grid.rendering.js +471 -0
- package/dist/ui/grid.rendering.js.map +1 -0
- package/dist/ui/grid.selecting.d.ts +99 -0
- package/dist/ui/grid.selecting.d.ts.map +1 -0
- package/dist/ui/grid.selecting.js +319 -0
- package/dist/ui/grid.selecting.js.map +1 -0
- package/dist/ui/grid.sorting.d.ts +23 -0
- package/dist/ui/grid.sorting.d.ts.map +1 -0
- package/dist/ui/grid.sorting.js +47 -0
- package/dist/ui/grid.sorting.js.map +1 -0
- package/dist/ui/grid.style.d.ts +2 -0
- package/dist/ui/grid.style.d.ts.map +1 -0
- package/dist/ui/grid.style.js +39 -0
- package/dist/ui/grid.style.js.map +1 -0
- package/dist/ui/group.d.ts +71 -0
- package/dist/ui/group.d.ts.map +1 -0
- package/dist/ui/group.js +312 -0
- package/dist/ui/group.js.map +1 -0
- package/dist/ui/index.d.ts +19 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +19 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/objectHost.d.ts +30 -0
- package/dist/ui/objectHost.d.ts.map +1 -0
- package/dist/ui/objectHost.js +114 -0
- package/dist/ui/objectHost.js.map +1 -0
- package/dist/ui/objectHost.style.d.ts +2 -0
- package/dist/ui/objectHost.style.d.ts.map +1 -0
- package/dist/ui/objectHost.style.js +43 -0
- package/dist/ui/objectHost.style.js.map +1 -0
- package/dist/ui/selector.d.ts +97 -0
- package/dist/ui/selector.d.ts.map +1 -0
- package/dist/ui/selector.js +489 -0
- package/dist/ui/selector.js.map +1 -0
- package/dist/ui/selector.style.d.ts +2 -0
- package/dist/ui/selector.style.d.ts.map +1 -0
- package/dist/ui/selector.style.js +106 -0
- package/dist/ui/selector.style.js.map +1 -0
- package/dist/ui/sortingArrow.d.ts +8 -0
- package/dist/ui/sortingArrow.d.ts.map +1 -0
- package/dist/ui/sortingArrow.js +42 -0
- package/dist/ui/sortingArrow.js.map +1 -0
- package/dist/ui/sparkline.d.ts +14 -0
- package/dist/ui/sparkline.d.ts.map +1 -0
- package/dist/ui/sparkline.js +111 -0
- package/dist/ui/sparkline.js.map +1 -0
- package/dist/ui/table.d.ts +122 -0
- package/dist/ui/table.d.ts.map +1 -0
- package/dist/ui/table.js +1063 -0
- package/dist/ui/table.js.map +1 -0
- package/dist/ui/table.styles.d.ts +2 -0
- package/dist/ui/table.styles.d.ts.map +1 -0
- package/dist/ui/table.styles.js +249 -0
- package/dist/ui/table.styles.js.map +1 -0
- package/dist/ui/tooltip.d.ts +9 -0
- package/dist/ui/tooltip.d.ts.map +1 -0
- package/dist/ui/tooltip.js +32 -0
- package/dist/ui/tooltip.js.map +1 -0
- package/package.json +7 -7
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { CellModel } from "@omegagrid/grid-core";
|
|
2
|
+
import { BaseEditor } from "./baseEditor";
|
|
3
|
+
export declare class CheckboxEditor extends BaseEditor {
|
|
4
|
+
private value;
|
|
5
|
+
activate(cell: CellModel): void;
|
|
6
|
+
getValue(): boolean;
|
|
7
|
+
setValue(value: string): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=checkboxEditor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkboxEditor.d.ts","sourceRoot":"","sources":["../../src/editors/checkboxEditor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C,qBACa,cAAe,SAAQ,UAAU;IAE7C,OAAO,CAAC,KAAK,CAAS;IAEtB,QAAQ,CAAC,IAAI,EAAE,SAAS;IAOxB,QAAQ,IAAK,OAAO;IAIpB,QAAQ,CAAC,KAAK,EAAE,MAAM;CAKtB"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { BaseEditor } from "./baseEditor";
|
|
8
|
+
import { customElement } from 'lit/decorators.js';
|
|
9
|
+
let CheckboxEditor = class CheckboxEditor extends BaseEditor {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
this.value = false;
|
|
13
|
+
}
|
|
14
|
+
activate(cell) {
|
|
15
|
+
super.activate(cell);
|
|
16
|
+
this.value = !cell.value;
|
|
17
|
+
this.commit();
|
|
18
|
+
this.close();
|
|
19
|
+
}
|
|
20
|
+
getValue() {
|
|
21
|
+
return this.value;
|
|
22
|
+
}
|
|
23
|
+
setValue(value) {
|
|
24
|
+
value = value.toLowerCase();
|
|
25
|
+
this.value = ['0', 'false', 'no', 'n'].indexOf(value) > -1;
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
CheckboxEditor = __decorate([
|
|
29
|
+
customElement('og-grid-checkboxeditor')
|
|
30
|
+
], CheckboxEditor);
|
|
31
|
+
export { CheckboxEditor };
|
|
32
|
+
//# sourceMappingURL=checkboxEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkboxEditor.js","sourceRoot":"","sources":["../../src/editors/checkboxEditor.ts"],"names":[],"mappings":";;;;;;AACA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAG3C,IAAM,cAAc,GAApB,MAAM,cAAe,SAAQ,UAAU;IAAvC;;QAEE,UAAK,GAAG,KAAK,CAAC;IAkBvB,CAAC;IAhBA,QAAQ,CAAC,IAAe;QACvB,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC;QACzB,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,CAAC,KAAK,EAAE,CAAC;IACd,CAAC;IAED,QAAQ;QACP,OAAO,IAAI,CAAC,KAAK,CAAC;IACnB,CAAC;IAED,QAAQ,CAAC,KAAa;QACrB,KAAK,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;QAC5B,IAAI,CAAC,KAAK,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5D,CAAC;CAED,CAAA;AApBY,cAAc;IAD1B,aAAa,CAAC,wBAAwB,CAAC;GAC3B,cAAc,CAoB1B","sourcesContent":["import { CellModel } from \"@omegagrid/grid-core\";\nimport { BaseEditor } from \"./baseEditor\";\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('og-grid-checkboxeditor')\nexport class CheckboxEditor extends BaseEditor {\n\n\tprivate value = false;\n\n\tactivate(cell: CellModel) {\n\t\tsuper.activate(cell);\n\t\tthis.value = !cell.value;\n\t\tthis.commit();\n\t\tthis.close();\n\t}\n\n\tgetValue() : boolean {\n\t\treturn this.value;\n\t}\n\n\tsetValue(value: string) {\n\t\tvalue = value.toLowerCase();\n\t\tthis.value = ['0', 'false', 'no', 'n'].indexOf(value) > -1;\n\t}\n\n}"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { TextEditor } from "./textEditor";
|
|
2
|
+
import { CellModel } from "@omegagrid/grid-core";
|
|
3
|
+
export declare class DateEditor extends TextEditor {
|
|
4
|
+
setValue(value: number | string | Date): void;
|
|
5
|
+
getValue(): number;
|
|
6
|
+
activate(cell: CellModel): void;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=dateEditor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dateEditor.d.ts","sourceRoot":"","sources":["../../src/editors/dateEditor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAI1C,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEjD,qBACa,UAAW,SAAQ,UAAU;IAEzC,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAC,MAAM,GAAC,IAAI;IAalC,QAAQ,IAAK,MAAM;IAKnB,QAAQ,CAAC,IAAI,EAAE,SAAS;CAKxB"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { TextEditor } from "./textEditor";
|
|
8
|
+
import { customElement } from 'lit/decorators.js';
|
|
9
|
+
import { dates } from "@omegagrid/core";
|
|
10
|
+
import { getLocale } from "@omegagrid/localize";
|
|
11
|
+
let DateEditor = class DateEditor extends TextEditor {
|
|
12
|
+
setValue(value) {
|
|
13
|
+
if (value == null) {
|
|
14
|
+
this.input.value = '';
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
try {
|
|
18
|
+
this.input.value = dates.getDateFormatter(getLocale(), 'yyyy-MM-dd')(value);
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
this.input.value = value ?? '';
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
getValue() {
|
|
25
|
+
const date = dates.parse(this.input.value, getLocale());
|
|
26
|
+
return date ? dates.dateToSerialDate(date) : null;
|
|
27
|
+
}
|
|
28
|
+
activate(cell) {
|
|
29
|
+
super.activate(cell);
|
|
30
|
+
this.setValue(cell.value);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
DateEditor = __decorate([
|
|
34
|
+
customElement('og-grid-dateeditor')
|
|
35
|
+
], DateEditor);
|
|
36
|
+
export { DateEditor };
|
|
37
|
+
//# sourceMappingURL=dateEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dateEditor.js","sourceRoot":"","sources":["../../src/editors/dateEditor.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAIzC,IAAM,UAAU,GAAhB,MAAM,UAAW,SAAQ,UAAU;IAEzC,QAAQ,CAAC,KAAyB;QACjC,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;YACnB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;YACtB,OAAO;QACR,CAAC;QAED,IAAI,CAAC;YACJ,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAE,YAAY,CAAC,CAAC,KAAK,CAAC,CAAC;QAC7E,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAe,IAAI,EAAE,CAAC;QAC1C,CAAC;IACF,CAAC;IAED,QAAQ;QACP,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;QACxD,OAAO,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACnD,CAAC;IAED,QAAQ,CAAC,IAAe;QACjB,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAe,CAAC,CAAC;IACxC,CAAC;CAEJ,CAAA;AAzBY,UAAU;IADtB,aAAa,CAAC,oBAAoB,CAAC;GACvB,UAAU,CAyBtB","sourcesContent":["import { TextEditor } from \"./textEditor\";\nimport { customElement } from 'lit/decorators.js';\nimport { dates } from \"@omegagrid/core\";\nimport { getLocale } from \"@omegagrid/localize\";\nimport { CellModel } from \"@omegagrid/grid-core\";\n\n@customElement('og-grid-dateeditor')\nexport class DateEditor extends TextEditor {\n\n\tsetValue(value: number|string|Date) {\n\t\tif (value == null) {\n\t\t\tthis.input.value = '';\n\t\t\treturn;\n\t\t}\n\n\t\ttry {\n\t\t\tthis.input.value = dates.getDateFormatter(getLocale(), 'yyyy-MM-dd')(value);\n\t\t} catch (error) {\n\t\t\tthis.input.value = value as string ?? '';\t\t\n\t\t}\n\t}\n\n\tgetValue() : number {\n\t\tconst date = dates.parse(this.input.value, getLocale());\n\t\treturn date ? dates.dateToSerialDate(date) : null;\n\t}\n\n\tactivate(cell: CellModel) {\n super.activate(cell);\n this.setValue(cell.value as number);\n }\n\n}"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { BaseEditor } from "./baseEditor";
|
|
2
|
+
import { CellModel } from "@omegagrid/grid-core";
|
|
3
|
+
import { SerializedValue, TreeDropdown, TreeEvent } from '@omegagrid/tree';
|
|
4
|
+
type DropdownValue = null | string | (string | number | SerializedValue)[];
|
|
5
|
+
export declare class DropdownEditor extends BaseEditor {
|
|
6
|
+
static styles: import("lit").CSSResult[];
|
|
7
|
+
dropdown: TreeDropdown;
|
|
8
|
+
private currentValue;
|
|
9
|
+
private currentDisplayValue;
|
|
10
|
+
private searchCommitted;
|
|
11
|
+
private searchUsed;
|
|
12
|
+
constructor();
|
|
13
|
+
/** Use value in dropdown search field as cell value if allowInvalid is true */
|
|
14
|
+
commitSearchValue(): void;
|
|
15
|
+
init(): void;
|
|
16
|
+
activate(cell: CellModel): Promise<void>;
|
|
17
|
+
getValue(): DropdownValue;
|
|
18
|
+
getDisplayValue(): string;
|
|
19
|
+
setValue(value: DropdownValue): void;
|
|
20
|
+
_onChange: (_e: TreeEvent) => void;
|
|
21
|
+
_onBlur: () => void;
|
|
22
|
+
render: () => import("lit-html").TemplateResult<1>;
|
|
23
|
+
close(): void;
|
|
24
|
+
}
|
|
25
|
+
export {};
|
|
26
|
+
//# sourceMappingURL=dropdownEditor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdownEditor.d.ts","sourceRoot":"","sources":["../../src/editors/dropdownEditor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEjD,OAAO,EAAyC,eAAe,EAAe,YAAY,EAAE,SAAS,EAAc,MAAM,iBAAiB,CAAC;AAE3I,KAAK,aAAa,GAAG,IAAI,GAAC,MAAM,GAAC,CAAC,MAAM,GAAC,MAAM,GAAC,eAAe,CAAC,EAAE,CAAC;AAEnE,qBACa,cAAe,SAAQ,UAAU;IAE7C,MAAM,CAAC,MAAM,4BAKV;IAGH,QAAQ,EAAE,YAAY,CAAC;IAEvB,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,mBAAmB,CAAS;IACpC,OAAO,CAAC,eAAe,CAAS;IAChC,OAAO,CAAC,UAAU,CAAS;;IAM3B,+EAA+E;IAC/E,iBAAiB;IAcjB,IAAI;IASE,QAAQ,CAAC,IAAI,EAAE,SAAS;IAyB9B,QAAQ;IAIR,eAAe;IAIf,QAAQ,CAAC,KAAK,EAAE,aAAa;IAoB7B,SAAS,GAAI,IAAI,SAAS,UAoBzB;IAED,OAAO,aAAkC;IAEzC,MAAM,6CAUJ;IAEF,KAAK;CAML"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { customElement, query } from 'lit/decorators.js';
|
|
8
|
+
import { BaseEditor } from "./baseEditor";
|
|
9
|
+
import { html, css } from 'lit';
|
|
10
|
+
import { normalizeSerializedValues, SelectMode } from '@omegagrid/tree';
|
|
11
|
+
let DropdownEditor = class DropdownEditor extends BaseEditor {
|
|
12
|
+
constructor() {
|
|
13
|
+
super();
|
|
14
|
+
this.searchCommitted = false;
|
|
15
|
+
this.searchUsed = false;
|
|
16
|
+
this._onChange = (_e) => {
|
|
17
|
+
if (this.activeCellModel.type == 's') {
|
|
18
|
+
this.currentValue = null;
|
|
19
|
+
this.currentDisplayValue = null;
|
|
20
|
+
for (const [key, node] of this.dropdown.selectedItems) {
|
|
21
|
+
this.currentValue = key;
|
|
22
|
+
this.currentDisplayValue = node.value;
|
|
23
|
+
break;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.currentValue = this.dropdown.selection.serialize();
|
|
28
|
+
this.currentDisplayValue = this.dropdown.getSelectionText();
|
|
29
|
+
}
|
|
30
|
+
this.commit();
|
|
31
|
+
if (this.activeCellModel.type == 's') {
|
|
32
|
+
this.dropdown.close();
|
|
33
|
+
this.close();
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
this._onBlur = () => this.commitSearchValue();
|
|
37
|
+
this.render = () => html `
|
|
38
|
+
<og-tree-dropdown
|
|
39
|
+
cross
|
|
40
|
+
buttonInput
|
|
41
|
+
dynamicWidth
|
|
42
|
+
alignment="left"
|
|
43
|
+
@change="${this._onChange}"
|
|
44
|
+
@tree.filter="${() => this.searchUsed = true}"
|
|
45
|
+
@blur="${this._onBlur}">
|
|
46
|
+
</og-tree-dropdown>
|
|
47
|
+
`;
|
|
48
|
+
}
|
|
49
|
+
/** Use value in dropdown search field as cell value if allowInvalid is true */
|
|
50
|
+
commitSearchValue() {
|
|
51
|
+
if (this.searchCommitted)
|
|
52
|
+
return;
|
|
53
|
+
if (!this.searchUsed)
|
|
54
|
+
return;
|
|
55
|
+
if (this.dropdown?.searchTerm == null)
|
|
56
|
+
return;
|
|
57
|
+
// if (!this.dropdown?.selection.count) return;
|
|
58
|
+
if (!this.activeCellModel?.validation?.allowInvalid)
|
|
59
|
+
return;
|
|
60
|
+
this.currentValue = this.dropdown.searchTerm;
|
|
61
|
+
this.currentDisplayValue = this.currentValue;
|
|
62
|
+
this.activeCellModel.displayValue = this.currentDisplayValue;
|
|
63
|
+
this.commit();
|
|
64
|
+
this.searchCommitted = true;
|
|
65
|
+
}
|
|
66
|
+
init() {
|
|
67
|
+
this.addEventListener('keydown', (e) => {
|
|
68
|
+
// handle (invalid) value in search field
|
|
69
|
+
if (e.key == 'Enter')
|
|
70
|
+
this.commitSearchValue();
|
|
71
|
+
});
|
|
72
|
+
super.init();
|
|
73
|
+
}
|
|
74
|
+
async activate(cell) {
|
|
75
|
+
super.activate(cell);
|
|
76
|
+
this.currentValue = null;
|
|
77
|
+
this.searchCommitted = false;
|
|
78
|
+
this.searchUsed = false;
|
|
79
|
+
await this.dropdown.updateComplete;
|
|
80
|
+
this.dropdown.updateOptions({ selectMode: cell.type == 's' ? SelectMode.Single : SelectMode.Multiple });
|
|
81
|
+
if (cell.editorContent) {
|
|
82
|
+
let sourceData = cell.editorContent;
|
|
83
|
+
if (!sourceData || sourceData.length == 0) {
|
|
84
|
+
sourceData = cell.hasValue ? [{ k: cell.value, v: cell.value }] : [];
|
|
85
|
+
}
|
|
86
|
+
this.dropdown.value = null;
|
|
87
|
+
this.dropdown.adapter = null;
|
|
88
|
+
this.dropdown.setSourceData(sourceData);
|
|
89
|
+
}
|
|
90
|
+
else if (cell.adapter) {
|
|
91
|
+
this.dropdown.adapter = cell.adapter;
|
|
92
|
+
}
|
|
93
|
+
await this.dropdown.open();
|
|
94
|
+
this.setValue(this.currentValue ?? cell.value);
|
|
95
|
+
}
|
|
96
|
+
getValue() {
|
|
97
|
+
return this.currentValue;
|
|
98
|
+
}
|
|
99
|
+
getDisplayValue() {
|
|
100
|
+
return this.currentDisplayValue;
|
|
101
|
+
}
|
|
102
|
+
setValue(value) {
|
|
103
|
+
this.currentValue = value;
|
|
104
|
+
if (value == null) {
|
|
105
|
+
this.dropdown.value = null;
|
|
106
|
+
}
|
|
107
|
+
else if (this.activeCellModel.type == 's') {
|
|
108
|
+
this.dropdown.value = this.activeCellModel.value == value && this.activeCellModel.displayValue != null
|
|
109
|
+
// pass display value if cell value and current value match
|
|
110
|
+
? [[value, null, null, { value: this.activeCellModel.displayValue }]]
|
|
111
|
+
: [[value]];
|
|
112
|
+
}
|
|
113
|
+
else if (Array.isArray(value)) {
|
|
114
|
+
this.dropdown.value = normalizeSerializedValues(value);
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
this.dropdown.value = null;
|
|
118
|
+
}
|
|
119
|
+
// initialValue is set when editor is open by direct typing or pasting
|
|
120
|
+
if (this.initialValue != null)
|
|
121
|
+
this.dropdown.filter(value.toString());
|
|
122
|
+
}
|
|
123
|
+
close() {
|
|
124
|
+
this.currentValue = null;
|
|
125
|
+
super.close();
|
|
126
|
+
this.dropdown.close();
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
DropdownEditor.styles = [BaseEditor.baseStyles, css `
|
|
130
|
+
og-tree-dropdown {
|
|
131
|
+
width: 100%;
|
|
132
|
+
height: 100%;
|
|
133
|
+
}
|
|
134
|
+
`];
|
|
135
|
+
__decorate([
|
|
136
|
+
query('og-tree-dropdown')
|
|
137
|
+
], DropdownEditor.prototype, "dropdown", void 0);
|
|
138
|
+
DropdownEditor = __decorate([
|
|
139
|
+
customElement('og-grid-dropdowneditor')
|
|
140
|
+
], DropdownEditor);
|
|
141
|
+
export { DropdownEditor };
|
|
142
|
+
//# sourceMappingURL=dropdownEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdownEditor.js","sourceRoot":"","sources":["../../src/editors/dropdownEditor.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,yBAAyB,EAAE,UAAU,EAAqE,MAAM,iBAAiB,CAAC;AAKpI,IAAM,cAAc,GAApB,MAAM,cAAe,SAAQ,UAAU;IAiB7C;QACC,KAAK,EAAE,CAAC;QAJD,oBAAe,GAAG,KAAK,CAAC;QACxB,eAAU,GAAG,KAAK,CAAC;QAmF3B,cAAS,GAAG,CAAC,EAAa,EAAE,EAAE;YAC7B,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,IAAI,GAAG,EAAE,CAAC;gBACtC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;gBACzB,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;gBAChC,KAAK,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;oBACvD,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;oBACxB,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC;oBACtC,MAAM;gBACP,CAAC;YACF,CAAC;iBAAM,CAAC;gBACP,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,EAAE,CAAC;gBACxD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,CAAC;YAC7D,CAAC;YAED,IAAI,CAAC,MAAM,EAAE,CAAC;YAEd,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,IAAI,GAAG,EAAE,CAAC;gBACtC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;gBACtB,IAAI,CAAC,KAAK,EAAE,CAAC;YACd,CAAC;QACF,CAAC,CAAA;QAED,YAAO,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzC,WAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAA;;;;;;cAMN,IAAI,CAAC,SAAS;mBACT,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI;YACnC,IAAI,CAAC,OAAO;;EAEtB,CAAC;IAjHF,CAAC;IAED,+EAA+E;IAC/E,iBAAiB;QAChB,IAAI,IAAI,CAAC,eAAe;YAAE,OAAO;QACjC,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO;QAC7B,IAAI,IAAI,CAAC,QAAQ,EAAE,UAAU,IAAI,IAAI;YAAE,OAAO;QAC9C,+CAA+C;QAC/C,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,UAAU,EAAE,YAAY;YAAE,OAAO;QAE5D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;QAC7C,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,YAAY,CAAC;QAC7C,IAAI,CAAC,eAAe,CAAC,YAAY,GAAG,IAAI,CAAC,mBAAmB,CAAC;QAC7D,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC7B,CAAC;IAED,IAAI;QACH,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAgB,EAAE,EAAE;YACrD,yCAAyC;YACzC,IAAI,CAAC,CAAC,GAAG,IAAI,OAAO;gBAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAChD,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,IAAe;QAC7B,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAExB,MAAM,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAC,UAAU,EAAE,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,EAAC,CAAC,CAAC;QAEtG,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACxB,IAAI,UAAU,GAAG,IAAI,CAAC,aAA2B,CAAC;YAClD,IAAI,CAAC,UAAU,IAAI,UAAU,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gBAC3C,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAC,CAAC,EAAE,IAAI,CAAC,KAAe,EAAE,CAAC,EAAE,IAAI,CAAC,KAAe,EAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACxF,CAAC;YACD,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QACzC,CAAC;aAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACzB,IAAI,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,OAAsB,CAAC;QACrD,CAAC;QAED,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,KAAsB,CAAC,CAAC;IACjE,CAAC;IAED,QAAQ;QACP,OAAO,IAAI,CAAC,YAAY,CAAC;IAC1B,CAAC;IAED,eAAe;QACd,OAAO,IAAI,CAAC,mBAAmB,CAAC;IACjC,CAAC;IAED,QAAQ,CAAC,KAAoB;QAC5B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAE1B,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC;QAC5B,CAAC;aAAM,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,IAAI,GAAG,EAAE,CAAC;YAC7C,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,eAAe,CAAC,YAAY,IAAI,IAAI;gBACrG,2DAA2D;gBAC3D,CAAC,CAAC,CAAC,CAAC,KAAe,EAAE,IAAI,EAAE,IAAI,EAAE,EAAC,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY,EAAC,CAAC,CAAC;gBAC7E,CAAC,CAAC,CAAC,CAAC,KAAe,CAAC,CAAC,CAAC;QACxB,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,yBAAyB,CAAC,KAA0C,CAAC,CAAC;QAC7F,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC;QAC5B,CAAC;QAED,sEAAsE;QACtE,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI;YAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;IACvE,CAAC;IAsCD,KAAK;QACJ,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,KAAK,CAAC,KAAK,EAAE,CAAC;QACd,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;;AAxIM,qBAAM,GAAG,CAAC,UAAU,CAAC,UAAU,EAAE,GAAG,CAAA;;;;;EAK1C,CAAC,AALW,CAKV;AAGH;IADC,KAAK,CAAC,kBAAkB,CAAC;gDACH;AAVX,cAAc;IAD1B,aAAa,CAAC,wBAAwB,CAAC;GAC3B,cAAc,CA4I1B","sourcesContent":["import { customElement, query } from 'lit/decorators.js';\nimport { BaseEditor } from \"./baseEditor\";\nimport { CellModel } from \"@omegagrid/grid-core\";\nimport { html, css } from 'lit';\nimport { normalizeSerializedValues, SelectMode, SerializedValue, TreeAdapter, TreeDropdown, TreeEvent, TreeSource } from '@omegagrid/tree';\n\ntype DropdownValue = null|string|(string|number|SerializedValue)[];\n\n@customElement('og-grid-dropdowneditor')\nexport class DropdownEditor extends BaseEditor {\n\n\tstatic styles = [BaseEditor.baseStyles, css`\n\t\tog-tree-dropdown {\n\t\t\twidth: 100%;\n\t\t\theight: 100%;\n\t\t}\n\t`];\n\n\t@query('og-tree-dropdown')\n\tdropdown: TreeDropdown;\n\n\tprivate currentValue: DropdownValue;\n\tprivate currentDisplayValue: string;\n\tprivate searchCommitted = false;\n\tprivate searchUsed = false;\n\n\tconstructor() {\n\t\tsuper();\n\t}\n\n\t/** Use value in dropdown search field as cell value if allowInvalid is true */\n\tcommitSearchValue() {\n\t\tif (this.searchCommitted) return;\n\t\tif (!this.searchUsed) return;\n\t\tif (this.dropdown?.searchTerm == null) return;\n\t\t// if (!this.dropdown?.selection.count) return;\n\t\tif (!this.activeCellModel?.validation?.allowInvalid) return;\n\n\t\tthis.currentValue = this.dropdown.searchTerm;\n\t\tthis.currentDisplayValue = this.currentValue;\n\t\tthis.activeCellModel.displayValue = this.currentDisplayValue;\n\t\tthis.commit();\n\t\tthis.searchCommitted = true;\n\t}\n\n\tinit() {\n\t\tthis.addEventListener('keydown', (e: KeyboardEvent) => {\n\t\t\t// handle (invalid) value in search field\n\t\t\tif (e.key == 'Enter') this.commitSearchValue();\n\t\t});\n\n\t\tsuper.init();\n\t}\n\n\tasync activate(cell: CellModel) {\n\t\tsuper.activate(cell);\n\t\tthis.currentValue = null;\n\t\tthis.searchCommitted = false;\n\t\tthis.searchUsed = false;\n\t\t\n\t\tawait this.dropdown.updateComplete;\n\t\tthis.dropdown.updateOptions({selectMode: cell.type == 's' ? SelectMode.Single : SelectMode.Multiple});\n\t\t\n\t\tif (cell.editorContent) {\n\t\t\tlet sourceData = cell.editorContent as TreeSource;\n\t\t\tif (!sourceData || sourceData.length == 0) {\n\t\t\t\tsourceData = cell.hasValue ? [{k: cell.value as string, v: cell.value as string}] : [];\n\t\t\t}\n\t\t\tthis.dropdown.value = null;\n\t\t\tthis.dropdown.adapter = null;\n\t\t\tthis.dropdown.setSourceData(sourceData);\n\t\t} else if (cell.adapter) {\n\t\t\tthis.dropdown.adapter = cell.adapter as TreeAdapter;\n\t\t}\n\n\t\tawait this.dropdown.open();\n\t\tthis.setValue(this.currentValue ?? cell.value as DropdownValue);\n\t}\n\n\tgetValue() {\n\t\treturn this.currentValue;\n\t}\n\n\tgetDisplayValue() {\n\t\treturn this.currentDisplayValue;\n\t}\n\n\tsetValue(value: DropdownValue) {\n\t\tthis.currentValue = value;\n\n\t\tif (value == null) {\n\t\t\tthis.dropdown.value = null;\n\t\t} else if (this.activeCellModel.type == 's') {\n\t\t\tthis.dropdown.value = this.activeCellModel.value == value && this.activeCellModel.displayValue != null\n\t\t\t\t// pass display value if cell value and current value match\n\t\t\t\t? [[value as string, null, null, {value: this.activeCellModel.displayValue}]]\n\t\t\t\t: [[value as string]];\n\t\t} else if (Array.isArray(value)) {\n\t\t\tthis.dropdown.value = normalizeSerializedValues(value as (string|number|SerializedValue)[]);\n\t\t} else {\n\t\t\tthis.dropdown.value = null;\n\t\t}\n\n\t\t// initialValue is set when editor is open by direct typing or pasting\n\t\tif (this.initialValue != null) this.dropdown.filter(value.toString());\n\t}\n\n\t_onChange = (_e: TreeEvent) => {\n\t\tif (this.activeCellModel.type == 's') {\n\t\t\tthis.currentValue = null;\n\t\t\tthis.currentDisplayValue = null;\n\t\t\tfor (const [key, node] of this.dropdown.selectedItems) {\n\t\t\t\tthis.currentValue = key;\n\t\t\t\tthis.currentDisplayValue = node.value;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t} else {\n\t\t\tthis.currentValue = this.dropdown.selection.serialize();\n\t\t\tthis.currentDisplayValue = this.dropdown.getSelectionText();\n\t\t}\n\n\t\tthis.commit();\n\n\t\tif (this.activeCellModel.type == 's') {\n\t\t\tthis.dropdown.close();\n\t\t\tthis.close();\n\t\t}\n\t}\n\n\t_onBlur = () => this.commitSearchValue();\n\n\trender = () => html`\n\t\t<og-tree-dropdown \n\t\t\tcross\n\t\t\tbuttonInput\n\t\t\tdynamicWidth\n\t\t\talignment=\"left\"\n\t\t\t@change=\"${this._onChange}\"\n\t\t\t@tree.filter=\"${() => this.searchUsed = true}\"\n\t\t\t@blur=\"${this._onBlur}\">\n\t\t</og-tree-dropdown>\n\t`;\n\t\n\tclose() {\n\t\tthis.currentValue = null;\n\t\tsuper.close();\n\t\tthis.dropdown.close();\n\t}\n\n}"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { CellModel } from "@omegagrid/grid-core";
|
|
2
|
+
import { BaseEditor } from "./baseEditor";
|
|
3
|
+
import { FormulaInput, FormulaInputEvent, GridEvent, SelectorEvent } from "../ui";
|
|
4
|
+
export declare class FormulaEditor extends BaseEditor {
|
|
5
|
+
static styles: import("lit").CSSResult[];
|
|
6
|
+
input: FormulaInput;
|
|
7
|
+
commit(): void;
|
|
8
|
+
close(): void;
|
|
9
|
+
_onGridSelectorUpdate: (e: SelectorEvent) => void;
|
|
10
|
+
_onGridSelect: (e: GridEvent) => void;
|
|
11
|
+
activate(cell: CellModel): void;
|
|
12
|
+
deactivate(): void;
|
|
13
|
+
getValue(): string;
|
|
14
|
+
setValue(value: string): void;
|
|
15
|
+
_onPreview: (e: FormulaInputEvent) => void;
|
|
16
|
+
_onInputCommit: () => void;
|
|
17
|
+
_onInputDiscard: () => void;
|
|
18
|
+
focus(): void;
|
|
19
|
+
render: () => import("lit-html").TemplateResult<1>;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=formulaEditor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formulaEditor.d.ts","sourceRoot":"","sources":["../../src/editors/formulaEditor.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAGlF,qBACa,aAAc,SAAQ,UAAU;IAE5C,MAAM,CAAC,MAAM,4BASV;IAGH,KAAK,EAAE,YAAY,CAAC;IAEpB,MAAM;IASN,KAAK;IAML,qBAAqB,GAAI,GAAG,aAAa,UAKxC;IAED,aAAa,GAAI,GAAG,SAAS,UAK5B;IAED,QAAQ,CAAC,IAAI,EAAE,SAAS;IAWxB,UAAU;IASV,QAAQ;IAIR,QAAQ,CAAC,KAAK,EAAE,MAAM;IAKtB,UAAU,GAAI,GAAG,iBAAiB,UAGjC;IAED,cAAc,aAEb;IAED,eAAe,aAEd;IAED,KAAK;IAIL,MAAM,6CAMJ;CAEF"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { customElement, query } from 'lit/decorators.js';
|
|
8
|
+
import { css, html, unsafeCSS } from "lit";
|
|
9
|
+
import { BaseEditor } from "./baseEditor";
|
|
10
|
+
import constants from "../constants";
|
|
11
|
+
import { dom } from '@omegagrid/core';
|
|
12
|
+
let FormulaEditor = class FormulaEditor extends BaseEditor {
|
|
13
|
+
constructor() {
|
|
14
|
+
super(...arguments);
|
|
15
|
+
this._onGridSelectorUpdate = (e) => {
|
|
16
|
+
if (e.selector?.index == null)
|
|
17
|
+
return;
|
|
18
|
+
const range = e.selector.selection.clone();
|
|
19
|
+
if (e.selector.grid != this.grid)
|
|
20
|
+
range.sheet = e.selector.grid.model.name;
|
|
21
|
+
this.input.setRange(range, e.selector.index);
|
|
22
|
+
};
|
|
23
|
+
this._onGridSelect = (e) => {
|
|
24
|
+
if (!this.grid.editing.isFormulaMode)
|
|
25
|
+
return;
|
|
26
|
+
const range = e.selection.range.clone();
|
|
27
|
+
if (e.grid != this.grid)
|
|
28
|
+
range.sheet = e.grid.model.name;
|
|
29
|
+
this.input.setRange(range);
|
|
30
|
+
};
|
|
31
|
+
this._onPreview = (e) => {
|
|
32
|
+
this.grid.selecting.removeFormulaHighlight();
|
|
33
|
+
if (e.formula)
|
|
34
|
+
this.grid.selecting.highlightFormula(e.formula);
|
|
35
|
+
};
|
|
36
|
+
this._onInputCommit = () => {
|
|
37
|
+
this.commit();
|
|
38
|
+
};
|
|
39
|
+
this._onInputDiscard = () => {
|
|
40
|
+
this.close();
|
|
41
|
+
};
|
|
42
|
+
this.render = () => html `
|
|
43
|
+
<og-grid-formula
|
|
44
|
+
@formula.preview="${this._onPreview}"
|
|
45
|
+
@formula.commit="${this._onInputCommit}"
|
|
46
|
+
@formula.discard="${this._onInputDiscard}">
|
|
47
|
+
</og-grid-formula>
|
|
48
|
+
`;
|
|
49
|
+
}
|
|
50
|
+
commit() {
|
|
51
|
+
if (this._open && !this.cancel && this.activeCellModel) {
|
|
52
|
+
this.grid.editing.updateCells([this.activeCellModel], [this.getValue()], true);
|
|
53
|
+
this.grid.rendering.updateCells([this.activeCellModel], true);
|
|
54
|
+
}
|
|
55
|
+
this.cancel = false;
|
|
56
|
+
this.close();
|
|
57
|
+
}
|
|
58
|
+
close() {
|
|
59
|
+
this.grid.selecting.removeFormulaHighlight();
|
|
60
|
+
this.grid.selecting.updateFormulaSelector();
|
|
61
|
+
super.close();
|
|
62
|
+
}
|
|
63
|
+
activate(cell) {
|
|
64
|
+
this.grid.editing.startFormulaMode();
|
|
65
|
+
super.activate(cell);
|
|
66
|
+
this.input.tokenizer = cell.model.calculations.tokenizer;
|
|
67
|
+
this.setValue(cell.hasOwnFormula ? cell.formula : '');
|
|
68
|
+
const eventTarget = this.grid.group ? this.grid.group : this.grid;
|
|
69
|
+
eventTarget.addEventListener('grid.selector.resize', this._onGridSelectorUpdate);
|
|
70
|
+
eventTarget.addEventListener('grid.selector.move', this._onGridSelectorUpdate);
|
|
71
|
+
eventTarget.addEventListener('grid.select', this._onGridSelect);
|
|
72
|
+
}
|
|
73
|
+
deactivate() {
|
|
74
|
+
const eventTarget = this.grid.group ? this.grid.group : this.grid;
|
|
75
|
+
eventTarget.removeEventListener('grid.selector.resize', this._onGridSelectorUpdate);
|
|
76
|
+
eventTarget.removeEventListener('grid.selector.move', this._onGridSelectorUpdate);
|
|
77
|
+
eventTarget.removeEventListener('grid.select', this._onGridSelect);
|
|
78
|
+
this.grid.editing.endFormulaMode();
|
|
79
|
+
super.deactivate();
|
|
80
|
+
}
|
|
81
|
+
getValue() {
|
|
82
|
+
return this.input.value;
|
|
83
|
+
}
|
|
84
|
+
setValue(value) {
|
|
85
|
+
dom.setSize(this.input, { w: this.clientWidth });
|
|
86
|
+
this.input.activate((value || '=').charAt(0) != '=' ? ('=' + value) : value);
|
|
87
|
+
}
|
|
88
|
+
focus() {
|
|
89
|
+
this.input.focus();
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
FormulaEditor.styles = [BaseEditor.baseStyles, css `
|
|
93
|
+
og-grid-formula {
|
|
94
|
+
display: block;
|
|
95
|
+
border: 1px solid var(--og-accent-color, ${unsafeCSS(constants.DEFAULT_ACCENT_COLOR)});
|
|
96
|
+
background: var(--og-cell-background);
|
|
97
|
+
width: 100%;
|
|
98
|
+
height: 100%;
|
|
99
|
+
padding: 0;
|
|
100
|
+
}
|
|
101
|
+
`];
|
|
102
|
+
__decorate([
|
|
103
|
+
query('og-grid-formula')
|
|
104
|
+
], FormulaEditor.prototype, "input", void 0);
|
|
105
|
+
FormulaEditor = __decorate([
|
|
106
|
+
customElement('og-grid-formulaeditor')
|
|
107
|
+
], FormulaEditor);
|
|
108
|
+
export { FormulaEditor };
|
|
109
|
+
//# sourceMappingURL=formulaEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formulaEditor.js","sourceRoot":"","sources":["../../src/editors/formulaEditor.ts"],"names":[],"mappings":"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","sourcesContent":["import { customElement, query } from 'lit/decorators.js';\nimport { css, html, unsafeCSS } from \"lit\";\nimport { CellModel } from \"@omegagrid/grid-core\";\nimport { BaseEditor } from \"./baseEditor\";\nimport constants from \"../constants\";\nimport { FormulaInput, FormulaInputEvent, GridEvent, SelectorEvent } from \"../ui\";\nimport { dom } from '@omegagrid/core';\n\n@customElement('og-grid-formulaeditor')\nexport class FormulaEditor extends BaseEditor {\n\n\tstatic styles = [BaseEditor.baseStyles, css`\n\t\tog-grid-formula {\n\t\t\tdisplay: block;\n\t\t\tborder: 1px solid var(--og-accent-color, ${unsafeCSS(constants.DEFAULT_ACCENT_COLOR)});\n\t\t\tbackground: var(--og-cell-background);\n\t\t\twidth: 100%;\n\t\t\theight: 100%;\n\t\t\tpadding: 0;\n\t\t}\n\t`];\n\n\t@query('og-grid-formula')\n\tinput: FormulaInput;\n\n\tcommit() {\n\t\tif (this._open && !this.cancel && this.activeCellModel) {\n\t\t\tthis.grid.editing.updateCells([this.activeCellModel], [this.getValue()], true);\n\t\t\tthis.grid.rendering.updateCells([this.activeCellModel], true);\n\t\t}\n\t\tthis.cancel = false;\n\t\tthis.close();\n\t}\n\n\tclose() {\n\t\tthis.grid.selecting.removeFormulaHighlight();\n\t\tthis.grid.selecting.updateFormulaSelector();\n\t\tsuper.close();\n\t}\n\n\t_onGridSelectorUpdate = (e: SelectorEvent) => {\n\t\tif (e.selector?.index == null) return;\n\t\tconst range = e.selector.selection.clone();\n\t\tif (e.selector.grid != this.grid) range.sheet = e.selector.grid.model.name;\n\t\tthis.input.setRange(range, e.selector.index);\n\t}\n\n\t_onGridSelect = (e: GridEvent) => {\n\t\tif (!this.grid.editing.isFormulaMode) return;\n\t\tconst range = e.selection.range.clone();\n\t\tif (e.grid != this.grid) range.sheet = e.grid.model.name;\n\t\tthis.input.setRange(range);\n\t}\n\n\tactivate(cell: CellModel) {\n\t\tthis.grid.editing.startFormulaMode();\n\t\tsuper.activate(cell);\n\t\tthis.input.tokenizer = cell.model.calculations.tokenizer;\n\t\tthis.setValue(cell.hasOwnFormula ? cell.formula : '');\n\t\tconst eventTarget = this.grid.group ? this.grid.group : this.grid;\n\t\teventTarget.addEventListener('grid.selector.resize', this._onGridSelectorUpdate);\n\t\teventTarget.addEventListener('grid.selector.move', this._onGridSelectorUpdate);\n\t\teventTarget.addEventListener('grid.select', this._onGridSelect);\n\t}\n\n\tdeactivate() {\n\t\tconst eventTarget = this.grid.group ? this.grid.group : this.grid;\n\t\teventTarget.removeEventListener('grid.selector.resize', this._onGridSelectorUpdate);\n\t\teventTarget.removeEventListener('grid.selector.move', this._onGridSelectorUpdate);\n\t\teventTarget.removeEventListener('grid.select', this._onGridSelect);\n\t\tthis.grid.editing.endFormulaMode();\n\t\tsuper.deactivate();\n\t}\n\n\tgetValue() {\n\t\treturn this.input.value;\n\t}\n\n\tsetValue(value: string) {\n\t\tdom.setSize(this.input, {w: this.clientWidth});\n\t\tthis.input.activate((value || '=').charAt(0) != '=' ? ('=' + value) : value);\n\t}\n\n\t_onPreview = (e: FormulaInputEvent) => {\n\t\tthis.grid.selecting.removeFormulaHighlight();\n\t\tif (e.formula) this.grid.selecting.highlightFormula(e.formula);\n\t}\n\n\t_onInputCommit = () => {\n\t\tthis.commit();\n\t}\n\n\t_onInputDiscard = () => {\n\t\tthis.close();\n\t}\n\n\tfocus() {\n\t\tthis.input.focus();\n\t}\n\n\trender = () => html`\n\t\t<og-grid-formula\n\t\t\t@formula.preview=\"${this._onPreview}\"\n\t\t\t@formula.commit=\"${this._onInputCommit}\"\n\t\t\t@formula.discard=\"${this._onInputDiscard}\">\n\t\t</og-grid-formula>\n\t`;\n\n}"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { BaseEditor } from "./baseEditor";
|
|
2
|
+
import { CellType, EditingOptions } from "@omegagrid/grid-core";
|
|
3
|
+
export * from "./formulaEditor";
|
|
4
|
+
export type EditorFactory = {
|
|
5
|
+
createComponent: (options?: EditingOptions) => BaseEditor;
|
|
6
|
+
};
|
|
7
|
+
export declare function getEditorFactory(type: CellType): EditorFactory;
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/editors/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAO1C,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEhE,cAAc,iBAAiB,CAAC;AAEhC,MAAM,MAAM,aAAa,GAAG;IAC3B,eAAe,EAAE,CAAC,OAAO,CAAC,EAAE,cAAc,KAAK,UAAU,CAAA;CACzD,CAAC;AAWF,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,QAAQ,GAAI,aAAa,CAE/D"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { CheckboxEditor } from "./checkboxEditor";
|
|
2
|
+
import { NumberEditor } from "./numberEditor";
|
|
3
|
+
import { TextEditor } from "./textEditor";
|
|
4
|
+
import { DropdownEditor } from "./dropdownEditor";
|
|
5
|
+
import { DateEditor } from "./dateEditor";
|
|
6
|
+
import { CalendarEditor } from "./calendarEditor";
|
|
7
|
+
export * from "./formulaEditor";
|
|
8
|
+
const editorMap = new Map([
|
|
9
|
+
['t', { createComponent: () => new TextEditor() }],
|
|
10
|
+
['n', { createComponent: () => new NumberEditor() }],
|
|
11
|
+
['b', { createComponent: () => new CheckboxEditor() }],
|
|
12
|
+
['s', { createComponent: () => new DropdownEditor() }],
|
|
13
|
+
['m', { createComponent: () => new DropdownEditor() }],
|
|
14
|
+
['d', { createComponent: (options) => options?.dateCalendarEditor ? new CalendarEditor() : new DateEditor() }],
|
|
15
|
+
]);
|
|
16
|
+
export function getEditorFactory(type) {
|
|
17
|
+
return editorMap.get(editorMap.has(type) ? type : 't');
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/editors/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAGlD,cAAc,iBAAiB,CAAC;AAMhC,MAAM,SAAS,GAAG,IAAI,GAAG,CAA0B;IAClD,CAAC,GAAG,EAAE,EAAC,eAAe,EAAE,GAAG,EAAE,CAAC,IAAI,UAAU,EAAE,EAAC,CAAC;IAChD,CAAC,GAAG,EAAE,EAAC,eAAe,EAAE,GAAG,EAAE,CAAC,IAAI,YAAY,EAAE,EAAC,CAAC;IAClD,CAAC,GAAG,EAAE,EAAC,eAAe,EAAE,GAAG,EAAE,CAAC,IAAI,cAAc,EAAE,EAAC,CAAC;IACpD,CAAC,GAAG,EAAE,EAAC,eAAe,EAAE,GAAG,EAAE,CAAC,IAAI,cAAc,EAAE,EAAC,CAAC;IACpD,CAAC,GAAG,EAAE,EAAC,eAAe,EAAE,GAAG,EAAE,CAAC,IAAI,cAAc,EAAE,EAAC,CAAC;IACpD,CAAC,GAAG,EAAE,EAAC,eAAe,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC,CAAC,IAAI,cAAc,EAAE,CAAC,CAAC,CAAC,IAAI,UAAU,EAAE,EAAC,CAAC;CAC5G,CAAC,CAAC;AAEH,MAAM,UAAU,gBAAgB,CAAC,IAAc;IAC9C,OAAO,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACxD,CAAC","sourcesContent":["import { BaseEditor } from \"./baseEditor\";\nimport { CheckboxEditor } from \"./checkboxEditor\";\nimport { NumberEditor } from \"./numberEditor\";\nimport { TextEditor } from \"./textEditor\";\nimport { DropdownEditor } from \"./dropdownEditor\";\nimport { DateEditor } from \"./dateEditor\";\nimport { CalendarEditor } from \"./calendarEditor\";\nimport { CellType, EditingOptions } from \"@omegagrid/grid-core\";\n\nexport * from \"./formulaEditor\";\n\nexport type EditorFactory = {\n\tcreateComponent: (options?: EditingOptions) => BaseEditor\n};\n\nconst editorMap = new Map<CellType, EditorFactory>([\n\t['t', {createComponent: () => new TextEditor()}],\n\t['n', {createComponent: () => new NumberEditor()}],\n\t['b', {createComponent: () => new CheckboxEditor()}],\n\t['s', {createComponent: () => new DropdownEditor()}],\n\t['m', {createComponent: () => new DropdownEditor()}],\n\t['d', {createComponent: (options) => options?.dateCalendarEditor ? new CalendarEditor() : new DateEditor()}],\n]);\n\nexport function getEditorFactory(type: CellType) : EditorFactory {\n\treturn editorMap.get(editorMap.has(type) ? type : 't');\n}"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TextEditor } from "./textEditor";
|
|
2
|
+
export declare class NumberEditor extends TextEditor {
|
|
3
|
+
private validateNumber;
|
|
4
|
+
_onKey(e: KeyboardEvent): void;
|
|
5
|
+
setValue(value: string): void;
|
|
6
|
+
firstUpdated(): void;
|
|
7
|
+
getValue(): string;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=numberEditor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"numberEditor.d.ts","sourceRoot":"","sources":["../../src/editors/numberEditor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAI1C,qBACa,YAAa,SAAQ,UAAU;IAE3C,OAAO,CAAC,cAAc;IAKtB,MAAM,CAAC,CAAC,EAAE,aAAa;IAQvB,QAAQ,CAAC,KAAK,EAAE,MAAM;IAItB,YAAY;IAKZ,QAAQ;CAIR"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { TextEditor } from "./textEditor";
|
|
8
|
+
import { customElement } from 'lit/decorators.js';
|
|
9
|
+
import { isFormula } from "@omegagrid/grid-core";
|
|
10
|
+
let NumberEditor = class NumberEditor extends TextEditor {
|
|
11
|
+
validateNumber(value) {
|
|
12
|
+
value = value.replace(',', '.');
|
|
13
|
+
return isFormula(value) || !isNaN(Number(value)) || value == '-';
|
|
14
|
+
}
|
|
15
|
+
_onKey(e) {
|
|
16
|
+
if (e.key.length === 1) {
|
|
17
|
+
if (!this.validateNumber(this.input.value + e.key)) {
|
|
18
|
+
e.preventDefault();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
setValue(value) {
|
|
23
|
+
this.input.value = this.validateNumber(value) ? value : '';
|
|
24
|
+
}
|
|
25
|
+
firstUpdated() {
|
|
26
|
+
this.input.addEventListener('keydown', e => this._onKey(e));
|
|
27
|
+
this.input.addEventListener('keypress', e => this._onKey(e));
|
|
28
|
+
}
|
|
29
|
+
getValue() {
|
|
30
|
+
return this.input.value === '' ? null : this.input.value.replace(',', '.');
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
NumberEditor = __decorate([
|
|
34
|
+
customElement('og-grid-numbereditor')
|
|
35
|
+
], NumberEditor);
|
|
36
|
+
export { NumberEditor };
|
|
37
|
+
//# sourceMappingURL=numberEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"numberEditor.js","sourceRoot":"","sources":["../../src/editors/numberEditor.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAG1C,IAAM,YAAY,GAAlB,MAAM,YAAa,SAAQ,UAAU;IAEnC,cAAc,CAAC,KAAa;QACnC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAChC,OAAO,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,IAAI,GAAG,CAAC;IAClE,CAAC;IAED,MAAM,CAAC,CAAgB;QACtB,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC;gBACpD,CAAC,CAAC,cAAc,EAAE,CAAC;YACpB,CAAC;QACF,CAAC;IACF,CAAC;IAED,QAAQ,CAAC,KAAa;QACrB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IAC5D,CAAC;IAED,YAAY;QACX,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,QAAQ;QACP,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAC5E,CAAC;CAED,CAAA;AA5BY,YAAY;IADxB,aAAa,CAAC,sBAAsB,CAAC;GACzB,YAAY,CA4BxB","sourcesContent":["import { TextEditor } from \"./textEditor\";\nimport { customElement } from 'lit/decorators.js';\nimport { isFormula } from \"@omegagrid/grid-core\";\n\n@customElement('og-grid-numbereditor')\nexport class NumberEditor extends TextEditor {\n\n\tprivate validateNumber(value: string) {\n\t\tvalue = value.replace(',', '.');\n\t\treturn isFormula(value) || !isNaN(Number(value)) || value == '-';\n\t}\n\n\t_onKey(e: KeyboardEvent) {\n\t\tif (e.key.length === 1) {\n\t\t\tif (!this.validateNumber(this.input.value + e.key)) {\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t}\n\t}\n\n\tsetValue(value: string) {\n\t\tthis.input.value = this.validateNumber(value) ? value : '';\n\t}\n\n\tfirstUpdated() {\n\t\tthis.input.addEventListener('keydown', e => this._onKey(e));\n\t\tthis.input.addEventListener('keypress', e => this._onKey(e));\n\t}\n\n\tgetValue() {\n\t\treturn this.input.value === '' ? null : this.input.value.replace(',', '.');\n\t}\n\n}"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { CellModel } from "@omegagrid/grid-core";
|
|
2
|
+
import { BaseEditor } from "./baseEditor";
|
|
3
|
+
import { Ref } from 'lit/directives/ref.js';
|
|
4
|
+
export declare class TextEditor extends BaseEditor {
|
|
5
|
+
static styles: import("lit").CSSResult[];
|
|
6
|
+
inputRef: Ref<HTMLInputElement>;
|
|
7
|
+
get input(): HTMLInputElement;
|
|
8
|
+
private _onBlur;
|
|
9
|
+
private _onKeyUp;
|
|
10
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
11
|
+
activate(cell: CellModel): void;
|
|
12
|
+
getValue(): unknown;
|
|
13
|
+
setValue(value: unknown): void;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=textEditor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"textEditor.d.ts","sourceRoot":"","sources":["../../src/editors/textEditor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAa,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C,OAAO,EAAa,GAAG,EAAO,MAAM,uBAAuB,CAAC;AAI5D,qBACa,UAAW,SAAQ,UAAU;IAEzC,MAAM,CAAC,MAAM,4BAaV;IAEH,QAAQ,EAAE,GAAG,CAAC,gBAAgB,CAAC,CAAe;IAC9C,IAAI,KAAK,qBAAiC;IAE1C,OAAO,CAAC,OAAO;IAKf,OAAO,CAAC,QAAQ;IAWhB,MAAM;IASN,QAAQ,CAAC,IAAI,EAAE,SAAS;IAMxB,QAAQ,IAAI,OAAO;IAInB,QAAQ,CAAC,KAAK,EAAE,OAAO;CAIvB"}
|