@operato/data-grist 8.0.0-beta.0 → 8.0.0-beta.1

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 (164) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/package.json +10 -10
  3. package/.storybook/main.js +0 -3
  4. package/.storybook/preview.js +0 -52
  5. package/.storybook/server.mjs +0 -8
  6. package/src/accumulator/accumulator.ts +0 -63
  7. package/src/configure/column-builder.ts +0 -114
  8. package/src/configure/config-builder.ts +0 -40
  9. package/src/configure/filters-option-builder.ts +0 -8
  10. package/src/configure/imex-option-builder.ts +0 -5
  11. package/src/configure/list-option-builder.ts +0 -9
  12. package/src/configure/rows-option-builder.ts +0 -38
  13. package/src/configure/tree-option-builder.ts +0 -22
  14. package/src/configure/zero-config.ts +0 -83
  15. package/src/const.ts +0 -1
  16. package/src/data-card/data-card-field.ts +0 -94
  17. package/src/data-card/data-card-gutter-menu.ts +0 -94
  18. package/src/data-card/data-card-gutter.ts +0 -103
  19. package/src/data-card/data-card.ts +0 -154
  20. package/src/data-card/event-handlers/record-card-click-handler.ts +0 -34
  21. package/src/data-card/event-handlers/record-card-dblclick-handler.ts +0 -34
  22. package/src/data-card/record-card.ts +0 -298
  23. package/src/data-consumer.ts +0 -11
  24. package/src/data-grid/data-grid-accum-field.ts +0 -109
  25. package/src/data-grid/data-grid-body-style.ts +0 -85
  26. package/src/data-grid/data-grid-body.ts +0 -765
  27. package/src/data-grid/data-grid-field.ts +0 -227
  28. package/src/data-grid/data-grid-footer.ts +0 -119
  29. package/src/data-grid/data-grid-header.ts +0 -578
  30. package/src/data-grid/data-grid.ts +0 -293
  31. package/src/data-grid/event-handlers/data-grid-body-click-handler.ts +0 -69
  32. package/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.ts +0 -32
  33. package/src/data-grid/event-handlers/data-grid-body-dblclick-handler.ts +0 -42
  34. package/src/data-grid/event-handlers/data-grid-body-focus-change-handler.ts +0 -24
  35. package/src/data-grid/event-handlers/data-grid-body-keydown-handler.ts +0 -234
  36. package/src/data-grist.ts +0 -1233
  37. package/src/data-list/data-list-field.ts +0 -82
  38. package/src/data-list/data-list-gutter.ts +0 -108
  39. package/src/data-list/data-list.ts +0 -145
  40. package/src/data-list/event-handlers/record-partial-click-handler.ts +0 -34
  41. package/src/data-list/event-handlers/record-partial-dblclick-handler.ts +0 -33
  42. package/src/data-list/event-handlers/record-partial-long-press-handler.ts +0 -33
  43. package/src/data-list/record-partial.ts +0 -264
  44. package/src/data-manipulator.ts +0 -426
  45. package/src/data-provider.ts +0 -271
  46. package/src/data-report/data-report-body-style.ts +0 -58
  47. package/src/data-report/data-report-body.ts +0 -189
  48. package/src/data-report/data-report-component.ts +0 -138
  49. package/src/data-report/data-report-field.ts +0 -83
  50. package/src/data-report/data-report-header.ts +0 -242
  51. package/src/data-report/event-handlers/data-report-body-click-handler.ts +0 -38
  52. package/src/data-report/event-handlers/data-report-body-dblclick-handler.ts +0 -25
  53. package/src/data-report/event-handlers/data-report-body-keydown-handler.ts +0 -68
  54. package/src/data-report.ts +0 -424
  55. package/src/editors/index.ts +0 -4
  56. package/src/editors/ox-grist-editor-checkbox.ts +0 -28
  57. package/src/editors/ox-grist-editor-color.ts +0 -10
  58. package/src/editors/ox-grist-editor-date.ts +0 -10
  59. package/src/editors/ox-grist-editor-datetime.ts +0 -27
  60. package/src/editors/ox-grist-editor-email.ts +0 -10
  61. package/src/editors/ox-grist-editor-file.ts +0 -28
  62. package/src/editors/ox-grist-editor-image.ts +0 -31
  63. package/src/editors/ox-grist-editor-month.ts +0 -10
  64. package/src/editors/ox-grist-editor-multiple-select.ts +0 -57
  65. package/src/editors/ox-grist-editor-number.ts +0 -27
  66. package/src/editors/ox-grist-editor-password.ts +0 -10
  67. package/src/editors/ox-grist-editor-select.ts +0 -55
  68. package/src/editors/ox-grist-editor-tel.ts +0 -10
  69. package/src/editors/ox-grist-editor-text.ts +0 -14
  70. package/src/editors/ox-grist-editor-textarea.ts +0 -16
  71. package/src/editors/ox-grist-editor-time.ts +0 -10
  72. package/src/editors/ox-grist-editor-tree.ts +0 -27
  73. package/src/editors/ox-grist-editor-varname.ts +0 -36
  74. package/src/editors/ox-grist-editor-week.ts +0 -10
  75. package/src/editors/ox-grist-editor.ts +0 -207
  76. package/src/editors/ox-input-tree.ts +0 -226
  77. package/src/editors/registry.ts +0 -82
  78. package/src/empty-note.ts +0 -46
  79. package/src/filters/filter-checkbox.ts +0 -49
  80. package/src/filters/filter-input-barcode.ts +0 -34
  81. package/src/filters/filter-input.ts +0 -30
  82. package/src/filters/filter-range-date.ts +0 -81
  83. package/src/filters/filter-range-number.ts +0 -64
  84. package/src/filters/filter-select-buttons.ts +0 -60
  85. package/src/filters/filter-select.ts +0 -68
  86. package/src/filters/filter-styles.ts +0 -119
  87. package/src/filters/filters-form.ts +0 -476
  88. package/src/filters/index.ts +0 -10
  89. package/src/filters/registry.ts +0 -56
  90. package/src/formatters/date-formatter.ts +0 -3
  91. package/src/formatters/index.ts +0 -1
  92. package/src/formatters/number-formatter.ts +0 -3
  93. package/src/formatters/registry.ts +0 -30
  94. package/src/formatters/text-formatter.ts +0 -3
  95. package/src/gutters/gutter-button.ts +0 -51
  96. package/src/gutters/gutter-dirty.ts +0 -96
  97. package/src/gutters/gutter-row-selector.ts +0 -89
  98. package/src/gutters/gutter-sequence.ts +0 -54
  99. package/src/gutters/index.ts +0 -1
  100. package/src/gutters/registry.ts +0 -32
  101. package/src/handlers/contextmenu-tree-mutation.ts +0 -80
  102. package/src/handlers/index.ts +0 -1
  103. package/src/handlers/move-down.ts +0 -44
  104. package/src/handlers/move-up.ts +0 -44
  105. package/src/handlers/record-copy.ts +0 -38
  106. package/src/handlers/record-delete.ts +0 -30
  107. package/src/handlers/record-view-handler.ts +0 -27
  108. package/src/handlers/registry.ts +0 -42
  109. package/src/handlers/select-row-toggle.ts +0 -30
  110. package/src/handlers/select-row.ts +0 -27
  111. package/src/index.ts +0 -17
  112. package/src/personalizer/index.ts +0 -1
  113. package/src/personalizer/ox-grist-filter-personalizer.ts +0 -192
  114. package/src/personalizer/ox-grist-personalizer.ts +0 -226
  115. package/src/record-view/event-handlers/record-view-body-click-handler.ts +0 -33
  116. package/src/record-view/event-handlers/record-view-body-keydown-handler.ts +0 -26
  117. package/src/record-view/index.ts +0 -2
  118. package/src/record-view/ox-record-creator.ts +0 -289
  119. package/src/record-view/record-view-body.ts +0 -257
  120. package/src/record-view/record-view-handler.ts +0 -86
  121. package/src/record-view/record-view.ts +0 -122
  122. package/src/renderers/index.ts +0 -14
  123. package/src/renderers/ox-grist-renderer-boolean.ts +0 -43
  124. package/src/renderers/ox-grist-renderer-color.ts +0 -15
  125. package/src/renderers/ox-grist-renderer-date.ts +0 -62
  126. package/src/renderers/ox-grist-renderer-file.ts +0 -31
  127. package/src/renderers/ox-grist-renderer-image.ts +0 -27
  128. package/src/renderers/ox-grist-renderer-json5.ts +0 -36
  129. package/src/renderers/ox-grist-renderer-link.ts +0 -17
  130. package/src/renderers/ox-grist-renderer-password.ts +0 -7
  131. package/src/renderers/ox-grist-renderer-progress.ts +0 -45
  132. package/src/renderers/ox-grist-renderer-select.ts +0 -58
  133. package/src/renderers/ox-grist-renderer-text.ts +0 -16
  134. package/src/renderers/ox-grist-renderer-textarea.ts +0 -7
  135. package/src/renderers/ox-grist-renderer-tree.ts +0 -189
  136. package/src/renderers/ox-grist-renderer.ts +0 -35
  137. package/src/renderers/registry.ts +0 -111
  138. package/src/sorters/sorters-control.ts +0 -143
  139. package/src/types.ts +0 -813
  140. package/src/utils/index.ts +0 -2
  141. package/src/utils/list-param.ts +0 -72
  142. package/src/utils/supports-passive.ts +0 -13
  143. package/stories/accumulator-format.stories.ts +0 -276
  144. package/stories/barcode-input-filter.stories.ts +0 -216
  145. package/stories/bounded-select-filters.stories.ts +0 -333
  146. package/stories/bounded-select-record.stories.ts +0 -336
  147. package/stories/click-event-custom.stories.ts +0 -287
  148. package/stories/click-event.stories.ts +0 -283
  149. package/stories/creatable-only-column.stories.ts +0 -253
  150. package/stories/default-filters.stories.ts +0 -241
  151. package/stories/dynamic-editable.stories.ts +0 -313
  152. package/stories/empty-sorters.stories.ts +0 -180
  153. package/stories/explicit-fetch.stories.ts +0 -186
  154. package/stories/fixed-column.stories.ts +0 -416
  155. package/stories/grid-setting.stories.ts +0 -501
  156. package/stories/grist-modes.stories.ts +0 -451
  157. package/stories/group-header.stories.ts +0 -442
  158. package/stories/record-view.stories.ts +0 -143
  159. package/stories/textarea.stories.ts +0 -261
  160. package/stories/tree-column-with-checkbox.stories.ts +0 -297
  161. package/stories/tree-column.stories.ts +0 -296
  162. package/tsconfig.json +0 -26
  163. package/web-dev-server.config.mjs +0 -27
  164. package/web-test-runner.config.mjs +0 -45
