@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.
Files changed (257) hide show
  1. package/dist/commands/editingCommands.d.ts +4 -0
  2. package/dist/commands/editingCommands.d.ts.map +1 -0
  3. package/dist/commands/editingCommands.js +74 -0
  4. package/dist/commands/editingCommands.js.map +1 -0
  5. package/dist/commands/groupCommands.d.ts +8 -0
  6. package/dist/commands/groupCommands.d.ts.map +1 -0
  7. package/dist/commands/groupCommands.js +7 -0
  8. package/dist/commands/groupCommands.js.map +1 -0
  9. package/dist/commands/index.d.ts +4 -0
  10. package/dist/commands/index.d.ts.map +1 -0
  11. package/dist/commands/index.js +9 -0
  12. package/dist/commands/index.js.map +1 -0
  13. package/dist/commands/navigationCommands.d.ts +5 -0
  14. package/dist/commands/navigationCommands.d.ts.map +1 -0
  15. package/dist/commands/navigationCommands.js +117 -0
  16. package/dist/commands/navigationCommands.js.map +1 -0
  17. package/dist/constants.d.ts +65 -0
  18. package/dist/constants.d.ts.map +1 -0
  19. package/dist/constants.js +8 -0
  20. package/dist/constants.js.map +1 -0
  21. package/dist/editors/baseEditor.d.ts +31 -0
  22. package/dist/editors/baseEditor.d.ts.map +1 -0
  23. package/dist/editors/baseEditor.js +112 -0
  24. package/dist/editors/baseEditor.js.map +1 -0
  25. package/dist/editors/calendarEditor.d.ts +12 -0
  26. package/dist/editors/calendarEditor.d.ts.map +1 -0
  27. package/dist/editors/calendarEditor.js +74 -0
  28. package/dist/editors/calendarEditor.js.map +1 -0
  29. package/dist/editors/checkboxEditor.d.ts +9 -0
  30. package/dist/editors/checkboxEditor.d.ts.map +1 -0
  31. package/dist/editors/checkboxEditor.js +32 -0
  32. package/dist/editors/checkboxEditor.js.map +1 -0
  33. package/dist/editors/dateEditor.d.ts +8 -0
  34. package/dist/editors/dateEditor.d.ts.map +1 -0
  35. package/dist/editors/dateEditor.js +37 -0
  36. package/dist/editors/dateEditor.js.map +1 -0
  37. package/dist/editors/dropdownEditor.d.ts +26 -0
  38. package/dist/editors/dropdownEditor.d.ts.map +1 -0
  39. package/dist/editors/dropdownEditor.js +142 -0
  40. package/dist/editors/dropdownEditor.js.map +1 -0
  41. package/dist/editors/formulaEditor.d.ts +21 -0
  42. package/dist/editors/formulaEditor.d.ts.map +1 -0
  43. package/dist/editors/formulaEditor.js +109 -0
  44. package/dist/editors/formulaEditor.js.map +1 -0
  45. package/dist/editors/index.d.ts +8 -0
  46. package/dist/editors/index.d.ts.map +1 -0
  47. package/dist/editors/index.js +19 -0
  48. package/dist/editors/index.js.map +1 -0
  49. package/dist/editors/numberEditor.d.ts +9 -0
  50. package/dist/editors/numberEditor.d.ts.map +1 -0
  51. package/dist/editors/numberEditor.js +37 -0
  52. package/dist/editors/numberEditor.js.map +1 -0
  53. package/dist/editors/textEditor.d.ts +15 -0
  54. package/dist/editors/textEditor.d.ts.map +1 -0
  55. package/dist/editors/textEditor.js +74 -0
  56. package/dist/editors/textEditor.js.map +1 -0
  57. package/dist/filters/NumberFilter.d.ts +8 -0
  58. package/dist/filters/NumberFilter.d.ts.map +1 -0
  59. package/dist/filters/NumberFilter.js +13 -0
  60. package/dist/filters/NumberFilter.js.map +1 -0
  61. package/dist/filters/baseFilter.d.ts +20 -0
  62. package/dist/filters/baseFilter.d.ts.map +1 -0
  63. package/dist/filters/baseFilter.js +47 -0
  64. package/dist/filters/baseFilter.js.map +1 -0
  65. package/dist/filters/checkboxFilter.d.ts +12 -0
  66. package/dist/filters/checkboxFilter.d.ts.map +1 -0
  67. package/dist/filters/checkboxFilter.js +67 -0
  68. package/dist/filters/checkboxFilter.js.map +1 -0
  69. package/dist/filters/dropdownFilter.d.ts +17 -0
  70. package/dist/filters/dropdownFilter.d.ts.map +1 -0
  71. package/dist/filters/dropdownFilter.js +116 -0
  72. package/dist/filters/dropdownFilter.js.map +1 -0
  73. package/dist/filters/filterFactory.d.ts +4 -0
  74. package/dist/filters/filterFactory.d.ts.map +1 -0
  75. package/dist/filters/filterFactory.js +39 -0
  76. package/dist/filters/filterFactory.js.map +1 -0
  77. package/dist/filters/index.d.ts +5 -0
  78. package/dist/filters/index.d.ts.map +1 -0
  79. package/dist/filters/index.js +5 -0
  80. package/dist/filters/index.js.map +1 -0
  81. package/dist/filters/textFilter.d.ts +17 -0
  82. package/dist/filters/textFilter.d.ts.map +1 -0
  83. package/dist/filters/textFilter.js +89 -0
  84. package/dist/filters/textFilter.js.map +1 -0
  85. package/dist/gridAdapter.d.ts +30 -0
  86. package/dist/gridAdapter.d.ts.map +1 -0
  87. package/dist/gridAdapter.js +11 -0
  88. package/dist/gridAdapter.js.map +1 -0
  89. package/dist/i18n/en-us.d.ts +4 -0
  90. package/dist/i18n/en-us.d.ts.map +1 -0
  91. package/dist/i18n/en-us.js +5 -0
  92. package/dist/i18n/en-us.js.map +1 -0
  93. package/dist/i18n/index.d.ts +5 -0
  94. package/dist/i18n/index.d.ts.map +1 -0
  95. package/dist/i18n/index.js +8 -0
  96. package/dist/i18n/index.js.map +1 -0
  97. package/dist/index.d.ts +7 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/dist/index.js +7 -0
  100. package/dist/index.js.map +1 -0
  101. package/dist/renderers/ActionRenderer.d.ts +3 -0
  102. package/dist/renderers/ActionRenderer.d.ts.map +1 -0
  103. package/dist/renderers/ActionRenderer.js +68 -0
  104. package/dist/renderers/ActionRenderer.js.map +1 -0
  105. package/dist/renderers/BaseRenderer.d.ts +6 -0
  106. package/dist/renderers/BaseRenderer.d.ts.map +1 -0
  107. package/dist/renderers/BaseRenderer.js +56 -0
  108. package/dist/renderers/BaseRenderer.js.map +1 -0
  109. package/dist/renderers/CheckboxRenderer.d.ts +4 -0
  110. package/dist/renderers/CheckboxRenderer.d.ts.map +1 -0
  111. package/dist/renderers/CheckboxRenderer.js +22 -0
  112. package/dist/renderers/CheckboxRenderer.js.map +1 -0
  113. package/dist/renderers/DateTimeRenderer.d.ts +4 -0
  114. package/dist/renderers/DateTimeRenderer.d.ts.map +1 -0
  115. package/dist/renderers/DateTimeRenderer.js +21 -0
  116. package/dist/renderers/DateTimeRenderer.js.map +1 -0
  117. package/dist/renderers/DropdownRenderer.d.ts +4 -0
  118. package/dist/renderers/DropdownRenderer.d.ts.map +1 -0
  119. package/dist/renderers/DropdownRenderer.js +18 -0
  120. package/dist/renderers/DropdownRenderer.js.map +1 -0
  121. package/dist/renderers/GeneralRenderer.d.ts +4 -0
  122. package/dist/renderers/GeneralRenderer.d.ts.map +1 -0
  123. package/dist/renderers/GeneralRenderer.js +12 -0
  124. package/dist/renderers/GeneralRenderer.js.map +1 -0
  125. package/dist/renderers/HtmlRenderer.d.ts +4 -0
  126. package/dist/renderers/HtmlRenderer.d.ts.map +1 -0
  127. package/dist/renderers/HtmlRenderer.js +6 -0
  128. package/dist/renderers/HtmlRenderer.js.map +1 -0
  129. package/dist/renderers/NumberRenderer.d.ts +4 -0
  130. package/dist/renderers/NumberRenderer.d.ts.map +1 -0
  131. package/dist/renderers/NumberRenderer.js +14 -0
  132. package/dist/renderers/NumberRenderer.js.map +1 -0
  133. package/dist/renderers/SparklineRenderer.d.ts +3 -0
  134. package/dist/renderers/SparklineRenderer.d.ts.map +1 -0
  135. package/dist/renderers/SparklineRenderer.js +8 -0
  136. package/dist/renderers/SparklineRenderer.js.map +1 -0
  137. package/dist/renderers/TextRenderer.d.ts +4 -0
  138. package/dist/renderers/TextRenderer.d.ts.map +1 -0
  139. package/dist/renderers/TextRenderer.js +38 -0
  140. package/dist/renderers/TextRenderer.js.map +1 -0
  141. package/dist/renderers/index.d.ts +12 -0
  142. package/dist/renderers/index.d.ts.map +1 -0
  143. package/dist/renderers/index.js +32 -0
  144. package/dist/renderers/index.js.map +1 -0
  145. package/dist/types.d.ts +10 -0
  146. package/dist/types.d.ts.map +1 -0
  147. package/dist/types.js +2 -0
  148. package/dist/types.js.map +1 -0
  149. package/dist/ui/comment.d.ts +59 -0
  150. package/dist/ui/comment.d.ts.map +1 -0
  151. package/dist/ui/comment.js +284 -0
  152. package/dist/ui/comment.js.map +1 -0
  153. package/dist/ui/comment.style.d.ts +2 -0
  154. package/dist/ui/comment.style.d.ts.map +1 -0
  155. package/dist/ui/comment.style.js +108 -0
  156. package/dist/ui/comment.style.js.map +1 -0
  157. package/dist/ui/elementCache.d.ts +15 -0
  158. package/dist/ui/elementCache.d.ts.map +1 -0
  159. package/dist/ui/elementCache.js +57 -0
  160. package/dist/ui/elementCache.js.map +1 -0
  161. package/dist/ui/filterLabel.d.ts +10 -0
  162. package/dist/ui/filterLabel.d.ts.map +1 -0
  163. package/dist/ui/filterLabel.js +76 -0
  164. package/dist/ui/filterLabel.js.map +1 -0
  165. package/dist/ui/formulaInput.d.ts +56 -0
  166. package/dist/ui/formulaInput.d.ts.map +1 -0
  167. package/dist/ui/formulaInput.js +251 -0
  168. package/dist/ui/formulaInput.js.map +1 -0
  169. package/dist/ui/formulaInput.style.d.ts +2 -0
  170. package/dist/ui/formulaInput.style.d.ts.map +1 -0
  171. package/dist/ui/formulaInput.style.js +65 -0
  172. package/dist/ui/formulaInput.style.js.map +1 -0
  173. package/dist/ui/grid.d.ts +91 -0
  174. package/dist/ui/grid.d.ts.map +1 -0
  175. package/dist/ui/grid.editing.d.ts +61 -0
  176. package/dist/ui/grid.editing.d.ts.map +1 -0
  177. package/dist/ui/grid.editing.js +439 -0
  178. package/dist/ui/grid.editing.js.map +1 -0
  179. package/dist/ui/grid.events.d.ts +97 -0
  180. package/dist/ui/grid.events.d.ts.map +1 -0
  181. package/dist/ui/grid.events.js +581 -0
  182. package/dist/ui/grid.events.js.map +1 -0
  183. package/dist/ui/grid.filtering.d.ts +23 -0
  184. package/dist/ui/grid.filtering.d.ts.map +1 -0
  185. package/dist/ui/grid.filtering.js +68 -0
  186. package/dist/ui/grid.filtering.js.map +1 -0
  187. package/dist/ui/grid.js +297 -0
  188. package/dist/ui/grid.js.map +1 -0
  189. package/dist/ui/grid.menu.d.ts +43 -0
  190. package/dist/ui/grid.menu.d.ts.map +1 -0
  191. package/dist/ui/grid.menu.js +168 -0
  192. package/dist/ui/grid.menu.js.map +1 -0
  193. package/dist/ui/grid.objects.d.ts +24 -0
  194. package/dist/ui/grid.objects.d.ts.map +1 -0
  195. package/dist/ui/grid.objects.js +69 -0
  196. package/dist/ui/grid.objects.js.map +1 -0
  197. package/dist/ui/grid.rendering.d.ts +84 -0
  198. package/dist/ui/grid.rendering.d.ts.map +1 -0
  199. package/dist/ui/grid.rendering.js +471 -0
  200. package/dist/ui/grid.rendering.js.map +1 -0
  201. package/dist/ui/grid.selecting.d.ts +99 -0
  202. package/dist/ui/grid.selecting.d.ts.map +1 -0
  203. package/dist/ui/grid.selecting.js +319 -0
  204. package/dist/ui/grid.selecting.js.map +1 -0
  205. package/dist/ui/grid.sorting.d.ts +23 -0
  206. package/dist/ui/grid.sorting.d.ts.map +1 -0
  207. package/dist/ui/grid.sorting.js +47 -0
  208. package/dist/ui/grid.sorting.js.map +1 -0
  209. package/dist/ui/grid.style.d.ts +2 -0
  210. package/dist/ui/grid.style.d.ts.map +1 -0
  211. package/dist/ui/grid.style.js +39 -0
  212. package/dist/ui/grid.style.js.map +1 -0
  213. package/dist/ui/group.d.ts +71 -0
  214. package/dist/ui/group.d.ts.map +1 -0
  215. package/dist/ui/group.js +312 -0
  216. package/dist/ui/group.js.map +1 -0
  217. package/dist/ui/index.d.ts +19 -0
  218. package/dist/ui/index.d.ts.map +1 -0
  219. package/dist/ui/index.js +19 -0
  220. package/dist/ui/index.js.map +1 -0
  221. package/dist/ui/objectHost.d.ts +30 -0
  222. package/dist/ui/objectHost.d.ts.map +1 -0
  223. package/dist/ui/objectHost.js +114 -0
  224. package/dist/ui/objectHost.js.map +1 -0
  225. package/dist/ui/objectHost.style.d.ts +2 -0
  226. package/dist/ui/objectHost.style.d.ts.map +1 -0
  227. package/dist/ui/objectHost.style.js +43 -0
  228. package/dist/ui/objectHost.style.js.map +1 -0
  229. package/dist/ui/selector.d.ts +97 -0
  230. package/dist/ui/selector.d.ts.map +1 -0
  231. package/dist/ui/selector.js +489 -0
  232. package/dist/ui/selector.js.map +1 -0
  233. package/dist/ui/selector.style.d.ts +2 -0
  234. package/dist/ui/selector.style.d.ts.map +1 -0
  235. package/dist/ui/selector.style.js +106 -0
  236. package/dist/ui/selector.style.js.map +1 -0
  237. package/dist/ui/sortingArrow.d.ts +8 -0
  238. package/dist/ui/sortingArrow.d.ts.map +1 -0
  239. package/dist/ui/sortingArrow.js +42 -0
  240. package/dist/ui/sortingArrow.js.map +1 -0
  241. package/dist/ui/sparkline.d.ts +14 -0
  242. package/dist/ui/sparkline.d.ts.map +1 -0
  243. package/dist/ui/sparkline.js +111 -0
  244. package/dist/ui/sparkline.js.map +1 -0
  245. package/dist/ui/table.d.ts +122 -0
  246. package/dist/ui/table.d.ts.map +1 -0
  247. package/dist/ui/table.js +1063 -0
  248. package/dist/ui/table.js.map +1 -0
  249. package/dist/ui/table.styles.d.ts +2 -0
  250. package/dist/ui/table.styles.d.ts.map +1 -0
  251. package/dist/ui/table.styles.js +249 -0
  252. package/dist/ui/table.styles.js.map +1 -0
  253. package/dist/ui/tooltip.d.ts +9 -0
  254. package/dist/ui/tooltip.d.ts.map +1 -0
  255. package/dist/ui/tooltip.js +32 -0
  256. package/dist/ui/tooltip.js.map +1 -0
  257. 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":"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","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":";;;;;;AAAA,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,KAAK,CAAC;AAE3C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,OAAO,EAAE,GAAG,EAAE,MAAM,iBAAiB,CAAC;AAG/B,IAAM,aAAa,GAAnB,MAAM,aAAc,SAAQ,UAAU;IAAtC;;QA+BN,0BAAqB,GAAG,CAAC,CAAgB,EAAE,EAAE;YAC5C,IAAI,CAAC,CAAC,QAAQ,EAAE,KAAK,IAAI,IAAI;gBAAE,OAAO;YACtC,MAAM,KAAK,GAAG,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;YAC3C,IAAI,CAAC,CAAC,QAAQ,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI;gBAAE,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YAC3E,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC9C,CAAC,CAAA;QAED,kBAAa,GAAG,CAAC,CAAY,EAAE,EAAE;YAChC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa;gBAAE,OAAO;YAC7C,MAAM,KAAK,GAAG,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YACxC,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI;gBAAE,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YACzD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC,CAAA;QA+BD,eAAU,GAAG,CAAC,CAAoB,EAAE,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,sBAAsB,EAAE,CAAC;YAC7C,IAAI,CAAC,CAAC,OAAO;gBAAE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QAChE,CAAC,CAAA;QAED,mBAAc,GAAG,GAAG,EAAE;YACrB,IAAI,CAAC,MAAM,EAAE,CAAC;QACf,CAAC,CAAA;QAED,oBAAe,GAAG,GAAG,EAAE;YACtB,IAAI,CAAC,KAAK,EAAE,CAAC;QACd,CAAC,CAAA;QAMD,WAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAA;;uBAEG,IAAI,CAAC,UAAU;sBAChB,IAAI,CAAC,cAAc;uBAClB,IAAI,CAAC,eAAe;;EAEzC,CAAC;IAEH,CAAC;IAnFA,MAAM;QACL,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACxD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;YAC/E,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,IAAI,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,KAAK,EAAE,CAAC;IACd,CAAC;IAED,KAAK;QACJ,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,sBAAsB,EAAE,CAAC;QAC7C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,qBAAqB,EAAE,CAAC;QAC5C,KAAK,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAgBD,QAAQ,CAAC,IAAe;QACvB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;QACrC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACrB,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,SAAS,CAAC;QACzD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACtD,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;QAClE,WAAW,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;QACjF,WAAW,CAAC,gBAAgB,CAAC,oBAAoB,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAC/E,WAAW,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;IACjE,CAAC;IAED,UAAU;QACT,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;QAClE,WAAW,CAAC,mBAAmB,CAAC,sBAAsB,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;QACpF,WAAW,CAAC,mBAAmB,CAAC,oBAAoB,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAClF,WAAW,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACnE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;QACnC,KAAK,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,QAAQ;QACP,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;IACzB,CAAC;IAED,QAAQ,CAAC,KAAa;QACrB,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,EAAC,CAAC,EAAE,IAAI,CAAC,WAAW,EAAC,CAAC,CAAC;QAC/C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,KAAK,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC9E,CAAC;IAeD,KAAK;QACJ,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACpB,CAAC;;AAvFM,oBAAM,GAAG,CAAC,UAAU,CAAC,UAAU,EAAE,GAAG,CAAA;;;8CAGE,SAAS,CAAC,SAAS,CAAC,oBAAoB,CAAC;;;;;;EAMrF,CAAC,AATW,CASV;AAGH;IADC,KAAK,CAAC,iBAAiB,CAAC;4CACL;AAdR,aAAa;IADzB,aAAa,CAAC,uBAAuB,CAAC;GAC1B,aAAa,CAmGzB","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"}