@operato/data-grist 9.0.0-beta.7 → 9.0.0-beta.85

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 (87) hide show
  1. package/CHANGELOG.md +285 -0
  2. package/README.md +337 -44
  3. package/dist/src/data-grid/data-grid-body.js +39 -27
  4. package/dist/src/data-grid/data-grid-body.js.map +1 -1
  5. package/dist/src/data-grid/data-grid-header.js +9 -0
  6. package/dist/src/data-grid/data-grid-header.js.map +1 -1
  7. package/dist/src/data-grist.d.ts +13 -1
  8. package/dist/src/data-grist.js +42 -0
  9. package/dist/src/data-grist.js.map +1 -1
  10. package/dist/src/data-report.js +4 -4
  11. package/dist/src/data-report.js.map +1 -1
  12. package/dist/src/editors/ox-grist-editor-json5.d.ts +8 -0
  13. package/dist/src/editors/ox-grist-editor-json5.js +66 -0
  14. package/dist/src/editors/ox-grist-editor-json5.js.map +1 -0
  15. package/dist/src/editors/ox-popup-code-input.d.ts +14 -0
  16. package/dist/src/editors/ox-popup-code-input.js +78 -0
  17. package/dist/src/editors/ox-popup-code-input.js.map +1 -0
  18. package/dist/src/editors/registry.js +3 -1
  19. package/dist/src/editors/registry.js.map +1 -1
  20. package/dist/src/filters/filter-select.js +2 -1
  21. package/dist/src/filters/filter-select.js.map +1 -1
  22. package/dist/src/formatters/registry.d.ts +1 -1
  23. package/dist/src/gutters/registry.d.ts +1 -1
  24. package/dist/src/handlers/registry.d.ts +1 -1
  25. package/dist/tsconfig.tsbuildinfo +1 -1
  26. package/package.json +18 -14
  27. package/dist/index.d.ts +0 -1
  28. package/dist/index.js +0 -2
  29. package/dist/index.js.map +0 -1
  30. package/dist/stories/accumulator-format.stories.d.ts +0 -41
  31. package/dist/stories/accumulator-format.stories.js +0 -237
  32. package/dist/stories/accumulator-format.stories.js.map +0 -1
  33. package/dist/stories/barcode-input-filter.stories.d.ts +0 -33
  34. package/dist/stories/barcode-input-filter.stories.js +0 -185
  35. package/dist/stories/barcode-input-filter.stories.js.map +0 -1
  36. package/dist/stories/bounded-select-filters.stories.d.ts +0 -25
  37. package/dist/stories/bounded-select-filters.stories.js +0 -283
  38. package/dist/stories/bounded-select-filters.stories.js.map +0 -1
  39. package/dist/stories/bounded-select-record.stories.d.ts +0 -25
  40. package/dist/stories/bounded-select-record.stories.js +0 -286
  41. package/dist/stories/bounded-select-record.stories.js.map +0 -1
  42. package/dist/stories/click-event-custom.stories.d.ts +0 -45
  43. package/dist/stories/click-event-custom.stories.js +0 -248
  44. package/dist/stories/click-event-custom.stories.js.map +0 -1
  45. package/dist/stories/click-event.stories.d.ts +0 -45
  46. package/dist/stories/click-event.stories.js +0 -243
  47. package/dist/stories/click-event.stories.js.map +0 -1
  48. package/dist/stories/creatable-only-column.stories.d.ts +0 -29
  49. package/dist/stories/creatable-only-column.stories.js +0 -232
  50. package/dist/stories/creatable-only-column.stories.js.map +0 -1
  51. package/dist/stories/default-filters.stories.d.ts +0 -26
  52. package/dist/stories/default-filters.stories.js +0 -219
  53. package/dist/stories/default-filters.stories.js.map +0 -1
  54. package/dist/stories/dynamic-editable.stories.d.ts +0 -25
  55. package/dist/stories/dynamic-editable.stories.js +0 -293
  56. package/dist/stories/dynamic-editable.stories.js.map +0 -1
  57. package/dist/stories/empty-sorters.stories.d.ts +0 -25
  58. package/dist/stories/empty-sorters.stories.js +0 -162
  59. package/dist/stories/empty-sorters.stories.js.map +0 -1
  60. package/dist/stories/explicit-fetch.stories.d.ts +0 -25
  61. package/dist/stories/explicit-fetch.stories.js +0 -166
  62. package/dist/stories/explicit-fetch.stories.js.map +0 -1
  63. package/dist/stories/fixed-column.stories.d.ts +0 -26
  64. package/dist/stories/fixed-column.stories.js +0 -383
  65. package/dist/stories/fixed-column.stories.js.map +0 -1
  66. package/dist/stories/grid-setting.stories.d.ts +0 -47
  67. package/dist/stories/grid-setting.stories.js +0 -453
  68. package/dist/stories/grid-setting.stories.js.map +0 -1
  69. package/dist/stories/grist-modes.stories.d.ts +0 -37
  70. package/dist/stories/grist-modes.stories.js +0 -416
  71. package/dist/stories/grist-modes.stories.js.map +0 -1
  72. package/dist/stories/group-header.stories.d.ts +0 -26
  73. package/dist/stories/group-header.stories.js +0 -410
  74. package/dist/stories/group-header.stories.js.map +0 -1
  75. package/dist/stories/record-view.stories.d.ts +0 -24
  76. package/dist/stories/record-view.stories.js +0 -125
  77. package/dist/stories/record-view.stories.js.map +0 -1
  78. package/dist/stories/textarea.stories.d.ts +0 -37
  79. package/dist/stories/textarea.stories.js +0 -229
  80. package/dist/stories/textarea.stories.js.map +0 -1
  81. package/dist/stories/tree-column-with-checkbox.stories.d.ts +0 -26
  82. package/dist/stories/tree-column-with-checkbox.stories.js +0 -267
  83. package/dist/stories/tree-column-with-checkbox.stories.js.map +0 -1
  84. package/dist/stories/tree-column.stories.d.ts +0 -26
  85. package/dist/stories/tree-column.stories.js +0 -266
  86. package/dist/stories/tree-column.stories.js.map +0 -1
  87. package/index.ts +0 -1