@@ -1,27 +0,0 @@
1
- import { DataGridField } from '../data-grid/data-grid-field'
2
- import { ColumnConfig, GristData, GristRecord } from '../types'
3
-
4
- /*
5
- * handler들은 ox-grid-field 로부터 호출되는 것을 전제로 하며,
6
- * 전반적인 처리를 위해서, columns 및 data 정보를 포함해서 제공할 수 있어야 한다.
7
- */
8
-
9
- export const RecordViewHandler = function (
10
- columns: ColumnConfig[],
11
- data: GristData,
12
- column: ColumnConfig,
13
- record: GristRecord,
14
- rowIndex: number,
15
- field: DataGridField
16
- ): void {
17
- field.dispatchEvent(
18
- new CustomEvent('show-record-view', {
19
- bubbles: true,
20
- composed: true,
21
- detail: {
22
- record,
23
- row: rowIndex
24
- }
25
- })
26
- )
27
- }
@@ -1,42 +0,0 @@
1
- import { GristEventHandler } from '../types'
2
- import { ContextMenuTreeMutation } from './contextmenu-tree-mutation'
3
- import { MoveDown } from './move-down'
4
- import { MoveUp } from './move-up'
5
- import { RecordCopy } from './record-copy'
6
- import { RecordDelete } from './record-delete'
7
- import { RecordViewHandler } from './record-view-handler'
8
- import { SelectRow } from './select-row'
9
- import { SelectRowToggle } from './select-row-toggle'
10
-
11
- var HANDLERS: {
12
- [name: string]: GristEventHandler
13
- } = {
14
- 'record-view': RecordViewHandler as GristEventHandler,
15
- 'select-row': SelectRow as GristEventHandler,
16
- 'select-row-toggle': SelectRowToggle as GristEventHandler,
17
- 'move-up': MoveUp as GristEventHandler,
18
- 'move-down': MoveDown as GristEventHandler,
19
- 'record-copy': RecordCopy as GristEventHandler,
20
- 'record-delete': RecordDelete as GristEventHandler,
21
- 'contextmenu-tree-mutation': ContextMenuTreeMutation as GristEventHandler
22
- }
23
-
24
- export function registerGristEventHandler(type: string, handler: GristEventHandler) {
25
- HANDLERS[type] = handler
26
- }
27
-
28
- export function unregisterGristEventHandler(type: string) {
29
- delete HANDLERS[type]
30
- }
31
-
32
- export function getGristEventHandlers() {
33
- return { ...HANDLERS }
34
- }
35
-
36
- export function getGristEventHandler(type: string | GristEventHandler): GristEventHandler {
37
- if (typeof type == 'function') {
38
- return type
39
- }
40
-
41
- return HANDLERS[type]
42
- }
@@ -1,30 +0,0 @@
1
- import { DataGridField } from '../data-grid/data-grid-field'
2
- import { ColumnConfig, GristData, GristRecord } from '../types'
3
-
4
- /*
5
- * handler들은 ox-grid-field 로부터 호출되는 것을 전제로 하며,
6
- * 전반적인 처리를 위해서, columns 및 data 정보를 포함해서 제공할 수 있어야 한다.
7
- */
8
-
9
- export const SelectRowToggle = function (
10
- columns: ColumnConfig[],
11
- data: GristData,
12
- column: ColumnConfig,
13
- record: GristRecord,
14
- rowIndex: number,
15
- field: DataGridField
16
- ): void {
17
- field?.dispatchEvent(
18
- new CustomEvent('select-record-change', {
19
- bubbles: true,
20
- composed: true,
21
- detail: record['__selected__']
22
- ? {
23
- removed: [record]
24
- }
25
- : {
26
- added: [record]
27
- }
28
- })
29
- )
30
- }
@@ -1,27 +0,0 @@
1
- import { ColumnConfig, GristData, GristRecord } from '../types'
2
-
3
- import { DataGridField } from '../data-grid/data-grid-field'
4
-
5
- /*
6
- * handler들은 ox-grid-field 로부터 호출되는 것을 전제로 하며,
7
- * 전반적인 처리를 위해서, columns 및 data 정보를 포함해서 제공할 수 있어야 한다.
8
- */
9
-
10
- export const SelectRow = function (
11
- columns: ColumnConfig[],
12
- data: GristData,
13
- column: ColumnConfig,
14
- record: GristRecord,
15
- rowIndex: number,
16
- field: DataGridField
17
- ): void {
18
- field.dispatchEvent(
19
- new CustomEvent('select-record-change', {
20
- bubbles: true,
21
- composed: true,
22
- detail: {
23
- added: [record]
24
- }
25
- })
26
- )
27
- }
package/src/index.ts DELETED
@@ -1,17 +0,0 @@
1
- export * from './types'
2
-
3
- export * from './configure/zero-config'
4
- export * from './data-grist'
5
- export * from './data-report'
6
-
7
- export * from './editors'
8
- export * from './renderers'
9
- export * from './handlers'
10
- export * from './formatters'
11
- export * from './gutters'
12
- export * from './filters'
13
- export * from './sorters/sorters-control'
14
- export * from './record-view'
15
- export * from './personalizer'
16
-
17
- export * from './utils/list-param'
@@ -1 +0,0 @@
1
- export * from './ox-grist-personalizer'
@@ -1,192 +0,0 @@
1
- import '@material/web/button/outlined-button.js'
2
-
3
- import { css, html, LitElement } from 'lit'
4
- import { customElement, property, state } from 'lit/decorators.js'
5
-
6
- import { i18next } from '@operato/i18n'
7
- import { OxPopupList } from '@operato/popup'
8
-
9
- import { FilterConfigObject, FilterPreference, PersonalGristPreference } from '../types.js'
10
-
11
- import { OxFiltersForm } from '../filters/filters-form'
12
-
13
- @customElement('ox-grist-filter-personalizer')
14
- export class OxGristFilterPersonalizer extends LitElement {
15
- static styles = [
16
- css`
17
- md-icon {
18
- --md-icon-size: 16px;
19
- width: 36px;
20
- height: 36px;
21
- color: var(--md-sys-color-secondary-container);
22
- cursor: pointer;
23
-
24
- display: flex;
25
- place-content: center;
26
- place-items: center;
27
- position: relative;
28
-
29
- &:hover {
30
- color: var(--md-sys-color-primary-container);
31
- }
32
- }
33
-
34
- md-ripple {
35
- border-radius: 50%;
36
- inset: unset;
37
- height: 36px;
38
- width: 36px;
39
- }
40
- `
41
- ]
42
-
43
- @property({ type: Boolean, attribute: true }) debug: boolean = false
44
-
45
- @state() private preference?: PersonalGristPreference
46
-
47
- render() {
48
- return html`
49
- <md-icon
50
- @click=${async (e: MouseEvent) => {
51
- const form = this.closest('ox-filters-form') as OxFiltersForm
52
- const { filterColumns, personalFilters = [] } = form
53
- const queryFilters = await form.getQueryFilters()
54
-
55
- this.preference = {
56
- filters: (
57
- personalFilters.map((filter: FilterPreference) => {
58
- const originFilterColumn =
59
- filter.name == 'search'
60
- ? { filter: { name: 'search' } }
61
- : filterColumns.find(f => f.name == filter.name)
62
-
63
- if (!originFilterColumn) {
64
- /* 원래 filters 설정에 있는 것들 만을 유지한다. */
65
- return
66
- }
67
-
68
- const { value } = originFilterColumn.filter! as FilterConfigObject
69
-
70
- return {
71
- name: filter.name,
72
- hidden: filter.hidden,
73
- /* 만약, filters에 기본값이 이미 설정되어 있다면, 그대로 유지한다. */
74
- value: value ?? queryFilters.find(f => f.name == filter.name)?.value
75
- }
76
- }) || []
77
- ).filter(Boolean) as FilterPreference[]
78
- }
79
-
80
- const template = html`
81
- <div class="personalizer-header" slot="header">
82
- <md-icon
83
- style="margin-left: auto;"
84
- @click=${async (e: MouseEvent) => {
85
- if (form.personalConfigProvider) {
86
- form.personalConfig = await form.personalConfigProvider.save(this.preference)
87
- }
88
- popup.close()
89
- }}
90
- title=${String(i18next.t('button.save'))}
91
- >keep</md-icon
92
- ><md-icon
93
- @click=${async (e: MouseEvent) => {
94
- if (form.personalConfigProvider) {
95
- form.personalConfig = this.preference = {}
96
- await form.personalConfigProvider.reset()
97
- }
98
- popup.close()
99
- }}
100
- title=${String(i18next.t('button.delete'))}
101
- >keep_off</md-icon
102
- ><md-icon @click=${async (e: MouseEvent) => popup.close()} title=${String(i18next.t('button.close'))}
103
- >close</md-icon
104
- >
105
- </div>
106
-
107
- ${this.preference?.filters!.map(
108
- filter => html`
109
- <ox-checkbox label="checkbox" ?checked=${!filter.hidden} value=${filter.name} option
110
- >${filter.name}<span style="position: absolute; right: 10px; cursor: row-resize;opacity:.5" handle
111
- >☰</span
112
- ></ox-checkbox
113
- >
114
- `
115
- )}
116
- `
117
-
118
- const popup = OxPopupList.open({
119
- template,
120
- multiple: true,
121
- sortable: true,
122
- debug: this.debug,
123
- attrSelected: 'checked',
124
- top: e.pageY,
125
- left: e.pageX,
126
- styles: css`
127
- :host {
128
- width: 240px;
129
- min-height: 300px;
130
- max-height: 80%;
131
- overflow: auto;
132
- }
133
-
134
- ::slotted(.personalizer-header) {
135
- --md-icon-size: 1.4em;
136
-
137
- display: flex;
138
- flex-direction: row;
139
- align-items: center;
140
- text-transform: capitalize;
141
- box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);
142
- }
143
-
144
- ::slotted([option]) {
145
- position: relative;
146
- user-select: none;
147
- }
148
- `
149
- })
150
-
151
- popup.onselect = (e: Event) => {
152
- const selected = (e as CustomEvent).detail
153
-
154
- const pconfig: PersonalGristPreference = { ...form.personalConfig }
155
- const pfilters = this.preference?.filters!
156
-
157
- pconfig.filters = pfilters.map(filter => {
158
- return {
159
- name: filter.name,
160
- hidden: selected.indexOf(filter.name) == -1,
161
- value: filter.value
162
- }
163
- })
164
-
165
- form.personalConfig = this.preference = pconfig
166
-
167
- form.applyUpdatedConfiguration()
168
- }
169
-
170
- popup.addEventListener('sorted', (e: Event) => {
171
- const sorted = (e as CustomEvent).detail as HTMLElement[]
172
-
173
- const pconfig: PersonalGristPreference = { ...form.personalConfig }
174
- const pfilters = this.preference?.filters!
175
-
176
- pconfig.filters = sorted
177
- .map(element => {
178
- const name = (element as HTMLInputElement).value
179
- return pfilters.find(filter => filter.name == name)!
180
- })
181
- .filter(Boolean)
182
-
183
- form.personalConfig = this.preference = pconfig
184
-
185
- form.applyUpdatedConfiguration()
186
- })
187
- }}
188
- >settings<md-ripple></md-ripple
189
- ></md-icon>
190
- `
191
- }
192
- }
@@ -1,226 +0,0 @@
1
- import '@material/web/button/outlined-button.js'
2
-
3
- import { css, html, LitElement } from 'lit'
4
- import { customElement, property, state } from 'lit/decorators.js'
5
-
6
- import { i18next } from '@operato/i18n'
7
- import { OxPopupList } from '@operato/popup'
8
- import { OxCheckbox } from '@operato/input'
9
-
10
- import { ColumnConfig, PersonalGristPreference } from '../types'
11
- import { DataGrist } from '../data-grist'
12
-
13
- @customElement('ox-grist-personalizer')
14
- export class OxGristPersonalizer extends LitElement {
15
- static styles = [
16
- css`
17
- md-icon {
18
- --md-icon-size: 14px;
19
- width: 16px;
20
- height: 16px;
21
- color: var(--ox-grist-p13n-color, var(--md-sys-color-on-primary));
22
- background-color: var(--ox-grist-p13n-background-color, var(--md-sys-color-primary));
23
- border-radius: 0px 0px 7px 7px;
24
- cursor: pointer;
25
- padding-top: var(--spacing-small);
26
-
27
- &:hover {
28
- color: var(--ox-grist-p13n-hover-color, var(--md-sys-color-on-primary));
29
- background-color: var(--ox-grist-p13n-hover-background-color, var(--md-sys-color-surface-tint));
30
- }
31
- }
32
- `
33
- ]
34
-
35
- @property({ type: Boolean, attribute: true }) debug: boolean = false
36
-
37
- @state() private preference?: PersonalGristPreference
38
-
39
- render() {
40
- return html`
41
- <md-icon
42
- @click=${(e: MouseEvent) => {
43
- const grist = this.closest('ox-grist') as DataGrist
44
-
45
- const { config, compiledConfig, sorters, pagination, mode } = grist
46
- const { columns: compiledColumns } = compiledConfig
47
-
48
- const columns = compiledColumns
49
- .filter(ccolumn => {
50
- const column = config.columns.find((column: Partial<ColumnConfig>) => column.name == ccolumn.name)
51
- return column && column.name && column.type !== 'gutter' && !column.hidden && !column.unusable
52
- })
53
- .map(column => compiledColumns.find(compiledColumn => compiledColumn.name == column.name)!)
54
-
55
- this.preference = {
56
- columns: columns.map(column => {
57
- return {
58
- name: column.name,
59
- hidden: column.hidden,
60
- width: column.width
61
- }
62
- }),
63
- sorters,
64
- pagination: {
65
- ...pagination,
66
- limit: grist.getCurrentLimit()
67
- },
68
- mode
69
- }
70
-
71
- const template = html`
72
- <div class="personalizer-header" slot="header">
73
- <div
74
- style=${`
75
- display: flex;
76
- align-items: center;
77
- margin: 0 0 0 auto;
78
- min-height: 1.4em;
79
- color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));
80
- background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));
81
- border-radius: var(--md-sys-shape-corner-small);
82
- padding: 0 var(--spacing-small);
83
- cursor: pointer;
84
- `}
85
- @click=${async (e: MouseEvent) => {
86
- if (grist.personalConfigProvider) {
87
- const { mode, columns, sorters, pagination } = this.preference || {}
88
- grist.personalConfig = this.preference = await grist.personalConfigProvider.save({
89
- mode,
90
- columns,
91
- sorters,
92
- pagination
93
- })
94
- }
95
- popup.close()
96
- }}
97
- >
98
- ${String(i18next.t('button.save'))}
99
- </div>
100
- <div
101
- style=${`
102
- display: flex;
103
- align-items: center;
104
- margin: 0 0 0 var(--spacing-small, 4px);
105
- min-height: 1.4em;
106
- color: var(--ox-grist-p13n-button-color, var(--md-sys-color-on-primary));
107
- background-color: var(--ox-grist-p13n-button-background-color, var(--md-sys-color-primary));
108
- border-radius: var(--md-sys-shape-corner-small);
109
- padding: 0 var(--spacing-small);
110
- cursor: pointer;
111
- `}
112
- @click=${async (e: MouseEvent) => {
113
- if (grist.personalConfigProvider) {
114
- grist.personalConfig = this.preference = {}
115
- await grist.personalConfigProvider.reset()
116
- }
117
- popup.close()
118
- }}
119
- >
120
- ${String(i18next.t('button.delete'))}
121
- </div>
122
- <md-icon
123
- style=${`
124
- --md-icon-size: 1.2em;
125
- margin-left: var(--spacing-tiny, 2px);
126
- cursor: pointer;
127
- `}
128
- @click=${async (e: MouseEvent) => popup.close()}
129
- title=${String(i18next.t('button.close'))}
130
- >close</md-icon
131
- >
132
- </div>
133
-
134
- ${columns.map(
135
- column => html`
136
- <ox-checkbox label="checkbox" ?checked=${!column.hidden} value=${column.name} option
137
- >${column.header.renderer(column)}<span
138
- style="position: absolute; right: 10px; cursor: row-resize;opacity:.5"
139
- handle
140
- >☰</span
141
- ></ox-checkbox
142
- >
143
- `
144
- )}
145
- `
146
-
147
- const popup = OxPopupList.open({
148
- template,
149
- multiple: true,
150
- sortable: true,
151
- debug: this.debug,
152
- attrSelected: 'checked',
153
- top: e.pageY,
154
- left: e.pageX,
155
- styles: css`
156
- :host {
157
- width: 240px;
158
- min-height: 300px;
159
- max-height: 80%;
160
- overflow: auto;
161
- }
162
-
163
- ::slotted(.personalizer-header) {
164
- --md-icon-size: 1.4em;
165
-
166
- display: flex;
167
- flex-direction: row;
168
- align-items: center;
169
- text-transform: capitalize;
170
- box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);
171
- }
172
-
173
- ::slotted([option]) {
174
- position: relative;
175
- user-select: none;
176
- }
177
- `
178
- })
179
-
180
- popup.onselect = (e: Event) => {
181
- const selected = (e as CustomEvent).detail
182
-
183
- const pconfig: PersonalGristPreference = grist.personalConfig || {}
184
- const pcolumns = this.preference?.columns || columns
185
-
186
- pconfig.columns = pcolumns.map(column => {
187
- return {
188
- name: column.name,
189
- hidden: selected.indexOf(column.name) == -1,
190
- width: column.width
191
- }
192
- })
193
-
194
- this.preference = pconfig
195
-
196
- grist.personalConfig = this.preference
197
-
198
- grist.applyUpdatedConfiguration()
199
- }
200
-
201
- popup.addEventListener('sorted', (e: Event) => {
202
- const sorted = (e as CustomEvent).detail as HTMLElement[]
203
-
204
- const pconfig: PersonalGristPreference = grist.personalConfig || {}
205
-
206
- pconfig.columns = sorted.map(element => {
207
- const name = (element as OxCheckbox).value
208
- return {
209
- name,
210
- hidden: !element.hasAttribute('checked'),
211
- width: columns.find(column => column.name == name)?.width
212
- }
213
- })
214
-
215
- this.preference = pconfig
216
-
217
- grist.personalConfig = this.preference
218
-
219
- grist.applyUpdatedConfiguration()
220
- })
221
- }}
222
- >settings</md-icon
223
- >
224
- `
225
- }
226
- }
@@ -1,33 +0,0 @@
1
- import { DataGridField } from '../../data-grid/data-grid-field'
2
- import { RecordViewBody } from '../record-view-body'
3
-
4
- /**
5
- * ox-record-view-body 의 click handler
6
- *
7
- * - handler의 this 는 ox-record-view-body임.
8
- */
9
- export function recordViewBodyClickHandler(this: RecordViewBody, e: Event): void {
10
- e.stopPropagation()
11
-
12
- /* target should be 'ox-grid-field' */
13
- var target = e.target as DataGridField
14
-
15
- if (this.currentTarget) {
16
- this.focus()
17
- this.currentTarget.removeAttribute('editing')
18
- }
19
-
20
- let editable = target?.column?.record.editable
21
- if (typeof editable === 'function') {
22
- editable = editable.call(this, target.value, target.column, target.record, target.rowIndex, this)
23
- }
24
-
25
- if (target.tagName !== 'OX-GRID-FIELD' || !editable) {
26
- this.focus()
27
- this.currentTarget = null
28
- return
29
- }
30
-
31
- this.currentTarget = target
32
- target.setAttribute('editing', 'true')
33
- }
@@ -1,26 +0,0 @@
1
- import { RecordViewBody } from '../record-view-body'
2
-
3
- /**
4
- * ox-record-view-body 의 keydown handler
5
- *
6
- * - handler의 this 는 ox-record-view-body임.
7
- */
8
- export async function recordViewBodyKeydownHandler(this: RecordViewBody, e: Event): Promise<void> {
9
- switch ((e as KeyboardEvent).key) {
10
- case 'Esc':
11
- case 'Escape':
12
- /* TODO 편집이 취소되어야 한다. */
13
- case 'Enter':
14
- /* 먼저, focus를 옮겨놓아야, focusout 으로 인해서 popup이 닫히는 것을 방지할 수 있다. */
15
- this.focus()
16
-
17
- if (this.currentTarget) {
18
- this.currentTarget.removeAttribute('editing')
19
- }
20
-
21
- this.currentTarget = null
22
-
23
- break
24
- default:
25
- }
26
- }
@@ -1,2 +0,0 @@
1
- export * from './record-view'
2
- export * from './ox-record-creator'