@operato/data-grist 2.0.0-alpha.0 → 2.0.0-alpha.11

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 (100) hide show
  1. package/CHANGELOG.md +95 -0
  2. package/dist/src/accumulator/accumulator.js +4 -4
  3. package/dist/src/accumulator/accumulator.js.map +1 -1
  4. package/dist/src/configure/column-builder.js +5 -5
  5. package/dist/src/configure/column-builder.js.map +1 -1
  6. package/dist/src/configure/zero-config.js +3 -1
  7. package/dist/src/configure/zero-config.js.map +1 -1
  8. package/dist/src/data-card/data-card-field.js +1 -1
  9. package/dist/src/data-card/data-card-field.js.map +1 -1
  10. package/dist/src/data-grid/data-grid-accum-field.d.ts +1 -0
  11. package/dist/src/data-grid/data-grid-accum-field.js +8 -0
  12. package/dist/src/data-grid/data-grid-accum-field.js.map +1 -1
  13. package/dist/src/data-grid/data-grid-body.js +24 -3
  14. package/dist/src/data-grid/data-grid-body.js.map +1 -1
  15. package/dist/src/data-grid/data-grid-field.d.ts +1 -0
  16. package/dist/src/data-grid/data-grid-field.js +5 -0
  17. package/dist/src/data-grid/data-grid-field.js.map +1 -1
  18. package/dist/src/data-grid/data-grid-header.d.ts +1 -0
  19. package/dist/src/data-grid/data-grid-header.js +16 -14
  20. package/dist/src/data-grid/data-grid-header.js.map +1 -1
  21. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js +2 -2
  22. package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js.map +1 -1
  23. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.d.ts +7 -0
  24. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js +25 -0
  25. package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js.map +1 -0
  26. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js +2 -2
  27. package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js.map +1 -1
  28. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js +2 -2
  29. package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js.map +1 -1
  30. package/dist/src/data-grist.d.ts +225 -3
  31. package/dist/src/data-grist.js +195 -3
  32. package/dist/src/data-grist.js.map +1 -1
  33. package/dist/src/data-list/data-list-field.js +1 -1
  34. package/dist/src/data-list/data-list-field.js.map +1 -1
  35. package/dist/src/data-manipulator.d.ts +7 -3
  36. package/dist/src/data-manipulator.js +103 -20
  37. package/dist/src/data-manipulator.js.map +1 -1
  38. package/dist/src/editors/ox-grist-editor-tree.d.ts +6 -0
  39. package/dist/src/editors/ox-grist-editor-tree.js +27 -0
  40. package/dist/src/editors/ox-grist-editor-tree.js.map +1 -0
  41. package/dist/src/editors/ox-grist-editor.d.ts +1 -0
  42. package/dist/src/editors/ox-grist-editor.js +3 -0
  43. package/dist/src/editors/ox-grist-editor.js.map +1 -1
  44. package/dist/src/editors/ox-input-tree.d.ts +20 -0
  45. package/dist/src/editors/ox-input-tree.js +221 -0
  46. package/dist/src/editors/ox-input-tree.js.map +1 -0
  47. package/dist/src/editors/registry.js +3 -1
  48. package/dist/src/editors/registry.js.map +1 -1
  49. package/dist/src/filters/filters-form.js +1 -1
  50. package/dist/src/filters/filters-form.js.map +1 -1
  51. package/dist/src/handlers/contextmenu-tree-mutation.d.ts +3 -0
  52. package/dist/src/handlers/contextmenu-tree-mutation.js +82 -0
  53. package/dist/src/handlers/contextmenu-tree-mutation.js.map +1 -0
  54. package/dist/src/handlers/registry.js +3 -1
  55. package/dist/src/handlers/registry.js.map +1 -1
  56. package/dist/src/renderers/ox-grist-renderer-tree.d.ts +1 -0
  57. package/dist/src/renderers/ox-grist-renderer-tree.js +6 -3
  58. package/dist/src/renderers/ox-grist-renderer-tree.js.map +1 -1
  59. package/dist/src/types.d.ts +437 -6
  60. package/dist/src/types.js +9 -0
  61. package/dist/src/types.js.map +1 -1
  62. package/dist/stories/accumulator.stories.js +2 -1
  63. package/dist/stories/accumulator.stories.js.map +1 -1
  64. package/dist/stories/fixed-column.stories.js +3 -3
  65. package/dist/stories/fixed-column.stories.js.map +1 -1
  66. package/dist/stories/tree-column-with-checkbox.stories.js +8 -3
  67. package/dist/stories/tree-column-with-checkbox.stories.js.map +1 -1
  68. package/dist/stories/tree-column.stories.js +8 -3
  69. package/dist/stories/tree-column.stories.js.map +1 -1
  70. package/dist/tsconfig.tsbuildinfo +1 -1
  71. package/docs/gutter/gutter.md +7 -0
  72. package/package.json +5 -5
  73. package/src/accumulator/accumulator.ts +4 -4
  74. package/src/configure/column-builder.ts +4 -4
  75. package/src/configure/zero-config.ts +3 -1
  76. package/src/data-card/data-card-field.ts +1 -1
  77. package/src/data-grid/data-grid-accum-field.ts +7 -0
  78. package/src/data-grid/data-grid-body.ts +30 -3
  79. package/src/data-grid/data-grid-field.ts +6 -0
  80. package/src/data-grid/data-grid-header.ts +22 -18
  81. package/src/data-grid/event-handlers/data-grid-body-click-handler.ts +2 -2
  82. package/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.ts +32 -0
  83. package/src/data-grid/event-handlers/data-grid-body-dblclick-handler.ts +2 -2
  84. package/src/data-grid/event-handlers/data-grid-body-focus-change-handler.ts +2 -2
  85. package/src/data-grist.ts +250 -3
  86. package/src/data-list/data-list-field.ts +1 -1
  87. package/src/data-manipulator.ts +130 -22
  88. package/src/editors/ox-grist-editor-tree.ts +27 -0
  89. package/src/editors/ox-grist-editor.ts +4 -0
  90. package/src/editors/ox-input-tree.ts +226 -0
  91. package/src/editors/registry.ts +3 -1
  92. package/src/filters/filters-form.ts +1 -1
  93. package/src/handlers/contextmenu-tree-mutation.ts +98 -0
  94. package/src/handlers/registry.ts +3 -1
  95. package/src/renderers/ox-grist-renderer-tree.ts +7 -3
  96. package/src/types.ts +446 -6
  97. package/stories/accumulator.stories.ts +2 -1
  98. package/stories/fixed-column.stories.ts +3 -3
  99. package/stories/tree-column-with-checkbox.stories.ts +8 -3
  100. package/stories/tree-column.stories.ts +8 -3
@@ -20,8 +20,12 @@ export declare class DataManipulator extends LitElement {
20
20
  removed: GristRecord[];
21
21
  }): void;
22
22
  onRecordChanged(recordData: GristRecord, row: number, column: ColumnConfig | null): void;
23
- onCollapsed(e: CustomEvent): void;
24
- onExpanded(e: CustomEvent): void;
23
+ collapseAll(): void;
24
+ expandAll(): void;
25
+ collapseNode(record: GristRecord): void;
26
+ expandNode(record: GristRecord): void;
27
+ addSiblingNode(record: GristRecord): void;
28
+ addChildNode(record: GristRecord): void;
25
29
  onCheckInTree(e: CustomEvent): void;