@@ -1,293 +0,0 @@
1
- import '../src/index.js';
2
- import '../src/filters/filters-form.js';
3
- import '../src/sorters/sorters-control.js';
4
- import '@operato/popup/ox-popup-list.js';
5
- import '@material/web/icon/icon.js';
6
- import { html } from 'lit';
7
- import { styles as MDTypeScaleStyles } from '@material/web/typography/md-typescale-styles.js';
8
- import { CommonHeaderStyles, CommonGristStyles } from '@operato/styles';
9
- const fetchHandler = async ({ sorters = [], filters, page, limit }) => {
10
- var total = 5;
11
- var start = (page - 1) * limit;
12
- await new Promise(resolve => setTimeout(resolve, 500));
13
- return {
14
- total,
15
- records: Array(limit * page > total ? total % limit : limit)
16
- .fill('')
17
- .map((item, idx) => {
18
- return {
19
- id: String(idx),
20
- name: idx % 2 ? `shnam-${start + idx + 1}` : `heartyoh-${start + idx + 1}`,
21
- description: idx % 2 ? `hatiolabmanager${start + idx + 1}1234567890` : `hatiosea manager-${start + idx + 1}`,
22
- number: idx,
23
- float: 1.3,
24
- date: '2023-09-20',
25
- active: idx % 2 === 0,
26
- role: 'admin',
27
- routing: {
28
- id: '006dc64d-4fb9-4afc-a9ea-962bd1b9e110',
29
- name: '조림>세척'
30
- },
31
- updatedAt: Date.now()
32
- };
33
- })
34
- };
35
- };
36
- // 그리드 필드에 들어오는 값: string, number, date, checkbox(boolean), object, image(url)
37
- // 입력되는 케이스: 뷰 상태에서 입력, 에딧 상태에서 입력, 그리드 복붙, 엑셀 복붙
38
- function buildConfig({ headerFilter }) {
39
- return {
40
- list: {
41
- fields: ['name', 'description'],
42
- details: ['updatedAt', 'createdAt']
43
- },
44
- columns: [
45
- {
46
- type: 'gutter',
47
- gutterName: 'sequence'
48
- },
49
- {
50
- type: 'string',
51
- name: 'id',
52
- hidden: true
53
- },
54
- {
55
- type: 'gutter',
56
- gutterName: 'button',
57
- icon: 'add',
58
- title: 'add',
59
- handlers: {
60
- click: 'record-copy'
61
- }
62
- },
63
- {
64
- type: 'string',
65
- name: 'name',
66
- label: true,
67
- header: 'name',
68
- filter: {
69
- operator: 'eq',
70
- value: 'shnam'
71
- },
72
- record: {
73
- editable: true
74
- },
75
- sortable: true,
76
- width: 120
77
- },
78
- {
79
- type: 'string',
80
- name: 'description',
81
- header: 'description',
82
- filter: {
83
- operator: 'like',
84
- value: 'hahaha'
85
- },
86
- record: {
87
- align: 'left',
88
- editable: (value, column, record, rowIndex, field) => {
89
- return (record === null || record === void 0 ? void 0 : record.name) !== 'heartyoh-3';
90
- }
91
- },
92
- width: 200
93
- },
94
- {
95
- type: 'checkbox',
96
- name: 'chk',
97
- header: 'chk',
98
- record: {
99
- editable: (value, column, record, rowIndex, field) => {
100
- return (record === null || record === void 0 ? void 0 : record.name) !== 'heartyoh-3';
101
- }
102
- },
103
- width: 40
104
- },
105
- {
106
- type: 'number',
107
- name: 'number',
108
- header: 'number',
109
- record: {
110
- editable: true,
111
- handlers: {
112
- change: () => {
113
- console.log('dblclick333');
114
- }
115
- }
116
- },
117
- width: 80
118
- },
119
- {
120
- type: 'float',
121
- name: 'float',
122
- header: 'float',
123
- record: {
124
- editable: true
125
- },
126
- width: 80
127
- },
128
- {
129
- type: 'date',
130
- name: 'date',
131
- header: 'date',
132
- width: 120
133
- },
134
- {
135
- type: 'boolean',
136
- name: 'active',
137
- header: 'active',
138
- record: {
139
- editable: true
140
- },
141
- filter: {
142
- value: 'false'
143
- },
144
- sortable: true,
145
- width: 60
146
- },
147
- {
148
- type: 'select',
149
- name: 'role',
150
- label: true,
151
- header: 'role',
152
- record: {
153
- // options: ['', 'admin', 'worker', 'tester'],
154
- options: [
155
- { display: 'admin', value: 'admin' },
156
- { display: 'worker', value: 'worker' },
157
- { display: 'tester', value: 'tester' }
158
- ],
159
- editable: true
160
- },
161
- filter: {
162
- operator: 'in',
163
- value: ['worker']
164
- },
165
- sortable: true,
166
- width: 120
167
- },
168
- {
169
- type: 'object',
170
- name: 'routing',
171
- header: 'routing',
172
- record: { editable: true, options: { queryName: 'routings' }, mandatory: true },
173
- width: 180
174
- },
175
- {
176
- type: 'datetime',
177
- name: 'updatedAt',
178
- header: 'updated at',
179
- width: 180
180
- }
181
- ],
182
- rows: {
183
- selectable: {
184
- multiple: false
185
- },
186
- handlers: {
187
- click: 'select-row',
188
- dblclick: () => {
189
- console.log('dblclick333');
190
- }
191
- },
192
- appendable: false
193
- },
194
- sorters: [
195
- {
196
- name: 'name',
197
- desc: true
198
- }
199
- ],
200
- filters: {
201
- header: headerFilter
202
- },
203
- pagination: {
204
- pages: [30, 50, 100, 200]
205
- }
206
- };
207
- }
208
- export default {
209
- title: 'dynamic-editable for ox-grist',
210
- component: 'ox-grist',
211
- argTypes: {
212
- headerFilter: { control: 'boolean' }
213
- }
214
- };
215
- const Template = ({ headerFilter }) => html ` <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap" rel="stylesheet" />
216
-
217
- <link href="/themes/light.css" rel="stylesheet" />
218
- <link href="/themes/dark.css" rel="stylesheet" />
219
- <link href="/themes/spacing.css" rel="stylesheet" />
220
- <link href="/themes/grist-theme.css" rel="stylesheet" />
221
-
222
- <link
223
- href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL@20..48,100..700,0..1"
224
- rel="stylesheet"
225
- />
226
- <link
227
- href="https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,100..700,0..1"
228
- rel="stylesheet"
229
- />
230
- <link
231
- href="https://fonts.googleapis.com/css2?family=Material+Symbols+Sharp:opsz,wght,FILL@20..48,100..700,0..1"
232
- rel="stylesheet"
233
- />
234
-
235
- <style>
236
- ${MDTypeScaleStyles.cssText}
237
- </style>
238
-
239
- <style>
240
- ${CommonGristStyles.cssText}
241
- ${CommonHeaderStyles.cssText}
242
- </style>
243
-
244
- <style>
245
- ox-grist {
246
- height: 600px;
247
- }
248
-
249
- ox-filters-form {
250
- flex: 1;
251
- }
252
- </style>
253
-
254
- <ox-grist
255
- .config=${buildConfig({ headerFilter })}
256
- mode="GRID"
257
- .fetchHandler=${fetchHandler}
258
- @filters-change=${(e) => console.log('filters', e.target.filters)}
259
- @field-change=${(e) => {
260
- const { name, number, chk } = e.detail.record;
261
- console.log(name, number, chk);
262
- }}
263
- >
264
- <div slot="headroom" class="header">
265
- <div class="filters">
266
- <ox-filters-form></ox-filters-form>
267
-
268
- <div id="sorters">
269
- Sort
270
- <md-icon
271
- @click=${(e) => {
272
- const target = e.currentTarget;
273
- target.closest('#sorters').querySelector('#sorter-control').open({
274
- right: 0,
275
- top: target.offsetTop + target.offsetHeight
276
- });
277
- }}
278
- >expand_more</md-icon
279
- >
280
- <ox-popup id="sorter-control">
281
- <ox-sorters-control> </ox-sorters-control>
282
- </ox-popup>
283
- </div>
284
-
285
- <ox-record-creator id="add" light-popup>
286
- <button><md-icon>add</md-icon></button>
287
- </ox-record-creator>
288
- </div>
289
- </div>
290
- </ox-grist>`;
291
- export const Regular = Template.bind({});
292
- Regular.args = {};
293
- //# sourceMappingURL=dynamic-editable.stories.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dynamic-editable.stories.js","sourceRoot":"","sources":["../../stories/dynamic-editable.stories.ts"],"names":[],"mappings":"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","sourcesContent":["import '../src/index.js'\nimport '../src/filters/filters-form.js'\nimport '../src/sorters/sorters-control.js'\nimport '@operato/popup/ox-popup-list.js'\nimport '@material/web/icon/icon.js'\n\nimport { html, TemplateResult } from 'lit'\nimport { styles as MDTypeScaleStyles } from '@material/web/typography/md-typescale-styles.js'\n\nimport { FetchHandler } from '../src/types.js'\nimport { CommonHeaderStyles, CommonGristStyles } from '@operato/styles'\n\nconst fetchHandler: FetchHandler = async ({ sorters = [], filters, page, limit }) => {\n var total = 5\n var start = (page! - 1) * limit!\n\n await new Promise(resolve => setTimeout(resolve, 500))\n\n return {\n total,\n records: Array(limit! * page! > total ? total % limit! : limit)\n .fill('')\n .map((item, idx) => {\n return {\n id: String(idx),\n name: idx % 2 ? `shnam-${start + idx + 1}` : `heartyoh-${start + idx + 1}`,\n description: idx % 2 ? `hatiolabmanager${start + idx + 1}1234567890` : `hatiosea manager-${start + idx + 1}`,\n number: idx,\n float: 1.3,\n date: '2023-09-20',\n active: idx % 2 === 0,\n role: 'admin',\n routing: {\n id: '006dc64d-4fb9-4afc-a9ea-962bd1b9e110',\n name: '조림>세척'\n },\n updatedAt: Date.now()\n }\n })\n }\n}\n\n// 그리드 필드에 들어오는 값: string, number, date, checkbox(boolean), object, image(url)\n// 입력되는 케이스: 뷰 상태에서 입력, 에딧 상태에서 입력, 그리드 복붙, 엑셀 복붙\nfunction buildConfig({ headerFilter }: { headerFilter: boolean }) {\n return {\n list: {\n fields: ['name', 'description'],\n details: ['updatedAt', 'createdAt']\n },\n columns: [\n {\n type: 'gutter',\n gutterName: 'sequence'\n },\n {\n type: 'string',\n name: 'id',\n hidden: true\n },\n {\n type: 'gutter',\n gutterName: 'button',\n icon: 'add',\n title: 'add',\n handlers: {\n click: 'record-copy'\n }\n },\n {\n type: 'string',\n name: 'name',\n label: true,\n header: 'name',\n filter: {\n operator: 'eq',\n value: 'shnam'\n },\n record: {\n editable: true\n },\n sortable: true,\n width: 120\n },\n {\n type: 'string',\n name: 'description',\n header: 'description',\n filter: {\n operator: 'like',\n value: 'hahaha'\n },\n record: {\n align: 'left',\n editable: (value: any, column: any, record: any, rowIndex: any, field: any) => {\n return record?.name !== 'heartyoh-3'\n }\n },\n width: 200\n },\n {\n type: 'checkbox',\n name: 'chk',\n header: 'chk',\n record: {\n editable: (value: any, column: any, record: any, rowIndex: any, field: any) => {\n return record?.name !== 'heartyoh-3'\n }\n },\n width: 40\n },\n {\n type: 'number',\n name: 'number',\n header: 'number',\n record: {\n editable: true,\n handlers: {\n change: () => {\n console.log('dblclick333')\n }\n }\n },\n width: 80\n },\n {\n type: 'float',\n name: 'float',\n header: 'float',\n record: {\n editable: true\n },\n width: 80\n },\n {\n type: 'date',\n name: 'date',\n header: 'date',\n width: 120\n },\n {\n type: 'boolean',\n name: 'active',\n header: 'active',\n record: {\n editable: true\n },\n filter: {\n value: 'false'\n },\n sortable: true,\n width: 60\n },\n {\n type: 'select',\n name: 'role',\n label: true,\n header: 'role',\n record: {\n // options: ['', 'admin', 'worker', 'tester'],\n options: [\n { display: 'admin', value: 'admin' },\n { display: 'worker', value: 'worker' },\n { display: 'tester', value: 'tester' }\n ],\n editable: true\n },\n filter: {\n operator: 'in',\n value: ['worker']\n },\n sortable: true,\n width: 120\n },\n {\n type: 'object',\n name: 'routing',\n header: 'routing',\n record: { editable: true, options: { queryName: 'routings' }, mandatory: true },\n width: 180\n },\n {\n type: 'datetime',\n name: 'updatedAt',\n header: 'updated at',\n width: 180\n }\n ],\n rows: {\n selectable: {\n multiple: false\n },\n handlers: {\n click: 'select-row',\n dblclick: () => {\n console.log('dblclick333')\n }\n },\n appendable: false\n },\n sorters: [\n {\n name: 'name',\n desc: true\n }\n ],\n filters: {\n header: headerFilter\n },\n pagination: {\n pages: [30, 50, 100, 200]\n }\n }\n}\n\nexport default {\n title: 'dynamic-editable for ox-grist',\n component: 'ox-grist',\n argTypes: {\n headerFilter: { control: 'boolean' }\n }\n}\n\ninterface Story<T> {\n (args: T): TemplateResult\n args?: Partial<T>\n argTypes?: Record<string, unknown>\n}\n\ninterface ArgTypes {\n headerFilter: boolean\n}\n\nconst Template: Story<ArgTypes> = ({ headerFilter }: ArgTypes) =>\n html` <link href=\"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap\" rel=\"stylesheet\" />\n\n <link href=\"/themes/light.css\" rel=\"stylesheet\" />\n <link href=\"/themes/dark.css\" rel=\"stylesheet\" />\n <link href=\"/themes/spacing.css\" rel=\"stylesheet\" />\n <link href=\"/themes/grist-theme.css\" rel=\"stylesheet\" />\n\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Sharp:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n\n <style>\n ${MDTypeScaleStyles.cssText}\n </style>\n\n <style>\n ${CommonGristStyles.cssText}\n ${CommonHeaderStyles.cssText}\n </style>\n\n <style>\n ox-grist {\n height: 600px;\n }\n\n ox-filters-form {\n flex: 1;\n }\n </style>\n\n <ox-grist\n .config=${buildConfig({ headerFilter })}\n mode=\"GRID\"\n .fetchHandler=${fetchHandler}\n @filters-change=${(e: Event) => console.log('filters', (e.target as any).filters)}\n @field-change=${(e: any) => {\n const { name, number, chk } = e.detail.record\n console.log(name, number, chk)\n }}\n >\n <div slot=\"headroom\" class=\"header\">\n <div class=\"filters\">\n <ox-filters-form></ox-filters-form>\n\n <div id=\"sorters\">\n Sort\n <md-icon\n @click=${(e: Event) => {\n const target = e.currentTarget as HTMLElement\n ;(target.closest('#sorters')!.querySelector('#sorter-control') as any).open({\n right: 0,\n top: target.offsetTop + target.offsetHeight\n })\n }}\n >expand_more</md-icon\n >\n <ox-popup id=\"sorter-control\">\n <ox-sorters-control> </ox-sorters-control>\n </ox-popup>\n </div>\n\n <ox-record-creator id=\"add\" light-popup>\n <button><md-icon>add</md-icon></button>\n </ox-record-creator>\n </div>\n </div>\n </ox-grist>`\n\nexport const Regular = Template.bind({})\nRegular.args = {}\n"]}
@@ -1,25 +0,0 @@
1
- import '../src/index.js';
2
- import '../src/filters/filters-form.js';
3
- import '../src/sorters/sorters-control.js';
4
- import '@operato/popup/ox-popup-list.js';
5
- import '@material/web/icon/icon.js';
6
- import { TemplateResult } from 'lit';
7
- declare const _default: {
8
- title: string;
9
- component: string;
10
- argTypes: {
11
- theme: {
12
- control: string;
13
- options: string[];
14
- };
15
- };
16
- };
17
- export default _default;
18
- interface Story<T> {
19
- (args: T): TemplateResult;
20
- args?: Partial<T>;
21
- argTypes?: Record<string, unknown>;
22
- }
23
- interface ArgTypes {
24
- }
25
- export declare const Regular: Story<ArgTypes>;
@@ -1,162 +0,0 @@
1
- import '../src/index.js';
2
- import '../src/filters/filters-form.js';
3
- import '../src/sorters/sorters-control.js';
4
- import '@operato/popup/ox-popup-list.js';
5
- import '@material/web/icon/icon.js';
6
- import { html } from 'lit';
7
- import { styles as MDTypeScaleStyles } from '@material/web/typography/md-typescale-styles.js';
8
- import { CommonHeaderStyles, CommonGristStyles } from '@operato/styles';
9
- const fetchHandler = async ({ filters, page, limit }) => {
10
- var total = 120993;
11
- var start = (page - 1) * limit;
12
- await new Promise(resolve => setTimeout(resolve, 500));
13
- return {
14
- total,
15
- records: Array(limit * page > total ? total % limit : limit)
16
- .fill('')
17
- .map((item, idx) => {
18
- return {
19
- id: String(idx),
20
- name: idx % 2 ? `shnam-${start + idx + 1}` : `heartyoh-${start + idx + 1}`,
21
- description: idx % 2 ? `hatiolabmanager${start + idx + 1}1234567890` : `hatiosea manager-${start + idx + 1}`,
22
- createdAt: Date.now(),
23
- updatedAt: Date.now()
24
- };
25
- })
26
- };
27
- };
28
- const config = {
29
- list: {
30
- fields: ['name', 'description'],
31
- details: ['updatedAt', 'createdAt']
32
- },
33
- columns: [
34
- {
35
- type: 'gutter',
36
- gutterName: 'sequence'
37
- },
38
- {
39
- type: 'string',
40
- name: 'id',
41
- hidden: true
42
- },
43
- {
44
- type: 'string',
45
- name: 'name',
46
- label: true,
47
- header: 'name',
48
- filter: {
49
- operator: 'eq',
50
- value: 'shnam'
51
- },
52
- sortable: true,
53
- width: 120
54
- },
55
- {
56
- type: 'string',
57
- name: 'description',
58
- header: 'description',
59
- filter: {
60
- operator: 'like',
61
- value: 'hahaha'
62
- },
63
- record: {
64
- align: 'left'
65
- },
66
- width: 200
67
- },
68
- {
69
- type: 'datetime',
70
- name: 'updatedAt',
71
- header: 'updated at',
72
- width: 180
73
- },
74
- {
75
- type: 'datetime',
76
- name: 'createdAt',
77
- header: 'created at',
78
- width: 180
79
- }
80
- ],
81
- pagination: {
82
- pages: [30, 50, 100, 200]
83
- }
84
- };
85
- export default {
86
- title: 'empty sorters for ox-grist',
87
- component: 'ox-grist',
88
- argTypes: {
89
- theme: { control: 'select', options: ['light', 'dark'] }
90
- }
91
- };
92
- const Template = ({}) => html ` <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap" rel="stylesheet" />
93
-
94
- <link href="/themes/light.css" rel="stylesheet" />
95
- <link href="/themes/dark.css" rel="stylesheet" />
96
- <link href="/themes/spacing.css" rel="stylesheet" />
97
- <link href="/themes/grist-theme.css" rel="stylesheet" />
98
-
99
- <link
100
- href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL@20..48,100..700,0..1"
101
- rel="stylesheet"
102
- />
103
- <link
104
- href="https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,100..700,0..1"
105
- rel="stylesheet"
106
- />
107
- <link
108
- href="https://fonts.googleapis.com/css2?family=Material+Symbols+Sharp:opsz,wght,FILL@20..48,100..700,0..1"
109
- rel="stylesheet"
110
- />
111
-
112
- <style>
113
- ${MDTypeScaleStyles.cssText}
114
- </style>
115
-
116
- <style>
117
- ${CommonGristStyles.cssText}
118
- ${CommonHeaderStyles.cssText}
119
- </style>
120
-
121
- <style>
122
- ox-grist {
123
- height: 600px;
124
- }
125
-
126
- ox-filters-form {
127
- flex: 1;
128
- }
129
- </style>
130
-
131
- <ox-grist
132
- .config=${config}
133
- mode="GRID"
134
- .fetchHandler=${fetchHandler}
135
- @filters-change=${(e) => console.log('filters', e.target.filters)}
136
- >
137
- <div slot="headroom" class="header">
138
- <div class="filters">
139
- <ox-filters-form></ox-filters-form>
140
-
141
- <div id="sorters">
142
- Sort
143
- <md-icon
144
- @click=${(e) => {
145
- const target = e.currentTarget;
146
- target.closest('#sorters').querySelector('#sorter-control').open({
147
- right: 0,
148
- top: target.offsetTop + target.offsetHeight
149
- });
150
- }}
151
- >expand_more</md-icon
152
- >
153
- <ox-popup id="sorter-control">
154
- <ox-sorters-control> </ox-sorters-control>
155
- </ox-popup>
156
- </div>
157
- </div>
158
- </div>
159
- </ox-grist>`;
160
- export const Regular = Template.bind({});
161
- Regular.args = {};
162
- //# sourceMappingURL=empty-sorters.stories.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"empty-sorters.stories.js","sourceRoot":"","sources":["../../stories/empty-sorters.stories.ts"],"names":[],"mappings":"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","sourcesContent":["import '../src/index.js'\nimport '../src/filters/filters-form.js'\nimport '../src/sorters/sorters-control.js'\nimport '@operato/popup/ox-popup-list.js'\nimport '@material/web/icon/icon.js'\n\nimport { html, TemplateResult } from 'lit'\nimport { styles as MDTypeScaleStyles } from '@material/web/typography/md-typescale-styles.js'\n\nimport { FetchHandler } from '../src/types.js'\nimport { CommonHeaderStyles, CommonGristStyles } from '@operato/styles'\n\nconst fetchHandler: FetchHandler = async ({ filters, page, limit }) => {\n var total = 120993\n var start = (page! - 1) * limit!\n\n await new Promise(resolve => setTimeout(resolve, 500))\n\n return {\n total,\n records: Array(limit! * page! > total ? total % limit! : limit)\n .fill('')\n .map((item, idx) => {\n return {\n id: String(idx),\n name: idx % 2 ? `shnam-${start + idx + 1}` : `heartyoh-${start + idx + 1}`,\n description: idx % 2 ? `hatiolabmanager${start + idx + 1}1234567890` : `hatiosea manager-${start + idx + 1}`,\n createdAt: Date.now(),\n updatedAt: Date.now()\n }\n })\n }\n}\n\nconst config = {\n list: {\n fields: ['name', 'description'],\n details: ['updatedAt', 'createdAt']\n },\n columns: [\n {\n type: 'gutter',\n gutterName: 'sequence'\n },\n {\n type: 'string',\n name: 'id',\n hidden: true\n },\n {\n type: 'string',\n name: 'name',\n label: true,\n header: 'name',\n filter: {\n operator: 'eq',\n value: 'shnam'\n },\n sortable: true,\n width: 120\n },\n {\n type: 'string',\n name: 'description',\n header: 'description',\n filter: {\n operator: 'like',\n value: 'hahaha'\n },\n record: {\n align: 'left'\n },\n width: 200\n },\n {\n type: 'datetime',\n name: 'updatedAt',\n header: 'updated at',\n width: 180\n },\n {\n type: 'datetime',\n name: 'createdAt',\n header: 'created at',\n width: 180\n }\n ],\n pagination: {\n pages: [30, 50, 100, 200]\n }\n}\n\nexport default {\n title: 'empty sorters for ox-grist',\n component: 'ox-grist',\n argTypes: {\n theme: { control: 'select', options: ['light', 'dark'] }\n }\n}\n\ninterface Story<T> {\n (args: T): TemplateResult\n args?: Partial<T>\n argTypes?: Record<string, unknown>\n}\n\ninterface ArgTypes {}\n\nconst Template: Story<ArgTypes> = ({}: ArgTypes) =>\n html` <link href=\"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap\" rel=\"stylesheet\" />\n\n <link href=\"/themes/light.css\" rel=\"stylesheet\" />\n <link href=\"/themes/dark.css\" rel=\"stylesheet\" />\n <link href=\"/themes/spacing.css\" rel=\"stylesheet\" />\n <link href=\"/themes/grist-theme.css\" rel=\"stylesheet\" />\n\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Sharp:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n\n <style>\n ${MDTypeScaleStyles.cssText}\n </style>\n\n <style>\n ${CommonGristStyles.cssText}\n ${CommonHeaderStyles.cssText}\n </style>\n\n <style>\n ox-grist {\n height: 600px;\n }\n\n ox-filters-form {\n flex: 1;\n }\n </style>\n\n <ox-grist\n .config=${config}\n mode=\"GRID\"\n .fetchHandler=${fetchHandler}\n @filters-change=${(e: Event) => console.log('filters', (e.target as any).filters)}\n >\n <div slot=\"headroom\" class=\"header\">\n <div class=\"filters\">\n <ox-filters-form></ox-filters-form>\n\n <div id=\"sorters\">\n Sort\n <md-icon\n @click=${(e: Event) => {\n const target = e.currentTarget as HTMLElement\n ;(target.closest('#sorters')!.querySelector('#sorter-control') as any).open({\n right: 0,\n top: target.offsetTop + target.offsetHeight\n })\n }}\n >expand_more</md-icon\n >\n <ox-popup id=\"sorter-control\">\n <ox-sorters-control> </ox-sorters-control>\n </ox-popup>\n </div>\n </div>\n </div>\n </ox-grist>`\n\nexport const Regular = Template.bind({})\nRegular.args = {}\n"]}
@@ -1,25 +0,0 @@
1
- import '../src/index.js';
2
- import '../src/filters/filters-form.js';
3
- import '../src/sorters/sorters-control.js';
4
- import '@operato/popup/ox-popup-list.js';
5
- import '@material/web/icon/icon.js';
6
- import { TemplateResult } from 'lit';
7
- declare const _default: {
8
- title: string;
9
- component: string;
10
- argTypes: {
11
- explicitFetch: {
12
- control: string;
13
- };
14
- };
15
- };
16
- export default _default;
17
- interface Story<T> {
18
- (args: T): TemplateResult;
19
- args?: Partial<T>;
20
- argTypes?: Record<string, unknown>;
21
- }
22
- interface ArgTypes {
23
- explicitFetch: boolean;
24
- }
25
- export declare const Regular: Story<ArgTypes>;