@operato/data-grist 7.1.31 → 7.1.32

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 (173) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/tsconfig.tsbuildinfo +1 -1
  3. package/package.json +10 -10
  4. package/.storybook/main.js +0 -3
  5. package/.storybook/preview.js +0 -52
  6. package/.storybook/server.mjs +0 -8
  7. package/demo/data-grist-test.html +0 -468
  8. package/demo/favicon.ico +0 -0
  9. package/demo/index.html +0 -541
  10. package/demo/report-test.html +0 -249
  11. package/dist/src/record-view/record-creator.d.ts +0 -17
  12. package/dist/src/record-view/record-creator.js +0 -148
  13. package/dist/src/record-view/record-creator.js.map +0 -1
  14. package/src/accumulator/accumulator.ts +0 -63
  15. package/src/configure/column-builder.ts +0 -114
  16. package/src/configure/config-builder.ts +0 -40
  17. package/src/configure/filters-option-builder.ts +0 -8
  18. package/src/configure/imex-option-builder.ts +0 -5
  19. package/src/configure/list-option-builder.ts +0 -9
  20. package/src/configure/rows-option-builder.ts +0 -38
  21. package/src/configure/tree-option-builder.ts +0 -22
  22. package/src/configure/zero-config.ts +0 -83
  23. package/src/const.ts +0 -1
  24. package/src/data-card/data-card-field.ts +0 -94
  25. package/src/data-card/data-card-gutter-menu.ts +0 -94
  26. package/src/data-card/data-card-gutter.ts +0 -103
  27. package/src/data-card/data-card.ts +0 -154
  28. package/src/data-card/event-handlers/record-card-click-handler.ts +0 -34
  29. package/src/data-card/event-handlers/record-card-dblclick-handler.ts +0 -34
  30. package/src/data-card/record-card.ts +0 -289
  31. package/src/data-consumer.ts +0 -11
  32. package/src/data-grid/data-grid-accum-field.ts +0 -109
  33. package/src/data-grid/data-grid-body-style.ts +0 -99
  34. package/src/data-grid/data-grid-body.ts +0 -753
  35. package/src/data-grid/data-grid-field.ts +0 -236
  36. package/src/data-grid/data-grid-footer.ts +0 -117
  37. package/src/data-grid/data-grid-header.ts +0 -574
  38. package/src/data-grid/data-grid.ts +0 -293
  39. package/src/data-grid/event-handlers/data-grid-body-click-handler.ts +0 -69
  40. package/src/data-grid/event-handlers/data-grid-body-contextmenu-handler.ts +0 -32
  41. package/src/data-grid/event-handlers/data-grid-body-dblclick-handler.ts +0 -42
  42. package/src/data-grid/event-handlers/data-grid-body-focus-change-handler.ts +0 -24
  43. package/src/data-grid/event-handlers/data-grid-body-keydown-handler.ts +0 -234
  44. package/src/data-grist.ts +0 -1233
  45. package/src/data-list/data-list-field.ts +0 -82
  46. package/src/data-list/data-list-gutter.ts +0 -108
  47. package/src/data-list/data-list.ts +0 -145
  48. package/src/data-list/event-handlers/record-partial-click-handler.ts +0 -34
  49. package/src/data-list/event-handlers/record-partial-dblclick-handler.ts +0 -33
  50. package/src/data-list/event-handlers/record-partial-long-press-handler.ts +0 -33
  51. package/src/data-list/record-partial.ts +0 -255
  52. package/src/data-manipulator.ts +0 -426
  53. package/src/data-provider.ts +0 -271
  54. package/src/data-report/data-report-body-style.ts +0 -58
  55. package/src/data-report/data-report-body.ts +0 -189
  56. package/src/data-report/data-report-component.ts +0 -138
  57. package/src/data-report/data-report-field.ts +0 -83
  58. package/src/data-report/data-report-header.ts +0 -242
  59. package/src/data-report/event-handlers/data-report-body-click-handler.ts +0 -38
  60. package/src/data-report/event-handlers/data-report-body-dblclick-handler.ts +0 -25
  61. package/src/data-report/event-handlers/data-report-body-keydown-handler.ts +0 -68
  62. package/src/data-report.ts +0 -424
  63. package/src/editors/index.ts +0 -4
  64. package/src/editors/ox-grist-editor-checkbox.ts +0 -28
  65. package/src/editors/ox-grist-editor-color.ts +0 -10
  66. package/src/editors/ox-grist-editor-date.ts +0 -10
  67. package/src/editors/ox-grist-editor-datetime.ts +0 -27
  68. package/src/editors/ox-grist-editor-email.ts +0 -10
  69. package/src/editors/ox-grist-editor-file.ts +0 -28
  70. package/src/editors/ox-grist-editor-image.ts +0 -31
  71. package/src/editors/ox-grist-editor-month.ts +0 -10
  72. package/src/editors/ox-grist-editor-multiple-select.ts +0 -57
  73. package/src/editors/ox-grist-editor-number.ts +0 -27
  74. package/src/editors/ox-grist-editor-password.ts +0 -10
  75. package/src/editors/ox-grist-editor-select.ts +0 -55
  76. package/src/editors/ox-grist-editor-tel.ts +0 -10
  77. package/src/editors/ox-grist-editor-text.ts +0 -14
  78. package/src/editors/ox-grist-editor-textarea.ts +0 -16
  79. package/src/editors/ox-grist-editor-time.ts +0 -10
  80. package/src/editors/ox-grist-editor-tree.ts +0 -27
  81. package/src/editors/ox-grist-editor-varname.ts +0 -36
  82. package/src/editors/ox-grist-editor-week.ts +0 -10
  83. package/src/editors/ox-grist-editor.ts +0 -207
  84. package/src/editors/ox-input-tree.ts +0 -226
  85. package/src/editors/registry.ts +0 -82
  86. package/src/empty-note.ts +0 -46
  87. package/src/filters/filter-checkbox.ts +0 -49
  88. package/src/filters/filter-input-barcode.ts +0 -34
  89. package/src/filters/filter-input.ts +0 -30
  90. package/src/filters/filter-range-date.ts +0 -81
  91. package/src/filters/filter-range-number.ts +0 -64
  92. package/src/filters/filter-select-buttons.ts +0 -60
  93. package/src/filters/filter-select.ts +0 -68
  94. package/src/filters/filter-styles.ts +0 -119
  95. package/src/filters/filters-form.ts +0 -476
  96. package/src/filters/index.ts +0 -10
  97. package/src/filters/registry.ts +0 -56
  98. package/src/formatters/date-formatter.ts +0 -3
  99. package/src/formatters/index.ts +0 -1
  100. package/src/formatters/number-formatter.ts +0 -3
  101. package/src/formatters/registry.ts +0 -30
  102. package/src/formatters/text-formatter.ts +0 -3
  103. package/src/gutters/gutter-button.ts +0 -51
  104. package/src/gutters/gutter-dirty.ts +0 -96
  105. package/src/gutters/gutter-row-selector.ts +0 -89
  106. package/src/gutters/gutter-sequence.ts +0 -54
  107. package/src/gutters/index.ts +0 -1
  108. package/src/gutters/registry.ts +0 -32
  109. package/src/handlers/contextmenu-tree-mutation.ts +0 -80
  110. package/src/handlers/index.ts +0 -1
  111. package/src/handlers/move-down.ts +0 -44
  112. package/src/handlers/move-up.ts +0 -44
  113. package/src/handlers/record-copy.ts +0 -38
  114. package/src/handlers/record-delete.ts +0 -30
  115. package/src/handlers/record-view-handler.ts +0 -27
  116. package/src/handlers/registry.ts +0 -42
  117. package/src/handlers/select-row-toggle.ts +0 -30
  118. package/src/handlers/select-row.ts +0 -27
  119. package/src/index.ts +0 -17
  120. package/src/personalizer/index.ts +0 -1
  121. package/src/personalizer/ox-grist-filter-personalizer.ts +0 -192
  122. package/src/personalizer/ox-grist-personalizer.ts +0 -226
  123. package/src/record-view/event-handlers/record-view-body-click-handler.ts +0 -33
  124. package/src/record-view/event-handlers/record-view-body-keydown-handler.ts +0 -26
  125. package/src/record-view/index.ts +0 -2
  126. package/src/record-view/ox-record-creator.ts +0 -289
  127. package/src/record-view/record-view-body.ts +0 -250
  128. package/src/record-view/record-view-handler.ts +0 -86
  129. package/src/record-view/record-view.ts +0 -122
  130. package/src/renderers/index.ts +0 -14
  131. package/src/renderers/ox-grist-renderer-boolean.ts +0 -43
  132. package/src/renderers/ox-grist-renderer-color.ts +0 -15
  133. package/src/renderers/ox-grist-renderer-date.ts +0 -62
  134. package/src/renderers/ox-grist-renderer-file.ts +0 -31
  135. package/src/renderers/ox-grist-renderer-image.ts +0 -27
  136. package/src/renderers/ox-grist-renderer-json5.ts +0 -36
  137. package/src/renderers/ox-grist-renderer-link.ts +0 -17
  138. package/src/renderers/ox-grist-renderer-password.ts +0 -7
  139. package/src/renderers/ox-grist-renderer-progress.ts +0 -45
  140. package/src/renderers/ox-grist-renderer-select.ts +0 -58
  141. package/src/renderers/ox-grist-renderer-text.ts +0 -16
  142. package/src/renderers/ox-grist-renderer-textarea.ts +0 -7
  143. package/src/renderers/ox-grist-renderer-tree.ts +0 -189
  144. package/src/renderers/ox-grist-renderer.ts +0 -35
  145. package/src/renderers/registry.ts +0 -111
  146. package/src/sorters/sorters-control.ts +0 -143
  147. package/src/types.ts +0 -813
  148. package/src/utils/index.ts +0 -2
  149. package/src/utils/list-param.ts +0 -72
  150. package/src/utils/supports-passive.ts +0 -13
  151. package/stories/accumulator-format.stories.ts +0 -276
  152. package/stories/barcode-input-filter.stories.ts +0 -216
  153. package/stories/bounded-select-filters.stories.ts +0 -333
  154. package/stories/bounded-select-record.stories.ts +0 -336
  155. package/stories/click-event-custom.stories.ts +0 -288
  156. package/stories/click-event.stories.ts +0 -283
  157. package/stories/creatable-only-column.stories.ts +0 -253
  158. package/stories/default-filters.stories.ts +0 -241
  159. package/stories/dynamic-editable.stories.ts +0 -313
  160. package/stories/empty-sorters.stories.ts +0 -180
  161. package/stories/explicit-fetch.stories.ts +0 -186
  162. package/stories/fixed-column.stories.ts +0 -416
  163. package/stories/grid-setting.stories.ts +0 -501
  164. package/stories/grist-modes.stories.ts +0 -451
  165. package/stories/group-header.stories.ts +0 -442
  166. package/stories/record-view.stories.ts +0 -143
  167. package/stories/textarea.stories.ts +0 -261
  168. package/stories/tree-column-with-checkbox.stories.ts +0 -297
  169. package/stories/tree-column.stories.ts +0 -296
  170. package/tsconfig.json +0 -26
  171. package/web-dev-server.config.mjs +0 -27
  172. package/web-test-runner.config.mjs +0 -45
  173. package/yarn-error.log +0 -16971
@@ -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'