26
30
  /**
27
31
  * Forced internal data to be reflected on the screen
@@ -29,6 +33,6 @@ export declare class DataManipulator extends LitElement {
29
33
  * Therefore, it will be deprecated.
30
34
  * @method
31
35
  */
32
- refresh(): void;
36
+ refresh(forceExpandOrCollapse?: boolean): void;
33
37
  private traverseRefresh;
34
38
  }
@@ -29,15 +29,14 @@ export class DataManipulator extends LitElement {
29
29
  this.onRecordChanged(record['__origin__'], row, null);
30
30
  });
31
31
  /* tree processing */
32
- this.addEventListener('collapsed', (e) => this.onCollapsed(e));
33
- this.addEventListener('expanded', (e) => this.onExpanded(e));
32
+ this.addEventListener('collapse-all', (e) => this.collapseAll());
33
+ this.addEventListener('expand-all', (e) => this.expandAll());
34
+ this.addEventListener('collapse-node', (e) => this.collapseNode(e.detail));
35
+ this.addEventListener('expand-node', (e) => this.expandNode(e.detail));
34
36
  this.addEventListener('check-in-tree', (e) => this.onCheckInTree(e));
37
+ this.addEventListener('add-sibling-node', (e) => this.addSiblingNode(e.detail));
38
+ this.addEventListener('add-child-node', (e) => this.addChildNode(e.detail));
35
39
  }
36
- // updated(changes: PropertyValues<this>) {
37
- // if (changes.has('data')) {
38
- // this.refresh()
39
- // }
40
- // }
41
40
  onFieldChange({ after, before, column, record, row }) {
42
41
  /* compare changes */
43
42
  if (after === before) {
@@ -142,18 +141,99 @@ export class DataManipulator extends LitElement {
142
141
  }));
143
142
  this.requestUpdate();
144
143
  }
