@things-factory/board-ui 6.2.102 → 6.2.112

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 (151) hide show
  1. package/dist-client/apptools/favorite-tool.d.ts +26 -0
  2. package/dist-client/apptools/favorite-tool.js +129 -0
  3. package/dist-client/apptools/favorite-tool.js.map +1 -0
  4. package/dist-client/board-list/board-importer.d.ts +6 -0
  5. package/dist-client/board-list/board-importer.js +112 -0
  6. package/dist-client/board-list/board-importer.js.map +1 -0
  7. package/dist-client/board-list/board-tile-list.d.ts +22 -0
  8. package/dist-client/board-list/board-tile-list.js +264 -0
  9. package/dist-client/board-list/board-tile-list.js.map +1 -0
  10. package/dist-client/board-list/group-bar.d.ts +14 -0
  11. package/dist-client/board-list/group-bar.js +145 -0
  12. package/dist-client/board-list/group-bar.js.map +1 -0
  13. package/dist-client/board-list/play-group-bar.d.ts +21 -0
  14. package/dist-client/board-list/play-group-bar.js +142 -0
  15. package/dist-client/board-list/play-group-bar.js.map +1 -0
  16. package/dist-client/board-provider.d.ts +3 -0
  17. package/dist-client/board-provider.js +77 -0
  18. package/dist-client/board-provider.js.map +1 -0
  19. package/dist-client/bootstrap.d.ts +2 -0
  20. package/dist-client/bootstrap.js +30 -0
  21. package/dist-client/bootstrap.js.map +1 -0
  22. package/dist-client/data-grist/board-editor.d.ts +14 -0
  23. package/dist-client/data-grist/board-editor.js +110 -0
  24. package/dist-client/data-grist/board-editor.js.map +1 -0
  25. package/dist-client/data-grist/board-renderer.d.ts +2 -0
  26. package/dist-client/data-grist/board-renderer.js +134 -0
  27. package/dist-client/data-grist/board-renderer.js.map +1 -0
  28. package/dist-client/data-grist/color-map-editor.d.ts +4 -0
  29. package/dist-client/data-grist/color-map-editor.js +15 -0
  30. package/dist-client/data-grist/color-map-editor.js.map +1 -0
  31. package/dist-client/data-grist/color-ranges-editor.d.ts +4 -0
  32. package/dist-client/data-grist/color-ranges-editor.js +15 -0
  33. package/dist-client/data-grist/color-ranges-editor.js.map +1 -0
  34. package/dist-client/graphql/board-template.d.ts +5 -0
  35. package/dist-client/graphql/board-template.js +128 -0
  36. package/dist-client/graphql/board-template.js.map +1 -0
  37. package/dist-client/graphql/board.d.ts +19 -0
  38. package/dist-client/graphql/board.js +231 -0
  39. package/dist-client/graphql/board.js.map +1 -0
  40. package/dist-client/graphql/favorite-board.d.ts +1 -0
  41. package/dist-client/graphql/favorite-board.js +24 -0
  42. package/dist-client/graphql/favorite-board.js.map +1 -0
  43. package/dist-client/graphql/group.d.ts +6 -0
  44. package/dist-client/graphql/group.js +125 -0
  45. package/dist-client/graphql/group.js.map +1 -0
  46. package/dist-client/graphql/index.d.ts +6 -0
  47. package/dist-client/graphql/index.js +7 -0
  48. package/dist-client/graphql/index.js.map +1 -0
  49. package/dist-client/graphql/my-board.d.ts +1 -0
  50. package/dist-client/graphql/my-board.js +24 -0
  51. package/dist-client/graphql/my-board.js.map +1 -0
  52. package/dist-client/graphql/play-group.d.ts +7 -0
  53. package/dist-client/graphql/play-group.js +173 -0
  54. package/dist-client/graphql/play-group.js.map +1 -0
  55. package/dist-client/index.d.ts +8 -0
  56. package/dist-client/index.js +9 -0
  57. package/dist-client/index.js.map +1 -0
  58. package/dist-client/pages/attachment-list-page.d.ts +30 -0
  59. package/dist-client/pages/attachment-list-page.js +128 -0
  60. package/dist-client/pages/attachment-list-page.js.map +1 -0
  61. package/dist-client/pages/board-list-page.d.ts +109 -0
  62. package/dist-client/pages/board-list-page.js +532 -0
  63. package/dist-client/pages/board-list-page.js.map +1 -0
  64. package/dist-client/pages/board-modeller-page.d.ts +49 -0
  65. package/dist-client/pages/board-modeller-page.js +309 -0
  66. package/dist-client/pages/board-modeller-page.js.map +1 -0
  67. package/dist-client/pages/board-player-by-name-page.d.ts +4 -0
  68. package/dist-client/pages/board-player-by-name-page.js +32 -0
  69. package/dist-client/pages/board-player-by-name-page.js.map +1 -0
  70. package/dist-client/pages/board-player-page.d.ts +42 -0
  71. package/dist-client/pages/board-player-page.js +230 -0
  72. package/dist-client/pages/board-player-page.js.map +1 -0
  73. package/dist-client/pages/board-template/board-template-list-page.d.ts +37 -0
  74. package/dist-client/pages/board-template/board-template-list-page.js +226 -0
  75. package/dist-client/pages/board-template/board-template-list-page.js.map +1 -0
  76. package/dist-client/pages/board-viewer-by-name-page.d.ts +4 -0
  77. package/dist-client/pages/board-viewer-by-name-page.js +27 -0
  78. package/dist-client/pages/board-viewer-by-name-page.js.map +1 -0
  79. package/dist-client/pages/board-viewer-page.d.ts +41 -0
  80. package/dist-client/pages/board-viewer-page.js +246 -0
  81. package/dist-client/pages/board-viewer-page.js.map +1 -0
  82. package/dist-client/pages/font-list-page.d.ts +9 -0
  83. package/dist-client/pages/font-list-page.js +31 -0
  84. package/dist-client/pages/font-list-page.js.map +1 -0
  85. package/dist-client/pages/play-list-page.d.ts +58 -0
  86. package/dist-client/pages/play-list-page.js +364 -0
  87. package/dist-client/pages/play-list-page.js.map +1 -0
  88. package/dist-client/pages/printable-board-viewer-page.d.ts +11 -0
  89. package/dist-client/pages/printable-board-viewer-page.js +43 -0
  90. package/dist-client/pages/printable-board-viewer-page.js.map +1 -0
  91. package/dist-client/pages/theme/theme-editors.d.ts +5 -0
  92. package/dist-client/pages/theme/theme-editors.js +53 -0
  93. package/dist-client/pages/theme/theme-editors.js.map +1 -0
  94. package/dist-client/pages/theme/theme-list-page.d.ts +49 -0
  95. package/dist-client/pages/theme/theme-list-page.js +318 -0
  96. package/dist-client/pages/theme/theme-list-page.js.map +1 -0
  97. package/dist-client/pages/things-scene-components-with-tools.import +0 -0
  98. package/dist-client/pages/things-scene-components.import +0 -0
  99. package/dist-client/route.d.ts +1 -0
  100. package/dist-client/route.js +41 -0
  101. package/dist-client/route.js.map +1 -0
  102. package/dist-client/setting-let/board-view-setting-let.d.ts +14 -0
  103. package/dist-client/setting-let/board-view-setting-let.js +66 -0
  104. package/dist-client/setting-let/board-view-setting-let.js.map +1 -0
  105. package/dist-client/themes/board-theme.css +76 -0
  106. package/dist-client/tsconfig.tsbuildinfo +1 -0
  107. package/dist-client/viewparts/board-basic-info.d.ts +47 -0
  108. package/dist-client/viewparts/board-basic-info.js +641 -0
  109. package/dist-client/viewparts/board-basic-info.js.map +1 -0
  110. package/dist-client/viewparts/board-info-link.d.ts +12 -0
  111. package/dist-client/viewparts/board-info-link.js +59 -0
  112. package/dist-client/viewparts/board-info-link.js.map +1 -0
  113. package/dist-client/viewparts/board-info.d.ts +14 -0
  114. package/dist-client/viewparts/board-info.js +94 -0
  115. package/dist-client/viewparts/board-info.js.map +1 -0
  116. package/dist-client/viewparts/board-template-builder.d.ts +16 -0
  117. package/dist-client/viewparts/board-template-builder.js +145 -0
  118. package/dist-client/viewparts/board-template-builder.js.map +1 -0
  119. package/dist-client/viewparts/board-versions.d.ts +12 -0
  120. package/dist-client/viewparts/board-versions.js +157 -0
  121. package/dist-client/viewparts/board-versions.js.map +1 -0
  122. package/dist-client/viewparts/group-info-basic.d.ts +16 -0
  123. package/dist-client/viewparts/group-info-basic.js +247 -0
  124. package/dist-client/viewparts/group-info-basic.js.map +1 -0
  125. package/dist-client/viewparts/group-info-import.d.ts +15 -0
  126. package/dist-client/viewparts/group-info-import.js +137 -0
  127. package/dist-client/viewparts/group-info-import.js.map +1 -0
  128. package/dist-client/viewparts/group-info.d.ts +10 -0
  129. package/dist-client/viewparts/group-info.js +92 -0
  130. package/dist-client/viewparts/group-info.js.map +1 -0
  131. package/dist-client/viewparts/index.d.ts +3 -0
  132. package/dist-client/viewparts/index.js +4 -0
  133. package/dist-client/viewparts/index.js.map +1 -0
  134. package/dist-client/viewparts/link-builder.d.ts +22 -0
  135. package/dist-client/viewparts/link-builder.js +217 -0
  136. package/dist-client/viewparts/link-builder.js.map +1 -0
  137. package/dist-client/viewparts/play-group-info-basic.d.ts +16 -0
  138. package/dist-client/viewparts/play-group-info-basic.js +249 -0
  139. package/dist-client/viewparts/play-group-info-basic.js.map +1 -0
  140. package/dist-client/viewparts/play-group-info-link.d.ts +10 -0
  141. package/dist-client/viewparts/play-group-info-link.js +48 -0
  142. package/dist-client/viewparts/play-group-info-link.js.map +1 -0
  143. package/dist-client/viewparts/play-group-info.d.ts +13 -0
  144. package/dist-client/viewparts/play-group-info.js +90 -0
  145. package/dist-client/viewparts/play-group-info.js.map +1 -0
  146. package/dist-server/index.js +5 -0
  147. package/dist-server/index.js.map +1 -0
  148. package/dist-server/migrations/index.js +12 -0
  149. package/dist-server/migrations/index.js.map +1 -0
  150. package/dist-server/tsconfig.tsbuildinfo +1 -0
  151. package/package.json +5 -5
