@operato/data-grist 9.0.0-beta.56 → 9.0.0-beta.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +3 -3
- package/dist/src/accumulator/accumulator.d.ts +0 -2
- package/dist/src/accumulator/accumulator.js +0 -42
- package/dist/src/accumulator/accumulator.js.map +0 -1
- package/dist/src/configure/column-builder.d.ts +0 -2
- package/dist/src/configure/column-builder.js +0 -99
- package/dist/src/configure/column-builder.js.map +0 -1
- package/dist/src/configure/config-builder.d.ts +0 -2
- package/dist/src/configure/config-builder.js +0 -36
- package/dist/src/configure/config-builder.js.map +0 -1
- package/dist/src/configure/filters-option-builder.d.ts +0 -2
- package/dist/src/configure/filters-option-builder.js +0 -7
- package/dist/src/configure/filters-option-builder.js.map +0 -1
- package/dist/src/configure/imex-option-builder.d.ts +0 -2
- package/dist/src/configure/imex-option-builder.js +0 -4
- package/dist/src/configure/imex-option-builder.js.map +0 -1
- package/dist/src/configure/list-option-builder.d.ts +0 -2
- package/dist/src/configure/list-option-builder.js +0 -8
- package/dist/src/configure/list-option-builder.js.map +0 -1
- package/dist/src/configure/rows-option-builder.d.ts +0 -2
- package/dist/src/configure/rows-option-builder.js +0 -26
- package/dist/src/configure/rows-option-builder.js.map +0 -1
- package/dist/src/configure/tree-option-builder.d.ts +0 -2
- package/dist/src/configure/tree-option-builder.js +0 -18
- package/dist/src/configure/tree-option-builder.js.map +0 -1
- package/dist/src/configure/zero-config.d.ts +0 -23
- package/dist/src/configure/zero-config.js +0 -59
- package/dist/src/configure/zero-config.js.map +0 -1
- package/dist/src/const.d.ts +0 -1
- package/dist/src/const.js +0 -2
- package/dist/src/const.js.map +0 -1
- package/dist/src/data-card/data-card-field.d.ts +0 -11
- package/dist/src/data-card/data-card-field.js +0 -106
- package/dist/src/data-card/data-card-field.js.map +0 -1
- package/dist/src/data-card/data-card-gutter-menu.d.ts +0 -2
- package/dist/src/data-card/data-card-gutter-menu.js +0 -96
- package/dist/src/data-card/data-card-gutter-menu.js.map +0 -1
- package/dist/src/data-card/data-card-gutter.d.ts +0 -12
- package/dist/src/data-card/data-card-gutter.js +0 -116
- package/dist/src/data-card/data-card-gutter.js.map +0 -1
- package/dist/src/data-card/data-card.d.ts +0 -19
- package/dist/src/data-card/data-card.js +0 -149
- package/dist/src/data-card/data-card.js.map +0 -1
- package/dist/src/data-card/event-handlers/record-card-click-handler.d.ts +0 -7
- package/dist/src/data-card/event-handlers/record-card-click-handler.js +0 -29
- package/dist/src/data-card/event-handlers/record-card-click-handler.js.map +0 -1
- package/dist/src/data-card/event-handlers/record-card-dblclick-handler.d.ts +0 -7
- package/dist/src/data-card/event-handlers/record-card-dblclick-handler.js +0 -29
- package/dist/src/data-card/event-handlers/record-card-dblclick-handler.js.map +0 -1
- package/dist/src/data-card/record-card.d.ts +0 -23
- package/dist/src/data-card/record-card.js +0 -288
- package/dist/src/data-card/record-card.js.map +0 -1
- package/dist/src/data-consumer.d.ts +0 -10
- package/dist/src/data-consumer.js +0 -2
- package/dist/src/data-consumer.js.map +0 -1
- package/dist/src/data-grid/data-grid-accum-field.d.ts +0 -16
- package/dist/src/data-grid/data-grid-accum-field.js +0 -133
- package/dist/src/data-grid/data-grid-accum-field.js.map +0 -1
- package/dist/src/data-grid/data-grid-body-style.d.ts +0 -1
- package/dist/src/data-grid/data-grid-body-style.js +0 -99
- package/dist/src/data-grid/data-grid-body-style.js.map +0 -1
- package/dist/src/data-grid/data-grid-body.d.ts +0 -52
- package/dist/src/data-grid/data-grid-body.js +0 -660
- package/dist/src/data-grid/data-grid-body.js.map +0 -1
- package/dist/src/data-grid/data-grid-field.d.ts +0 -25
- package/dist/src/data-grid/data-grid-field.js +0 -263
- package/dist/src/data-grid/data-grid-field.js.map +0 -1
- package/dist/src/data-grid/data-grid-footer.d.ts +0 -11
- package/dist/src/data-grid/data-grid-footer.js +0 -120
- package/dist/src/data-grid/data-grid-footer.js.map +0 -1
- package/dist/src/data-grid/data-grid-header.d.ts +0 -29
- package/dist/src/data-grid/data-grid-header.js +0 -531
- package/dist/src/data-grid/data-grid-header.js.map +0 -1
- package/dist/src/data-grid/data-grid.d.ts +0 -36
- package/dist/src/data-grid/data-grid.js +0 -260
- package/dist/src/data-grid/data-grid.js.map +0 -1
- package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.d.ts +0 -7
- package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js +0 -57
- package/dist/src/data-grid/event-handlers/data-grid-body-click-handler.js.map +0 -1
- package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.d.ts +0 -7
- package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js +0 -25
- package/dist/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.js.map +0 -1
- package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.d.ts +0 -7
- package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js +0 -34
- package/dist/src/data-grid/event-handlers/data-grid-body-dblclick-handler.js.map +0 -1
- package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.d.ts +0 -7
- package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js +0 -19
- package/dist/src/data-grid/event-handlers/data-grid-body-focus-change-handler.js.map +0 -1
- package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.d.ts +0 -7
- package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.js +0 -226
- package/dist/src/data-grid/event-handlers/data-grid-body-keydown-handler.js.map +0 -1
- package/dist/src/data-grist.d.ts +0 -367
- package/dist/src/data-grist.js +0 -1064
- package/dist/src/data-grist.js.map +0 -1
- package/dist/src/data-list/data-list-field.d.ts +0 -11
- package/dist/src/data-list/data-list-field.js +0 -95
- package/dist/src/data-list/data-list-field.js.map +0 -1
- package/dist/src/data-list/data-list-gutter.d.ts +0 -12
- package/dist/src/data-list/data-list-gutter.js +0 -121
- package/dist/src/data-list/data-list-gutter.js.map +0 -1
- package/dist/src/data-list/data-list.d.ts +0 -18
- package/dist/src/data-list/data-list.js +0 -139
- package/dist/src/data-list/data-list.js.map +0 -1
- package/dist/src/data-list/event-handlers/record-partial-click-handler.d.ts +0 -7
- package/dist/src/data-list/event-handlers/record-partial-click-handler.js +0 -29
- package/dist/src/data-list/event-handlers/record-partial-click-handler.js.map +0 -1
- package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.d.ts +0 -7
- package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.js +0 -29
- package/dist/src/data-list/event-handlers/record-partial-dblclick-handler.js.map +0 -1
- package/dist/src/data-list/event-handlers/record-partial-long-press-handler.d.ts +0 -7
- package/dist/src/data-list/event-handlers/record-partial-long-press-handler.js +0 -29
- package/dist/src/data-list/event-handlers/record-partial-long-press-handler.js.map +0 -1
- package/dist/src/data-list/record-partial.d.ts +0 -21
- package/dist/src/data-list/record-partial.js +0 -252
- package/dist/src/data-list/record-partial.js.map +0 -1
- package/dist/src/data-manipulator.d.ts +0 -38
- package/dist/src/data-manipulator.js +0 -324
- package/dist/src/data-manipulator.js.map +0 -1
- package/dist/src/data-provider.d.ts +0 -50
- package/dist/src/data-provider.js +0 -200
- package/dist/src/data-provider.js.map +0 -1
- package/dist/src/data-report/data-report-body-style.d.ts +0 -1
- package/dist/src/data-report/data-report-body-style.js +0 -58
- package/dist/src/data-report/data-report-body-style.js.map +0 -1
- package/dist/src/data-report/data-report-body.d.ts +0 -18
- package/dist/src/data-report/data-report-body.js +0 -181
- package/dist/src/data-report/data-report-body.js.map +0 -1
- package/dist/src/data-report/data-report-component.d.ts +0 -21
- package/dist/src/data-report/data-report-component.js +0 -138
- package/dist/src/data-report/data-report-component.js.map +0 -1
- package/dist/src/data-report/data-report-field.d.ts +0 -13
- package/dist/src/data-report/data-report-field.js +0 -99
- package/dist/src/data-report/data-report-field.js.map +0 -1
- package/dist/src/data-report/data-report-header.d.ts +0 -1
- package/dist/src/data-report/data-report-header.js +0 -221
- package/dist/src/data-report/data-report-header.js.map +0 -1
- package/dist/src/data-report/event-handlers/data-report-body-click-handler.d.ts +0 -5
- package/dist/src/data-report/event-handlers/data-report-body-click-handler.js +0 -33
- package/dist/src/data-report/event-handlers/data-report-body-click-handler.js.map +0 -1
- package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.d.ts +0 -5
- package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.js +0 -19
- package/dist/src/data-report/event-handlers/data-report-body-dblclick-handler.js.map +0 -1
- package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.d.ts +0 -5
- package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.js +0 -58
- package/dist/src/data-report/event-handlers/data-report-body-keydown-handler.js.map +0 -1
- package/dist/src/data-report.d.ts +0 -44
- package/dist/src/data-report.js +0 -386
- package/dist/src/data-report.js.map +0 -1
- package/dist/src/editors/index.d.ts +0 -3
- package/dist/src/editors/index.js +0 -4
- package/dist/src/editors/index.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-checkbox.d.ts +0 -7
- package/dist/src/editors/ox-grist-editor-checkbox.js +0 -27
- package/dist/src/editors/ox-grist-editor-checkbox.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-color.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-color.js +0 -14
- package/dist/src/editors/ox-grist-editor-color.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-date.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-date.js +0 -14
- package/dist/src/editors/ox-grist-editor-date.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-datetime.d.ts +0 -6
- package/dist/src/editors/ox-grist-editor-datetime.js +0 -26
- package/dist/src/editors/ox-grist-editor-datetime.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-email.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-email.js +0 -14
- package/dist/src/editors/ox-grist-editor-email.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-file.d.ts +0 -6
- package/dist/src/editors/ox-grist-editor-file.js +0 -25
- package/dist/src/editors/ox-grist-editor-file.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-image.d.ts +0 -7
- package/dist/src/editors/ox-grist-editor-image.js +0 -31
- package/dist/src/editors/ox-grist-editor-image.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-month.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-month.js +0 -14
- package/dist/src/editors/ox-grist-editor-month.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-multiple-select.d.ts +0 -8
- package/dist/src/editors/ox-grist-editor-multiple-select.js +0 -52
- package/dist/src/editors/ox-grist-editor-multiple-select.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-number.d.ts +0 -6
- package/dist/src/editors/ox-grist-editor-number.js +0 -27
- package/dist/src/editors/ox-grist-editor-number.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-password.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-password.js +0 -14
- package/dist/src/editors/ox-grist-editor-password.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-select.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-select.js +0 -53
- package/dist/src/editors/ox-grist-editor-select.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-tel.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-tel.js +0 -14
- package/dist/src/editors/ox-grist-editor-tel.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-text.d.ts +0 -5
- package/dist/src/editors/ox-grist-editor-text.js +0 -17
- package/dist/src/editors/ox-grist-editor-text.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-textarea.d.ts +0 -6
- package/dist/src/editors/ox-grist-editor-textarea.js +0 -18
- package/dist/src/editors/ox-grist-editor-textarea.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-time.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-time.js +0 -14
- package/dist/src/editors/ox-grist-editor-time.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-tree.d.ts +0 -6
- package/dist/src/editors/ox-grist-editor-tree.js +0 -27
- package/dist/src/editors/ox-grist-editor-tree.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-varname.d.ts +0 -6
- package/dist/src/editors/ox-grist-editor-varname.js +0 -36
- package/dist/src/editors/ox-grist-editor-varname.js.map +0 -1
- package/dist/src/editors/ox-grist-editor-week.d.ts +0 -4
- package/dist/src/editors/ox-grist-editor-week.js +0 -14
- package/dist/src/editors/ox-grist-editor-week.js.map +0 -1
- package/dist/src/editors/ox-grist-editor.d.ts +0 -27
- package/dist/src/editors/ox-grist-editor.js +0 -197
- package/dist/src/editors/ox-grist-editor.js.map +0 -1
- package/dist/src/editors/ox-input-tree.d.ts +0 -20
- package/dist/src/editors/ox-input-tree.js +0 -221
- package/dist/src/editors/ox-input-tree.js.map +0 -1
- package/dist/src/editors/registry.d.ts +0 -12
- package/dist/src/editors/registry.js +0 -71
- package/dist/src/editors/registry.js.map +0 -1
- package/dist/src/empty-note.d.ts +0 -9
- package/dist/src/empty-note.js +0 -53
- package/dist/src/empty-note.js.map +0 -1
- package/dist/src/filters/filter-checkbox.d.ts +0 -3
- package/dist/src/filters/filter-checkbox.js +0 -41
- package/dist/src/filters/filter-checkbox.js.map +0 -1
- package/dist/src/filters/filter-input-barcode.d.ts +0 -3
- package/dist/src/filters/filter-input-barcode.js +0 -28
- package/dist/src/filters/filter-input-barcode.js.map +0 -1
- package/dist/src/filters/filter-input.d.ts +0 -2
- package/dist/src/filters/filter-input.js +0 -25
- package/dist/src/filters/filter-input.js.map +0 -1
- package/dist/src/filters/filter-range-date.d.ts +0 -2
- package/dist/src/filters/filter-range-date.js +0 -66
- package/dist/src/filters/filter-range-date.js.map +0 -1
- package/dist/src/filters/filter-range-number.d.ts +0 -2
- package/dist/src/filters/filter-range-number.js +0 -54
- package/dist/src/filters/filter-range-number.js.map +0 -1
- package/dist/src/filters/filter-select-buttons.d.ts +0 -3
- package/dist/src/filters/filter-select-buttons.js +0 -50
- package/dist/src/filters/filter-select-buttons.js.map +0 -1
- package/dist/src/filters/filter-select.d.ts +0 -3
- package/dist/src/filters/filter-select.js +0 -52
- package/dist/src/filters/filter-select.js.map +0 -1
- package/dist/src/filters/filter-styles.d.ts +0 -1
- package/dist/src/filters/filter-styles.js +0 -119
- package/dist/src/filters/filter-styles.js.map +0 -1
- package/dist/src/filters/filters-form.d.ts +0 -40
- package/dist/src/filters/filters-form.js +0 -430
- package/dist/src/filters/filters-form.js.map +0 -1
- package/dist/src/filters/index.d.ts +0 -8
- package/dist/src/filters/index.js +0 -9
- package/dist/src/filters/index.js.map +0 -1
- package/dist/src/filters/registry.d.ts +0 -7
- package/dist/src/filters/registry.js +0 -48
- package/dist/src/filters/registry.js.map +0 -1
- package/dist/src/formatters/date-formatter.d.ts +0 -1
- package/dist/src/formatters/date-formatter.js +0 -4
- package/dist/src/formatters/date-formatter.js.map +0 -1
- package/dist/src/formatters/index.d.ts +0 -1
- package/dist/src/formatters/index.js +0 -2
- package/dist/src/formatters/index.js.map +0 -1
- package/dist/src/formatters/number-formatter.d.ts +0 -1
- package/dist/src/formatters/number-formatter.js +0 -4
- package/dist/src/formatters/number-formatter.js.map +0 -1
- package/dist/src/formatters/registry.d.ts +0 -6
- package/dist/src/formatters/registry.js +0 -25
- package/dist/src/formatters/registry.js.map +0 -1
- package/dist/src/formatters/text-formatter.d.ts +0 -1
- package/dist/src/formatters/text-formatter.js +0 -4
- package/dist/src/formatters/text-formatter.js.map +0 -1
- package/dist/src/gutters/gutter-button.d.ts +0 -21
- package/dist/src/gutters/gutter-button.js +0 -40
- package/dist/src/gutters/gutter-button.js.map +0 -1
- package/dist/src/gutters/gutter-dirty.d.ts +0 -23
- package/dist/src/gutters/gutter-dirty.js +0 -87
- package/dist/src/gutters/gutter-dirty.js.map +0 -1
- package/dist/src/gutters/gutter-row-selector.d.ts +0 -21
- package/dist/src/gutters/gutter-row-selector.js +0 -70
- package/dist/src/gutters/gutter-row-selector.js.map +0 -1
- package/dist/src/gutters/gutter-sequence.d.ts +0 -35
- package/dist/src/gutters/gutter-sequence.js +0 -48
- package/dist/src/gutters/gutter-sequence.js.map +0 -1
- package/dist/src/gutters/index.d.ts +0 -1
- package/dist/src/gutters/index.js +0 -2
- package/dist/src/gutters/index.js.map +0 -1
- package/dist/src/gutters/registry.d.ts +0 -7
- package/dist/src/gutters/registry.js +0 -26
- package/dist/src/gutters/registry.js.map +0 -1
- package/dist/src/handlers/contextmenu-tree-mutation.d.ts +0 -3
- package/dist/src/handlers/contextmenu-tree-mutation.js +0 -64
- package/dist/src/handlers/contextmenu-tree-mutation.js.map +0 -1
- package/dist/src/handlers/index.d.ts +0 -1
- package/dist/src/handlers/index.js +0 -2
- package/dist/src/handlers/index.js.map +0 -1
- package/dist/src/handlers/move-down.d.ts +0 -3
- package/dist/src/handlers/move-down.js +0 -26
- package/dist/src/handlers/move-down.js.map +0 -1
- package/dist/src/handlers/move-up.d.ts +0 -3
- package/dist/src/handlers/move-up.js +0 -26
- package/dist/src/handlers/move-up.js.map +0 -1
- package/dist/src/handlers/record-copy.d.ts +0 -3
- package/dist/src/handlers/record-copy.js +0 -23
- package/dist/src/handlers/record-copy.js.map +0 -1
- package/dist/src/handlers/record-delete.d.ts +0 -3
- package/dist/src/handlers/record-delete.js +0 -16
- package/dist/src/handlers/record-delete.js.map +0 -1
- package/dist/src/handlers/record-view-handler.d.ts +0 -3
- package/dist/src/handlers/record-view-handler.js +0 -15
- package/dist/src/handlers/record-view-handler.js.map +0 -1
- package/dist/src/handlers/registry.d.ts +0 -7
- package/dist/src/handlers/registry.js +0 -34
- package/dist/src/handlers/registry.js.map +0 -1
- package/dist/src/handlers/select-row-toggle.d.ts +0 -3
- package/dist/src/handlers/select-row-toggle.js +0 -18
- package/dist/src/handlers/select-row-toggle.js.map +0 -1
- package/dist/src/handlers/select-row.d.ts +0 -3
- package/dist/src/handlers/select-row.js +0 -14
- package/dist/src/handlers/select-row.js.map +0 -1
- package/dist/src/index.d.ts +0 -14
- package/dist/src/index.js +0 -15
- package/dist/src/index.js.map +0 -1
- package/dist/src/personalizer/index.d.ts +0 -1
- package/dist/src/personalizer/index.js +0 -2
- package/dist/src/personalizer/index.js.map +0 -1
- package/dist/src/personalizer/ox-grist-filter-personalizer.d.ts +0 -8
- package/dist/src/personalizer/ox-grist-filter-personalizer.js +0 -178
- package/dist/src/personalizer/ox-grist-filter-personalizer.js.map +0 -1
- package/dist/src/personalizer/ox-grist-personalizer.d.ts +0 -8
- package/dist/src/personalizer/ox-grist-personalizer.js +0 -212
- package/dist/src/personalizer/ox-grist-personalizer.js.map +0 -1
- package/dist/src/record-view/event-handlers/record-view-body-click-handler.d.ts +0 -7
- package/dist/src/record-view/event-handlers/record-view-body-click-handler.js +0 -27
- package/dist/src/record-view/event-handlers/record-view-body-click-handler.js.map +0 -1
- package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.d.ts +0 -7
- package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js +0 -22
- package/dist/src/record-view/event-handlers/record-view-body-keydown-handler.js.map +0 -1
- package/dist/src/record-view/index.d.ts +0 -2
- package/dist/src/record-view/index.js +0 -3
- package/dist/src/record-view/index.js.map +0 -1
- package/dist/src/record-view/ox-record-creator.d.ts +0 -26
- package/dist/src/record-view/ox-record-creator.js +0 -247
- package/dist/src/record-view/ox-record-creator.js.map +0 -1
- package/dist/src/record-view/record-view-body.d.ts +0 -21
- package/dist/src/record-view/record-view-body.js +0 -252
- package/dist/src/record-view/record-view-body.js.map +0 -1
- package/dist/src/record-view/record-view-handler.d.ts +0 -9
- package/dist/src/record-view/record-view-handler.js +0 -57
- package/dist/src/record-view/record-view-handler.js.map +0 -1
- package/dist/src/record-view/record-view.d.ts +0 -23
- package/dist/src/record-view/record-view.js +0 -117
- package/dist/src/record-view/record-view.js.map +0 -1
- package/dist/src/renderers/index.d.ts +0 -13
- package/dist/src/renderers/index.js +0 -14
- package/dist/src/renderers/index.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-boolean.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-boolean.js +0 -39
- package/dist/src/renderers/ox-grist-renderer-boolean.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-color.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-color.js +0 -12
- package/dist/src/renderers/ox-grist-renderer-color.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-date.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-date.js +0 -53
- package/dist/src/renderers/ox-grist-renderer-date.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-file.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-file.js +0 -27
- package/dist/src/renderers/ox-grist-renderer-file.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-image.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-image.js +0 -24
- package/dist/src/renderers/ox-grist-renderer-image.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-json5.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-json5.js +0 -30
- package/dist/src/renderers/ox-grist-renderer-json5.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-link.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-link.js +0 -12
- package/dist/src/renderers/ox-grist-renderer-link.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-password.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-password.js +0 -5
- package/dist/src/renderers/ox-grist-renderer-password.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-progress.d.ts +0 -5
- package/dist/src/renderers/ox-grist-renderer-progress.js +0 -46
- package/dist/src/renderers/ox-grist-renderer-progress.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-select.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-select.js +0 -50
- package/dist/src/renderers/ox-grist-renderer-select.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-text.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-text.js +0 -11
- package/dist/src/renderers/ox-grist-renderer-text.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-textarea.d.ts +0 -2
- package/dist/src/renderers/ox-grist-renderer-textarea.js +0 -5
- package/dist/src/renderers/ox-grist-renderer-textarea.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer-tree.d.ts +0 -12
- package/dist/src/renderers/ox-grist-renderer-tree.js +0 -183
- package/dist/src/renderers/ox-grist-renderer-tree.js.map +0 -1
- package/dist/src/renderers/ox-grist-renderer.d.ts +0 -15
- package/dist/src/renderers/ox-grist-renderer.js +0 -48
- package/dist/src/renderers/ox-grist-renderer.js.map +0 -1
- package/dist/src/renderers/registry.d.ts +0 -12
- package/dist/src/renderers/registry.js +0 -70
- package/dist/src/renderers/registry.js.map +0 -1
- package/dist/src/sorters/sorters-control.d.ts +0 -12
- package/dist/src/sorters/sorters-control.js +0 -138
- package/dist/src/sorters/sorters-control.js.map +0 -1
- package/dist/src/types.d.ts +0 -696
- package/dist/src/types.js +0 -23
- package/dist/src/types.js.map +0 -1
- package/dist/src/utils/index.d.ts +0 -2
- package/dist/src/utils/index.js +0 -3
- package/dist/src/utils/index.js.map +0 -1
- package/dist/src/utils/list-param.d.ts +0 -16
- package/dist/src/utils/list-param.js +0 -40
- package/dist/src/utils/list-param.js.map +0 -1
- package/dist/src/utils/supports-passive.d.ts +0 -1
- package/dist/src/utils/supports-passive.js +0 -13
- package/dist/src/utils/supports-passive.js.map +0 -1
- package/dist/stories/accumulator-format.stories.d.ts +0 -41
- package/dist/stories/accumulator-format.stories.js +0 -237
- package/dist/stories/accumulator-format.stories.js.map +0 -1
- package/dist/stories/append-position.stories.d.ts +0 -8
- package/dist/stories/append-position.stories.js +0 -183
- package/dist/stories/append-position.stories.js.map +0 -1
- package/dist/stories/barcode-input-filter.stories.d.ts +0 -33
- package/dist/stories/barcode-input-filter.stories.js +0 -185
- package/dist/stories/barcode-input-filter.stories.js.map +0 -1
- package/dist/stories/bounded-select-filters.stories.d.ts +0 -25
- package/dist/stories/bounded-select-filters.stories.js +0 -283
- package/dist/stories/bounded-select-filters.stories.js.map +0 -1
- package/dist/stories/bounded-select-record.stories.d.ts +0 -25
- package/dist/stories/bounded-select-record.stories.js +0 -286
- package/dist/stories/bounded-select-record.stories.js.map +0 -1
- package/dist/stories/click-event-custom.stories.d.ts +0 -45
- package/dist/stories/click-event-custom.stories.js +0 -248
- package/dist/stories/click-event-custom.stories.js.map +0 -1
- package/dist/stories/click-event.stories.d.ts +0 -45
- package/dist/stories/click-event.stories.js +0 -243
- package/dist/stories/click-event.stories.js.map +0 -1
- package/dist/stories/creatable-only-column.stories.d.ts +0 -29
- package/dist/stories/creatable-only-column.stories.js +0 -232
- package/dist/stories/creatable-only-column.stories.js.map +0 -1
- package/dist/stories/default-filters.stories.d.ts +0 -26
- package/dist/stories/default-filters.stories.js +0 -219
- package/dist/stories/default-filters.stories.js.map +0 -1
- package/dist/stories/dynamic-editable.stories.d.ts +0 -25
- package/dist/stories/dynamic-editable.stories.js +0 -293
- package/dist/stories/dynamic-editable.stories.js.map +0 -1
- package/dist/stories/empty-sorters.stories.d.ts +0 -25
- package/dist/stories/empty-sorters.stories.js +0 -162
- package/dist/stories/empty-sorters.stories.js.map +0 -1
- package/dist/stories/explicit-fetch.stories.d.ts +0 -25
- package/dist/stories/explicit-fetch.stories.js +0 -166
- package/dist/stories/explicit-fetch.stories.js.map +0 -1
- package/dist/stories/fixed-column.stories.d.ts +0 -26
- package/dist/stories/fixed-column.stories.js +0 -383
- package/dist/stories/fixed-column.stories.js.map +0 -1
- package/dist/stories/grid-setting.stories.d.ts +0 -47
- package/dist/stories/grid-setting.stories.js +0 -453
- package/dist/stories/grid-setting.stories.js.map +0 -1
- package/dist/stories/grist-modes.stories.d.ts +0 -37
- package/dist/stories/grist-modes.stories.js +0 -416
- package/dist/stories/grist-modes.stories.js.map +0 -1
- package/dist/stories/group-header.stories.d.ts +0 -26
- package/dist/stories/group-header.stories.js +0 -410
- package/dist/stories/group-header.stories.js.map +0 -1
- package/dist/stories/record-view.stories.d.ts +0 -24
- package/dist/stories/record-view.stories.js +0 -125
- package/dist/stories/record-view.stories.js.map +0 -1
- package/dist/stories/textarea.stories.d.ts +0 -37
- package/dist/stories/textarea.stories.js +0 -229
- package/dist/stories/textarea.stories.js.map +0 -1
- package/dist/stories/tree-column-with-checkbox.stories.d.ts +0 -26
- package/dist/stories/tree-column-with-checkbox.stories.js +0 -267
- package/dist/stories/tree-column-with-checkbox.stories.js.map +0 -1
- package/dist/stories/tree-column.stories.d.ts +0 -26
- package/dist/stories/tree-column.stories.js +0 -266
- package/dist/stories/tree-column.stories.js.map +0 -1
@@ -1,212 +0,0 @@
|
|
1
|
-
import { __decorate } from "tslib";
|
2
|
-
import '@material/web/button/outlined-button.js';
|
3
|
-
import { css, html, LitElement } from 'lit';
|
4
|
-
import { customElement, property, state } from 'lit/decorators.js';
|
5
|
-
import { i18next } from '@operato/i18n';
|
6
|
-
import { OxPopupList } from '@operato/popup';
|
7
|
-
let OxGristPersonalizer = class OxGristPersonalizer extends LitElement {
|
8
|
-
constructor() {
|
9
|
-
super(...arguments);
|
10
|
-
this.debug = false;
|
11
|
-
}
|
12
|
-
render() {
|
13
|
-
return html `
|
14
|
-
<md-icon
|
15
|
-
@click=${(e) => {
|
16
|
-
const grist = this.closest('ox-grist');
|
17
|
-
const { config, compiledConfig, sorters, pagination, mode } = grist;
|
18
|
-
const { columns: compiledColumns } = compiledConfig;
|
19
|
-
const columns = compiledColumns
|
20
|
-
.filter(ccolumn => {
|
21
|
-
const column = config.columns.find((column) => column.name == ccolumn.name);
|
22
|
-
return column && column.name && column.type !== 'gutter' && !column.hidden && !column.unusable;
|
23
|
-
})
|
24
|
-
.map(column => compiledColumns.find(compiledColumn => compiledColumn.name == column.name));
|
25
|
-
this.preference = {
|
26
|
-
columns: columns.map(column => {
|
27
|
-
return {
|
28
|
-
name: column.name,
|
29
|
-
hidden: column.hidden,
|
30
|
-
width: column.width
|
31
|
-
};
|
32
|
-
}),
|
33
|
-
sorters,
|
34
|
-
pagination: {
|
35
|
-
...pagination,
|
36
|
-
limit: grist.getCurrentLimit()
|
37
|
-
},
|
38
|
-
mode
|
39
|
-
};
|
40
|
-
const template = html `
|
41
|
-
<div class="personalizer-header" slot="header">
|
42
|
-
<div
|
43
|
-
style=${`
|
44
|
-
display: flex;
|
45
|
-
align-items: center;
|
46
|
-
margin: 0 0 0 auto;
|
47
|
-
min-height: 1.4em;
|
48
|
-
color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));
|
49
|
-
background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));
|
50
|
-
border-radius: var(--md-sys-shape-corner-small);
|
51
|
-
padding: 0 var(--spacing-small);
|
52
|
-
cursor: pointer;
|
53
|
-
`}
|
54
|
-
@click=${async (e) => {
|
55
|
-
if (grist.personalConfigProvider) {
|
56
|
-
const { mode, columns, sorters, pagination } = this.preference || {};
|
57
|
-
grist.personalConfig = this.preference = await grist.personalConfigProvider.save({
|
58
|
-
mode,
|
59
|
-
columns,
|
60
|
-
sorters,
|
61
|
-
pagination
|
62
|
-
});
|
63
|
-
}
|
64
|
-
popup.close();
|
65
|
-
}}
|
66
|
-
>
|
67
|
-
${String(i18next.t('button.save'))}
|
68
|
-
</div>
|
69
|
-
<div
|
70
|
-
style=${`
|
71
|
-
display: flex;
|
72
|
-
align-items: center;
|
73
|
-
margin: 0 0 0 var(--spacing-small, 4px);
|
74
|
-
min-height: 1.4em;
|
75
|
-
color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));
|
76
|
-
background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));
|
77
|
-
border-radius: var(--md-sys-shape-corner-small);
|
78
|
-
padding: 0 var(--spacing-small);
|
79
|
-
cursor: pointer;
|
80
|
-
`}
|
81
|
-
@click=${async (e) => {
|
82
|
-
if (grist.personalConfigProvider) {
|
83
|
-
grist.personalConfig = this.preference = {};
|
84
|
-
await grist.personalConfigProvider.reset();
|
85
|
-
}
|
86
|
-
popup.close();
|
87
|
-
}}
|
88
|
-
>
|
89
|
-
${String(i18next.t('button.delete'))}
|
90
|
-
</div>
|
91
|
-
<md-icon
|
92
|
-
style=${`
|
93
|
-
--md-icon-size: 1.2em;
|
94
|
-
margin-left: var(--spacing-tiny, 2px);
|
95
|
-
cursor: pointer;
|
96
|
-
`}
|
97
|
-
@click=${async (e) => popup.close()}
|
98
|
-
title=${String(i18next.t('button.close'))}
|
99
|
-
>close</md-icon
|
100
|
-
>
|
101
|
-
</div>
|
102
|
-
|
103
|
-
${columns.map(column => html `
|
104
|
-
<ox-checkbox label="checkbox" ?checked=${!column.hidden} value=${column.name} option
|
105
|
-
>${column.header.renderer(column)}<span
|
106
|
-
style="position: absolute; right: 10px; cursor: row-resize;opacity:.5"
|
107
|
-
handle
|
108
|
-
>☰</span
|
109
|
-
></ox-checkbox
|
110
|
-
>
|
111
|
-
`)}
|
112
|
-
`;
|
113
|
-
const popup = OxPopupList.open({
|
114
|
-
template,
|
115
|
-
multiple: true,
|
116
|
-
sortable: true,
|
117
|
-
debug: this.debug,
|
118
|
-
attrSelected: 'checked',
|
119
|
-
top: e.pageY,
|
120
|
-
left: e.pageX,
|
121
|
-
styles: css `
|
122
|
-
:host {
|
123
|
-
width: 240px;
|
124
|
-
min-height: 300px;
|
125
|
-
max-height: 80%;
|
126
|
-
overflow: auto;
|
127
|
-
}
|
128
|
-
|
129
|
-
::slotted(.personalizer-header) {
|
130
|
-
--md-icon-size: 1.4em;
|
131
|
-
|
132
|
-
display: flex;
|
133
|
-
flex-direction: row;
|
134
|
-
align-items: center;
|
135
|
-
text-transform: capitalize;
|
136
|
-
box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);
|
137
|
-
}
|
138
|
-
|
139
|
-
::slotted([option]) {
|
140
|
-
position: relative;
|
141
|
-
user-select: none;
|
142
|
-
}
|
143
|
-
`
|
144
|
-
});
|
145
|
-
popup.onselect = (e) => {
|
146
|
-
var _a;
|
147
|
-
const selected = e.detail;
|
148
|
-
const pconfig = grist.personalConfig || {};
|
149
|
-
const pcolumns = ((_a = this.preference) === null || _a === void 0 ? void 0 : _a.columns) || columns;
|
150
|
-
pconfig.columns = pcolumns.map(column => {
|
151
|
-
return {
|
152
|
-
name: column.name,
|
153
|
-
hidden: selected.indexOf(column.name) == -1,
|
154
|
-
width: column.width
|
155
|
-
};
|
156
|
-
});
|
157
|
-
this.preference = pconfig;
|
158
|
-
grist.personalConfig = this.preference;
|
159
|
-
grist.applyUpdatedConfiguration();
|
160
|
-
};
|
161
|
-
popup.addEventListener('sorted', (e) => {
|
162
|
-
const sorted = e.detail;
|
163
|
-
const pconfig = grist.personalConfig || {};
|
164
|
-
pconfig.columns = sorted.map(element => {
|
165
|
-
var _a;
|
166
|
-
const name = element.value;
|
167
|
-
return {
|
168
|
-
name,
|
169
|
-
hidden: !element.hasAttribute('checked'),
|
170
|
-
width: (_a = columns.find(column => column.name == name)) === null || _a === void 0 ? void 0 : _a.width
|
171
|
-
};
|
172
|
-
});
|
173
|
-
this.preference = pconfig;
|
174
|
-
grist.personalConfig = this.preference;
|
175
|
-
grist.applyUpdatedConfiguration();
|
176
|
-
});
|
177
|
-
}}
|
178
|
-
>settings</md-icon
|
179
|
-
>
|
180
|
-
`;
|
181
|
-
}
|
182
|
-
};
|
183
|
-
OxGristPersonalizer.styles = [
|
184
|
-
css `
|
185
|
-
md-icon {
|
186
|
-
--md-icon-size: 14px;
|
187
|
-
width: 16px;
|
188
|
-
height: 16px;
|
189
|
-
color: var(--ox-grist-p13n-color, var(--md-sys-color-on-primary));
|
190
|
-
background-color: var(--ox-grist-p13n-background-color, var(--md-sys-color-primary));
|
191
|
-
border-radius: 0px 0px 7px 7px;
|
192
|
-
cursor: pointer;
|
193
|
-
padding-top: var(--spacing-small);
|
194
|
-
|
195
|
-
&:hover {
|
196
|
-
color: var(--ox-grist-p13n-hover-color, var(--md-sys-color-on-primary));
|
197
|
-
background-color: var(--ox-grist-p13n-hover-background-color, var(--md-sys-color-surface-tint));
|
198
|
-
}
|
199
|
-
}
|
200
|
-
`
|
201
|
-
];
|
202
|
-
__decorate([
|
203
|
-
property({ type: Boolean, attribute: true })
|
204
|
-
], OxGristPersonalizer.prototype, "debug", void 0);
|
205
|
-
__decorate([
|
206
|
-
state()
|
207
|
-
], OxGristPersonalizer.prototype, "preference", void 0);
|
208
|
-
OxGristPersonalizer = __decorate([
|
209
|
-
customElement('ox-grist-personalizer')
|
210
|
-
], OxGristPersonalizer);
|
211
|
-
export { OxGristPersonalizer };
|
212
|
-
//# sourceMappingURL=ox-grist-personalizer.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ox-grist-personalizer.js","sourceRoot":"","sources":["../../../src/personalizer/ox-grist-personalizer.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/button/outlined-button.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { i18next } from '@operato/i18n'\nimport { OxPopupList } from '@operato/popup'\nimport { OxCheckbox } from '@operato/input'\n\nimport { ColumnConfig, PersonalGristPreference } from '../types.js'\nimport { DataGrist } from '../data-grist.js'\n\n@customElement('ox-grist-personalizer')\nexport class OxGristPersonalizer extends LitElement {\n static styles = [\n css`\n md-icon {\n --md-icon-size: 14px;\n width: 16px;\n height: 16px;\n color: var(--ox-grist-p13n-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-background-color, var(--md-sys-color-primary));\n border-radius: 0px 0px 7px 7px;\n cursor: pointer;\n padding-top: var(--spacing-small);\n\n &:hover {\n color: var(--ox-grist-p13n-hover-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-hover-background-color, var(--md-sys-color-surface-tint));\n }\n }\n `\n ]\n\n @property({ type: Boolean, attribute: true }) debug: boolean = false\n\n @state() private preference?: PersonalGristPreference\n\n render() {\n return html`\n <md-icon\n @click=${(e: MouseEvent) => {\n const grist = this.closest('ox-grist') as DataGrist\n\n const { config, compiledConfig, sorters, pagination, mode } = grist\n const { columns: compiledColumns } = compiledConfig\n\n const columns = compiledColumns\n .filter(ccolumn => {\n const column = config.columns.find((column: Partial<ColumnConfig>) => column.name == ccolumn.name)\n return column && column.name && column.type !== 'gutter' && !column.hidden && !column.unusable\n })\n .map(column => compiledColumns.find(compiledColumn => compiledColumn.name == column.name)!)\n\n this.preference = {\n columns: columns.map(column => {\n return {\n name: column.name,\n hidden: column.hidden,\n width: column.width\n }\n }),\n sorters,\n pagination: {\n ...pagination,\n limit: grist.getCurrentLimit()\n },\n mode\n }\n\n const template = html`\n <div class=\"personalizer-header\" slot=\"header\">\n <div\n style=${`\n display: flex;\n align-items: center;\n margin: 0 0 0 auto;\n min-height: 1.4em;\n color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));\n border-radius: var(--md-sys-shape-corner-small);\n padding: 0 var(--spacing-small);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => {\n if (grist.personalConfigProvider) {\n const { mode, columns, sorters, pagination } = this.preference || {}\n grist.personalConfig = this.preference = await grist.personalConfigProvider.save({\n mode,\n columns,\n sorters,\n pagination\n })\n }\n popup.close()\n }}\n >\n ${String(i18next.t('button.save'))}\n </div>\n <div\n style=${`\n display: flex;\n align-items: center;\n margin: 0 0 0 var(--spacing-small, 4px);\n min-height: 1.4em;\n color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));\n background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));\n border-radius: var(--md-sys-shape-corner-small);\n padding: 0 var(--spacing-small);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => {\n if (grist.personalConfigProvider) {\n grist.personalConfig = this.preference = {}\n await grist.personalConfigProvider.reset()\n }\n popup.close()\n }}\n >\n ${String(i18next.t('button.delete'))}\n </div>\n <md-icon\n style=${`\n --md-icon-size: 1.2em;\n margin-left: var(--spacing-tiny, 2px);\n cursor: pointer;\n `}\n @click=${async (e: MouseEvent) => popup.close()}\n title=${String(i18next.t('button.close'))}\n >close</md-icon\n >\n </div>\n\n ${columns.map(\n column => html`\n <ox-checkbox label=\"checkbox\" ?checked=${!column.hidden} value=${column.name} option\n >${column.header.renderer(column)}<span\n style=\"position: absolute; right: 10px; cursor: row-resize;opacity:.5\"\n handle\n >☰</span\n ></ox-checkbox\n >\n `\n )}\n `\n\n const popup = OxPopupList.open({\n template,\n multiple: true,\n sortable: true,\n debug: this.debug,\n attrSelected: 'checked',\n top: e.pageY,\n left: e.pageX,\n styles: css`\n :host {\n width: 240px;\n min-height: 300px;\n max-height: 80%;\n overflow: auto;\n }\n\n ::slotted(.personalizer-header) {\n --md-icon-size: 1.4em;\n\n display: flex;\n flex-direction: row;\n align-items: center;\n text-transform: capitalize;\n box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);\n }\n\n ::slotted([option]) {\n position: relative;\n user-select: none;\n }\n `\n })\n\n popup.onselect = (e: Event) => {\n const selected = (e as CustomEvent).detail\n\n const pconfig: PersonalGristPreference = grist.personalConfig || {}\n const pcolumns = this.preference?.columns || columns\n\n pconfig.columns = pcolumns.map(column => {\n return {\n name: column.name,\n hidden: selected.indexOf(column.name) == -1,\n width: column.width\n }\n })\n\n this.preference = pconfig\n\n grist.personalConfig = this.preference\n\n grist.applyUpdatedConfiguration()\n }\n\n popup.addEventListener('sorted', (e: Event) => {\n const sorted = (e as CustomEvent).detail as HTMLElement[]\n\n const pconfig: PersonalGristPreference = grist.personalConfig || {}\n\n pconfig.columns = sorted.map(element => {\n const name = (element as OxCheckbox).value\n return {\n name,\n hidden: !element.hasAttribute('checked'),\n width: columns.find(column => column.name == name)?.width\n }\n })\n\n this.preference = pconfig\n\n grist.personalConfig = this.preference\n\n grist.applyUpdatedConfiguration()\n })\n }}\n >settings</md-icon\n >\n `\n }\n}\n"]}
|
@@ -1,27 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* ox-record-view-body 의 click handler
|
3
|
-
*
|
4
|
-
* - handler의 this 는 ox-record-view-body임.
|
5
|
-
*/
|
6
|
-
export function recordViewBodyClickHandler(e) {
|
7
|
-
var _a;
|
8
|
-
e.stopPropagation();
|
9
|
-
/* target should be 'ox-grid-field' */
|
10
|
-
var target = e.target;
|
11
|
-
if (this.currentTarget) {
|
12
|
-
this.focus();
|
13
|
-
this.currentTarget.removeAttribute('editing');
|
14
|
-
}
|
15
|
-
let editable = (_a = target === null || target === void 0 ? void 0 : target.column) === null || _a === void 0 ? void 0 : _a.record.editable;
|
16
|
-
if (typeof editable === 'function') {
|
17
|
-
editable = editable.call(this, target.value, target.column, target.record, target.rowIndex, this);
|
18
|
-
}
|
19
|
-
if (target.tagName !== 'OX-GRID-FIELD' || !editable) {
|
20
|
-
this.focus();
|
21
|
-
this.currentTarget = null;
|
22
|
-
return;
|
23
|
-
}
|
24
|
-
this.currentTarget = target;
|
25
|
-
target.setAttribute('editing', 'true');
|
26
|
-
}
|
27
|
-
//# sourceMappingURL=record-view-body-click-handler.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"record-view-body-click-handler.js","sourceRoot":"","sources":["../../../../src/record-view/event-handlers/record-view-body-click-handler.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AACH,MAAM,UAAU,0BAA0B,CAAuB,CAAQ;;IACvE,CAAC,CAAC,eAAe,EAAE,CAAA;IAEnB,sCAAsC;IACtC,IAAI,MAAM,GAAG,CAAC,CAAC,MAAuB,CAAA;IAEtC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK,EAAE,CAAA;QACZ,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAA;IAC/C,CAAC;IAED,IAAI,QAAQ,GAAG,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,0CAAE,MAAM,CAAC,QAAQ,CAAA;IAC9C,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE,CAAC;QACnC,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAA;IACnG,CAAC;IAED,IAAI,MAAM,CAAC,OAAO,KAAK,eAAe,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,KAAK,EAAE,CAAA;QACZ,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;QACzB,OAAM;IACR,CAAC;IAED,IAAI,CAAC,aAAa,GAAG,MAAM,CAAA;IAC3B,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,CAAA;AACxC,CAAC","sourcesContent":["import { DataGridField } from '../../data-grid/data-grid-field.js'\nimport { RecordViewBody } from '../record-view-body.js'\n\n/**\n * ox-record-view-body 의 click handler\n *\n * - handler의 this 는 ox-record-view-body임.\n */\nexport function recordViewBodyClickHandler(this: RecordViewBody, e: Event): void {\n e.stopPropagation()\n\n /* target should be 'ox-grid-field' */\n var target = e.target as DataGridField\n\n if (this.currentTarget) {\n this.focus()\n this.currentTarget.removeAttribute('editing')\n }\n\n let editable = target?.column?.record.editable\n if (typeof editable === 'function') {\n editable = editable.call(this, target.value, target.column, target.record, target.rowIndex, this)\n }\n\n if (target.tagName !== 'OX-GRID-FIELD' || !editable) {\n this.focus()\n this.currentTarget = null\n return\n }\n\n this.currentTarget = target\n target.setAttribute('editing', 'true')\n}\n"]}
|
@@ -1,22 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* ox-record-view-body 의 keydown handler
|
3
|
-
*
|
4
|
-
* - handler의 this 는 ox-record-view-body임.
|
5
|
-
*/
|
6
|
-
export async function recordViewBodyKeydownHandler(e) {
|
7
|
-
switch (e.key) {
|
8
|
-
case 'Esc':
|
9
|
-
case 'Escape':
|
10
|
-
/* TODO 편집이 취소되어야 한다. */
|
11
|
-
case 'Enter':
|
12
|
-
/* 먼저, focus를 옮겨놓아야, focusout 으로 인해서 popup이 닫히는 것을 방지할 수 있다. */
|
13
|
-
this.focus();
|
14
|
-
if (this.currentTarget) {
|
15
|
-
this.currentTarget.removeAttribute('editing');
|
16
|
-
}
|
17
|
-
this.currentTarget = null;
|
18
|
-
break;
|
19
|
-
default:
|
20
|
-
}
|
21
|
-
}
|
22
|
-
//# sourceMappingURL=record-view-body-keydown-handler.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"record-view-body-keydown-handler.js","sourceRoot":"","sources":["../../../../src/record-view/event-handlers/record-view-body-keydown-handler.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,4BAA4B,CAAuB,CAAQ;IAC/E,QAAS,CAAmB,CAAC,GAAG,EAAE,CAAC;QACjC,KAAK,KAAK,CAAC;QACX,KAAK,QAAQ,CAAC;QACd,wBAAwB;QACxB,KAAK,OAAO;YACV,+DAA+D;YAC/D,IAAI,CAAC,KAAK,EAAE,CAAA;YAEZ,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAA;YAC/C,CAAC;YAED,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;YAEzB,MAAK;QACP,QAAQ;IACV,CAAC;AACH,CAAC","sourcesContent":["import { RecordViewBody } from '../record-view-body.js'\n\n/**\n * ox-record-view-body 의 keydown handler\n *\n * - handler의 this 는 ox-record-view-body임.\n */\nexport async function recordViewBodyKeydownHandler(this: RecordViewBody, e: Event): Promise<void> {\n switch ((e as KeyboardEvent).key) {\n case 'Esc':\n case 'Escape':\n /* TODO 편집이 취소되어야 한다. */\n case 'Enter':\n /* 먼저, focus를 옮겨놓아야, focusout 으로 인해서 popup이 닫히는 것을 방지할 수 있다. */\n this.focus()\n\n if (this.currentTarget) {\n this.currentTarget.removeAttribute('editing')\n }\n\n this.currentTarget = null\n\n break\n default:\n }\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/record-view/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,wBAAwB,CAAA","sourcesContent":["export * from './record-view.js'\nexport * from './ox-record-creator.js'\n"]}
|
@@ -1,26 +0,0 @@
|
|
1
|
-
import '@material/web/icon/icon.js';
|
2
|
-
import './record-view.js';
|
3
|
-
import { LitElement } from 'lit';
|
4
|
-
import { DataGrist } from '../data-grist.js';
|
5
|
-
import { GristRecord, ValidationReason } from '../types.js';
|
6
|
-
export declare class OxRecordCreator extends LitElement {
|
7
|
-
static styles: import("lit").CSSResult[];
|
8
|
-
grist?: DataGrist;
|
9
|
-
callback?: (record: GristRecord) => boolean;
|
10
|
-
customPopupCallback?: (popup: any) => boolean;
|
11
|
-
lightPopup: boolean;
|
12
|
-
preventCloseOnBlur: boolean;
|
13
|
-
constructor();
|
14
|
-
connectedCallback(): void;
|
15
|
-
render(): import("lit-html").TemplateResult<1>;
|
16
|
-
validateRecord(record: GristRecord): {
|
17
|
-
field: string;
|
18
|
-
reason: ValidationReason;
|
19
|
-
}[];
|
20
|
-
openLightPopup(): void;
|
21
|
-
openPopup(): void;
|
22
|
-
lightPopupRecordView(): void;
|
23
|
-
popupRecordView(): void;
|
24
|
-
lightPopupCustomCreator(originalContent: HTMLElement): void;
|
25
|
-
popupCustomCreator(originalContent: HTMLElement): void;
|
26
|
-
}
|
@@ -1,247 +0,0 @@
|
|
1
|
-
import { __decorate } from "tslib";
|
2
|
-
import '@material/web/icon/icon.js';
|
3
|
-
import './record-view.js';
|
4
|
-
import { css, html, LitElement } from 'lit';
|
5
|
-
import { customElement, property, state } from 'lit/decorators.js';
|
6
|
-
import { OxPopup } from '@operato/popup';
|
7
|
-
import { ValidationReason } from '../types.js';
|
8
|
-
let OxRecordCreator = class OxRecordCreator extends LitElement {
|
9
|
-
constructor() {
|
10
|
-
super();
|
11
|
-
this.lightPopup = false;
|
12
|
-
this.preventCloseOnBlur = false;
|
13
|
-
this.addEventListener('click', (e) => {
|
14
|
-
e.preventDefault();
|
15
|
-
e.stopPropagation();
|
16
|
-
if (this.lightPopup) {
|
17
|
-
this.openLightPopup();
|
18
|
-
}
|
19
|
-
else {
|
20
|
-
this.openPopup();
|
21
|
-
}
|
22
|
-
});
|
23
|
-
}
|
24
|
-
connectedCallback() {
|
25
|
-
super.connectedCallback();
|
26
|
-
this.grist = this.closest('ox-grist');
|
27
|
-
}
|
28
|
-
render() {
|
29
|
-
return html `
|
30
|
-
<slot></slot>
|
31
|
-
<slot name="popup"></slot>
|
32
|
-
`;
|
33
|
-
}
|
34
|
-
validateRecord(record) {
|
35
|
-
const columns = this.grist.compiledConfig.columns;
|
36
|
-
const invalidFields = [];
|
37
|
-
columns
|
38
|
-
.filter(column => !column.hidden)
|
39
|
-
.forEach(column => {
|
40
|
-
var _a;
|
41
|
-
if (((_a = column.record) === null || _a === void 0 ? void 0 : _a.mandatory) &&
|
42
|
-
(record[column.name] === undefined || record[column.name] === null || record[column.name] === '')) {
|
43
|
-
invalidFields.push({
|
44
|
-
field: column.name,
|
45
|
-
reason: ValidationReason.MANDATORY
|
46
|
-
});
|
47
|
-
}
|
48
|
-
});
|
49
|
-
return invalidFields;
|
50
|
-
}
|
51
|
-
openLightPopup() {
|
52
|
-
var _a;
|
53
|
-
const slot = (_a = this.renderRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`slot[name='popup']`);
|
54
|
-
const slottedElements = slot === null || slot === void 0 ? void 0 : slot.assignedElements({ flatten: true });
|
55
|
-
const originalContent = slottedElements === null || slottedElements === void 0 ? void 0 : slottedElements[0];
|
56
|
-
if (originalContent) {
|
57
|
-
this.lightPopupCustomCreator(originalContent);
|
58
|
-
}
|
59
|
-
else {
|
60
|
-
this.lightPopupRecordView();
|
61
|
-
}
|
62
|
-
}
|
63
|
-
openPopup() {
|
64
|
-
var _a;
|
65
|
-
const slot = (_a = this.renderRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`slot[name='popup']`);
|
66
|
-
const slottedElements = slot === null || slot === void 0 ? void 0 : slot.assignedElements({ flatten: true });
|
67
|
-
const originalContent = slottedElements === null || slottedElements === void 0 ? void 0 : slottedElements[0];
|
68
|
-
if (originalContent) {
|
69
|
-
this.popupCustomCreator(originalContent);
|
70
|
-
}
|
71
|
-
else {
|
72
|
-
this.popupRecordView();
|
73
|
-
}
|
74
|
-
}
|
75
|
-
lightPopupRecordView() {
|
76
|
-
const config = this.grist.compiledConfig;
|
77
|
-
var title = 'create';
|
78
|
-
const rowIndex = -1;
|
79
|
-
var record = {};
|
80
|
-
const columns = config.columns;
|
81
|
-
var popup = OxPopup.open({
|
82
|
-
template: html `
|
83
|
-
<div title>${title}</div>
|
84
|
-
<ox-record-view
|
85
|
-
@field-change=${(e) => {
|
86
|
-
const view = e.currentTarget;
|
87
|
-
var { after, before, column, record, row } = e.detail;
|
88
|
-
var validation = column.validation;
|
89
|
-
if (validation && typeof validation == 'function') {
|
90
|
-
if (!validation.call(this, after, before, record, column)) {
|
91
|
-
return;
|
92
|
-
}
|
93
|
-
}
|
94
|
-
view.record = {
|
95
|
-
...record,
|
96
|
-
[column.name]: after
|
97
|
-
};
|
98
|
-
}}
|
99
|
-
.columns=${columns}
|
100
|
-
.record=${record}
|
101
|
-
.rowIndex=${rowIndex}
|
102
|
-
@reset=${(e) => {
|
103
|
-
const view = e.currentTarget;
|
104
|
-
view.record = {};
|
105
|
-
}}
|
106
|
-
@cancel=${(e) => {
|
107
|
-
popup.close();
|
108
|
-
}}
|
109
|
-
@ok=${async (e) => {
|
110
|
-
const view = e.currentTarget;
|
111
|
-
const invalidFields = await this.validateRecord(view.record);
|
112
|
-
if (invalidFields.length > 0) {
|
113
|
-
view.setFocusOnInvalid(invalidFields);
|
114
|
-
return false;
|
115
|
-
}
|
116
|
-
popup.close();
|
117
|
-
this.dispatchEvent(new CustomEvent('ok', {
|
118
|
-
bubbles: true,
|
119
|
-
composed: true,
|
120
|
-
detail: view.record
|
121
|
-
}));
|
122
|
-
}}
|
123
|
-
></ox-record-view>
|
124
|
-
`,
|
125
|
-
parent: document.body,
|
126
|
-
preventCloseOnBlur: this.preventCloseOnBlur
|
127
|
-
});
|
128
|
-
}
|
129
|
-
popupRecordView() {
|
130
|
-
const config = this.grist.compiledConfig;
|
131
|
-
const rowIndex = -1;
|
132
|
-
var record = {};
|
133
|
-
const columns = config.columns;
|
134
|
-
var title = 'create';
|
135
|
-
var recordView = document.createElement('ox-record-view');
|
136
|
-
recordView.columns = columns;
|
137
|
-
recordView.record = record;
|
138
|
-
recordView.rowIndex = rowIndex;
|
139
|
-
document.dispatchEvent(new CustomEvent('open-popup', {
|
140
|
-
detail: {
|
141
|
-
template: recordView,
|
142
|
-
options: {
|
143
|
-
backdrop: true,
|
144
|
-
size: 'large',
|
145
|
-
title
|
146
|
-
},
|
147
|
-
callback: (popup) => {
|
148
|
-
recordView.addEventListener('reset', (e) => {
|
149
|
-
const view = e.currentTarget;
|
150
|
-
view.record = {};
|
151
|
-
});
|
152
|
-
recordView.addEventListener('cancel', (e) => {
|
153
|
-
popup.close();
|
154
|
-
});
|
155
|
-
recordView.addEventListener('ok', async (e) => {
|
156
|
-
var _a;
|
157
|
-
const view = e.currentTarget;
|
158
|
-
const invalidFields = await this.validateRecord(view.record);
|
159
|
-
if (invalidFields.length > 0) {
|
160
|
-
view.setFocusOnInvalid(invalidFields);
|
161
|
-
return false;
|
162
|
-
}
|
163
|
-
if (await ((_a = this.callback) === null || _a === void 0 ? void 0 : _a.call(this, view.record))) {
|
164
|
-
popup.close();
|
165
|
-
}
|
166
|
-
else {
|
167
|
-
console.error('validation failed');
|
168
|
-
}
|
169
|
-
});
|
170
|
-
recordView.addEventListener('field-change', async (e) => {
|
171
|
-
const view = e.currentTarget;
|
172
|
-
var { after, before, column, record, row } = e.detail;
|
173
|
-
var validation = column.validation;
|
174
|
-
if (validation && typeof validation == 'function') {
|
175
|
-
if (!(await validation.call(this, after, before, record, column))) {
|
176
|
-
return;
|
177
|
-
}
|
178
|
-
}
|
179
|
-
view.record = {
|
180
|
-
...record,
|
181
|
-
[column.name]: after
|
182
|
-
};
|
183
|
-
});
|
184
|
-
popup.onclosed = () => { };
|
185
|
-
}
|
186
|
-
}
|
187
|
-
}));
|
188
|
-
}
|
189
|
-
lightPopupCustomCreator(originalContent) {
|
190
|
-
var _a;
|
191
|
-
const title = 'create';
|
192
|
-
const popupContent = originalContent.cloneNode(true);
|
193
|
-
popupContent.removeAttribute('slot');
|
194
|
-
OxPopup.open({
|
195
|
-
template: html `
|
196
|
-
<div title>${title}</div>
|
197
|
-
${popupContent}
|
198
|
-
`,
|
199
|
-
parent: document.body,
|
200
|
-
preventCloseOnBlur: this.preventCloseOnBlur
|
201
|
-
});
|
202
|
-
(_a = this.customPopupCallback) === null || _a === void 0 ? void 0 : _a.call(this, popupContent); // 사용자 정의 팝업용 콜백 실행
|
203
|
-
}
|
204
|
-
popupCustomCreator(originalContent) {
|
205
|
-
const title = 'create';
|
206
|
-
const popupContent = originalContent.cloneNode(true);
|
207
|
-
popupContent.removeAttribute('slot');
|
208
|
-
document.dispatchEvent(new CustomEvent('open-popup', {
|
209
|
-
detail: {
|
210
|
-
template: popupContent,
|
211
|
-
options: {
|
212
|
-
backdrop: true,
|
213
|
-
size: 'large',
|
214
|
-
title
|
215
|
-
},
|
216
|
-
callback: this.customPopupCallback
|
217
|
-
}
|
218
|
-
}));
|
219
|
-
}
|
220
|
-
};
|
221
|
-
OxRecordCreator.styles = [
|
222
|
-
css `
|
223
|
-
::slotted([slot='popup']) {
|
224
|
-
display: none;
|
225
|
-
}
|
226
|
-
`
|
227
|
-
];
|
228
|
-
__decorate([
|
229
|
-
state()
|
230
|
-
], OxRecordCreator.prototype, "grist", void 0);
|
231
|
-
__decorate([
|
232
|
-
property({ type: Object })
|
233
|
-
], OxRecordCreator.prototype, "callback", void 0);
|
234
|
-
__decorate([
|
235
|
-
property({ type: Object })
|
236
|
-
], OxRecordCreator.prototype, "customPopupCallback", void 0);
|
237
|
-
__decorate([
|
238
|
-
property({ type: Boolean, attribute: 'light-popup' })
|
239
|
-
], OxRecordCreator.prototype, "lightPopup", void 0);
|
240
|
-
__decorate([
|
241
|
-
property({ type: Boolean, attribute: 'prevent-close-on-blur' })
|
242
|
-
], OxRecordCreator.prototype, "preventCloseOnBlur", void 0);
|
243
|
-
OxRecordCreator = __decorate([
|
244
|
-
customElement('ox-record-creator')
|
245
|
-
], OxRecordCreator);
|
246
|
-
export { OxRecordCreator };
|
247
|
-
//# sourceMappingURL=ox-record-creator.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ox-record-creator.js","sourceRoot":"","sources":["../../../src/record-view/ox-record-creator.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport './record-view.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { OxPopup } from '@operato/popup'\n\nimport { DataGrist } from '../data-grist.js'\nimport { ColumnConfig, GristRecord, ValidationReason } from '../types.js'\nimport { RecordView } from './record-view.js'\n\n@customElement('ox-record-creator')\nexport class OxRecordCreator extends LitElement {\n static styles = [\n css`\n ::slotted([slot='popup']) {\n display: none;\n }\n `\n ]\n\n @state() grist?: DataGrist\n\n @property({ type: Object }) callback?: (record: GristRecord) => boolean\n @property({ type: Object }) customPopupCallback?: (popup: any) => boolean\n @property({ type: Boolean, attribute: 'light-popup' }) lightPopup: boolean = false\n @property({ type: Boolean, attribute: 'prevent-close-on-blur' }) preventCloseOnBlur = false\n\n constructor() {\n super()\n\n this.addEventListener('click', (e: Event) => {\n e.preventDefault()\n e.stopPropagation()\n\n if (this.lightPopup) {\n this.openLightPopup()\n } else {\n this.openPopup()\n }\n })\n }\n\n connectedCallback(): void {\n super.connectedCallback()\n\n this.grist = this.closest('ox-grist') as DataGrist\n }\n\n render() {\n return html`\n <slot></slot>\n <slot name=\"popup\"></slot>\n `\n }\n\n validateRecord(record: GristRecord): { field: string; reason: ValidationReason }[] {\n const columns = this.grist!.compiledConfig.columns\n const invalidFields: { field: string; reason: ValidationReason }[] = []\n\n columns\n .filter(column => !column.hidden)\n .forEach(column => {\n if (\n column.record?.mandatory &&\n (record[column.name] === undefined || record[column.name] === null || record[column.name] === '')\n ) {\n invalidFields.push({\n field: column.name,\n reason: ValidationReason.MANDATORY\n })\n }\n })\n\n return invalidFields\n }\n\n openLightPopup() {\n const slot = this.renderRoot?.querySelector(`slot[name='popup']`) as HTMLSlotElement\n const slottedElements = slot?.assignedElements({ flatten: true })\n const originalContent = slottedElements?.[0] as HTMLElement\n\n if (originalContent) {\n this.lightPopupCustomCreator(originalContent)\n } else {\n this.lightPopupRecordView()\n }\n }\n\n openPopup() {\n const slot = this.renderRoot?.querySelector(`slot[name='popup']`) as HTMLSlotElement\n const slottedElements = slot?.assignedElements({ flatten: true })\n const originalContent = slottedElements?.[0] as HTMLElement\n\n if (originalContent) {\n this.popupCustomCreator(originalContent)\n } else {\n this.popupRecordView()\n }\n }\n\n lightPopupRecordView() {\n const config = this.grist!.compiledConfig\n var title = 'create'\n const rowIndex = -1\n var record: GristRecord = {}\n const columns = config.columns\n\n var popup = OxPopup.open({\n template: html`\n <div title>${title}</div>\n <ox-record-view\n @field-change=${(e: CustomEvent) => {\n const view = e.currentTarget as RecordView\n\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 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 view.record = {\n ...record,\n [column.name]: after\n }\n }}\n .columns=${columns}\n .record=${record}\n .rowIndex=${rowIndex}\n @reset=${(e: Event) => {\n const view = e.currentTarget as RecordView\n view.record = {}\n }}\n @cancel=${(e: Event) => {\n popup.close()\n }}\n @ok=${async (e: Event) => {\n const view = e.currentTarget as RecordView\n\n const invalidFields = await this.validateRecord(view.record)\n if (invalidFields.length > 0) {\n view.setFocusOnInvalid(invalidFields)\n return false\n }\n\n popup.close()\n\n this.dispatchEvent(\n new CustomEvent('ok', {\n bubbles: true,\n composed: true,\n detail: view.record\n })\n )\n }}\n ></ox-record-view>\n `,\n parent: document.body,\n preventCloseOnBlur: this.preventCloseOnBlur\n })\n }\n\n popupRecordView() {\n const config = this.grist!.compiledConfig\n const rowIndex = -1\n var record: GristRecord = {}\n const columns = config.columns\n\n var title = 'create'\n\n var recordView = document.createElement('ox-record-view') as RecordView\n\n recordView.columns = columns\n recordView.record = record\n recordView.rowIndex = rowIndex\n\n document.dispatchEvent(\n new CustomEvent('open-popup', {\n detail: {\n template: recordView,\n options: {\n backdrop: true,\n size: 'large',\n title\n },\n callback: (popup: any) => {\n recordView.addEventListener('reset', (e: Event) => {\n const view = e.currentTarget as RecordView\n view.record = {}\n })\n\n recordView.addEventListener('cancel', (e: Event) => {\n popup.close()\n })\n\n recordView.addEventListener('ok', async (e: Event) => {\n const view = e.currentTarget as RecordView\n\n const invalidFields = await this.validateRecord(view.record)\n if (invalidFields.length > 0) {\n view.setFocusOnInvalid(invalidFields)\n return false\n }\n\n if (await this.callback?.(view.record)) {\n popup.close()\n } else {\n console.error('validation failed')\n }\n })\n\n recordView.addEventListener('field-change', async (e: Event) => {\n const view = e.currentTarget as RecordView\n\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 var validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!(await validation.call(this, after, before, record, column))) {\n return\n }\n }\n\n view.record = {\n ...record,\n [column.name]: after\n }\n })\n\n popup.onclosed = () => {}\n }\n }\n })\n )\n }\n\n lightPopupCustomCreator(originalContent: HTMLElement) {\n const title = 'create'\n const popupContent = originalContent.cloneNode(true) as HTMLElement\n popupContent.removeAttribute('slot')\n\n OxPopup.open({\n template: html`\n <div title>${title}</div>\n ${popupContent}\n `,\n parent: document.body,\n preventCloseOnBlur: this.preventCloseOnBlur\n })\n\n this.customPopupCallback?.(popupContent) // 사용자 정의 팝업용 콜백 실행\n }\n\n popupCustomCreator(originalContent: HTMLElement) {\n const title = 'create'\n const popupContent = originalContent.cloneNode(true) as HTMLElement\n popupContent.removeAttribute('slot')\n\n document.dispatchEvent(\n new CustomEvent('open-popup', {\n detail: {\n template: popupContent,\n options: {\n backdrop: true,\n size: 'large',\n title\n },\n callback: this.customPopupCallback\n }\n })\n )\n }\n}\n"]}
|