145
- onCollapsed(e) {
146
- const record = e.detail;
144
+ collapseAll() {
145
+ this.refresh(false);
146
+ }
147
+ expandAll() {
148
+ this.refresh(true);
149
+ }
150
+ collapseNode(record) {
147
151
  record.__expanded__ = false;
148
152
  this.refresh();
149
153
  }
150
- onExpanded(e) {
151
- const record = e.detail;
154
+ expandNode(record) {
155
+ record.__expanded__ = true;
156
+ this.refresh();
157
+ }
158
+ // onCollapse(e: CustomEvent) {
159
+ // const record = e.detail as GristRecord
160
+ // record.__expanded__ = false
161
+ // this.refresh()
162
+ // }
163
+ // onExpand(e: CustomEvent) {
164
+ // const record = e.detail as GristRecord
165
+ // record.__expanded__ = true
166
+ // this.refresh()
167
+ // }
168
+ addSiblingNode(record) {
169
+ const { records } = this.data;
170
+ const toplevelRecords = records.filter(record => !record.__depth__); /* __depth__ 가 설정되지 않았거나, 0 인 경우만 수집 */
171
+ const { __depth__ } = record;
172
+ function findParent(record, parent) {
173
+ var children = (parent ? parent.__children__ || [] : toplevelRecords);
174
+ if (children.find(child => child === record)) {
175
+ return parent;
176
+ }
177
+ else {
178
+ for (let child of children) {
179
+ const found = findParent(record, child);
180
+ if (found) {
181
+ return found;
182
+ }
183
+ }
184
+ }
185
+ }
186
+ const parent = findParent(record);
187
+ const sibling = {
188
+ __depth__,
189
+ __dirty__: '+'
190
+ };
191
+ if (parent) {
192
+ const { id } = parent;
193
+ sibling.parent = { id };
194
+ if (!parent.__children__) {
195
+ parent.__children__ = [sibling];
196
+ }
197
+ else {
198
+ let index = parent.__children__.indexOf(record);
199
+ if (index !== -1) {
200
+ parent.__children__ = [
201
+ ...parent.__children__.slice(0, index + 1),
202
+ sibling,
203
+ ...parent.__children__.slice(index + 1)
204
+ ];
205
+ }
206
+ else {
207
+ parent.__children__ = [...parent.__children__, sibling];
208
+ }
209
+ }
210
+ parent.__expanded__ = true;
211
+ }
212
+ else {
213
+ this.data.records = [...toplevelRecords, sibling];
214
+ }
215
+ this.refresh();
216
+ }
217
+ addChildNode(record) {
218
+ const { id: parentId, __children__, __depth__ } = record;
219
+ const child = {
220
+ parent: {
221
+ id: parentId
222
+ },
223
+ __depth__: (__depth__ || 0) + 1,
224
+ __dirty__: '+'
225
+ };
226
+ if (!record.__children__) {
227
+ record.__children__ = [child];
228
+ }
229
+ else {
230
+ record.__children__.unshift(child);
231
+ }
152
232
  record.__expanded__ = true;
233
+ // this.requestUpdate()
153
234
  this.refresh();
154
235
  }
155
236
  onCheckInTree(e) {
156
- const self = this;
157
237
  function walkTreeCheckedUpdate(record, checked) {
158
238
  const children = record.__children__;
159
239
  children === null || children === void 0 ? void 0 : children.forEach(child => walkTreeCheckedUpdate(child, checked));
@@ -167,14 +247,14 @@ export class DataManipulator extends LitElement {
167
247
  return;
168
248
  }
169
249
  children.forEach(child => updateCheckedAll(child));
170
- var checked;
250
+ var checked = record.__check_in_tree__ == 'checked' ? 'checked' : undefined;
171
251
  children.forEach(child => {
172
252
  const { __check_in_tree__ } = child;
173
253
  if (__check_in_tree__ == 'half-checked') {
174
254
  checked = 'half-checked';
175
255
  }
176
256
  else if (__check_in_tree__ == 'checked') {
177
- checked = checked == 'checked' || !checked ? 'checked' : 'half-checked';
257
+ checked = checked == 'checked' ? 'checked' : 'half-checked';
178
258
  }
179
259
  else {
180
260
  checked = checked == 'unchecked' || !checked ? 'unchecked' : 'half-checked';
@@ -197,7 +277,7 @@ export class DataManipulator extends LitElement {
197
277
  * Therefore, it will be deprecated.
198
278
  * @method
199
279
  */
200
- refresh() {
280
+ refresh(forceExpandOrCollapse) {
201
281
  /*
202
282
  - TODO 여기에서 TREE 형태 데이터의 접고, 펴는 것을 재구성한다.
203
283
  - 동적으로 서브항목을 fetch 하는 기능은 제공하지 않는다.
@@ -210,13 +290,16 @@ export class DataManipulator extends LitElement {
210
290
  const toplevelRecords = records.filter(record => !record.__depth__); /* __depth__ 가 설정되지 않았거나, 0 인 경우만 수집 */
211
291
  this.data = {
212
292
  ...this.data,
213
- records: [].concat(...toplevelRecords.map(record => this.traverseRefresh(record)))
293
+ records: [].concat(...toplevelRecords.map(record => this.traverseRefresh(record, forceExpandOrCollapse)))
214
294
  };
215
295
  }
216
- traverseRefresh(record) {
296
+ traverseRefresh(record, forceExpandOrCollapse) {
297
+ if (forceExpandOrCollapse !== undefined) {
298
+ record.__expanded__ = forceExpandOrCollapse;
299
+ }
217
300
  const { __expanded__, __children__ = [] } = record;
218
301
  if (__expanded__ && __children__.length > 0) {
219
- return [record].concat(...__children__.map(child => this.traverseRefresh(child)));
302
+ return [record].concat(...__children__.map(child => this.traverseRefresh(child, forceExpandOrCollapse)));
220
303
  }
221
304
  else {
222
305
  return [record];
@@ -230,10 +313,10 @@ __decorate([
230
313
  property({ type: Object })
231
314
  ], DataManipulator.prototype, "data", void 0);
232
315
  __decorate([
233
- property({ type: Object })
316
+ property({ type: Array })
234
317
  ], DataManipulator.prototype, "sorters", void 0);
235
318
  __decorate([
236
- property({ type: Object })
319
+ property({ type: Array })
237
320
  ], DataManipulator.prototype, "filters", void 0);
238
321
  __decorate([
239
322
  property({ type: Object })
@@ -1 +1 @@
1
- {"version":3,"file":"data-manipulator.js","sourceRoot":"","sources":["../../src/data-manipulator.ts"],"names":[],"mappings":"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","sourcesContent":["import { LitElement, PropertyValues } from 'lit'\nimport { property } from 'lit/decorators.js'\n\nimport { ZERO_CONFIG, ZERO_DATA } from './configure/zero-config'\nimport {\n ColumnConfig,\n FilterValue,\n GristConfig,\n GristData,\n GristRecord,\n PaginationConfig,\n SortersConfig\n} from './types'\n\nexport class DataManipulator extends LitElement {\n @property({ type: Object }) config: GristConfig = ZERO_CONFIG\n @property({ type: Object }) data: GristData = ZERO_DATA\n @property({ type: Object }) sorters: SortersConfig = []\n @property({ type: Object }) filters: FilterValue[] = []\n @property({ type: Object }) pagination: PaginationConfig = {}\n\n constructor() {\n super()\n\n this.addEventListener('select-record-change', e => {\n var {\n records: selectedRecords,\n added = [],\n removed = []\n } = (e as CustomEvent).detail as {\n records: GristRecord[]\n added: GristRecord[]\n removed: GristRecord[]\n }\n\n this.onSelectRecordChanged({\n selectedRecords,\n added,\n removed\n })\n })\n\n /* field change processing */\n this.addEventListener('field-change', e => {\n var { after, before, column, record, row } = (e as CustomEvent).detail as {\n after: any\n before: any\n column: ColumnConfig\n record: GristRecord\n row: number\n }\n\n this.onFieldChange({ after, before, column, record, row })\n })\n\n /* record reset processing */\n this.addEventListener('record-reset', e => {\n var { record, row } = (e as CustomEvent).detail as {\n record: GristRecord\n row: number\n }\n\n this.onRecordChanged(record['__origin__'], row, null)\n })\n\n /* tree processing */\n this.addEventListener('collapsed', (e: Event) => this.onCollapsed(e as CustomEvent))\n this.addEventListener('expanded', (e: Event) => this.onExpanded(e as CustomEvent))\n this.addEventListener('check-in-tree', (e: Event) => this.onCheckInTree(e as CustomEvent))\n }\n\n // updated(changes: PropertyValues<this>) {\n // if (changes.has('data')) {\n // this.refresh()\n // }\n // }\n\n onFieldChange({\n after,\n before,\n column,\n record,\n row\n }: {\n after: any\n before: any\n column: ColumnConfig\n record: GristRecord\n row: number\n }) {\n /* compare changes */\n if (after === before) {\n return\n }\n\n var validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!validation.call(this, after, before, record, column)) {\n return\n }\n }\n\n this.onRecordChanged({ [column.name]: after }, row, column)\n }\n\n onSelectRecordChanged({\n selectedRecords,\n added = [],\n removed = []\n }: {\n selectedRecords: GristRecord[]\n added: GristRecord[]\n removed: GristRecord[]\n }) {\n var { records } = this.data || {}\n var { selectable = false } = this.config.rows || {}\n\n if (!records || !selectable) {\n return\n }\n\n if (selectable && !selectable.multiple) {\n records.forEach(record => (record['__selected__'] = false))\n }\n\n if (selectedRecords) {\n records.forEach(record => (record['__selected__'] = false))\n selectedRecords.forEach(record => (record['__selected__'] = true))\n } else {\n removed.forEach(record => (record['__selected__'] = false))\n added.forEach(record => (record['__selected__'] = true))\n }\n\n this.requestUpdate()\n }\n\n onRecordChanged(\n recordData: GristRecord,\n row: number,\n column: ColumnConfig | null /* TODO column should be removed */\n ) {\n // TODO 오브젝트나 배열 타입인 경우 deepCompare 후에 변경 적용 여부를 결정한다.\n\n /* 빈 그리드로 시작한 경우, data 설정이 되어있지 않을 수 있다. */\n var records = this.data.records\n\n var beforeRecord = records[row]\n var afterRecord: GristRecord\n var wantToDelete = false\n var wantToAppend = false\n\n if (!recordData) {\n if (!beforeRecord) {\n /* recordData가 없고, beforeRecord도 없다면, 레코드 생성 중에 리셋된 경우이므로 아무것도 하지 않는다. */\n this.requestUpdate()\n return\n } else {\n /*\n * beforeRecord가 있는데, 빈데이타로 업데이트하고자 한다면,\n * 삭제하고자 하는 의도로 이해된다. (주의 필요)\n */\n if (beforeRecord['__dirty__'] == '+') {\n wantToDelete = true\n } else {\n afterRecord = {\n ...beforeRecord,\n __dirty__: '-'\n }\n }\n }\n } else {\n if (!beforeRecord) {\n /* 기존 레코드가 없는 경우에는 새로운 레코드가 생성된다 */\n afterRecord = {\n ...recordData,\n __dirty__: '+'\n }\n\n wantToAppend = true\n } else {\n let beforeDirty = beforeRecord['__dirty__']\n if (beforeDirty == '+') {\n /* 기존에 새로 생성된 레코드가 있었으며 계속 수정중이다.(레코드 레퍼런스를 유지해야한다) */\n afterRecord = Object.assign(beforeRecord, recordData, { __dirty__: '+' })\n } else {\n /* 기존에 레코드가 있었으며 계속 수정중이다.(레코드 레퍼런스를 유지해야한다) */\n afterRecord = Object.assign(beforeRecord, recordData, { __dirty__: 'M' })\n }\n }\n }\n\n if (wantToAppend) {\n records.push(afterRecord!)\n } else if (wantToDelete) {\n records.splice(row, 1)\n } else {\n records.splice(row, 1, afterRecord!)\n }\n\n this.dispatchEvent(\n new CustomEvent('record-change', {\n bubbles: true,\n composed: true,\n detail: {\n before: beforeRecord,\n after: afterRecord!,\n column,\n row\n }\n })\n )\n\n this.requestUpdate()\n }\n\n onCollapsed(e: CustomEvent) {\n const record = e.detail\n record.__expanded__ = false\n\n this.refresh()\n }\n\n onExpanded(e: CustomEvent) {\n const record = e.detail\n record.__expanded__ = true\n\n this.refresh()\n }\n\n onCheckInTree(e: CustomEvent) {\n const self = this\n\n function walkTreeCheckedUpdate(record: GristRecord, checked: 'checked' | 'unchecked') {\n const children = record.__children__\n\n children?.forEach(child => walkTreeCheckedUpdate(child, checked))\n record.__check_in_tree__ = checked\n record.__selected__ = checked == 'checked'\n }\n\n function updateCheckedAll(record: GristRecord) {\n /* 자식들의 checked 상태로 record의 checked 상태를 수정한다. */\n const children = record.__children__\n\n if (!children || children.length == 0) {\n return\n }\n\n children.forEach(child => updateCheckedAll(child))\n\n var checked: 'checked' | 'half-checked' | 'unchecked' | undefined\n\n children.forEach(child => {\n const { __check_in_tree__ } = child\n\n if (__check_in_tree__ == 'half-checked') {\n checked = 'half-checked'\n } else if (__check_in_tree__ == 'checked') {\n checked = checked == 'checked' || !checked ? 'checked' : 'half-checked'\n } else {\n checked = checked == 'unchecked' || !checked ? 'unchecked' : 'half-checked'\n }\n })\n\n record.__check_in_tree__ = checked\n record.__selected__ = checked == 'checked'\n }\n\n e.stopPropagation()\n\n const record = e.detail\n var checked = record.__check_in_tree__\n\n walkTreeCheckedUpdate(record, !checked || checked == 'unchecked' ? 'checked' : 'unchecked')\n const toplevelRecords = this.data.records.filter(\n record => !record.__depth__\n ) /* __depth__ 가 설정되지 않았거나, 0 인 경우만 수집 */\n\n toplevelRecords.forEach(record => updateCheckedAll(record))\n\n this.refresh()\n }\n\n /**\n * Forced internal data to be reflected on the screen\n * Data changing through a normal method is automatically reflected on the screen, so it is a method that does not need to be used in general.\n * Therefore, it will be deprecated.\n * @method\n */\n refresh() {\n /*\n - TODO 여기에서 TREE 형태 데이터의 접고, 펴는 것을 재구성한다.\n - 동적으로 서브항목을 fetch 하는 기능은 제공하지 않는다.\n\n 1. 빈배열에서 시작한다.\n 2. 기존 배열을 traverseRefresh하면서, collapsed 여부에 따라서, 자식의 포함여부를 결정하고 준비한 배열에 하나씩 추가한다.\n\n */\n const { records } = this.data\n const toplevelRecords = records.filter(\n record => !record.__depth__\n ) /* __depth__ 가 설정되지 않았거나, 0 인 경우만 수집 */\n this.data = {\n ...this.data,\n records: ([] as GristRecord[]).concat(...toplevelRecords.map(record => this.traverseRefresh(record)))\n }\n }\n\n private traverseRefresh(record: GristRecord): GristRecord[] {\n const { __expanded__, __children__ = [] } = record\n\n if (__expanded__ && __children__.length > 0) {\n return [record].concat(...__children__.map(child => this.traverseRefresh(child)))\n } else {\n return [record]\n }\n }\n}\n"]}
1
+ {"version":3,"file":"data-manipulator.js","sourceRoot":"","sources":["../../src/data-manipulator.ts"],"names":[],"mappings":"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","sourcesContent":["import { LitElement, PropertyValues } from 'lit'\nimport { property } from 'lit/decorators.js'\n\nimport { ZERO_CONFIG, ZERO_DATA } from './configure/zero-config'\nimport {\n ColumnConfig,\n FilterValue,\n GristConfig,\n GristData,\n GristRecord,\n PaginationConfig,\n SortersConfig\n} from './types'\n\nexport class DataManipulator extends LitElement {\n @property({ type: Object }) config: GristConfig = ZERO_CONFIG\n @property({ type: Object }) data: GristData = ZERO_DATA\n @property({ type: Array }) sorters: SortersConfig = []\n @property({ type: Array }) filters: FilterValue[] = []\n @property({ type: Object }) pagination: PaginationConfig = {}\n\n constructor() {\n super()\n\n this.addEventListener('select-record-change', e => {\n var {\n records: selectedRecords,\n added = [],\n removed = []\n } = (e as CustomEvent).detail as {\n records: GristRecord[]\n added: GristRecord[]\n removed: GristRecord[]\n }\n\n this.onSelectRecordChanged({\n selectedRecords,\n added,\n removed\n })\n })\n\n /* field change processing */\n this.addEventListener('field-change', e => {\n var { after, before, column, record, row } = (e as CustomEvent).detail as {\n after: any\n before: any\n column: ColumnConfig\n record: GristRecord\n row: number\n }\n\n this.onFieldChange({ after, before, column, record, row })\n })\n\n /* record reset processing */\n this.addEventListener('record-reset', e => {\n var { record, row } = (e as CustomEvent).detail as {\n record: GristRecord\n row: number\n }\n\n this.onRecordChanged(record['__origin__'], row, null)\n })\n\n /* tree processing */\n this.addEventListener('collapse-all', (e: Event) => this.collapseAll())\n this.addEventListener('expand-all', (e: Event) => this.expandAll())\n this.addEventListener('collapse-node', (e: Event) => this.collapseNode((e as CustomEvent).detail as GristRecord))\n this.addEventListener('expand-node', (e: Event) => this.expandNode((e as CustomEvent).detail as GristRecord))\n this.addEventListener('check-in-tree', (e: Event) => this.onCheckInTree(e as CustomEvent))\n\n this.addEventListener('add-sibling-node', (e: Event) =>\n this.addSiblingNode((e as CustomEvent).detail as GristRecord)\n )\n this.addEventListener('add-child-node', (e: Event) => this.addChildNode((e as CustomEvent).detail as GristRecord))\n }\n\n onFieldChange({\n after,\n before,\n column,\n record,\n row\n }: {\n after: any\n before: any\n column: ColumnConfig\n record: GristRecord\n row: number\n }) {\n /* compare changes */\n if (after === before) {\n return\n }\n\n var validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!validation.call(this, after, before, record, column)) {\n return\n }\n }\n\n this.onRecordChanged({ [column.name]: after }, row, column)\n }\n\n onSelectRecordChanged({\n selectedRecords,\n added = [],\n removed = []\n }: {\n selectedRecords: GristRecord[]\n added: GristRecord[]\n removed: GristRecord[]\n }) {\n var { records } = this.data || {}\n var { selectable = false } = this.config.rows || {}\n\n if (!records || !selectable) {\n return\n }\n\n if (selectable && !selectable.multiple) {\n records.forEach(record => (record['__selected__'] = false))\n }\n\n if (selectedRecords) {\n records.forEach(record => (record['__selected__'] = false))\n selectedRecords.forEach(record => (record['__selected__'] = true))\n } else {\n removed.forEach(record => (record['__selected__'] = false))\n added.forEach(record => (record['__selected__'] = true))\n }\n\n this.requestUpdate()\n }\n\n onRecordChanged(\n recordData: GristRecord,\n row: number,\n column: ColumnConfig | null /* TODO column should be removed */\n ) {\n // TODO 오브젝트나 배열 타입인 경우 deepCompare 후에 변경 적용 여부를 결정한다.\n\n /* 빈 그리드로 시작한 경우, data 설정이 되어있지 않을 수 있다. */\n var records = this.data.records\n\n var beforeRecord = records[row]\n var afterRecord: GristRecord\n var wantToDelete = false\n var wantToAppend = false\n\n if (!recordData) {\n if (!beforeRecord) {\n /* recordData가 없고, beforeRecord도 없다면, 레코드 생성 중에 리셋된 경우이므로 아무것도 하지 않는다. */\n this.requestUpdate()\n return\n } else {\n /*\n * beforeRecord가 있는데, 빈데이타로 업데이트하고자 한다면,\n * 삭제하고자 하는 의도로 이해된다. (주의 필요)\n */\n if (beforeRecord['__dirty__'] == '+') {\n wantToDelete = true\n } else {\n afterRecord = {\n ...beforeRecord,\n __dirty__: '-'\n }\n }\n }\n } else {\n if (!beforeRecord) {\n /* 기존 레코드가 없는 경우에는 새로운 레코드가 생성된다 */\n afterRecord = {\n ...recordData,\n __dirty__: '+'\n }\n\n wantToAppend = true\n } else {\n let beforeDirty = beforeRecord['__dirty__']\n if (beforeDirty == '+') {\n /* 기존에 새로 생성된 레코드가 있었으며 계속 수정중이다.(레코드 레퍼런스를 유지해야한다) */\n afterRecord = Object.assign(beforeRecord, recordData, { __dirty__: '+' })\n } else {\n /* 기존에 레코드가 있었으며 계속 수정중이다.(레코드 레퍼런스를 유지해야한다) */\n afterRecord = Object.assign(beforeRecord, recordData, { __dirty__: 'M' })\n }\n }\n }\n\n if (wantToAppend) {\n records.push(afterRecord!)\n } else if (wantToDelete) {\n records.splice(row, 1)\n } else {\n records.splice(row, 1, afterRecord!)\n }\n\n this.dispatchEvent(\n new CustomEvent('record-change', {\n bubbles: true,\n composed: true,\n detail: {\n before: beforeRecord,\n after: afterRecord!,\n column,\n row\n }\n })\n )\n\n this.requestUpdate()\n }\n\n collapseAll() {\n this.refresh(false)\n }\n\n expandAll() {\n this.refresh(true)\n }\n\n collapseNode(record: GristRecord) {\n record.__expanded__ = false\n\n this.refresh()\n }\n\n expandNode(record: GristRecord) {\n record.__expanded__ = true\n\n this.refresh()\n }\n\n // onCollapse(e: CustomEvent) {\n // const record = e.detail as GristRecord\n // record.__expanded__ = false\n\n // this.refresh()\n // }\n\n // onExpand(e: CustomEvent) {\n // const record = e.detail as GristRecord\n // record.__expanded__ = true\n\n // this.refresh()\n // }\n\n addSiblingNode(record: GristRecord) {\n const { records } = this.data\n const toplevelRecords = records.filter(\n record => !record.__depth__\n ) /* __depth__ 가 설정되지 않았거나, 0 인 경우만 수집 */\n\n const { __depth__ } = record as GristRecord\n\n function findParent(record: GristRecord, parent?: GristRecord): GristRecord | undefined {\n var children = (parent ? parent.__children__ || [] : toplevelRecords) as GristRecord[]\n\n if (children.find(child => child === record)) {\n return parent\n } else {\n for (let child of children) {\n const found = findParent(record, child)\n if (found) {\n return found\n }\n }\n }\n }\n\n const parent = findParent(record)\n\n const sibling = {\n __depth__,\n __dirty__: '+'\n } as GristRecord\n\n if (parent) {\n const { id } = parent as GristRecord\n\n sibling.parent = { id }\n\n if (!parent.__children__) {\n parent.__children__ = [sibling]\n } else {\n let index = parent.__children__.indexOf(record)\n\n if (index !== -1) {\n parent.__children__ = [\n ...parent.__children__.slice(0, index + 1),\n sibling,\n ...parent.__children__.slice(index + 1)\n ]\n } else {\n parent.__children__ = [...parent.__children__, sibling]\n }\n }\n\n parent.__expanded__ = true\n } else {\n this.data.records = [...toplevelRecords, sibling]\n }\n\n this.refresh()\n }\n\n addChildNode(record: GristRecord) {\n const { id: parentId, __children__, __depth__ } = record as GristRecord\n const child = {\n parent: {\n id: parentId\n },\n __depth__: (__depth__ || 0) + 1,\n __dirty__: '+'\n }\n\n if (!record.__children__) {\n record.__children__ = [child]\n } else {\n record.__children__.unshift(child)\n }\n\n record.__expanded__ = true\n\n // this.requestUpdate()\n\n this.refresh()\n }\n\n onCheckInTree(e: CustomEvent) {\n function walkTreeCheckedUpdate(record: GristRecord, checked: 'checked' | 'unchecked') {\n const children = record.__children__\n\n children?.forEach(child => walkTreeCheckedUpdate(child, checked))\n record.__check_in_tree__ = checked\n record.__selected__ = checked == 'checked'\n }\n\n function updateCheckedAll(record: GristRecord) {\n /* 자식들의 checked 상태로 record의 checked 상태를 수정한다. */\n const children = record.__children__\n\n if (!children || children.length == 0) {\n return\n }\n\n children.forEach(child => updateCheckedAll(child))\n\n var checked: 'checked' | 'half-checked' | 'unchecked' | undefined =\n record.__check_in_tree__ == 'checked' ? 'checked' : undefined\n\n children.forEach(child => {\n const { __check_in_tree__ } = child\n\n if (__check_in_tree__ == 'half-checked') {\n checked = 'half-checked'\n } else if (__check_in_tree__ == 'checked') {\n checked = checked == 'checked' ? 'checked' : 'half-checked'\n } else {\n checked = checked == 'unchecked' || !checked ? 'unchecked' : 'half-checked'\n }\n })\n\n record.__check_in_tree__ = checked\n record.__selected__ = checked == 'checked'\n }\n\n e.stopPropagation()\n\n const record = e.detail\n var checked = record.__check_in_tree__\n\n walkTreeCheckedUpdate(record, !checked || checked == 'unchecked' ? 'checked' : 'unchecked')\n const toplevelRecords = this.data.records.filter(\n record => !record.__depth__\n ) /* __depth__ 가 설정되지 않았거나, 0 인 경우만 수집 */\n\n toplevelRecords.forEach(record => updateCheckedAll(record))\n\n this.refresh()\n }\n\n /**\n * Forced internal data to be reflected on the screen\n * Data changing through a normal method is automatically reflected on the screen, so it is a method that does not need to be used in general.\n * Therefore, it will be deprecated.\n * @method\n */\n refresh(forceExpandOrCollapse?: boolean) {\n /*\n - TODO 여기에서 TREE 형태 데이터의 접고, 펴는 것을 재구성한다.\n - 동적으로 서브항목을 fetch 하는 기능은 제공하지 않는다.\n\n 1. 빈배열에서 시작한다.\n 2. 기존 배열을 traverseRefresh하면서, collapsed 여부에 따라서, 자식의 포함여부를 결정하고 준비한 배열에 하나씩 추가한다.\n\n */\n const { records } = this.data\n const toplevelRecords = records.filter(\n record => !record.__depth__\n ) /* __depth__ 가 설정되지 않았거나, 0 인 경우만 수집 */\n this.data = {\n ...this.data,\n records: ([] as GristRecord[]).concat(\n ...toplevelRecords.map(record => this.traverseRefresh(record, forceExpandOrCollapse))\n )\n }\n }\n\n private traverseRefresh(record: GristRecord, forceExpandOrCollapse?: boolean): GristRecord[] {\n if (forceExpandOrCollapse !== undefined) {\n record.__expanded__ = forceExpandOrCollapse\n }\n\n const { __expanded__, __children__ = [] } = record\n\n if (__expanded__ && __children__.length > 0) {\n return [record].concat(...__children__.map(child => this.traverseRefresh(child, forceExpandOrCollapse)))\n } else {\n return [record]\n }\n }\n}\n"]}
@@ -0,0 +1,6 @@
1
+ import './ox-input-tree';
2
+ import { OxGristEditor } from './ox-grist-editor.js';
3
+ export declare class OxGristEditorTree extends OxGristEditor {
4
+ static styles: import("lit").CSSResult[];
5
+ get editorTemplate(): import("lit").TemplateResult<1>;
6
+ }
@@ -0,0 +1,27 @@
1
+ import { __decorate } from "tslib";
2
+ import './ox-input-tree';
3
+ import { html, css } from 'lit';
4
+ import { customElement } from 'lit/decorators.js';
5
+ import { OxGristEditor } from './ox-grist-editor.js';
6
+ let OxGristEditorTree = class OxGristEditorTree extends OxGristEditor {
7
+ get editorTemplate() {
8
+ var { selectable } = this.column.record.options || {};
9
+ return html `<ox-input-tree .value=${this.value} .record=${this.record} ?selectable=${selectable}></ox-input-tree>`;
10
+ }
11
+ };
12
+ OxGristEditorTree.styles = [
13
+ css `
14
+ :host {
15
+ flex: 1;
16
+ }
17
+
18
+ ox-input-tree {
19
+ flex: 1;
20
+ }
21
+ `
22
+ ];
23
+ OxGristEditorTree = __decorate([
24
+ customElement('ox-grist-editor-tree')
25
+ ], OxGristEditorTree);
26
+ export { OxGristEditorTree };
27
+ //# sourceMappingURL=ox-grist-editor-tree.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ox-grist-editor-tree.js","sourceRoot":"","sources":["../../../src/editors/ox-grist-editor-tree.ts"],"names":[],"mappings":";AAAA,OAAO,iBAAiB,CAAA;AAExB,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAS,MAAM,mBAAmB,CAAA;AAExD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAG7C,IAAM,iBAAiB,GAAvB,MAAM,iBAAkB,SAAQ,aAAa;IAalD,IAAI,cAAc;QAChB,IAAI,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAA;QAErD,OAAO,IAAI,CAAA,yBAAyB,IAAI,CAAC,KAAK,YAAY,IAAI,CAAC,MAAM,gBAAgB,UAAU,mBAAmB,CAAA;IACpH,CAAC;;AAhBM,wBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;KAQF;CACF,AAVY,CAUZ;AAXU,iBAAiB;IAD7B,aAAa,CAAC,sBAAsB,CAAC;GACzB,iBAAiB,CAkB7B","sourcesContent":["import './ox-input-tree'\n\nimport { html, css } from 'lit'\nimport { customElement, query } from 'lit/decorators.js'\n\nimport { OxGristEditor } from './ox-grist-editor.js'\n\n@customElement('ox-grist-editor-tree')\nexport class OxGristEditorTree extends OxGristEditor {\n static styles = [\n css`\n :host {\n flex: 1;\n }\n\n ox-input-tree {\n flex: 1;\n }\n `\n ]\n\n get editorTemplate() {\n var { selectable } = this.column.record.options || {}\n\n return html`<ox-input-tree .value=${this.value} .record=${this.record} ?selectable=${selectable}></ox-input-tree>`\n }\n}\n"]}
@@ -12,6 +12,7 @@ export declare class OxGristEditor extends LitElement {
12
12
  protected _dirtyValue?: any;
13
13
  render(): import("lit").TemplateResult<1>;
14
14
  get editor(): HTMLElement | null;
15
+ get directEditable(): boolean;
15
16
  firstUpdated(): Promise<void>;
16
17
  select(): void;
17
18
  focus(): void;
@@ -78,6 +78,9 @@ let OxGristEditor = class OxGristEditor extends LitElement {
78
78
  get editor() {
79
79
  return this.renderRoot.firstElementChild;
80
80
  }
81
+ get directEditable() {
82
+ return true;
83
+ }
81
84
  async firstUpdated() {
82
85
  var _a, _b;
83
86
  this.renderRoot.addEventListener('change', this._onchange.bind(this));
@@ -1 +1 @@
1
- {"version":3,"file":"ox-grist-editor.js","sourceRoot":"","sources":["../../../src/editors/ox-grist-editor.ts"],"names":[],"mappings":"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","sourcesContent":["import { css, html, LitElement, PropertyValues } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config'\nimport { DataGridField } from '../data-grid/data-grid-field'\nimport { ColumnConfig, GristRecord } from '../types'\nimport { getDefaultValue } from '../value-generator'\n\nconst STYLE = css`\n :host {\n display: flex;\n\n align-items: center;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background-color: transparent;\n\n overflow: hidden;\n justify-content: var(--data-grid-field-justify-content, flex-start);\n }\n\n :host > * {\n display: flex;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background-color: transparent;\n\n box-sizing: border-box;\n\n align-items: center;\n }\n\n :host > style {\n display: none;\n }\n\n :host > input[type='checkbox'] {\n width: initial;\n margin: 0;\n }\n *:focus {\n outline: none;\n }\n\n input[type='file'] {\n opacity: 0%;\n }\n\n @media screen and (max-width: 460px) {\n :host > * {\n border: initial;\n background-color: initial;\n }\n\n *:focus {\n outline: none;\n }\n\n input,\n select,\n textarea {\n font-size: 16px;\n }\n }\n`\n\n@customElement('ox-grist-editor')\nexport class OxGristEditor extends LitElement {\n static styles = [STYLE]\n\n @property({ type: Object }) value?: any\n @property({ type: Object }) column: ColumnConfig = ZERO_COLUMN\n @property({ type: Object }) record: GristRecord = ZERO_RECORD\n @property({ type: Number }) rowIndex?: number\n @property({ type: Object }) field?: DataGridField\n @property({ type: Number }) row?: number\n\n protected _dirtyValue?: any\n\n render() {\n return this.editorTemplate\n }\n\n get editor(): HTMLElement | null {\n return this.renderRoot.firstElementChild as HTMLElement\n }\n\n async firstUpdated() {\n this.renderRoot.addEventListener('change', this._onchange.bind(this))\n this.renderRoot.addEventListener('focusout', this._onfocusout.bind(this))\n this.addEventListener('click', this._onclick.bind(this))\n this.addEventListener('dblclick', this._ondblclick.bind(this))\n this.addEventListener('keydown', this._onkeydown.bind(this))\n\n /* editor mode 인 경우의 마우스 움직임이, grist-body의 이벤트 처리에 의해서 에디터를 리셋시킬 수 있으므로, 이벤트 전파를 막는다. */\n this.addEventListener('mousedown', (e: Event) => e.stopPropagation())\n this.addEventListener('mousemove', (e: Event) => e.stopPropagation())\n this.addEventListener('mouseup', (e: Event) => e.stopPropagation())\n\n const { name = '' } = this.column\n const { align, defaultValue } = this.column.record\n\n if (align) {\n this.style.textAlign = align\n this.style.textAlignLast = align /* for select */\n }\n\n var currentValue = this.record[name]\n\n if (typeof currentValue == 'undefined' && defaultValue) {\n currentValue = getDefaultValue(defaultValue, this.record)\n }\n\n // 입력을 위한 키를 누르면서 편집모드가 될때는 누른 키가 처음에 입력되도록, enter 같은 것을 눌러서 편집모드가 되면 현재 값으로 편집모드 전환\n const editorValue = this.field?.valueWithEdit ? this.field.valueWithEdit : this.formatForEditor(currentValue)\n this.value = this._dirtyValue = this.field?.type === 'number' ? Number(editorValue) : editorValue\n\n requestAnimationFrame(() => {\n this.focus()\n this.select()\n })\n }\n\n select() {\n const editor = this.editor\n if ((editor as HTMLInputElement)?.select && !this.field?.valueWithEdit) {\n return (editor as HTMLInputElement).select()\n }\n }\n\n focus() {\n const editor = this.editor\n if (editor) {\n editor.focus()\n }\n }\n\n formatForEditor(value: any): any {\n return value == null ? '' : value\n }\n\n formatFromEditor(e: Event): any {\n return (e.target as HTMLInputElement).value\n }\n\n _onfocusout() {\n // paste시 field-change는 Body에서 하므로 X\n if (this.field?.isWorking === true) return\n\n const { name = '' } = this.column\n var currentValue = this.record[name] || ''\n\n if (this._dirtyValue !== currentValue) {\n this.dispatchEvent(\n new CustomEvent('field-change', {\n bubbles: true,\n composed: true,\n detail: {\n before: currentValue,\n after: this._dirtyValue,\n column: this.column,\n record: this.record,\n row: this.row\n }\n })\n )\n }\n }\n\n _onchange(e: Event): void {\n e.stopPropagation()\n\n this._dirtyValue = this.formatFromEditor(e)\n }\n\n _onkeydown(e: Event): void {}\n\n _onclick(e: Event): void {\n e.stopPropagation()\n }\n\n _ondblclick(e: Event): void {\n e.stopPropagation()\n }\n\n get editorTemplate() {\n return html``\n }\n}\n"]}
1
+ {"version":3,"file":"ox-grist-editor.js","sourceRoot":"","sources":["../../../src/editors/ox-grist-editor.ts"],"names":[],"mappings":"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","sourcesContent":["import { css, html, LitElement, PropertyValues } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { ZERO_COLUMN, ZERO_RECORD } from '../configure/zero-config'\nimport { DataGridField } from '../data-grid/data-grid-field'\nimport { ColumnConfig, GristRecord } from '../types'\nimport { getDefaultValue } from '../value-generator'\n\nconst STYLE = css`\n :host {\n display: flex;\n\n align-items: center;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background-color: transparent;\n\n overflow: hidden;\n justify-content: var(--data-grid-field-justify-content, flex-start);\n }\n\n :host > * {\n display: flex;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background-color: transparent;\n\n box-sizing: border-box;\n\n align-items: center;\n }\n\n :host > style {\n display: none;\n }\n\n :host > input[type='checkbox'] {\n width: initial;\n margin: 0;\n }\n *:focus {\n outline: none;\n }\n\n input[type='file'] {\n opacity: 0%;\n }\n\n @media screen and (max-width: 460px) {\n :host > * {\n border: initial;\n background-color: initial;\n }\n\n *:focus {\n outline: none;\n }\n\n input,\n select,\n textarea {\n font-size: 16px;\n }\n }\n`\n\n@customElement('ox-grist-editor')\nexport class OxGristEditor extends LitElement {\n static styles = [STYLE]\n\n @property({ type: Object }) value?: any\n @property({ type: Object }) column: ColumnConfig = ZERO_COLUMN\n @property({ type: Object }) record: GristRecord = ZERO_RECORD\n @property({ type: Number }) rowIndex?: number\n @property({ type: Object }) field?: DataGridField\n @property({ type: Number }) row?: number\n\n protected _dirtyValue?: any\n\n render() {\n return this.editorTemplate\n }\n\n get editor(): HTMLElement | null {\n return this.renderRoot.firstElementChild as HTMLElement\n }\n\n get directEditable() {\n return true\n }\n\n async firstUpdated() {\n this.renderRoot.addEventListener('change', this._onchange.bind(this))\n this.renderRoot.addEventListener('focusout', this._onfocusout.bind(this))\n this.addEventListener('click', this._onclick.bind(this))\n this.addEventListener('dblclick', this._ondblclick.bind(this))\n this.addEventListener('keydown', this._onkeydown.bind(this))\n\n /* editor mode 인 경우의 마우스 움직임이, grist-body의 이벤트 처리에 의해서 에디터를 리셋시킬 수 있으므로, 이벤트 전파를 막는다. */\n this.addEventListener('mousedown', (e: Event) => e.stopPropagation())\n this.addEventListener('mousemove', (e: Event) => e.stopPropagation())\n this.addEventListener('mouseup', (e: Event) => e.stopPropagation())\n\n const { name = '' } = this.column\n const { align, defaultValue } = this.column.record\n\n if (align) {\n this.style.textAlign = align\n this.style.textAlignLast = align /* for select */\n }\n\n var currentValue = this.record[name]\n\n if (typeof currentValue == 'undefined' && defaultValue) {\n currentValue = getDefaultValue(defaultValue, this.record)\n }\n\n // 입력을 위한 키를 누르면서 편집모드가 될때는 누른 키가 처음에 입력되도록, enter 같은 것을 눌러서 편집모드가 되면 현재 값으로 편집모드 전환\n const editorValue = this.field?.valueWithEdit ? this.field.valueWithEdit : this.formatForEditor(currentValue)\n this.value = this._dirtyValue = this.field?.type === 'number' ? Number(editorValue) : editorValue\n\n requestAnimationFrame(() => {\n this.focus()\n this.select()\n })\n }\n\n select() {\n const editor = this.editor\n if ((editor as HTMLInputElement)?.select && !this.field?.valueWithEdit) {\n return (editor as HTMLInputElement).select()\n }\n }\n\n focus() {\n const editor = this.editor\n if (editor) {\n editor.focus()\n }\n }\n\n formatForEditor(value: any): any {\n return value == null ? '' : value\n }\n\n formatFromEditor(e: Event): any {\n return (e.target as HTMLInputElement).value\n }\n\n _onfocusout() {\n // paste시 field-change는 Body에서 하므로 X\n if (this.field?.isWorking === true) return\n\n const { name = '' } = this.column\n var currentValue = this.record[name] || ''\n\n if (this._dirtyValue !== currentValue) {\n this.dispatchEvent(\n new CustomEvent('field-change', {\n bubbles: true,\n composed: true,\n detail: {\n before: currentValue,\n after: this._dirtyValue,\n column: this.column,\n record: this.record,\n row: this.row\n }\n })\n )\n }\n }\n\n _onchange(e: Event): void {\n e.stopPropagation()\n\n this._dirtyValue = this.formatFromEditor(e)\n }\n\n _onkeydown(e: Event): void {}\n\n _onclick(e: Event): void {\n e.stopPropagation()\n }\n\n _ondblclick(e: Event): void {\n e.stopPropagation()\n }\n\n get editorTemplate() {\n return html``\n }\n}\n"]}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+ import { PropertyValues } from 'lit';
5
+ import { OxFormField } from '@operato/input';
6
+ import { GristRecord } from '../types';
7
+ export declare class OxInputTree extends OxFormField {
8
+ static styles: import("lit").CSSResult;
9
+ record: GristRecord;
10
+ selectable?: boolean;
11
+ private checked?;
12
+ private expanded?;
13
+ input: HTMLInputElement;
14
+ render(): import("lit").TemplateResult<1>;
15
+ updated(changes: PropertyValues<this>): void;
16
+ focus(): void;
17
+ select(): void;
18
+ onClickCheckbox(e: MouseEvent): void;
19
+ onClickExpander(e: MouseEvent): void;
20
+ }
@@ -0,0 +1,221 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+ import { __decorate } from "tslib";
5
+ import { css, html, nothing } from 'lit';
6
+ import { customElement, property, query, state } from 'lit/decorators.js';
7
+ import { ifDefined } from 'lit/directives/if-defined.js';
8
+ import { OxFormField } from '@operato/input';
9
+ let OxInputTree = class OxInputTree extends OxFormField {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.expanded = false;
13
+ }
14
+ render() {
15
+ var { __children__ } = this.record;
16
+ const expandable = __children__ && __children__.length > 0;
17
+ return html `
18
+ <div wrap>
19
+ ${expandable
20
+ ? html `
21
+ <span
22
+ expander
23
+ @click=${this.onClickExpander.bind(this)}
24
+ ?expanded=${this.expanded}
25
+ ?collapsed=${!this.expanded}
26
+ ></span>
27
+ `
28
+ : html `<span expander></span>`}
29
+ ${this.selectable
30
+ ? html ` <span checkbox @click=${this.onClickCheckbox.bind(this)} checked=${ifDefined(this.checked)}></span>`
31
+ : nothing}
32
+
33
+ <span label
34
+ ><input
35
+ value=${ifDefined(this.value)}
36
+ @change=${(e) => {
37
+ e.stopPropagation();
38
+ this.value = e.target.value;
39
+ this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true }));
40
+ }}
41
+ focus
42
+ /></span>
43
+
44
+ <!-- <span label>${this.value}</span> -->
45
+ </div>
46
+ `;
47
+ }
48
+ updated(changes) {
49
+ var { __depth__, __check_in_tree__, __expanded__ } = this.record;
50
+ this.checked = __check_in_tree__;
51
+ this.expanded = __expanded__;
52
+ this.style.setProperty('--tree-depth', String(__depth__));
53
+ }
54
+ focus() {
55
+ this.input.focus();
56
+ }
57
+ select() {
58
+ this.input.select();
59
+ }
60
+ onClickCheckbox(e) {
61
+ e.stopPropagation();
62
+ this.dispatchEvent(new CustomEvent('check-in-tree', {
63
+ bubbles: true,
64
+ composed: true,
65
+ detail: this.record
66
+ }));
67
+ this.requestUpdate();
68
+ }
69
+ onClickExpander(e) {
70
+ e.stopPropagation();
71
+ this.dispatchEvent(new CustomEvent(this.record.__expanded__ ? 'collapse-node' : 'expand-node', {
72
+ bubbles: true,
73
+ composed: true,
74
+ detail: this.record
75
+ }));
76
+ this.requestUpdate();
77
+ }
78
+ };
79
+ OxInputTree.styles = css `
80
+ :host {
81
+ overflow: hidden;
82
+ }
83
+
84
+ div[wrap] {
85
+ flex: 1;
86
+
87
+ position: relative;
88
+
89
+ display: flex;
90
+ align-items: center;
91
+ gap: 6px;
92
+
93
+ padding-left: calc(var(--tree-depth, 0) * 18px);
94
+ }
95
+
96
+ span[expander] {
97
+ display: inline-block;
98
+ vertical-align: middle;
99
+ width: 12px;
100
+ height: 20px;
101
+ cursor: pointer;
102
+ position: relative;
103
+ }
104
+
105
+ span[expander][collapsed]::before {
106
+ position: absolute;
107
+ top: 50%;
108
+ left: 50%;
109
+ transform: translate(-25%, -50%) rotate(-90deg);
110
+ content: ' ';
111
+ border: 5px solid transparent;
112
+ border-top: 5px solid var(--primary-color, #1890ff);
113
+ }
114
+
115
+ span[expander][expanded]::before {
116
+ position: absolute;
117
+ top: 50%;
118
+ left: 50%;
119
+ transform: translate(-50%, -25%);
120
+ content: ' ';
121
+ border: 5px solid transparent;
122
+ border-top: 5px solid var(--primary-color, #1890ff);
123
+ }
124
+
125
+ span[checkbox] {
126
+ display: inline-block;
127
+ vertical-align: middle;
128
+ width: 12px;
129
+ height: 20px;
130
+ cursor: pointer;
131
+ position: relative;
132
+ }
133
+
134
+ span[checkbox]::before {
135
+ cursor: pointer;
136
+ position: absolute;
137
+ top: 50%;
138
+ left: 50%;
139
+ transform: translate(-50%, -50%);
140
+ content: ' ';
141
+ display: block;
142
+ width: 10px;
143
+ height: 10px;
144
+ border: 1px solid var(--primary-color, #1890ff);
145
+ border-radius: 2px;
146
+ }
147
+
148
+ span[checkbox][checked='checked']::before {
149
+ background-color: var(--primary-color, #1890ff);
150
+ border-color: var(--primary-color, #1890ff);
151
+ }
152
+
153
+ span[checkbox][checked='checked']::after {
154
+ position: absolute;
155
+ content: ' ';
156
+ display: block;
157
+ top: 50%;
158
+ left: 50%;
159
+ width: 3px;
160
+ height: 7px;
161
+ border: 2px solid #fff;
162
+ border-top: none;
163
+ border-left: none;
164
+ -webkit-transform: translate(-50%, -50%) rotate(45deg);
165
+ -ms-transform: translate(-50%, -50%) rotate(45deg);
166
+ transform: translate(-50%, -50%) rotate(45deg);
167
+ }
168
+
169
+ span[checkbox][checked='half-checked']::before {
170
+ background-color: var(--primary-color, #1890ff);
171
+ border-color: var(--primary-color, #1890ff);
172
+ }
173
+
174
+ span[checkbox][checked='half-checked']::after {
175
+ position: absolute;
176
+ content: ' ';
177
+ display: block;
178
+ top: 50%;
179
+ left: 50%;
180
+ transform: translate(-50%, -50%);
181
+ width: 10px;
182
+ height: 2px;
183
+ background-color: #fff;
184
+ }
185
+
186
+ span[label] {
187
+ flex: 1;
188
+ }
189
+
190
+ input {
191
+ width: 100%;
192
+ height: 100%;
193
+ border: 0;
194
+ background-color: transparent;
195
+ box-sizing: border-box;
196
+ }
197
+
198
+ input:focus {
199
+ outline: none;
200
+ }
201
+ `;
202
+ __decorate([
203
+ property({ type: Object })
204
+ ], OxInputTree.prototype, "record", void 0);
205
+ __decorate([
206
+ property({ type: Boolean })
207
+ ], OxInputTree.prototype, "selectable", void 0);
208
+ __decorate([
209
+ state()
210
+ ], OxInputTree.prototype, "checked", void 0);
211
+ __decorate([
212
+ state()
213
+ ], OxInputTree.prototype, "expanded", void 0);
214
+ __decorate([
215
+ query('input')
216
+ ], OxInputTree.prototype, "input", void 0);
217
+ OxInputTree = __decorate([
218
+ customElement('ox-input-tree')
219
+ ], OxInputTree);
220
+ export { OxInputTree };
221
+ //# sourceMappingURL=ox-input-tree.js.map