@@ -0,0 +1,318 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import '@operato/data-grist';
3
+ import { CommonButtonStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles';
4
+ import { PageView, store } from '@operato/shell';
5
+ import { css, html } from 'lit';
6
+ import { useMutation } from '@apollo/client';
7
+ import { customElement, property, query } from 'lit/decorators.js';
8
+ import { connect } from 'pwa-helpers/connect-mixin';
9
+ import gql from 'graphql-tag';
10
+ import { ScopedElementsMixin } from '@open-wc/scoped-elements';
11
+ import { DataGrist, getEditor, getRenderer } from '@operato/data-grist';
12
+ import { client } from '@operato/graphql';
13
+ import { i18next, localize } from '@operato/i18n';
14
+ import { notify } from '@operato/layout';
15
+ import { OxPopup } from '@operato/popup';
16
+ import { isMobileDevice } from '@operato/utils';
17
+ // export interface ThemeType {
18
+ // name: string
19
+ // propType: string
20
+ // }
21
+ // var ThemeTypes: { [name: string]: ThemeType } = {
22
+ // Legend: {
23
+ // name: 'Legend',
24
+ // propType: 'legend'
25
+ // }
26
+ // }
27
+ let ThemeListPage = class ThemeListPage extends connect(store)(localize(i18next)(ScopedElementsMixin(PageView))) {
28
+ constructor() {
29
+ super(...arguments);
30
+ this.mode = isMobileDevice() ? 'CARD' : 'GRID';
31
+ }
32
+ get context() {
33
+ var _a;
34
+ return {
35
+ title: i18next.t('title.theme list'),
36
+ search: {
37
+ handler: (search) => {
38
+ this.grist.searchText = search;
39
+ },
40
+ value: ((_a = this.grist) === null || _a === void 0 ? void 0 : _a.searchText) || ''
41
+ },
42
+ filter: {
43
+ handler: () => {
44
+ this.grist.toggleHeadroom();
45
+ }
46
+ },
47
+ help: 'board-service/theme',
48
+ actions: [
49
+ Object.assign({ title: i18next.t('button.save'), action: this._updateTheme.bind(this) }, CommonButtonStyles.save),
50
+ Object.assign({ title: i18next.t('button.delete'), action: this._deleteTheme.bind(this) }, CommonButtonStyles.delete)
51
+ ]
52
+ };
53
+ }
54
+ render() {
55
+ const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID');
56
+ return html `
57
+ <ox-grist .mode=${mode} .config=${this.gristConfig} .fetchHandler=${this.fetchHandler.bind(this)}>
58
+ <div slot="headroom">
59
+ <div id="filters">
60
+ <ox-filters-form autofocus without-search></ox-filters-form>
61
+ </div>
62
+
63
+ <div id="sorters">
64
+ Sort
65
+ <mwc-icon
66
+ @click=${e => {
67
+ const target = e.currentTarget;
68
+ this.sortersControl.open({
69
+ right: 0,
70
+ top: target.offsetTop + target.offsetHeight
71
+ });
72
+ }}
73
+ >expand_more</mwc-icon
74
+ >
75
+ <ox-popup id="sorter-control">
76
+ <ox-sorters-control> </ox-sorters-control>
77
+ </ox-popup>
78
+ </div>
79
+
80
+ <div id="modes">
81
+ <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>
82
+ <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>
83
+ <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>
84
+ </div>
85
+ </div>
86
+ </ox-grist>
87
+ `;
88
+ }
89
+ async pageInitialized(lifecycle) {
90
+ this.gristConfig = {
91
+ list: {
92
+ fields: ['name', 'description'],
93
+ details: ['type', 'updatedAt']
94
+ },
95
+ columns: [
96
+ { type: 'gutter', gutterName: 'sequence' },
97
+ { type: 'gutter', gutterName: 'row-selector', multiple: true },
98
+ {
99
+ type: 'string',
100
+ name: 'name',
101
+ header: i18next.t('field.name'),
102
+ record: {
103
+ editable: true
104
+ },
105
+ filter: 'search',
106
+ sortable: true,
107
+ width: 150
108
+ },
109
+ {
110
+ type: 'string',
111
+ name: 'description',
112
+ header: i18next.t('field.description'),
113
+ record: {
114
+ editable: true
115
+ },
116
+ filter: 'search',
117
+ width: 200
118
+ },
119
+ {
120
+ type: 'checkbox',
121
+ name: 'active',
122
+ header: i18next.t('field.active'),
123
+ record: {
124
+ editable: true
125
+ },
126
+ width: 60
127
+ },
128
+ {
129
+ type: 'select',
130
+ name: 'type',
131
+ header: i18next.t('field.type'),
132
+ record: {
133
+ options: ['', 'color-map', 'color-ranges', 'color', 'text'],
134
+ editable: true
135
+ },
136
+ width: 120
137
+ },
138
+ {
139
+ type: 'object',
140
+ name: 'value',
141
+ header: i18next.t('field.value'),
142
+ record: {
143
+ editor: function (value, column, record, rowIndex, field) {
144
+ return getEditor(record.type || 'text')(value, column, record, rowIndex, field);
145
+ },
146
+ renderer: function (value, column, record, rowIndex, field) {
147
+ return getRenderer(record.type || 'text')(value, column, record, rowIndex, field);
148
+ },
149
+ editable: true,
150
+ options: {
151
+ objectified: true
152
+ }
153
+ },
154
+ sortable: true,
155
+ width: 180
156
+ },
157
+ {
158
+ type: 'resource-object',
159
+ name: 'updater',
160
+ header: i18next.t('field.updater'),
161
+ record: {
162
+ editable: false
163
+ },
164
+ sortable: true,
165
+ width: 120
166
+ },
167
+ {
168
+ type: 'datetime',
169
+ name: 'updatedAt',
170
+ header: i18next.t('field.updated_at'),
171
+ record: {
172
+ editable: false
173
+ },
174
+ sortable: true,
175
+ width: 180
176
+ }
177
+ ],
178
+ rows: {
179
+ selectable: {
180
+ multiple: true
181
+ }
182
+ },
183
+ sorters: [
184
+ {
185
+ name: 'name'
186
+ }
187
+ ]
188
+ };
189
+ }
190
+ async pageUpdated(changes, lifecycle) {
191
+ if (this.active) {
192
+ // do something here when this page just became as active
193
+ }
194
+ }
195
+ async fetchHandler({ page = 1, limit = 100, sortings = [], filters = [] }) {
196
+ const response = await client.query({
197
+ query: gql `
198
+ query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
199
+ responses: themes(filters: $filters, pagination: $pagination, sortings: $sortings) {
200
+ items {
201
+ id
202
+ name
203
+ description
204
+ active
205
+ type
206
+ value
207
+ updater {
208
+ id
209
+ name
210
+ }
211
+ updatedAt
212
+ }
213
+ total
214
+ }
215
+ }
216
+ `,
217
+ variables: {
218
+ filters,
219
+ pagination: { page, limit },
220
+ sortings
221
+ }
222
+ });
223
+ return {
224
+ total: response.data.responses.total || 0,
225
+ records: response.data.responses.items || []
226
+ };
227
+ }
228
+ async _deleteTheme() {
229
+ if (confirm(i18next.t('text.sure_to_x', { x: i18next.t('text.delete') }))) {
230
+ const ids = this.grist.selected.map(record => record.id);
231
+ if (ids && ids.length > 0) {
232
+ const [mutateFunction, { error }] = useMutation(`
233
+ mutation ($ids: [String!]!) {
234
+ deleteThemes(ids: $ids)
235
+ }`);
236
+ useMutation({
237
+ variables: {
238
+ ids
239
+ }
240
+ });
241
+ if (!error) {
242
+ this.grist.fetch();
243
+ notify({
244
+ message: i18next.t('text.info_x_successfully', { x: i18next.t('text.delete') })
245
+ });
246
+ }
247
+ }
248
+ }
249
+ }
250
+ async _updateTheme() {
251
+ let patches = this.grist.dirtyRecords;
252
+ if (patches && patches.length) {
253
+ patches = patches.map(patch => {
254
+ let patchField = patch.id ? { id: patch.id } : {};
255
+ const dirtyFields = patch.__dirtyfields__;
256
+ for (let key in dirtyFields) {
257
+ patchField[key] = dirtyFields[key].after;
258
+ }
259
+ patchField.cuFlag = patch.__dirty__;
260
+ return patchField;
261
+ });
262
+ const [mutateFunction, { error }] = useMutation(`
263
+ mutation ($patches: [ThemePatch!]!) {
264
+ updateMultipleTheme(patches: $patches) {
265
+ name
266
+ }
267
+ }`);
268
+ mutateFunction({
269
+ variables: {
270
+ patches
271
+ }
272
+ });
273
+ if (!error) {
274
+ this.grist.fetch();
275
+ }
276
+ }
277
+ }
278
+ };
279
+ ThemeListPage.styles = [
280
+ ScrollbarStyles,
281
+ CommonGristStyles,
282
+ css `
283
+ :host {
284
+ display: flex;
285
+
286
+ width: 100%;
287
+
288
+ --grid-record-emphasized-background-color: #8b0000;
289
+ --grid-record-emphasized-color: #ff6b6b;
290
+ }
291
+
292
+ ox-grist {
293
+ overflow-y: auto;
294
+ flex: 1;
295
+ }
296
+ `
297
+ ];
298
+ __decorate([
299
+ property({ type: Object }),
300
+ __metadata("design:type", Object)
301
+ ], ThemeListPage.prototype, "gristConfig", void 0);
302
+ __decorate([
303
+ property({ type: String }),
304
+ __metadata("design:type", String)
305
+ ], ThemeListPage.prototype, "mode", void 0);
306
+ __decorate([
307
+ query('ox-grist'),
308
+ __metadata("design:type", DataGrist)
309
+ ], ThemeListPage.prototype, "grist", void 0);
310
+ __decorate([
311
+ query('#sorter-control'),
312
+ __metadata("design:type", OxPopup)
313
+ ], ThemeListPage.prototype, "sortersControl", void 0);
314
+ ThemeListPage = __decorate([
315
+ customElement('theme-list-page')
316
+ ], ThemeListPage);
317
+ export { ThemeListPage };
318
+ //# sourceMappingURL=theme-list-page.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme-list-page.js","sourceRoot":"","sources":["../../../client/pages/theme/theme-list-page.ts"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\n\nimport { CommonButtonStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'\nimport { PageView, store } from '@operato/shell'\nimport { css, html } from 'lit'\nimport { useMutation } from '@apollo/client'\n\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin'\nimport gql from 'graphql-tag'\nimport { ScopedElementsMixin } from '@open-wc/scoped-elements'\nimport { ColumnConfig, DataGrist, FetchOption, SortersControl, getEditor, getRenderer } from '@operato/data-grist'\n\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { notify, openPopup } from '@operato/layout'\nimport { OxPopup } from '@operato/popup'\nimport { isMobileDevice } from '@operato/utils'\n\n// export interface ThemeType {\n// name: string\n// propType: string\n// }\n\n// var ThemeTypes: { [name: string]: ThemeType } = {\n// Legend: {\n// name: 'Legend',\n// propType: 'legend'\n// }\n// }\n\n@customElement('theme-list-page')\nexport class ThemeListPage extends connect(store)(localize(i18next)(ScopedElementsMixin(PageView))) {\n static styles = [\n ScrollbarStyles,\n CommonGristStyles,\n css`\n :host {\n display: flex;\n\n width: 100%;\n\n --grid-record-emphasized-background-color: #8b0000;\n --grid-record-emphasized-color: #ff6b6b;\n }\n\n ox-grist {\n overflow-y: auto;\n flex: 1;\n }\n `\n ]\n\n @property({ type: Object }) gristConfig: any\n @property({ type: String }) mode: 'CARD' | 'GRID' | 'LIST' = isMobileDevice() ? 'CARD' : 'GRID'\n\n @query('ox-grist') private grist!: DataGrist\n @query('#sorter-control') private sortersControl!: OxPopup\n\n get context() {\n return {\n title: i18next.t('title.theme list'),\n search: {\n handler: (search: string) => {\n this.grist.searchText = search\n },\n value: this.grist?.searchText || ''\n },\n filter: {\n handler: () => {\n this.grist.toggleHeadroom()\n }\n },\n help: 'board-service/theme',\n actions: [\n {\n title: i18next.t('button.save'),\n action: this._updateTheme.bind(this),\n ...CommonButtonStyles.save\n },\n {\n title: i18next.t('button.delete'),\n action: this._deleteTheme.bind(this),\n ...CommonButtonStyles.delete\n }\n ]\n }\n }\n\n render() {\n const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID')\n\n return html`\n <ox-grist .mode=${mode} .config=${this.gristConfig} .fetchHandler=${this.fetchHandler.bind(this)}>\n <div slot=\"headroom\">\n <div id=\"filters\">\n <ox-filters-form autofocus without-search></ox-filters-form>\n </div>\n\n <div id=\"sorters\">\n Sort\n <mwc-icon\n @click=${e => {\n const target = e.currentTarget\n this.sortersControl.open({\n right: 0,\n top: target.offsetTop + target.offsetHeight\n })\n }}\n >expand_more</mwc-icon\n >\n <ox-popup id=\"sorter-control\">\n <ox-sorters-control> </ox-sorters-control>\n </ox-popup>\n </div>\n\n <div id=\"modes\">\n <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>\n <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>\n <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>\n </div>\n </div>\n </ox-grist>\n `\n }\n\n async pageInitialized(lifecycle: any) {\n this.gristConfig = {\n list: {\n fields: ['name', 'description'],\n details: ['type', 'updatedAt']\n },\n columns: [\n { type: 'gutter', gutterName: 'sequence' },\n { type: 'gutter', gutterName: 'row-selector', multiple: true },\n {\n type: 'string',\n name: 'name',\n header: i18next.t('field.name'),\n record: {\n editable: true\n },\n filter: 'search',\n sortable: true,\n width: 150\n },\n {\n type: 'string',\n name: 'description',\n header: i18next.t('field.description'),\n record: {\n editable: true\n },\n filter: 'search',\n width: 200\n },\n {\n type: 'checkbox',\n name: 'active',\n header: i18next.t('field.active'),\n record: {\n editable: true\n },\n width: 60\n },\n {\n type: 'select',\n name: 'type',\n header: i18next.t('field.type'),\n record: {\n options: ['', 'color-map', 'color-ranges', 'color', 'text'],\n editable: true\n },\n width: 120\n },\n {\n type: 'object',\n name: 'value',\n header: i18next.t('field.value'),\n record: {\n editor: function (value, column, record, rowIndex, field) {\n return getEditor(record.type || 'text')(value, column, record, rowIndex, field)\n },\n renderer: function (value, column, record, rowIndex, field) {\n return getRenderer(record.type || 'text')(value, column, record, rowIndex, field)\n },\n editable: true,\n options: {\n objectified: true\n }\n },\n sortable: true,\n width: 180\n },\n {\n type: 'resource-object',\n name: 'updater',\n header: i18next.t('field.updater'),\n record: {\n editable: false\n },\n sortable: true,\n width: 120\n },\n {\n type: 'datetime',\n name: 'updatedAt',\n header: i18next.t('field.updated_at'),\n record: {\n editable: false\n },\n sortable: true,\n width: 180\n }\n ],\n rows: {\n selectable: {\n multiple: true\n }\n },\n sorters: [\n {\n name: 'name'\n }\n ]\n }\n }\n\n async pageUpdated(changes: any, lifecycle: any) {\n if (this.active) {\n // do something here when this page just became as active\n }\n }\n\n async fetchHandler({ page = 1, limit = 100, sortings = [], filters = [] }: FetchOption) {\n const response = await client.query({\n query: gql`\n query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {\n responses: themes(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n description\n active\n type\n value\n updater {\n id\n name\n }\n updatedAt\n }\n total\n }\n }\n `,\n variables: {\n filters,\n pagination: { page, limit },\n sortings\n }\n })\n\n return {\n total: response.data.responses.total || 0,\n records: response.data.responses.items || []\n }\n }\n\n async _deleteTheme() {\n if (confirm(i18next.t('text.sure_to_x', { x: i18next.t('text.delete') }))) {\n const ids = this.grist.selected.map(record => record.id)\n if (ids && ids.length > 0) {\n const [mutateFunction, { error }] = useMutation(`\nmutation ($ids: [String!]!) {\n deleteThemes(ids: $ids)\n}`)\n\n useMutation({\n variables: {\n ids\n }\n })\n\n if (!error) {\n this.grist.fetch()\n notify({\n message: i18next.t('text.info_x_successfully', { x: i18next.t('text.delete') })\n })\n }\n }\n }\n }\n\n async _updateTheme() {\n let patches = this.grist.dirtyRecords\n if (patches && patches.length) {\n patches = patches.map(patch => {\n let patchField: any = patch.id ? { id: patch.id } : {}\n const dirtyFields = patch.__dirtyfields__\n for (let key in dirtyFields) {\n patchField[key] = dirtyFields[key].after\n }\n patchField.cuFlag = patch.__dirty__\n\n return patchField\n })\n\n const [mutateFunction, { error }] = useMutation(`\nmutation ($patches: [ThemePatch!]!) {\n updateMultipleTheme(patches: $patches) {\n name\n }\n}`)\n\n mutateFunction({\n variables: {\n patches\n }\n })\n\n if (!error) {\n this.grist.fetch()\n }\n }\n }\n}\n"]}
@@ -0,0 +1 @@
1
+ export default function route(page: any): any;
@@ -0,0 +1,41 @@
1
+ export default function route(page) {
2
+ switch (page) {
3
+ case 'board-viewer':
4
+ import('./pages/board-viewer-page');
5
+ return page;
6
+ case 'board-viewer-by-name':
7
+ import('./pages/board-viewer-by-name-page');
8
+ return page;
9
+ case 'board-player':
10
+ import('./pages/board-player-page');
11
+ return page;
12
+ case 'board-player-by-name':
13
+ import('./pages/board-player-by-name-page');
14
+ return page;
15
+ case 'board-modeller':
16
+ import('./pages/board-modeller-page');
17
+ return page;
18
+ case 'board-list':
19
+ import('./pages/board-list-page');
20
+ return page;
21
+ case 'play-list':
22
+ import('./pages/play-list-page');
23
+ return page;
24
+ case 'attachment-list':
25
+ import('./pages/attachment-list-page');
26
+ return page;
27
+ case 'font-list':
28
+ import('./pages/font-list-page');
29
+ return page;
30
+ case 'printable-board-viewer':
31
+ import('./pages/printable-board-viewer-page');
32
+ return page;
33
+ case 'theme-list':
34
+ import('./pages/theme/theme-list-page');
35
+ return page;
36
+ case 'board-template-list':
37
+ import('./pages/board-template/board-template-list-page');
38
+ return page;
39
+ }
40
+ }
41
+ //# sourceMappingURL=route.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.js","sourceRoot":"","sources":["../client/route.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,OAAO,UAAU,KAAK,CAAC,IAAI;IAChC,QAAQ,IAAI,EAAE;QACZ,KAAK,cAAc;YACjB,MAAM,CAAC,2BAA2B,CAAC,CAAA;YACnC,OAAO,IAAI,CAAA;QAEb,KAAK,sBAAsB;YACzB,MAAM,CAAC,mCAAmC,CAAC,CAAA;YAC3C,OAAO,IAAI,CAAA;QAEb,KAAK,cAAc;YACjB,MAAM,CAAC,2BAA2B,CAAC,CAAA;YACnC,OAAO,IAAI,CAAA;QAEb,KAAK,sBAAsB;YACzB,MAAM,CAAC,mCAAmC,CAAC,CAAA;YAC3C,OAAO,IAAI,CAAA;QAEb,KAAK,gBAAgB;YACnB,MAAM,CAAC,6BAA6B,CAAC,CAAA;YACrC,OAAO,IAAI,CAAA;QAEb,KAAK,YAAY;YACf,MAAM,CAAC,yBAAyB,CAAC,CAAA;YACjC,OAAO,IAAI,CAAA;QAEb,KAAK,WAAW;YACd,MAAM,CAAC,wBAAwB,CAAC,CAAA;YAChC,OAAO,IAAI,CAAA;QAEb,KAAK,iBAAiB;YACpB,MAAM,CAAC,8BAA8B,CAAC,CAAA;YACtC,OAAO,IAAI,CAAA;QAEb,KAAK,WAAW;YACd,MAAM,CAAC,wBAAwB,CAAC,CAAA;YAChC,OAAO,IAAI,CAAA;QAEb,KAAK,wBAAwB;YAC3B,MAAM,CAAC,qCAAqC,CAAC,CAAA;YAC7C,OAAO,IAAI,CAAA;QAEb,KAAK,YAAY;YACf,MAAM,CAAC,+BAA+B,CAAC,CAAA;YACvC,OAAO,IAAI,CAAA;QAEb,KAAK,qBAAqB;YACxB,MAAM,CAAC,iDAAiD,CAAC,CAAA;YACzD,OAAO,IAAI,CAAA;KACd;AACH,CAAC","sourcesContent":["export default function route(page) {\n switch (page) {\n case 'board-viewer':\n import('./pages/board-viewer-page')\n return page\n\n case 'board-viewer-by-name':\n import('./pages/board-viewer-by-name-page')\n return page\n\n case 'board-player':\n import('./pages/board-player-page')\n return page\n\n case 'board-player-by-name':\n import('./pages/board-player-by-name-page')\n return page\n\n case 'board-modeller':\n import('./pages/board-modeller-page')\n return page\n\n case 'board-list':\n import('./pages/board-list-page')\n return page\n\n case 'play-list':\n import('./pages/play-list-page')\n return page\n\n case 'attachment-list':\n import('./pages/attachment-list-page')\n return page\n\n case 'font-list':\n import('./pages/font-list-page')\n return page\n\n case 'printable-board-viewer':\n import('./pages/printable-board-viewer-page')\n return page\n\n case 'theme-list':\n import('./pages/theme/theme-list-page')\n return page\n\n case 'board-template-list':\n import('./pages/board-template/board-template-list-page')\n return page\n }\n}\n"]}
@@ -0,0 +1,14 @@
1
+ import '@things-factory/setting-base';
2
+ import '@material/mwc-formfield';
3
+ import '@material/mwc-checkbox';
4
+ import '@operato/i18n/ox-i18n.js';
5
+ import { LitElement } from 'lit';
6
+ declare const BoardViewSettingLet_base: (new (...args: any[]) => LitElement) & typeof LitElement;
7
+ export declare class BoardViewSettingLet extends BoardViewSettingLet_base {
8
+ static styles: import("lit").CSSResult[];
9
+ autoRefresh?: boolean;
10
+ render(): import("lit-html").TemplateResult<1>;
11
+ firstUpdated(): Promise<void>;
12
+ onChange(e: any): Promise<void>;
13
+ }
14
+ export {};
@@ -0,0 +1,66 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import '@things-factory/setting-base';
3
+ import '@material/mwc-formfield';
4
+ import '@material/mwc-checkbox';
5
+ import '@operato/i18n/ox-i18n.js';
6
+ import { css, html, LitElement } from 'lit';
7
+ import { customElement, property } from 'lit/decorators.js';
8
+ import { i18next, localize } from '@operato/i18n';
9
+ import { clientSettingStore } from '@operato/shell/object-store.js';
10
+ let BoardViewSettingLet = class BoardViewSettingLet extends localize(i18next)(LitElement) {
11
+ render() {
12
+ return html `
13
+ <setting-let>
14
+ <ox-i18n slot="title" msgid="title.board view setting"></ox-i18n>
15
+
16
+ <div slot="content">
17
+ <mwc-formfield label=${String(i18next.t('label.auto refresh board view'))}>
18
+ <mwc-checkbox id="auto-refresh" @change=${e => this.onChange(e)} ?checked=${this.autoRefresh}></mwc-checkbox>
19
+ </mwc-formfield>
20
+ </div>
21
+ </setting-let>
22
+ `;
23
+ }
24
+ async firstUpdated() {
25
+ var _a;
26
+ const { autoRefresh = true } = ((_a = (await clientSettingStore.get('board-view'))) === null || _a === void 0 ? void 0 : _a.value) || {};
27
+ this.autoRefresh = autoRefresh;
28
+ }
29
+ async onChange(e) {
30
+ var _a;
31
+ this.autoRefresh = e.target.checked;
32
+ const { autoRefresh: valueFromStore } = ((_a = (await clientSettingStore.get('board-view'))) === null || _a === void 0 ? void 0 : _a.value) || {};
33
+ if (this.autoRefresh === valueFromStore) {
34
+ return;
35
+ }
36
+ try {
37
+ await clientSettingStore.put({
38
+ key: 'board-view',
39
+ value: {
40
+ autoRefresh: this.autoRefresh
41
+ }
42
+ });
43
+ }
44
+ catch (e) {
45
+ console.error(e);
46
+ }
47
+ }
48
+ };
49
+ BoardViewSettingLet.styles = [
50
+ css `
51
+ label {
52
+ font: var(--label-font);
53
+ color: var(--label-color);
54
+ text-transform: var(--label-text-transform);
55
+ }
56
+ `
57
+ ];
58
+ __decorate([
59
+ property({ type: Boolean }),
60
+ __metadata("design:type", Boolean)
61
+ ], BoardViewSettingLet.prototype, "autoRefresh", void 0);
62
+ BoardViewSettingLet = __decorate([
63
+ customElement('board-view-setting-let')
64
+ ], BoardViewSettingLet);
65
+ export { BoardViewSettingLet };
66
+ //# sourceMappingURL=board-view-setting-let.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"board-view-setting-let.js","sourceRoot":"","sources":["../../client/setting-let/board-view-setting-let.ts"],"names":[],"mappings":";AAAA,OAAO,8BAA8B,CAAA;AACrC,OAAO,yBAAyB,CAAA;AAChC,OAAO,wBAAwB,CAAA;AAC/B,OAAO,0BAA0B,CAAA;AAEjC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE3D,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAA;AAG5D,IAAM,mBAAmB,GAAzB,MAAM,mBAAoB,SAAQ,QAAQ,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC;IAapE,MAAM;QACJ,OAAO,IAAI,CAAA;;;;;iCAKkB,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC;sDAC7B,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,IAAI,CAAC,WAAW;;;;KAInG,CAAA;IACH,CAAC;IAED,KAAK,CAAC,YAAY;;QAChB,MAAM,EAAE,WAAW,GAAG,IAAI,EAAE,GAAG,CAAA,MAAA,CAAC,MAAM,kBAAkB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,0CAAE,KAAK,KAAI,EAAE,CAAA;QACxF,IAAI,CAAC,WAAW,GAAG,WAAW,CAAA;IAChC,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,CAAC;;QACd,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAA;QAEnC,MAAM,EAAE,WAAW,EAAE,cAAc,EAAE,GAAG,CAAA,MAAA,CAAC,MAAM,kBAAkB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,0CAAE,KAAK,KAAI,EAAE,CAAA;QACjG,IAAI,IAAI,CAAC,WAAW,KAAK,cAAc,EAAE;YACvC,OAAM;SACP;QAED,IAAI;YACF,MAAM,kBAAkB,CAAC,GAAG,CAAC;gBAC3B,GAAG,EAAE,YAAY;gBACjB,KAAK,EAAE;oBACL,WAAW,EAAE,IAAI,CAAC,WAAW;iBAC9B;aACF,CAAC,CAAA;SACH;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;SACjB;IACH,CAAC;;AAjDM,0BAAM,GAAG;IACd,GAAG,CAAA;;;;;;KAMF;CACF,CAAA;AAED;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;;wDAAsB;AAXvC,mBAAmB;IAD/B,aAAa,CAAC,wBAAwB,CAAC;GAC3B,mBAAmB,CAmD/B;SAnDY,mBAAmB","sourcesContent":["import '@things-factory/setting-base'\nimport '@material/mwc-formfield'\nimport '@material/mwc-checkbox'\nimport '@operato/i18n/ox-i18n.js'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { i18next, localize } from '@operato/i18n'\nimport { clientSettingStore } from '@operato/shell/object-store.js'\n\n@customElement('board-view-setting-let')\nexport class BoardViewSettingLet extends localize(i18next)(LitElement) {\n static styles = [\n css`\n label {\n font: var(--label-font);\n color: var(--label-color);\n text-transform: var(--label-text-transform);\n }\n `\n ]\n\n @property({ type: Boolean }) autoRefresh?: boolean\n\n render() {\n return html`\n <setting-let>\n <ox-i18n slot=\"title\" msgid=\"title.board view setting\"></ox-i18n>\n\n <div slot=\"content\">\n <mwc-formfield label=${String(i18next.t('label.auto refresh board view'))}>\n <mwc-checkbox id=\"auto-refresh\" @change=${e => this.onChange(e)} ?checked=${this.autoRefresh}></mwc-checkbox>\n </mwc-formfield>\n </div>\n </setting-let>\n `\n }\n\n async firstUpdated() {\n const { autoRefresh = true } = (await clientSettingStore.get('board-view'))?.value || {}\n this.autoRefresh = autoRefresh\n }\n\n async onChange(e) {\n this.autoRefresh = e.target.checked\n\n const { autoRefresh: valueFromStore } = (await clientSettingStore.get('board-view'))?.value || {}\n if (this.autoRefresh === valueFromStore) {\n return\n }\n\n try {\n await clientSettingStore.put({\n key: 'board-view',\n value: {\n autoRefresh: this.autoRefresh\n }\n })\n } catch (e) {\n console.error(e)\n }\n }\n}\n"]}
@@ -0,0 +1,76 @@
1
+ body {
2
+ --board-renderer-border: 1px solid rgba(0, 0, 0, 0.1);
3
+ --board-renderer-max-width: 120px;
4
+ --board-renderer-name-background-color: var(--secondary-text-color);
5
+ --board-renderer-name-font: normal 13px var(--theme-font);
6
+ --board-renderer-icon-size: 24px;
7
+ --board-renderer-icon-border-radius: 10px;
8
+ --board-renderer-font: bold 16px/25px var(--mdc-icon-font, 'Material Icons');
9
+ --board-renderer-icon-edit-background-color: #95d40f;
10
+ --board-renderer-icon-view-background-color: #27a1de;
11
+
12
+ /* list page style*/
13
+ --board-list-background-color: var(--main-section-background-color);
14
+ --board-list-border-radius: var(--border-radius);
15
+ --board-list-box-border: var(--margin-default) solid #fff;
16
+ --board-list-box-shadow: var(--box-shadow);
17
+ --board-list-margin: var(--margin-default);
18
+ --board-list-tile-background-color: #fff;
19
+ --board-list-tile-name-font: bold 14px/18px var(--theme-font);
20
+ --board-list-tile-name-color: var(--secondary-color);
21
+ --board-list-tile-description-font: 12px/14px var(--theme-font);
22
+ --board-list-tile-description-color: var(--secondary-text-color);
23
+ --board-list-tile-icon-color: var(--opacity-dark-color);
24
+ --board-list-star-color: var(--opacity-dark-color);
25
+ --board-list-star-active-color: var(--status-warning-color);
26
+
27
+ --card-list-rows-height: 180px;
28
+ --card-list-background-color: rgba(0, 0, 0, 0.07);
29
+ --card-list-border-radius: var(--border-radius);
30
+ --card-list-flip-transform: rotateX(180deg);
31
+ --card-list-create-border: 1px dashed var(--primary-color);
32
+ --card-list-create-border-radius: var(--border-radius);
33
+ --card-list-create-icon-color: var(--primary-color);
34
+ --card-list-create-color: var(--secondary-color);
35
+ --card-list-create-form-padding: 15px;
36
+ --card-list-create-label-font: normal 14px var(--theme-font);
37
+ --card-list-create-label-color: var(--secondary-color);
38
+ --card-list-create-input-font: normal 14px var(--theme-font);
39
+ --card-list-create-input-color: var();
40
+ --card-list-create-input-border: 1px solid rgba(0, 0, 0, 0.2);
41
+ --card-list-create-input-border-radius: var(--border-radius);
42
+ --card-list-create-input-padding: 2px 9px;
43
+ --card-list-create-margin: 0 0 7px 0;
44
+
45
+ /* board modeler page style */
46
+ --edit-toolbar-background-color: var(--secondary-text-color);
47
+ --edit-toolbar-bigger-icon-size: 45px;
48
+ --edit-toolbar-bigger-icon-line: 1px solid rgba(0, 0, 0, 0.1);
49
+ --component-toolbar-background-color: var(--main-section-background-color);
50
+ --component-toolbar-icon-size: 45px;
51
+ --component-toolbar-border: 1px solid rgba(0, 0, 0, 0.1);
52
+ --component-menu-background-color: #fff;
53
+ --component-menu-border-color: var(--secondary-text-color);
54
+ --component-menu-title: bold 11px/16px var(--theme-font);
55
+ --component-menu-item-color: var(--secondary-color);
56
+ --component-menu-item-hover-color: var(--secondary-text-color);
57
+ --component-menu-item-icon-size: 20px;
58
+ --property-sidebar-background-color: #eceff1;
59
+ --property-sidebar-tab-icon-color: var(--secondary-color);
60
+ --property-sidebar-fieldset-border: 1px solid rgba(0, 0, 0, 0.2);
61
+ --property-sidebar-fieldset-label-color: var(--secondary-color);
62
+ --property-sidebar-fieldset-label: normal 12px/16px var(--theme-font);
63
+ --property-sidebar-fieldset-legend-color: var(--secondary-text-color);
64
+ --property-sidebar-fieldset-legend: bold 13px var(--theme-font);
65
+ --scene-inspector-color: var(--secondary-color);
66
+ --scene-inspector-selected-background-color: rgba(115, 188, 28, 0.2);
67
+ --scene-inspector-selected-border: 1px solid rgba(115, 188, 28, 1);
68
+ --scene-inspector-name-background-color: var(--primary-color);
69
+ --scene-inspector-eye-icon-color: var(--secondary-text-color);
70
+ }
71
+
72
+ @media (min-width: 461px) and (max-width: 1024px) {
73
+ body {
74
+ --card-list-create-form-padding: 7px;
75
+ }
76
+ }