@things-factory/setting-ui 9.0.0-beta.8 → 9.0.2

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.
@@ -1,8 +1,7 @@
1
1
  import { clientSettingStore } from '@operato/shell';
2
2
  import { setThemeMode } from './set-theme-mode.js';
3
3
  export default async function bootstrap() {
4
- var _a;
5
- const themeMode = (((_a = (await clientSettingStore.get('theme'))) === null || _a === void 0 ? void 0 : _a.value) || {}).mode || 'light';
4
+ const themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light';
6
5
  setThemeMode(themeMode);
7
6
  }
8
7
  //# sourceMappingURL=bootstrap.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"bootstrap.js","sourceRoot":"","sources":["../client/bootstrap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAElD,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,SAAS;;IACrC,MAAM,SAAS,GAAG,CAAC,CAAA,MAAA,CAAC,MAAM,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,0CAAE,KAAK,KAAI,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,CAAA;IAExF,YAAY,CAAC,SAAS,CAAC,CAAA;AACzB,CAAC","sourcesContent":["import { clientSettingStore } from '@operato/shell'\nimport { setThemeMode } from './set-theme-mode.js'\n\nexport default async function bootstrap() {\n const themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light'\n\n setThemeMode(themeMode)\n}\n"]}
1
+ {"version":3,"file":"bootstrap.js","sourceRoot":"","sources":["../client/bootstrap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAElD,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,SAAS;IACrC,MAAM,SAAS,GAAG,CAAC,CAAC,MAAM,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,CAAA;IAExF,YAAY,CAAC,SAAS,CAAC,CAAA;AACzB,CAAC","sourcesContent":["import { clientSettingStore } from '@operato/shell'\nimport { setThemeMode } from './set-theme-mode.js'\n\nexport default async function bootstrap() {\n const themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light'\n\n setThemeMode(themeMode)\n}\n"]}
@@ -1,7 +1,6 @@
1
1
  import gql from 'graphql-tag';
2
2
  import { client } from '@operato/graphql';
3
3
  export async function fetchSettingRule(name) {
4
- var _a;
5
4
  const response = await client.query({
6
5
  query: gql `
7
6
  query ($name: String!) {
@@ -13,7 +12,7 @@ export async function fetchSettingRule(name) {
13
12
  variables: { name }
14
13
  });
15
14
  if (!response.errors) {
16
- if ((_a = response.data.setting) === null || _a === void 0 ? void 0 : _a.value) {
15
+ if (response.data.setting?.value) {
17
16
  switch (response.data.setting.value.toLowerCase().trim()) {
18
17
  case 'true':
19
18
  return true;
@@ -1 +1 @@
1
- {"version":3,"file":"fetch-setting-value.js","sourceRoot":"","sources":["../client/fetch-setting-value.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAEzC,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,IAAY;;IACjD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;QAClC,KAAK,EAAE,GAAG,CAAA;;;;;;KAMT;QACD,SAAS,EAAE,EAAE,IAAI,EAAE;KACpB,CAAC,CAAA;IAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QACrB,IAAI,MAAA,QAAQ,CAAC,IAAI,CAAC,OAAO,0CAAE,KAAK,EAAE,CAAC;YACjC,QAAQ,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC;gBACzD,KAAK,MAAM;oBACT,OAAO,IAAI,CAAA;gBACb,KAAK,OAAO;oBACV,OAAO,KAAK,CAAA;gBACd;oBACE,OAAO,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,CAAA;YAC7C,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;AACH,CAAC","sourcesContent":["import gql from 'graphql-tag'\nimport { client } from '@operato/graphql'\n\nexport async function fetchSettingRule(name: string) {\n const response = await client.query({\n query: gql`\n query ($name: String!) {\n setting(name: $name) {\n value\n }\n }\n `,\n variables: { name }\n })\n\n if (!response.errors) {\n if (response.data.setting?.value) {\n switch (response.data.setting.value.toLowerCase().trim()) {\n case 'true':\n return true\n case 'false':\n return false\n default:\n return response.data.setting.value.trim()\n }\n }\n\n return false\n }\n}\n"]}
1
+ {"version":3,"file":"fetch-setting-value.js","sourceRoot":"","sources":["../client/fetch-setting-value.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAEzC,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,IAAY;IACjD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;QAClC,KAAK,EAAE,GAAG,CAAA;;;;;;KAMT;QACD,SAAS,EAAE,EAAE,IAAI,EAAE;KACpB,CAAC,CAAA;IAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QACrB,IAAI,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;YACjC,QAAQ,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC;gBACzD,KAAK,MAAM;oBACT,OAAO,IAAI,CAAA;gBACb,KAAK,OAAO;oBACV,OAAO,KAAK,CAAA;gBACd;oBACE,OAAO,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,CAAA;YAC7C,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;AACH,CAAC","sourcesContent":["import gql from 'graphql-tag'\nimport { client } from '@operato/graphql'\n\nexport async function fetchSettingRule(name: string) {\n const response = await client.query({\n query: gql`\n query ($name: String!) {\n setting(name: $name) {\n value\n }\n }\n `,\n variables: { name }\n })\n\n if (!response.errors) {\n if (response.data.setting?.value) {\n switch (response.data.setting.value.toLowerCase().trim()) {\n case 'true':\n return true\n case 'false':\n return false\n default:\n return response.data.setting.value.trim()\n }\n }\n\n return false\n }\n}\n"]}
@@ -20,6 +20,27 @@ let SettingList = class SettingList extends connect(store)(localize(i18next)(Pag
20
20
  this.mode = isMobileDevice() ? 'LIST' : 'GRID';
21
21
  this.refreshHandlers = [];
22
22
  }
23
+ static { this.styles = [
24
+ CommonGristStyles,
25
+ ScrollbarStyles,
26
+ CommonHeaderStyles,
27
+ css `
28
+ :host {
29
+ display: flex;
30
+ flex-direction: column;
31
+ overflow: hidden;
32
+ }
33
+
34
+ ox-grist {
35
+ overflow-y: auto;
36
+ flex: 1;
37
+ }
38
+
39
+ ox-filters-form {
40
+ flex: 1;
41
+ }
42
+ `
43
+ ]; }
23
44
  render() {
24
45
  return html `
25
46
  <ox-grist .mode=${this.mode} auto-fetch .config=${this.config} .fetchHandler=${this.fetchHandler.bind(this)}>
@@ -36,8 +57,16 @@ let SettingList = class SettingList extends connect(store)(localize(i18next)(Pag
36
57
  title: i18next.t('title.setting'),
37
58
  help: 'setting/settings',
38
59
  actions: [
39
- Object.assign({ title: i18next.t('button.save'), action: this._saveSettings.bind(this) }, CommonButtonStyles.save),
40
- Object.assign({ title: i18next.t('button.delete'), action: this._deleteSettings.bind(this) }, CommonButtonStyles.delete)
60
+ {
61
+ title: i18next.t('button.save'),
62
+ action: this._saveSettings.bind(this),
63
+ ...CommonButtonStyles.save
64
+ },
65
+ {
66
+ title: i18next.t('button.delete'),
67
+ action: this._deleteSettings.bind(this),
68
+ ...CommonButtonStyles.delete
69
+ }
41
70
  ],
42
71
  exportable: {
43
72
  name: i18next.t('title.setting'),
@@ -157,7 +186,7 @@ let SettingList = class SettingList extends connect(store)(localize(i18next)(Pag
157
186
  }
158
187
  async _saveSettings() {
159
188
  let patches = this.dataGrist.dirtyRecords;
160
- if (!(patches === null || patches === void 0 ? void 0 : patches.length)) {
189
+ if (!patches?.length) {
161
190
  return this.showToast(i18next.t('text.nothing_changed'));
162
191
  }
163
192
  patches = patches.map(setting => {
@@ -194,8 +223,7 @@ let SettingList = class SettingList extends connect(store)(localize(i18next)(Pag
194
223
  }
195
224
  }
196
225
  async _deleteSettings() {
197
- var _a;
198
- if (!((_a = this.dataGrist.selected) === null || _a === void 0 ? void 0 : _a.length)) {
226
+ if (!this.dataGrist.selected?.length) {
199
227
  return this.showToast(i18next.t('text.there_is_nothing_to_delete'));
200
228
  }
201
229
  const names = this.dataGrist.selected.map(record => record.name);
@@ -234,34 +262,12 @@ let SettingList = class SettingList extends connect(store)(localize(i18next)(Pag
234
262
  return this.dataGrist.exportRecords();
235
263
  }
236
264
  stateChanged(state) {
237
- var _a;
238
- this.refreshHandlers = ((_a = state.setting) === null || _a === void 0 ? void 0 : _a.refreshHandlers) || [];
265
+ this.refreshHandlers = state.setting?.refreshHandlers || [];
239
266
  }
240
267
  showToast(message) {
241
268
  document.dispatchEvent(new CustomEvent('notify', { detail: { message, option: { timer: 1000 } } }));
242
269
  }
243
270
  };
244
- SettingList.styles = [
245
- CommonGristStyles,
246
- ScrollbarStyles,
247
- CommonHeaderStyles,
248
- css `
249
- :host {
250
- display: flex;
251
- flex-direction: column;
252
- overflow: hidden;
253
- }
254
-
255
- ox-grist {
256
- overflow-y: auto;
257
- flex: 1;
258
- }
259
-
260
- ox-filters-form {
261
- flex: 1;
262
- }
263
- `
264
- ];
265
271
  __decorate([
266
272
  state(),
267
273
  __metadata("design:type", Object)
@@ -1 +1 @@
1
- {"version":3,"file":"setting-list.js","sourceRoot":"","sources":["../../client/pages/setting-list.ts"],"names":[],"mappings":";AAAA,OAAO,iCAAiC,CAAA;AACxC,OAAO,wCAAwC,CAAA;AAC/C,OAAO,2CAA2C,CAAA;AAClD,OAAO,0CAA0C,CAAA;AAEjD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AAC5D,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACjD,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AAChD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AACrD,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAC5G,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAA;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAE/C,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAY,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AAG5C,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC;IAArE;;QAyBY,SAAI,GAAW,cAAc,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAA;QACjD,oBAAe,GAAU,EAAE,CAAA;IA6P9C,CAAC;IAzPC,MAAM;QACJ,OAAO,IAAI,CAAA;wBACS,IAAI,CAAC,IAAI,uBAAuB,IAAI,CAAC,MAAM,kBAAkB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;;;KAO5G,CAAA;IACH,CAAC;IAED,IAAI,OAAO;QACT,OAAO;YACL,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;YACjC,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE;gCAEL,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,EAC/B,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,IAClC,kBAAkB,CAAC,IAAI;gCAG1B,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,EACjC,MAAM,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,IACpC,kBAAkB,CAAC,MAAM;aAE/B;YACD,UAAU,EAAE;gBACV,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;gBAChC,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;aACtC;YACD,UAAU,EAAE;gBACV,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;aAClB;SACF,CAAA;IACH,CAAC;IAED,WAAW,CAAC,OAAO,EAAE,SAAS;QAC5B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAA;YAEtB,IAAI,CAAC,MAAM,GAAG;gBACZ,IAAI,EAAE;oBACJ,MAAM,EAAE,CAAC,MAAM,EAAE,aAAa,EAAE,OAAO,CAAC;iBACzC;gBACD,IAAI,EAAE,EAAE,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE;gBACxC,OAAO,EAAE;oBACP,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE;oBACvC,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE;oBAC1C,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAE,IAAI,EAAE;oBAC9D;wBACE,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,MAAM;wBACZ,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC;wBAC/B,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE;wBACzC,QAAQ,EAAE,IAAI;wBACd,MAAM,EAAE,QAAQ;wBAChB,KAAK,EAAE,GAAG;qBACX;oBACD;wBACE,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,aAAa;wBACnB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC;wBACtC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE;wBACzC,QAAQ,EAAE,IAAI;wBACd,MAAM,EAAE,QAAQ;wBAChB,KAAK,EAAE,GAAG;qBACX;oBACD;wBACE,IAAI,EAAE,MAAM;wBACZ,IAAI,EAAE,UAAU;wBAChB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC;wBACnC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,oBAAoB,EAAE;wBAC1D,QAAQ,EAAE,IAAI;wBACd,MAAM,EAAE,QAAQ;wBAChB,KAAK,EAAE,GAAG;qBACX;oBACD;wBACE,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,OAAO;wBACb,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC;wBAChC,MAAM,EAAE;4BACN,MAAM,EAAE,UAAU,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK;gCACtD,OAAO,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAA;4BAC3E,CAAC;4BACD,QAAQ,EAAE,UAAU,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK;gCACxD,OAAO,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAA;4BAC7E,CAAC;4BACD,QAAQ,EAAE,IAAI;yBACf;wBACD,QAAQ,EAAE,IAAI;wBACd,KAAK,EAAE,GAAG;qBACX;oBACD;wBACE,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,SAAS;wBACf,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;wBAClC,MAAM,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE;wBAC1C,QAAQ,EAAE,IAAI;wBACd,KAAK,EAAE,EAAE;qBACV;oBACD;wBACE,IAAI,EAAE,UAAU;wBAChB,IAAI,EAAE,WAAW;wBACjB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,kBAAkB,CAAC;wBACrC,MAAM,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE;wBAC1C,QAAQ,EAAE,IAAI;wBACd,KAAK,EAAE,GAAG;qBACX;iBACF;aACF,CAAA;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,GAAG,EAAE,EAAE;QACvD,MAAM,UAAU,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,CAAA;QAClC,MAAM,QAAQ,GAAG,OAAO,CAAA;QAExB,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;YAClC,KAAK,EAAE,GAAG,CAAA;;;;;;;;;;;;;;;;;;;OAmBT;YACD,SAAS,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE;YAC5C,OAAO,EAAE,UAAU,EAAE;SACtB,CAAC,CAAA;QAEF,OAAO;YACL,KAAK,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC;YACxC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;SAC5C,CAAA;IACH,CAAC;IAED,KAAK,CAAC,aAAa;QACjB,IAAI,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAA;QAEzC,IAAI,CAAC,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,CAAA,EAAE,CAAC;YACrB,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAA;QAC1D,CAAC;QAED,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;YAC9B,IAAI,UAAU,GAAQ,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAA;YAC1D,MAAM,WAAW,GAAG,OAAO,CAAC,eAAe,CAAA;YAC3C,KAAK,IAAI,GAAG,IAAI,WAAW,EAAE,CAAC;gBAC5B,UAAU,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,KAAK,CAAA;YAC1C,CAAC;YACD,UAAU,CAAC,MAAM,GAAG,OAAO,CAAC,SAAS,CAAA;YAErC,OAAO,UAAU,CAAA;QACnB,CAAC,CAAC,CAAA;QAEF,IAAI,eAAe,GAAG,IAAI,CAAA;QAC1B,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACtB,IAAI,KAAK,CAAC,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAAE,OAAO,CAAC,eAAe,GAAG,KAAK,CAAC,CAAA;QAChG,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,eAAe;YAAE,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB,EAAE,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC,CAAC,CAAA;QAE7G,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;YACnC,QAAQ,EAAE,GAAG,CAAA;;;;;;OAMZ;YACD,SAAS,EAAE,EAAE,OAAO,EAAE;YACtB,OAAO,EAAE,UAAU,EAAE;SACtB,CAAC,CAAA;QAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;YACrB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAA;YAC3D,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAA;YACtB,IAAI,CAAC,oBAAoB,EAAE,CAAA;QAC7B,CAAC;IACH,CAAC;IAED,KAAK,CAAC,eAAe;;QACnB,IAAI,CAAC,CAAA,MAAA,IAAI,CAAC,SAAS,CAAC,QAAQ,0CAAE,MAAM,CAAA,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAA;QACrE,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAEhE,IACE,MAAM,QAAQ,CAAC,IAAI,CAAC;YAClB,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;YACjC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC;YACpC,aAAa,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;YACnD,YAAY,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;SACnD,CAAC,EACF,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;gBACnC,QAAQ,EAAE,GAAG,CAAA;;;;SAIZ;gBACD,SAAS,EAAE,EAAE,KAAK,EAAE;gBACpB,OAAO,EAAE,UAAU,EAAE;aACtB,CAAC,CAAA;YAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gBACrB,MAAM,QAAQ,CAAC,IAAI,CAAC;oBAClB,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC;oBAClC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,gCAAgC,CAAC;oBACjD,aAAa,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC,EAAE;iBACrD,CAAC,CAAA;gBAEF,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAA;gBACtB,IAAI,CAAC,oBAAoB,EAAE,CAAA;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,CAAC,cAAc,EAAE,CAAC,CAAA;IAClE,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAA;IACvC,CAAC;IAED,YAAY,CAAC,KAAK;;QAChB,IAAI,CAAC,eAAe,GAAG,CAAA,MAAA,KAAK,CAAC,OAAO,0CAAE,eAAe,KAAI,EAAE,CAAA;IAC7D,CAAC;IAED,SAAS,CAAC,OAAO;QACf,QAAQ,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;IACrG,CAAC;;AArRM,kBAAM,GAAG;IACd,iBAAiB;IACjB,eAAe;IACf,kBAAkB;IAClB,GAAG,CAAA;;;;;;;;;;;;;;;KAeF;CACF,AApBY,CAoBZ;AAEgB;IAAhB,KAAK,EAAE;;2CAAoB;AACX;IAAhB,KAAK,EAAE;;yCAAkB;AACT;IAAhB,KAAK,EAAE;;yCAA0D;AACjD;IAAhB,KAAK,EAAE;;oDAAoC;AAEjB;IAA1B,KAAK,CAAC,UAAU,CAAC;;8CAAuB;AA5B9B,WAAW;IADvB,aAAa,CAAC,cAAc,CAAC;GACjB,WAAW,CAuRvB","sourcesContent":["import '@operato/data-grist/ox-grist.js'\nimport '@operato/data-grist/ox-filters-form.js'\nimport '@operato/data-grist/ox-sorters-control.js'\nimport '@operato/data-grist/ox-record-creator.js'\n\nimport { getEditor, getRenderer } from '@operato/data-grist'\nimport { i18next, localize } from '@operato/i18n'\nimport { PageView, store } from '@operato/shell'\nimport { client, gqlContext } from '@operato/graphql'\nimport { CommonButtonStyles, CommonHeaderStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'\nimport { OxPrompt } from '@operato/popup/ox-prompt.js'\nimport { isMobileDevice } from '@operato/utils'\n\nimport gql from 'graphql-tag'\nimport { css, html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin'\n\n@customElement('setting-list')\nexport class SettingList extends connect(store)(localize(i18next)(PageView)) {\n static styles = [\n CommonGristStyles,\n ScrollbarStyles,\n CommonHeaderStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n }\n\n ox-grist {\n overflow-y: auto;\n flex: 1;\n }\n\n ox-filters-form {\n flex: 1;\n }\n `\n ]\n\n @state() private config: any\n @state() private data: any\n @state() private mode: string = isMobileDevice() ? 'LIST' : 'GRID'\n @state() private refreshHandlers: any[] = []\n\n @query('ox-grist') private dataGrist: any\n\n render() {\n return html`\n <ox-grist .mode=${this.mode} auto-fetch .config=${this.config} .fetchHandler=${this.fetchHandler.bind(this)}>\n <div slot=\"headroom\" class=\"header\">\n <div class=\"filters\">\n <ox-filters-form></ox-filters-form>\n </div>\n </div>\n </ox-grist>\n `\n }\n\n get context() {\n return {\n title: i18next.t('title.setting'),\n help: 'setting/settings',\n actions: [\n {\n title: i18next.t('button.save'),\n action: this._saveSettings.bind(this),\n ...CommonButtonStyles.save\n },\n {\n title: i18next.t('button.delete'),\n action: this._deleteSettings.bind(this),\n ...CommonButtonStyles.delete\n }\n ],\n exportable: {\n name: i18next.t('title.setting'),\n data: this._exportableData.bind(this)\n },\n importable: {\n handler: () => {}\n }\n }\n }\n\n pageUpdated(changes, lifecycle) {\n if (this.active) {\n this.dataGrist.fetch()\n\n this.config = {\n list: {\n fields: ['name', 'description', 'value']\n },\n rows: { selectable: { multiple: true } },\n columns: [\n { type: 'gutter', gutterName: 'dirty' },\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: { editable: true, align: 'left' },\n sortable: true,\n filter: 'search',\n width: 235\n },\n {\n type: 'string',\n name: 'description',\n header: i18next.t('field.description'),\n record: { editable: true, align: 'left' },\n sortable: true,\n filter: 'search',\n width: 275\n },\n {\n type: 'code',\n name: 'category',\n header: i18next.t('field.category'),\n record: { editable: true, codeName: 'SETTING_CATEGORIES' },\n sortable: true,\n filter: 'search',\n width: 100\n },\n {\n type: 'string',\n name: 'value',\n header: i18next.t('field.value'),\n record: {\n editor: function (value, column, record, rowIndex, field) {\n return getEditor(record.category)(value, column, record, rowIndex, field)\n },\n renderer: function (value, column, record, rowIndex, field) {\n return getRenderer(record.category)(value, column, record, rowIndex, field)\n },\n editable: true\n },\n sortable: true,\n width: 180\n },\n {\n type: 'object',\n name: 'updater',\n header: i18next.t('field.updater'),\n record: { editable: false, align: 'left' },\n sortable: true,\n width: 90\n },\n {\n type: 'datetime',\n name: 'updatedAt',\n header: i18next.t('field.updated_at'),\n record: { editable: false, align: 'left' },\n sortable: true,\n width: 180\n }\n ]\n }\n }\n }\n\n async fetchHandler({ filters, page, limit, sorters = [] }) {\n const pagination = { page, limit }\n const sortings = sorters\n\n const response = await client.query({\n query: gql`\n query settings($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {\n settings(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n description\n category\n value\n updatedAt\n updater {\n id\n name\n description\n }\n }\n total\n }\n }\n `,\n variables: { filters, pagination, sortings },\n context: gqlContext()\n })\n\n return {\n total: response.data.settings.total || 0,\n records: response.data.settings.items || []\n }\n }\n\n async _saveSettings() {\n let patches = this.dataGrist.dirtyRecords\n\n if (!patches?.length) {\n return this.showToast(i18next.t('text.nothing_changed'))\n }\n\n patches = patches.map(setting => {\n let patchField: any = setting.id ? { id: setting.id } : {}\n const dirtyFields = setting.__dirtyfields__\n for (let key in dirtyFields) {\n patchField[key] = dirtyFields[key].after\n }\n patchField.cuFlag = setting.__dirty__\n\n return patchField\n })\n\n let checkValidation = true\n patches.forEach(patch => {\n if (patch.cuFlag === '+' && (!patch.name || !patch.category)) return (checkValidation = false)\n })\n\n if (!checkValidation) return this.showToast(i18next.t('error.value is empty', { value: 'name or category' }))\n\n const response = await client.mutate({\n mutation: gql`\n mutation updateMultipleSetting($patches: [SettingPatch!]!) {\n updateMultipleSetting(patches: $patches) {\n name\n }\n }\n `,\n variables: { patches },\n context: gqlContext()\n })\n\n if (!response.errors) {\n this.showToast(i18next.t('text.data_updated_successfully'))\n this.dataGrist.fetch()\n this.applyRefreshHandlers()\n }\n }\n\n async _deleteSettings() {\n if (!this.dataGrist.selected?.length) {\n return this.showToast(i18next.t('text.there_is_nothing_to_delete'))\n }\n\n const names = this.dataGrist.selected.map(record => record.name)\n\n if (\n await OxPrompt.open({\n type: 'warning',\n title: i18next.t('button.delete'),\n text: i18next.t('text.are_you_sure'),\n confirmButton: { text: i18next.t('button.delete') },\n cancelButton: { text: i18next.t('button.cancel') }\n })\n ) {\n const response = await client.mutate({\n mutation: gql`\n mutation deleteSettings($names: [String!]!) {\n deleteSettings(names: $names)\n }\n `,\n variables: { names },\n context: gqlContext()\n })\n\n if (!response.errors) {\n await OxPrompt.open({\n type: 'success',\n title: i18next.t('text.completed'),\n text: i18next.t('text.data_deleted_successfully'),\n confirmButton: { text: i18next.t('button.confirm') }\n })\n\n this.dataGrist.fetch()\n this.applyRefreshHandlers()\n }\n }\n }\n\n applyRefreshHandlers() {\n this.refreshHandlers.forEach(refreshHandler => refreshHandler())\n }\n\n _exportableData() {\n return this.dataGrist.exportRecords()\n }\n\n stateChanged(state) {\n this.refreshHandlers = state.setting?.refreshHandlers || []\n }\n\n showToast(message) {\n document.dispatchEvent(new CustomEvent('notify', { detail: { message, option: { timer: 1000 } } }))\n }\n}\n"]}
1
+ {"version":3,"file":"setting-list.js","sourceRoot":"","sources":["../../client/pages/setting-list.ts"],"names":[],"mappings":";AAAA,OAAO,iCAAiC,CAAA;AACxC,OAAO,wCAAwC,CAAA;AAC/C,OAAO,2CAA2C,CAAA;AAClD,OAAO,0CAA0C,CAAA;AAEjD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AAC5D,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACjD,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AAChD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AACrD,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAC5G,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAA;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAE/C,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAY,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AAG5C,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC;IAArE;;QAyBY,SAAI,GAAW,cAAc,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAA;QACjD,oBAAe,GAAU,EAAE,CAAA;IA6P9C,CAAC;aAtRQ,WAAM,GAAG;QACd,iBAAiB;QACjB,eAAe;QACf,kBAAkB;QAClB,GAAG,CAAA;;;;;;;;;;;;;;;KAeF;KACF,AApBY,CAoBZ;IASD,MAAM;QACJ,OAAO,IAAI,CAAA;wBACS,IAAI,CAAC,IAAI,uBAAuB,IAAI,CAAC,MAAM,kBAAkB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;;;KAO5G,CAAA;IACH,CAAC;IAED,IAAI,OAAO;QACT,OAAO;YACL,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;YACjC,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE;gBACP;oBACE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC;oBAC/B,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC;oBACrC,GAAG,kBAAkB,CAAC,IAAI;iBAC3B;gBACD;oBACE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;oBACjC,MAAM,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;oBACvC,GAAG,kBAAkB,CAAC,MAAM;iBAC7B;aACF;YACD,UAAU,EAAE;gBACV,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;gBAChC,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;aACtC;YACD,UAAU,EAAE;gBACV,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;aAClB;SACF,CAAA;IACH,CAAC;IAED,WAAW,CAAC,OAAO,EAAE,SAAS;QAC5B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAA;YAEtB,IAAI,CAAC,MAAM,GAAG;gBACZ,IAAI,EAAE;oBACJ,MAAM,EAAE,CAAC,MAAM,EAAE,aAAa,EAAE,OAAO,CAAC;iBACzC;gBACD,IAAI,EAAE,EAAE,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE;gBACxC,OAAO,EAAE;oBACP,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE;oBACvC,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE;oBAC1C,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAE,IAAI,EAAE;oBAC9D;wBACE,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,MAAM;wBACZ,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC;wBAC/B,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE;wBACzC,QAAQ,EAAE,IAAI;wBACd,MAAM,EAAE,QAAQ;wBAChB,KAAK,EAAE,GAAG;qBACX;oBACD;wBACE,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,aAAa;wBACnB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC;wBACtC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE;wBACzC,QAAQ,EAAE,IAAI;wBACd,MAAM,EAAE,QAAQ;wBAChB,KAAK,EAAE,GAAG;qBACX;oBACD;wBACE,IAAI,EAAE,MAAM;wBACZ,IAAI,EAAE,UAAU;wBAChB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC;wBACnC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,oBAAoB,EAAE;wBAC1D,QAAQ,EAAE,IAAI;wBACd,MAAM,EAAE,QAAQ;wBAChB,KAAK,EAAE,GAAG;qBACX;oBACD;wBACE,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,OAAO;wBACb,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC;wBAChC,MAAM,EAAE;4BACN,MAAM,EAAE,UAAU,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK;gCACtD,OAAO,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAA;4BAC3E,CAAC;4BACD,QAAQ,EAAE,UAAU,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK;gCACxD,OAAO,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAA;4BAC7E,CAAC;4BACD,QAAQ,EAAE,IAAI;yBACf;wBACD,QAAQ,EAAE,IAAI;wBACd,KAAK,EAAE,GAAG;qBACX;oBACD;wBACE,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,SAAS;wBACf,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;wBAClC,MAAM,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE;wBAC1C,QAAQ,EAAE,IAAI;wBACd,KAAK,EAAE,EAAE;qBACV;oBACD;wBACE,IAAI,EAAE,UAAU;wBAChB,IAAI,EAAE,WAAW;wBACjB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,kBAAkB,CAAC;wBACrC,MAAM,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE;wBAC1C,QAAQ,EAAE,IAAI;wBACd,KAAK,EAAE,GAAG;qBACX;iBACF;aACF,CAAA;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,GAAG,EAAE,EAAE;QACvD,MAAM,UAAU,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,CAAA;QAClC,MAAM,QAAQ,GAAG,OAAO,CAAA;QAExB,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;YAClC,KAAK,EAAE,GAAG,CAAA;;;;;;;;;;;;;;;;;;;OAmBT;YACD,SAAS,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE;YAC5C,OAAO,EAAE,UAAU,EAAE;SACtB,CAAC,CAAA;QAEF,OAAO;YACL,KAAK,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC;YACxC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;SAC5C,CAAA;IACH,CAAC;IAED,KAAK,CAAC,aAAa;QACjB,IAAI,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAA;QAEzC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC;YACrB,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAA;QAC1D,CAAC;QAED,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;YAC9B,IAAI,UAAU,GAAQ,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAA;YAC1D,MAAM,WAAW,GAAG,OAAO,CAAC,eAAe,CAAA;YAC3C,KAAK,IAAI,GAAG,IAAI,WAAW,EAAE,CAAC;gBAC5B,UAAU,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,KAAK,CAAA;YAC1C,CAAC;YACD,UAAU,CAAC,MAAM,GAAG,OAAO,CAAC,SAAS,CAAA;YAErC,OAAO,UAAU,CAAA;QACnB,CAAC,CAAC,CAAA;QAEF,IAAI,eAAe,GAAG,IAAI,CAAA;QAC1B,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACtB,IAAI,KAAK,CAAC,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAAE,OAAO,CAAC,eAAe,GAAG,KAAK,CAAC,CAAA;QAChG,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,eAAe;YAAE,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB,EAAE,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC,CAAC,CAAA;QAE7G,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;YACnC,QAAQ,EAAE,GAAG,CAAA;;;;;;OAMZ;YACD,SAAS,EAAE,EAAE,OAAO,EAAE;YACtB,OAAO,EAAE,UAAU,EAAE;SACtB,CAAC,CAAA;QAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;YACrB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAA;YAC3D,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAA;YACtB,IAAI,CAAC,oBAAoB,EAAE,CAAA;QAC7B,CAAC;IACH,CAAC;IAED,KAAK,CAAC,eAAe;QACnB,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAA;QACrE,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAEhE,IACE,MAAM,QAAQ,CAAC,IAAI,CAAC;YAClB,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;YACjC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC;YACpC,aAAa,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;YACnD,YAAY,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;SACnD,CAAC,EACF,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;gBACnC,QAAQ,EAAE,GAAG,CAAA;;;;SAIZ;gBACD,SAAS,EAAE,EAAE,KAAK,EAAE;gBACpB,OAAO,EAAE,UAAU,EAAE;aACtB,CAAC,CAAA;YAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gBACrB,MAAM,QAAQ,CAAC,IAAI,CAAC;oBAClB,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC;oBAClC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,gCAAgC,CAAC;oBACjD,aAAa,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC,EAAE;iBACrD,CAAC,CAAA;gBAEF,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAA;gBACtB,IAAI,CAAC,oBAAoB,EAAE,CAAA;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,CAAC,cAAc,EAAE,CAAC,CAAA;IAClE,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAA;IACvC,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,OAAO,EAAE,eAAe,IAAI,EAAE,CAAA;IAC7D,CAAC;IAED,SAAS,CAAC,OAAO;QACf,QAAQ,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;IACrG,CAAC;;AA/PgB;IAAhB,KAAK,EAAE;;2CAAoB;AACX;IAAhB,KAAK,EAAE;;yCAAkB;AACT;IAAhB,KAAK,EAAE;;yCAA0D;AACjD;IAAhB,KAAK,EAAE;;oDAAoC;AAEjB;IAA1B,KAAK,CAAC,UAAU,CAAC;;8CAAuB;AA5B9B,WAAW;IADvB,aAAa,CAAC,cAAc,CAAC;GACjB,WAAW,CAuRvB","sourcesContent":["import '@operato/data-grist/ox-grist.js'\nimport '@operato/data-grist/ox-filters-form.js'\nimport '@operato/data-grist/ox-sorters-control.js'\nimport '@operato/data-grist/ox-record-creator.js'\n\nimport { getEditor, getRenderer } from '@operato/data-grist'\nimport { i18next, localize } from '@operato/i18n'\nimport { PageView, store } from '@operato/shell'\nimport { client, gqlContext } from '@operato/graphql'\nimport { CommonButtonStyles, CommonHeaderStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'\nimport { OxPrompt } from '@operato/popup/ox-prompt.js'\nimport { isMobileDevice } from '@operato/utils'\n\nimport gql from 'graphql-tag'\nimport { css, html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin'\n\n@customElement('setting-list')\nexport class SettingList extends connect(store)(localize(i18next)(PageView)) {\n static styles = [\n CommonGristStyles,\n ScrollbarStyles,\n CommonHeaderStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n }\n\n ox-grist {\n overflow-y: auto;\n flex: 1;\n }\n\n ox-filters-form {\n flex: 1;\n }\n `\n ]\n\n @state() private config: any\n @state() private data: any\n @state() private mode: string = isMobileDevice() ? 'LIST' : 'GRID'\n @state() private refreshHandlers: any[] = []\n\n @query('ox-grist') private dataGrist: any\n\n render() {\n return html`\n <ox-grist .mode=${this.mode} auto-fetch .config=${this.config} .fetchHandler=${this.fetchHandler.bind(this)}>\n <div slot=\"headroom\" class=\"header\">\n <div class=\"filters\">\n <ox-filters-form></ox-filters-form>\n </div>\n </div>\n </ox-grist>\n `\n }\n\n get context() {\n return {\n title: i18next.t('title.setting'),\n help: 'setting/settings',\n actions: [\n {\n title: i18next.t('button.save'),\n action: this._saveSettings.bind(this),\n ...CommonButtonStyles.save\n },\n {\n title: i18next.t('button.delete'),\n action: this._deleteSettings.bind(this),\n ...CommonButtonStyles.delete\n }\n ],\n exportable: {\n name: i18next.t('title.setting'),\n data: this._exportableData.bind(this)\n },\n importable: {\n handler: () => {}\n }\n }\n }\n\n pageUpdated(changes, lifecycle) {\n if (this.active) {\n this.dataGrist.fetch()\n\n this.config = {\n list: {\n fields: ['name', 'description', 'value']\n },\n rows: { selectable: { multiple: true } },\n columns: [\n { type: 'gutter', gutterName: 'dirty' },\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: { editable: true, align: 'left' },\n sortable: true,\n filter: 'search',\n width: 235\n },\n {\n type: 'string',\n name: 'description',\n header: i18next.t('field.description'),\n record: { editable: true, align: 'left' },\n sortable: true,\n filter: 'search',\n width: 275\n },\n {\n type: 'code',\n name: 'category',\n header: i18next.t('field.category'),\n record: { editable: true, codeName: 'SETTING_CATEGORIES' },\n sortable: true,\n filter: 'search',\n width: 100\n },\n {\n type: 'string',\n name: 'value',\n header: i18next.t('field.value'),\n record: {\n editor: function (value, column, record, rowIndex, field) {\n return getEditor(record.category)(value, column, record, rowIndex, field)\n },\n renderer: function (value, column, record, rowIndex, field) {\n return getRenderer(record.category)(value, column, record, rowIndex, field)\n },\n editable: true\n },\n sortable: true,\n width: 180\n },\n {\n type: 'object',\n name: 'updater',\n header: i18next.t('field.updater'),\n record: { editable: false, align: 'left' },\n sortable: true,\n width: 90\n },\n {\n type: 'datetime',\n name: 'updatedAt',\n header: i18next.t('field.updated_at'),\n record: { editable: false, align: 'left' },\n sortable: true,\n width: 180\n }\n ]\n }\n }\n }\n\n async fetchHandler({ filters, page, limit, sorters = [] }) {\n const pagination = { page, limit }\n const sortings = sorters\n\n const response = await client.query({\n query: gql`\n query settings($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {\n settings(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n description\n category\n value\n updatedAt\n updater {\n id\n name\n description\n }\n }\n total\n }\n }\n `,\n variables: { filters, pagination, sortings },\n context: gqlContext()\n })\n\n return {\n total: response.data.settings.total || 0,\n records: response.data.settings.items || []\n }\n }\n\n async _saveSettings() {\n let patches = this.dataGrist.dirtyRecords\n\n if (!patches?.length) {\n return this.showToast(i18next.t('text.nothing_changed'))\n }\n\n patches = patches.map(setting => {\n let patchField: any = setting.id ? { id: setting.id } : {}\n const dirtyFields = setting.__dirtyfields__\n for (let key in dirtyFields) {\n patchField[key] = dirtyFields[key].after\n }\n patchField.cuFlag = setting.__dirty__\n\n return patchField\n })\n\n let checkValidation = true\n patches.forEach(patch => {\n if (patch.cuFlag === '+' && (!patch.name || !patch.category)) return (checkValidation = false)\n })\n\n if (!checkValidation) return this.showToast(i18next.t('error.value is empty', { value: 'name or category' }))\n\n const response = await client.mutate({\n mutation: gql`\n mutation updateMultipleSetting($patches: [SettingPatch!]!) {\n updateMultipleSetting(patches: $patches) {\n name\n }\n }\n `,\n variables: { patches },\n context: gqlContext()\n })\n\n if (!response.errors) {\n this.showToast(i18next.t('text.data_updated_successfully'))\n this.dataGrist.fetch()\n this.applyRefreshHandlers()\n }\n }\n\n async _deleteSettings() {\n if (!this.dataGrist.selected?.length) {\n return this.showToast(i18next.t('text.there_is_nothing_to_delete'))\n }\n\n const names = this.dataGrist.selected.map(record => record.name)\n\n if (\n await OxPrompt.open({\n type: 'warning',\n title: i18next.t('button.delete'),\n text: i18next.t('text.are_you_sure'),\n confirmButton: { text: i18next.t('button.delete') },\n cancelButton: { text: i18next.t('button.cancel') }\n })\n ) {\n const response = await client.mutate({\n mutation: gql`\n mutation deleteSettings($names: [String!]!) {\n deleteSettings(names: $names)\n }\n `,\n variables: { names },\n context: gqlContext()\n })\n\n if (!response.errors) {\n await OxPrompt.open({\n type: 'success',\n title: i18next.t('text.completed'),\n text: i18next.t('text.data_deleted_successfully'),\n confirmButton: { text: i18next.t('button.confirm') }\n })\n\n this.dataGrist.fetch()\n this.applyRefreshHandlers()\n }\n }\n }\n\n applyRefreshHandlers() {\n this.refreshHandlers.forEach(refreshHandler => refreshHandler())\n }\n\n _exportableData() {\n return this.dataGrist.exportRecords()\n }\n\n stateChanged(state) {\n this.refreshHandlers = state.setting?.refreshHandlers || []\n }\n\n showToast(message) {\n document.dispatchEvent(new CustomEvent('notify', { detail: { message, option: { timer: 1000 } } }))\n }\n}\n"]}
@@ -9,6 +9,20 @@ let SettingPage = class SettingPage extends connect(store)(localize(i18next)(Pag
9
9
  super(...arguments);
10
10
  this._settings = [];
11
11
  }
12
+ static { this.styles = [
13
+ css `
14
+ :host {
15
+ overflow-y: auto;
16
+ background-color: var(--md-sys-color-background);
17
+ }
18
+ div {
19
+ margin: var(--setting-icon-margin);
20
+ height: var(--setting-icon-height);
21
+ background: url(/assets/images/icon-setting.png) center top no-repeat;
22
+ background-size: contain;
23
+ }
24
+ `
25
+ ]; }
12
26
  render() {
13
27
  var _sortedSettings = this._settings.sort((a, b) => {
14
28
  return a.seq - b.seq;
@@ -27,20 +41,6 @@ let SettingPage = class SettingPage extends connect(store)(localize(i18next)(Pag
27
41
  };
28
42
  }
29
43
  };
30
- SettingPage.styles = [
31
- css `
32
- :host {
33
- overflow-y: auto;
34
- background-color: var(--md-sys-color-background);
35
- }
36
- div {
37
- margin: var(--setting-icon-margin);
38
- height: var(--setting-icon-height);
39
- background: url(/assets/images/icon-setting.png) center top no-repeat;
40
- background-size: contain;
41
- }
42
- `
43
- ];
44
44
  __decorate([
45
45
  state(),
46
46
  __metadata("design:type", Array)
@@ -1 +1 @@
1
- {"version":3,"file":"setting.js","sourceRoot":"","sources":["../../client/pages/setting.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAmB,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAA;AAEtD,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAChD,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAG1C,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC;IAArE;;QAgBY,cAAS,GAAU,EAAE,CAAA;IAsBxC,CAAC;IApBC,MAAM;QACJ,IAAI,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACjD,OAAO,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAA;QACtB,CAAC,CAAC,CAAA;QAEF,OAAO,IAAI,CAAA;;QAEP,eAAe,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAA,IAAI,OAAO,CAAC,QAAQ,GAAG,CAAC;KAC9D,CAAA;IACH,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAA;IACzC,CAAC;IAED,IAAI,OAAO;QACT,OAAO;YACL,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;SAClC,CAAA;IACH,CAAC;;AApCM,kBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;KAWF;CACF,AAbY,CAaZ;AAEgB;IAAhB,KAAK,EAAE;;8CAA8B;AAhB3B,WAAW;IADvB,aAAa,CAAC,cAAc,CAAC;GACjB,WAAW,CAsCvB","sourcesContent":["import { html, css } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin.js'\n\nimport { store, PageView } from '@operato/shell'\nimport { i18next, localize } from '@operato/i18n'\n\n@customElement('setting-page')\nexport class SettingPage extends connect(store)(localize(i18next)(PageView)) {\n static styles = [\n css`\n :host {\n overflow-y: auto;\n background-color: var(--md-sys-color-background);\n }\n div {\n margin: var(--setting-icon-margin);\n height: var(--setting-icon-height);\n background: url(/assets/images/icon-setting.png) center top no-repeat;\n background-size: contain;\n }\n `\n ]\n\n @state() private _settings: any[] = []\n\n render() {\n var _sortedSettings = this._settings.sort((a, b) => {\n return a.seq - b.seq\n })\n\n return html`\n <div class=\"page-icon\"></div>\n ${_sortedSettings.map(setting => html` ${setting.template} `)}\n `\n }\n\n stateChanged(state) {\n this._settings = state.setting.settings\n }\n\n get context() {\n return {\n title: i18next.t('title.setting')\n }\n }\n}\n"]}
1
+ {"version":3,"file":"setting.js","sourceRoot":"","sources":["../../client/pages/setting.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAmB,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAA;AAEtD,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAChD,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAG1C,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC;IAArE;;QAgBY,cAAS,GAAU,EAAE,CAAA;IAsBxC,CAAC;aArCQ,WAAM,GAAG;QACd,GAAG,CAAA;;;;;;;;;;;KAWF;KACF,AAbY,CAaZ;IAID,MAAM;QACJ,IAAI,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACjD,OAAO,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAA;QACtB,CAAC,CAAC,CAAA;QAEF,OAAO,IAAI,CAAA;;QAEP,eAAe,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAA,IAAI,OAAO,CAAC,QAAQ,GAAG,CAAC;KAC9D,CAAA;IACH,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAA;IACzC,CAAC;IAED,IAAI,OAAO;QACT,OAAO;YACL,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;SAClC,CAAA;IACH,CAAC;;AArBgB;IAAhB,KAAK,EAAE;;8CAA8B;AAhB3B,WAAW;IADvB,aAAa,CAAC,cAAc,CAAC;GACjB,WAAW,CAsCvB","sourcesContent":["import { html, css } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin.js'\n\nimport { store, PageView } from '@operato/shell'\nimport { i18next, localize } from '@operato/i18n'\n\n@customElement('setting-page')\nexport class SettingPage extends connect(store)(localize(i18next)(PageView)) {\n static styles = [\n css`\n :host {\n overflow-y: auto;\n background-color: var(--md-sys-color-background);\n }\n div {\n margin: var(--setting-icon-margin);\n height: var(--setting-icon-height);\n background: url(/assets/images/icon-setting.png) center top no-repeat;\n background-size: contain;\n }\n `\n ]\n\n @state() private _settings: any[] = []\n\n render() {\n var _sortedSettings = this._settings.sort((a, b) => {\n return a.seq - b.seq\n })\n\n return html`\n <div class=\"page-icon\"></div>\n ${_sortedSettings.map(setting => html` ${setting.template} `)}\n `\n }\n\n stateChanged(state) {\n this._settings = state.setting.settings\n }\n\n get context() {\n return {\n title: i18next.t('title.setting')\n }\n }\n}\n"]}
@@ -7,8 +7,7 @@ function getPrefersColorSchemeMedia() {
7
7
  return prefersColorSchemeMedia;
8
8
  }
9
9
  async function onPreferColorSchemeChanged() {
10
- var _a;
11
- const themeMode = (((_a = (await clientSettingStore.get('theme'))) === null || _a === void 0 ? void 0 : _a.value) || {}).mode || 'light';
10
+ const themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light';
12
11
  if (themeMode !== 'auto') {
13
12
  getPrefersColorSchemeMedia().removeEventListener('change', onPreferColorSchemeChanged);
14
13
  return;
@@ -1 +1 @@
1
- {"version":3,"file":"set-theme-mode.js","sourceRoot":"","sources":["../client/set-theme-mode.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAEnD,IAAI,uBAAuB,CAAA;AAE3B,SAAS,0BAA0B;IACjC,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC7B,uBAAuB,GAAG,MAAM,CAAC,UAAU,CAAC,8BAA8B,CAAC,CAAA;IAC7E,CAAC;IACD,OAAO,uBAAuB,CAAA;AAChC,CAAC;AAED,KAAK,UAAU,0BAA0B;;IACvC,MAAM,SAAS,GAAG,CAAC,CAAA,MAAA,CAAC,MAAM,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,0CAAE,KAAK,KAAI,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,CAAA;IAExF,IAAI,SAAS,KAAK,MAAM,EAAE,CAAC;QACzB,0BAA0B,EAAE,CAAC,mBAAmB,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAA;QAEtF,OAAM;IACR,CAAC;IAED,IAAI,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,CAAC,8BAA8B,CAAC,CAAC,OAAO,EAAE,CAAC;QACnF,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QACnC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IACzC,CAAC;SAAM,CAAC;QACN,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QACpC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACxC,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,IAAI;IAC/B,0BAA0B,EAAE,CAAC,mBAAmB,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAA;IAEtF,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;QACpB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QACnC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IACzC,CAAC;SAAM,IAAI,IAAI,KAAK,OAAO,EAAE,CAAC;QAC5B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QACpC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACxC,CAAC;SAAM,CAAC;QACN,IAAI,0BAA0B,EAAE,CAAC,OAAO,EAAE,CAAC;YACzC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;YACnC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;QACzC,CAAC;aAAM,CAAC;YACN,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACpC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACxC,CAAC;QAED,0BAA0B,EAAE,CAAC,gBAAgB,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAA;IACrF,CAAC;AACH,CAAC","sourcesContent":["import { clientSettingStore } from '@operato/shell'\n\nvar prefersColorSchemeMedia\n\nfunction getPrefersColorSchemeMedia() {\n if (!prefersColorSchemeMedia) {\n prefersColorSchemeMedia = window.matchMedia('(prefers-color-scheme: dark)')\n }\n return prefersColorSchemeMedia\n}\n\nasync function onPreferColorSchemeChanged() {\n const themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light'\n\n if (themeMode !== 'auto') {\n getPrefersColorSchemeMedia().removeEventListener('change', onPreferColorSchemeChanged)\n\n return\n }\n\n if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n document.body.classList.add('dark')\n document.body.classList.remove('light')\n } else {\n document.body.classList.add('light')\n document.body.classList.remove('dark')\n }\n}\n\nexport function setThemeMode(mode) {\n getPrefersColorSchemeMedia().removeEventListener('change', onPreferColorSchemeChanged)\n\n if (mode === 'dark') {\n document.body.classList.add('dark')\n document.body.classList.remove('light')\n } else if (mode === 'light') {\n document.body.classList.add('light')\n document.body.classList.remove('dark')\n } else {\n if (getPrefersColorSchemeMedia().matches) {\n document.body.classList.add('dark')\n document.body.classList.remove('light')\n } else {\n document.body.classList.add('light')\n document.body.classList.remove('dark')\n }\n\n getPrefersColorSchemeMedia().addEventListener('change', onPreferColorSchemeChanged)\n }\n}\n"]}
1
+ {"version":3,"file":"set-theme-mode.js","sourceRoot":"","sources":["../client/set-theme-mode.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAEnD,IAAI,uBAAuB,CAAA;AAE3B,SAAS,0BAA0B;IACjC,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC7B,uBAAuB,GAAG,MAAM,CAAC,UAAU,CAAC,8BAA8B,CAAC,CAAA;IAC7E,CAAC;IACD,OAAO,uBAAuB,CAAA;AAChC,CAAC;AAED,KAAK,UAAU,0BAA0B;IACvC,MAAM,SAAS,GAAG,CAAC,CAAC,MAAM,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,CAAA;IAExF,IAAI,SAAS,KAAK,MAAM,EAAE,CAAC;QACzB,0BAA0B,EAAE,CAAC,mBAAmB,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAA;QAEtF,OAAM;IACR,CAAC;IAED,IAAI,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,CAAC,8BAA8B,CAAC,CAAC,OAAO,EAAE,CAAC;QACnF,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QACnC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IACzC,CAAC;SAAM,CAAC;QACN,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QACpC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACxC,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,IAAI;IAC/B,0BAA0B,EAAE,CAAC,mBAAmB,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAA;IAEtF,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;QACpB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QACnC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IACzC,CAAC;SAAM,IAAI,IAAI,KAAK,OAAO,EAAE,CAAC;QAC5B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QACpC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACxC,CAAC;SAAM,CAAC;QACN,IAAI,0BAA0B,EAAE,CAAC,OAAO,EAAE,CAAC;YACzC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;YACnC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;QACzC,CAAC;aAAM,CAAC;YACN,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACpC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACxC,CAAC;QAED,0BAA0B,EAAE,CAAC,gBAAgB,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAA;IACrF,CAAC;AACH,CAAC","sourcesContent":["import { clientSettingStore } from '@operato/shell'\n\nvar prefersColorSchemeMedia\n\nfunction getPrefersColorSchemeMedia() {\n if (!prefersColorSchemeMedia) {\n prefersColorSchemeMedia = window.matchMedia('(prefers-color-scheme: dark)')\n }\n return prefersColorSchemeMedia\n}\n\nasync function onPreferColorSchemeChanged() {\n const themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light'\n\n if (themeMode !== 'auto') {\n getPrefersColorSchemeMedia().removeEventListener('change', onPreferColorSchemeChanged)\n\n return\n }\n\n if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n document.body.classList.add('dark')\n document.body.classList.remove('light')\n } else {\n document.body.classList.add('light')\n document.body.classList.remove('dark')\n }\n}\n\nexport function setThemeMode(mode) {\n getPrefersColorSchemeMedia().removeEventListener('change', onPreferColorSchemeChanged)\n\n if (mode === 'dark') {\n document.body.classList.add('dark')\n document.body.classList.remove('light')\n } else if (mode === 'light') {\n document.body.classList.add('light')\n document.body.classList.remove('dark')\n } else {\n if (getPrefersColorSchemeMedia().matches) {\n document.body.classList.add('dark')\n document.body.classList.remove('light')\n } else {\n document.body.classList.add('light')\n document.body.classList.remove('dark')\n }\n\n getPrefersColorSchemeMedia().addEventListener('change', onPreferColorSchemeChanged)\n }\n}\n"]}
@@ -10,6 +10,16 @@ let DomainSwitchLet = class DomainSwitchLet extends connect(store)(LitElement) {
10
10
  super(...arguments);
11
11
  this.domains = [];
12
12
  }
13
+ static { this.styles = [
14
+ css `
15
+ select {
16
+ border: var(--input-field-border);
17
+ padding: var(--input-padding);
18
+ border-radius: var(--border-radius);
19
+ font: var(--input-font);
20
+ }
21
+ `
22
+ ]; }
13
23
  render() {
14
24
  return html `
15
25
  <setting-let>
@@ -17,14 +27,11 @@ let DomainSwitchLet = class DomainSwitchLet extends connect(store)(LitElement) {
17
27
 
18
28
  <select slot="content" @change=${e => (window.location.pathname = '/auth/checkin/' + e.target.value)}>
19
29
  <option value="">&nbsp</option>
20
- ${this.domains.map(option => {
21
- var _a;
22
- return html `
23
- <option value=${option.subdomain} ?selected=${((_a = this.domain) === null || _a === void 0 ? void 0 : _a.subdomain) == option.subdomain}>
30
+ ${this.domains.map(option => html `
31
+ <option value=${option.subdomain} ?selected=${this.domain?.subdomain == option.subdomain}>
24
32
  ${option.name}
25
33
  </option>
26
- `;
27
- })}
34
+ `)}
28
35
  </select>
29
36
  </setting-let>
30
37
  `;
@@ -34,16 +41,6 @@ let DomainSwitchLet = class DomainSwitchLet extends connect(store)(LitElement) {
34
41
  this.domain = state.app.domain;
35
42
  }
36
43
  };
37
- DomainSwitchLet.styles = [
38
- css `
39
- select {
40
- border: var(--input-field-border);
41
- padding: var(--input-padding);
42
- border-radius: var(--border-radius);
43
- font: var(--input-font);
44
- }
45
- `
46
- ];
47
44
  __decorate([
48
45
  state(),
49
46
  __metadata("design:type", Array)
@@ -1 +1 @@
1
- {"version":3,"file":"domain-switch-let.js","sourceRoot":"","sources":["../../client/setting-lets/domain-switch-let.ts"],"names":[],"mappings":";AAAA,OAAO,8BAA8B,CAAA;AACrC,OAAO,0BAA0B,CAAA;AAEjC,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AAEtC,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAA6B,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACnF,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AAG5C,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC;IAAxD;;QAYI,YAAO,GAAU,EAAE,CAAA;IA0B9B,CAAC;IAvBC,MAAM;QACJ,OAAO,IAAI,CAAA;;;;yCAI0B,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,GAAG,gBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;;YAEhG,IAAI,CAAC,OAAO,CAAC,GAAG,CAChB,MAAM,CAAC,EAAE;;YAAC,OAAA,IAAI,CAAA;8BACI,MAAM,CAAC,SAAS,cAAc,CAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,SAAS,KAAI,MAAM,CAAC,SAAS;kBACpF,MAAM,CAAC,IAAI;;aAEhB,CAAA;SAAA,CACF;;;KAGN,CAAA;IACH,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,CAAA;QAChC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM,CAAA;IAChC,CAAC;;AApCM,sBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;KAOF;CACF,AATY,CASZ;AAEQ;IAAR,KAAK,EAAE;;gDAAoB;AACnB;IAAR,KAAK,EAAE;;+CAAY;AAbT,eAAe;IAD3B,aAAa,CAAC,mBAAmB,CAAC;GACtB,eAAe,CAsC3B","sourcesContent":["import '@things-factory/setting-base'\nimport '@operato/i18n/ox-i18n.js'\n\nimport { store } from '@operato/shell'\n\nimport { html, css, LitElement } from 'lit'\nimport { customElement, property, query, queryAll, state } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin'\n\n@customElement('domain-switch-let')\nexport class DomainSwitchLet extends connect(store)(LitElement) {\n static styles = [\n css`\n select {\n border: var(--input-field-border);\n padding: var(--input-padding);\n border-radius: var(--border-radius);\n font: var(--input-font);\n }\n `\n ]\n\n @state() domains: any[] = []\n @state() domain: any\n\n render() {\n return html`\n <setting-let>\n <ox-i18n slot=\"title\" msgid=\"title.switch domain\"></ox-i18n>\n\n <select slot=\"content\" @change=${e => (window.location.pathname = '/auth/checkin/' + e.target.value)}>\n <option value=\"\">&nbsp</option>\n ${this.domains.map(\n option => html`\n <option value=${option.subdomain} ?selected=${this.domain?.subdomain == option.subdomain}>\n ${option.name}\n </option>\n `\n )}\n </select>\n </setting-let>\n `\n }\n\n stateChanged(state) {\n this.domains = state.app.domains\n this.domain = state.app.domain\n }\n}\n"]}
1
+ {"version":3,"file":"domain-switch-let.js","sourceRoot":"","sources":["../../client/setting-lets/domain-switch-let.ts"],"names":[],"mappings":";AAAA,OAAO,8BAA8B,CAAA;AACrC,OAAO,0BAA0B,CAAA;AAEjC,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AAEtC,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAA6B,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACnF,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AAG5C,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC;IAAxD;;QAYI,YAAO,GAAU,EAAE,CAAA;IA0B9B,CAAC;aArCQ,WAAM,GAAG;QACd,GAAG,CAAA;;;;;;;KAOF;KACF,AATY,CASZ;IAKD,MAAM;QACJ,OAAO,IAAI,CAAA;;;;yCAI0B,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,GAAG,gBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;;YAEhG,IAAI,CAAC,OAAO,CAAC,GAAG,CAChB,MAAM,CAAC,EAAE,CAAC,IAAI,CAAA;8BACI,MAAM,CAAC,SAAS,cAAc,IAAI,CAAC,MAAM,EAAE,SAAS,IAAI,MAAM,CAAC,SAAS;kBACpF,MAAM,CAAC,IAAI;;aAEhB,CACF;;;KAGN,CAAA;IACH,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,CAAA;QAChC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM,CAAA;IAChC,CAAC;;AAzBQ;IAAR,KAAK,EAAE;;gDAAoB;AACnB;IAAR,KAAK,EAAE;;+CAAY;AAbT,eAAe;IAD3B,aAAa,CAAC,mBAAmB,CAAC;GACtB,eAAe,CAsC3B","sourcesContent":["import '@things-factory/setting-base'\nimport '@operato/i18n/ox-i18n.js'\n\nimport { store } from '@operato/shell'\n\nimport { html, css, LitElement } from 'lit'\nimport { customElement, property, query, queryAll, state } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin'\n\n@customElement('domain-switch-let')\nexport class DomainSwitchLet extends connect(store)(LitElement) {\n static styles = [\n css`\n select {\n border: var(--input-field-border);\n padding: var(--input-padding);\n border-radius: var(--border-radius);\n font: var(--input-font);\n }\n `\n ]\n\n @state() domains: any[] = []\n @state() domain: any\n\n render() {\n return html`\n <setting-let>\n <ox-i18n slot=\"title\" msgid=\"title.switch domain\"></ox-i18n>\n\n <select slot=\"content\" @change=${e => (window.location.pathname = '/auth/checkin/' + e.target.value)}>\n <option value=\"\">&nbsp</option>\n ${this.domains.map(\n option => html`\n <option value=${option.subdomain} ?selected=${this.domain?.subdomain == option.subdomain}>\n ${option.name}\n </option>\n `\n )}\n </select>\n </setting-let>\n `\n }\n\n stateChanged(state) {\n this.domains = state.app.domains\n this.domain = state.app.domain\n }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { __decorate, __metadata, __rest } from "tslib";
1
+ import { __decorate, __metadata } from "tslib";
2
2
  import '@material/web/textfield/filled-text-field.js';
3
3
  import '@things-factory/setting-base';
4
4
  import '@operato/i18n/ox-i18n.js';
@@ -12,6 +12,38 @@ let SecureIPListSettingLet = class SecureIPListSettingLet extends LitElement {
12
12
  super(...arguments);
13
13
  this.allPrivileges = [];
14
14
  }
15
+ static { this.styles = [
16
+ css `
17
+ div[slot='content'] {
18
+ display: flex;
19
+ flex-direction: column;
20
+ gap: 6px;
21
+ }
22
+
23
+ ul {
24
+ flex: 1;
25
+ background-color: var(--md-sys-color-surface);
26
+ overflow: auto;
27
+ display: grid;
28
+ grid-template-columns: 1fr 1fr;
29
+ margin: 0;
30
+ padding: var(--spacing-medium);
31
+ list-style: none;
32
+ border: 1px dashed var(--md-sys-color-outline);
33
+ border-width: 1px 0;
34
+ }
35
+
36
+ [hidden] {
37
+ display: none;
38
+ }
39
+
40
+ @media screen and (max-width: 480px) {
41
+ ul {
42
+ grid-template-columns: 1fr;
43
+ }
44
+ }
45
+ `
46
+ ]; }
15
47
  render() {
16
48
  const { whitelist = [], blacklist = [], protectedlist = [], privileges = [] } = this.value || {};
17
49
  return html `
@@ -96,7 +128,7 @@ let SecureIPListSettingLet = class SecureIPListSettingLet extends LitElement {
96
128
  }
97
129
  `
98
130
  });
99
- this.allPrivileges = (data === null || data === void 0 ? void 0 : data.privileges.items) || [];
131
+ this.allPrivileges = data?.privileges.items || [];
100
132
  var { data } = await client.query({
101
133
  query: gql `
102
134
  query {
@@ -119,7 +151,7 @@ let SecureIPListSettingLet = class SecureIPListSettingLet extends LitElement {
119
151
  const privileges = Array.from(this.protectedPrivileges)
120
152
  .map((e) => e['data-privilege'])
121
153
  .map((priv) => {
122
- const { description } = priv, others = __rest(priv, ["description"]);
154
+ const { description, ...others } = priv;
123
155
  return others;
124
156
  });
125
157
  const iplist = {
@@ -141,38 +173,6 @@ let SecureIPListSettingLet = class SecureIPListSettingLet extends LitElement {
141
173
  this.value = data ? data.updateSecureIPList : {};
142
174
  }
143
175
  };
144
- SecureIPListSettingLet.styles = [
145
- css `
146
- div[slot='content'] {
147
- display: flex;
148
- flex-direction: column;
149
- gap: 6px;
150
- }
151
-
152
- ul {
153
- flex: 1;
154
- background-color: var(--md-sys-color-surface);
155
- overflow: auto;
156
- display: grid;
157
- grid-template-columns: 1fr 1fr;
158
- margin: 0;
159
- padding: var(--spacing-medium);
160
- list-style: none;
161
- border: 1px dashed var(--md-sys-color-outline);
162
- border-width: 1px 0;
163
- }
164
-
165
- [hidden] {
166
- display: none;
167
- }
168
-
169
- @media screen and (max-width: 480px) {
170
- ul {
171
- grid-template-columns: 1fr;
172
- }
173
- }
174
- `
175
- ];
176
176
  __decorate([
177
177
  property({ type: Object }),
178
178
  __metadata("design:type", Object)
@@ -1 +1 @@
1
- {"version":3,"file":"secure-iplist-setting-let.js","sourceRoot":"","sources":["../../client/setting-lets/secure-iplist-setting-let.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/textfield/filled-text-field.js'\nimport '@things-factory/setting-base'\nimport '@operato/i18n/ox-i18n.js'\n\nimport gql from 'graphql-tag'\nimport { html, css, LitElement, PropertyValueMap } from 'lit'\nimport { customElement, property, query, queryAll, state } from 'lit/decorators.js'\n\nimport { i18next } from '@operato/i18n'\nimport { client } from '@operato/graphql'\n\n@customElement('secure-iplist-setting-let')\nexport class SecureIPListSettingLet extends LitElement {\n static styles = [\n css`\n div[slot='content'] {\n display: flex;\n flex-direction: column;\n gap: 6px;\n }\n\n ul {\n flex: 1;\n background-color: var(--md-sys-color-surface);\n overflow: auto;\n display: grid;\n grid-template-columns: 1fr 1fr;\n margin: 0;\n padding: var(--spacing-medium);\n list-style: none;\n border: 1px dashed var(--md-sys-color-outline);\n border-width: 1px 0;\n }\n\n [hidden] {\n display: none;\n }\n\n @media screen and (max-width: 480px) {\n ul {\n grid-template-columns: 1fr;\n }\n }\n `\n ]\n\n @property({ type: Object }) value?: {\n blacklist?: string[]\n whitelist?: string[]\n protectedlist?: string[]\n privileges?: any[]\n }\n\n @state() private allPrivileges: {\n privilege: string\n category: string\n description: string\n }[] = []\n\n @query('[name=\"whitelist\"]') whitelist\n @query('[name=\"blacklist\"]') blacklist\n @query('[name=\"protectedlist\"]') protectedlist\n @queryAll('ul[privileges] input[type=checkbox]:checked') protectedPrivileges\n\n render() {\n const { whitelist = [], blacklist = [], protectedlist = [], privileges = [] } = this.value || {}\n\n return html`\n <setting-let>\n <ox-title-with-help slot=\"title\" topic=\"setting/secure-ip-list\" msgid=\"title.secure-ip-list\"\n >secure IP list</ox-title-with-help\n >\n\n <div slot=\"content\" @change=${() => this.onSave()}>\n <md-filled-text-field\n type=\"text\"\n name=\"whitelist\"\n .label=${String(i18next.t('label.whitelist'))}\n icon=\"health_and_safety\"\n value=${whitelist.join(', ')}\n supporting-text=${String(i18next.t('text.supporting text for whitelist'))}\n hidden\n >\n <md-icon slot=\"leading-icon\">health_and_safety</md-icon>\n </md-filled-text-field>\n\n <md-filled-text-field\n type=\"text\"\n name=\"blacklist\"\n .label=${String(i18next.t('label.blacklist'))}\n value=${blacklist.join(', ')}\n supporting-text=${String(i18next.t('text.supporting text for blacklist'))}\n >\n <md-icon slot=\"leading-icon\">block</md-icon>\n </md-filled-text-field>\n\n <md-filled-text-field\n type=\"text\"\n name=\"protectedlist\"\n .label=${String(i18next.t('label.protectedlist'))}\n value=${protectedlist.join(', ')}\n supporting-text=${String(i18next.t('text.supporting text for protected ip-list'))}\n >\n <md-icon slot=\"leading-icon\">security</md-icon>\n </md-filled-text-field>\n\n <div>\n <h3><ox-i18n msgid=\"title.protected-privileges\"></ox-i18n></h3>\n <div>\n <input id=\"checkAll\" type=\"checkbox\" @change=${e => this.oncheckAll(e)} />\n <label for=\"checkAll\">Check all</label>\n </div>\n\n <ul privileges>\n ${this.allPrivileges.map(privilege => {\n const id = `${privilege.category}-${privilege.privilege}`\n return html`\n <li>\n <input\n type=\"checkbox\"\n id=${id}\n .checked=${!!privileges.find(\n p => p.privilege == privilege.privilege && p.category == privilege.category\n )}\n .data-privilege=${privilege}\n />\n <label for=\"${id}\">${privilege.description}</label>\n </li>\n `\n })}\n </ul>\n </div>\n </div>\n </setting-let>\n `\n }\n\n async firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): Promise<void> {\n var { data } = await client.query({\n query: gql`\n query {\n privileges {\n items {\n privilege\n category\n description\n }\n total\n }\n }\n `\n })\n\n this.allPrivileges = data?.privileges.items || []\n\n var { data } = await client.query({\n query: gql`\n query {\n secureIPList\n }\n `\n })\n\n this.value = data ? data.secureIPList : {}\n }\n\n checkAll(checked) {\n Array.from(this.renderRoot.querySelectorAll('ul[privileges] input[type=checkbox]')).forEach(\n checkbox => ((checkbox as HTMLInputElement).checked = checked)\n )\n }\n\n oncheckAll(e) {\n this.checkAll(e.target.checked)\n }\n\n async onSave() {\n const whitelist = !this.whitelist.value ? [] : this.whitelist.value.split(',').map(ip => ip.trim())\n const blacklist = !this.blacklist.value ? [] : this.blacklist.value.split(',').map(ip => ip.trim())\n const protectedlist = !this.protectedlist.value ? [] : this.protectedlist.value.split(',').map(ip => ip.trim())\n const privileges = Array.from(this.protectedPrivileges)\n .map((e: any) => e['data-privilege'])\n .map((priv: any) => {\n const { description, ...others } = priv\n return others\n })\n\n const iplist = {\n whitelist,\n blacklist,\n protectedlist,\n privileges\n }\n\n const { data } = await client.query({\n query: gql`\n mutation ($iplist: Object!) {\n updateSecureIPList(iplist: $iplist)\n }\n `,\n variables: {\n iplist\n }\n })\n\n this.value = data ? data.updateSecureIPList : {}\n }\n}\n"]}
1
+ {"version":3,"file":"secure-iplist-setting-let.js","sourceRoot":"","sources":["../../client/setting-lets/secure-iplist-setting-let.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/textfield/filled-text-field.js'\nimport '@things-factory/setting-base'\nimport '@operato/i18n/ox-i18n.js'\n\nimport gql from 'graphql-tag'\nimport { html, css, LitElement, PropertyValueMap } from 'lit'\nimport { customElement, property, query, queryAll, state } from 'lit/decorators.js'\n\nimport { i18next } from '@operato/i18n'\nimport { client } from '@operato/graphql'\n\n@customElement('secure-iplist-setting-let')\nexport class SecureIPListSettingLet extends LitElement {\n static styles = [\n css`\n div[slot='content'] {\n display: flex;\n flex-direction: column;\n gap: 6px;\n }\n\n ul {\n flex: 1;\n background-color: var(--md-sys-color-surface);\n overflow: auto;\n display: grid;\n grid-template-columns: 1fr 1fr;\n margin: 0;\n padding: var(--spacing-medium);\n list-style: none;\n border: 1px dashed var(--md-sys-color-outline);\n border-width: 1px 0;\n }\n\n [hidden] {\n display: none;\n }\n\n @media screen and (max-width: 480px) {\n ul {\n grid-template-columns: 1fr;\n }\n }\n `\n ]\n\n @property({ type: Object }) value?: {\n blacklist?: string[]\n whitelist?: string[]\n protectedlist?: string[]\n privileges?: any[]\n }\n\n @state() private allPrivileges: {\n privilege: string\n category: string\n description: string\n }[] = []\n\n @query('[name=\"whitelist\"]') whitelist\n @query('[name=\"blacklist\"]') blacklist\n @query('[name=\"protectedlist\"]') protectedlist\n @queryAll('ul[privileges] input[type=checkbox]:checked') protectedPrivileges\n\n render() {\n const { whitelist = [], blacklist = [], protectedlist = [], privileges = [] } = this.value || {}\n\n return html`\n <setting-let>\n <ox-title-with-help slot=\"title\" topic=\"setting/secure-ip-list\" msgid=\"title.secure-ip-list\"\n >secure IP list</ox-title-with-help\n >\n\n <div slot=\"content\" @change=${() => this.onSave()}>\n <md-filled-text-field\n type=\"text\"\n name=\"whitelist\"\n .label=${String(i18next.t('label.whitelist'))}\n icon=\"health_and_safety\"\n value=${whitelist.join(', ')}\n supporting-text=${String(i18next.t('text.supporting text for whitelist'))}\n hidden\n >\n <md-icon slot=\"leading-icon\">health_and_safety</md-icon>\n </md-filled-text-field>\n\n <md-filled-text-field\n type=\"text\"\n name=\"blacklist\"\n .label=${String(i18next.t('label.blacklist'))}\n value=${blacklist.join(', ')}\n supporting-text=${String(i18next.t('text.supporting text for blacklist'))}\n >\n <md-icon slot=\"leading-icon\">block</md-icon>\n </md-filled-text-field>\n\n <md-filled-text-field\n type=\"text\"\n name=\"protectedlist\"\n .label=${String(i18next.t('label.protectedlist'))}\n value=${protectedlist.join(', ')}\n supporting-text=${String(i18next.t('text.supporting text for protected ip-list'))}\n >\n <md-icon slot=\"leading-icon\">security</md-icon>\n </md-filled-text-field>\n\n <div>\n <h3><ox-i18n msgid=\"title.protected-privileges\"></ox-i18n></h3>\n <div>\n <input id=\"checkAll\" type=\"checkbox\" @change=${e => this.oncheckAll(e)} />\n <label for=\"checkAll\">Check all</label>\n </div>\n\n <ul privileges>\n ${this.allPrivileges.map(privilege => {\n const id = `${privilege.category}-${privilege.privilege}`\n return html`\n <li>\n <input\n type=\"checkbox\"\n id=${id}\n .checked=${!!privileges.find(\n p => p.privilege == privilege.privilege && p.category == privilege.category\n )}\n .data-privilege=${privilege}\n />\n <label for=\"${id}\">${privilege.description}</label>\n </li>\n `\n })}\n </ul>\n </div>\n </div>\n </setting-let>\n `\n }\n\n async firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): Promise<void> {\n var { data } = await client.query({\n query: gql`\n query {\n privileges {\n items {\n privilege\n category\n description\n }\n total\n }\n }\n `\n })\n\n this.allPrivileges = data?.privileges.items || []\n\n var { data } = await client.query({\n query: gql`\n query {\n secureIPList\n }\n `\n })\n\n this.value = data ? data.secureIPList : {}\n }\n\n checkAll(checked) {\n Array.from(this.renderRoot.querySelectorAll('ul[privileges] input[type=checkbox]')).forEach(\n checkbox => ((checkbox as HTMLInputElement).checked = checked)\n )\n }\n\n oncheckAll(e) {\n this.checkAll(e.target.checked)\n }\n\n async onSave() {\n const whitelist = !this.whitelist.value ? [] : this.whitelist.value.split(',').map(ip => ip.trim())\n const blacklist = !this.blacklist.value ? [] : this.blacklist.value.split(',').map(ip => ip.trim())\n const protectedlist = !this.protectedlist.value ? [] : this.protectedlist.value.split(',').map(ip => ip.trim())\n const privileges = Array.from(this.protectedPrivileges)\n .map((e: any) => e['data-privilege'])\n .map((priv: any) => {\n const { description, ...others } = priv\n return others\n })\n\n const iplist = {\n whitelist,\n blacklist,\n protectedlist,\n privileges\n }\n\n const { data } = await client.query({\n query: gql`\n mutation ($iplist: Object!) {\n updateSecureIPList(iplist: $iplist)\n }\n `,\n variables: {\n iplist\n }\n })\n\n this.value = data ? data.updateSecureIPList : {}\n }\n}\n"]}
@@ -11,6 +11,24 @@ let ThemeModeSettingLet = class ThemeModeSettingLet extends localize(i18next)(Li
11
11
  super(...arguments);
12
12
  this.themeMode = 'light';
13
13
  }
14
+ static { this.styles = [
15
+ css `
16
+ label {
17
+ display: flex;
18
+ gap: 10px;
19
+ align-items: center;
20
+
21
+ font: var(--label-font);
22
+ color: var(--md-sys-color-on-surface);
23
+ text-transform: var(--label-text-transform);
24
+ }
25
+
26
+ div[slot='content'] {
27
+ display: flex;
28
+ gap: 10px;
29
+ }
30
+ `
31
+ ]; }
14
32
  render() {
15
33
  const themeMode = this.themeMode;
16
34
  return html `
@@ -31,14 +49,12 @@ let ThemeModeSettingLet = class ThemeModeSettingLet extends localize(i18next)(Li
31
49
  `;
32
50
  }
33
51
  async firstUpdated() {
34
- var _a;
35
- this.themeMode = (((_a = (await clientSettingStore.get('theme'))) === null || _a === void 0 ? void 0 : _a.value) || {}).mode || 'light';
52
+ this.themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light';
36
53
  }
37
54
  async onChangeThemeMode(e) {
38
- var _a;
39
55
  const target = e.target;
40
56
  const value = target.value;
41
- const mode = ((_a = this.querySelector('md-radio[checked]')) === null || _a === void 0 ? void 0 : _a.value) || value;
57
+ const mode = this.querySelector('md-radio[checked]')?.value || value;
42
58
  if (mode) {
43
59
  try {
44
60
  await clientSettingStore.put({
@@ -55,24 +71,6 @@ let ThemeModeSettingLet = class ThemeModeSettingLet extends localize(i18next)(Li
55
71
  }
56
72
  }
57
73
  };
58
- ThemeModeSettingLet.styles = [
59
- css `
60
- label {
61
- display: flex;
62
- gap: 10px;
63
- align-items: center;
64
-
65
- font: var(--label-font);
66
- color: var(--md-sys-color-on-surface);
67
- text-transform: var(--label-text-transform);
68
- }
69
-
70
- div[slot='content'] {
71
- display: flex;
72
- gap: 10px;
73
- }
74
- `
75
- ];
76
74
  __decorate([
77
75
  property({ type: String, attribute: 'theme-mode' }),
78
76
  __metadata("design:type", String)
@@ -1 +1 @@
1
- {"version":3,"file":"theme-mode-setting-let.js","sourceRoot":"","sources":["../../client/setting-lets/theme-mode-setting-let.ts"],"names":[],"mappings":";AAAA,OAAO,0BAA0B,CAAA;AACjC,OAAO,8BAA8B,CAAA;AAErC,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,gBAAgB,CAAA;AAEnD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAG5C,IAAM,mBAAmB,GAAzB,MAAM,mBAAoB,SAAQ,QAAQ,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC;IAA/D;;QAoBgD,cAAS,GAA8B,OAAO,CAAA;IA+CrG,CAAC;IA7CC,MAAM;QACJ,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAA;QAEhC,OAAO,IAAI,CAAA;;;;sCAIuB,CAAC,CAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;6EACA,SAAS,IAAI,MAAM;;;+EAGjB,SAAS,IAAI,OAAO;;;6EAGtB,SAAS,IAAI,MAAM;;;;KAI3F,CAAA;IACH,CAAC;IAED,KAAK,CAAC,YAAY;;QAChB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAA,MAAA,CAAC,MAAM,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,0CAAE,KAAK,KAAI,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,CAAA;IACzF,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,CAAQ;;QAC9B,MAAM,MAAM,GAAG,CAAC,CAAC,MAAiB,CAAA;QAClC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAA;QAC1B,MAAM,IAAI,GAAG,CAAA,MAAC,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAa,0CAAE,KAAK,KAAI,KAAK,CAAA;QAEjF,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC;gBACH,MAAM,kBAAkB,CAAC,GAAG,CAAC;oBAC3B,GAAG,EAAE,OAAO;oBACZ,KAAK,EAAE;wBACL,IAAI;qBACL;iBACF,CAAC,CAAA;gBAEF,YAAY,CAAC,IAAI,CAAC,CAAA;YACpB,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YAClB,CAAC;QACH,CAAC;IACH,CAAC;;AAjEM,0BAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;KAeF;CACF,AAjBY,CAiBZ;AAEoD;IAApD,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC;;sDAA+C;AApBxF,mBAAmB;IAD/B,aAAa,CAAC,wBAAwB,CAAC;GAC3B,mBAAmB,CAmE/B","sourcesContent":["import '@operato/i18n/ox-i18n.js'\nimport '@material/web/radio/radio.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'\nimport { MdRadio } from '@material/web/radio/radio.js'\nimport { setThemeMode } from '../set-theme-mode.js'\n\n@customElement('theme-mode-setting-let')\nexport class ThemeModeSettingLet extends localize(i18next)(LitElement) {\n static styles = [\n css`\n label {\n display: flex;\n gap: 10px;\n align-items: center;\n\n font: var(--label-font);\n color: var(--md-sys-color-on-surface);\n text-transform: var(--label-text-transform);\n }\n\n div[slot='content'] {\n display: flex;\n gap: 10px;\n }\n `\n ]\n\n @property({ type: String, attribute: 'theme-mode' }) themeMode: 'dark' | 'light' | 'auto' = 'light'\n\n render() {\n const themeMode = this.themeMode\n\n return html`\n <setting-let>\n <ox-i18n slot=\"title\" msgid=\"title.theme setting\"></ox-i18n>\n\n <div slot=\"content\" @change=${(e: Event) => this.onChangeThemeMode(e)}>\n <md-radio id=\"dark-mode\" name=\"theme-mode\" value=\"dark\" ?checked=${themeMode == 'dark'}></md-radio>\n <label for=\"dark-mode\">dark mode</label>\n\n <md-radio id=\"light-mode\" name=\"theme-mode\" value=\"light\" ?checked=${themeMode == 'light'}></md-radio>\n <label for=\"light-mode\">light mode</label>\n\n <md-radio id=\"auto-mode\" name=\"theme-mode\" value=\"auto\" ?checked=${themeMode == 'auto'}></md-radio>\n <label for=\"auto-mode\">auto mode</label>\n </div>\n </setting-let>\n `\n }\n\n async firstUpdated() {\n this.themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light'\n }\n\n async onChangeThemeMode(e: Event) {\n const target = e.target as MdRadio\n const value = target.value\n const mode = (this.querySelector('md-radio[checked]') as MdRadio)?.value || value\n\n if (mode) {\n try {\n await clientSettingStore.put({\n key: 'theme',\n value: {\n mode\n }\n })\n\n setThemeMode(mode)\n } catch (e) {\n console.error(e)\n }\n }\n }\n}\n"]}
1
+ {"version":3,"file":"theme-mode-setting-let.js","sourceRoot":"","sources":["../../client/setting-lets/theme-mode-setting-let.ts"],"names":[],"mappings":";AAAA,OAAO,0BAA0B,CAAA;AACjC,OAAO,8BAA8B,CAAA;AAErC,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,gBAAgB,CAAA;AAEnD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAG5C,IAAM,mBAAmB,GAAzB,MAAM,mBAAoB,SAAQ,QAAQ,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC;IAA/D;;QAoBgD,cAAS,GAA8B,OAAO,CAAA;IA+CrG,CAAC;aAlEQ,WAAM,GAAG;QACd,GAAG,CAAA;;;;;;;;;;;;;;;KAeF;KACF,AAjBY,CAiBZ;IAID,MAAM;QACJ,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAA;QAEhC,OAAO,IAAI,CAAA;;;;sCAIuB,CAAC,CAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;6EACA,SAAS,IAAI,MAAM;;;+EAGjB,SAAS,IAAI,OAAO;;;6EAGtB,SAAS,IAAI,MAAM;;;;KAI3F,CAAA;IACH,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,MAAM,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,CAAA;IACzF,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,CAAQ;QAC9B,MAAM,MAAM,GAAG,CAAC,CAAC,MAAiB,CAAA;QAClC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAA;QAC1B,MAAM,IAAI,GAAI,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAa,EAAE,KAAK,IAAI,KAAK,CAAA;QAEjF,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC;gBACH,MAAM,kBAAkB,CAAC,GAAG,CAAC;oBAC3B,GAAG,EAAE,OAAO;oBACZ,KAAK,EAAE;wBACL,IAAI;qBACL;iBACF,CAAC,CAAA;gBAEF,YAAY,CAAC,IAAI,CAAC,CAAA;YACpB,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YAClB,CAAC;QACH,CAAC;IACH,CAAC;;AA9CoD;IAApD,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC;;sDAA+C;AApBxF,mBAAmB;IAD/B,aAAa,CAAC,wBAAwB,CAAC;GAC3B,mBAAmB,CAmE/B","sourcesContent":["import '@operato/i18n/ox-i18n.js'\nimport '@material/web/radio/radio.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'\nimport { MdRadio } from '@material/web/radio/radio.js'\nimport { setThemeMode } from '../set-theme-mode.js'\n\n@customElement('theme-mode-setting-let')\nexport class ThemeModeSettingLet extends localize(i18next)(LitElement) {\n static styles = [\n css`\n label {\n display: flex;\n gap: 10px;\n align-items: center;\n\n font: var(--label-font);\n color: var(--md-sys-color-on-surface);\n text-transform: var(--label-text-transform);\n }\n\n div[slot='content'] {\n display: flex;\n gap: 10px;\n }\n `\n ]\n\n @property({ type: String, attribute: 'theme-mode' }) themeMode: 'dark' | 'light' | 'auto' = 'light'\n\n render() {\n const themeMode = this.themeMode\n\n return html`\n <setting-let>\n <ox-i18n slot=\"title\" msgid=\"title.theme setting\"></ox-i18n>\n\n <div slot=\"content\" @change=${(e: Event) => this.onChangeThemeMode(e)}>\n <md-radio id=\"dark-mode\" name=\"theme-mode\" value=\"dark\" ?checked=${themeMode == 'dark'}></md-radio>\n <label for=\"dark-mode\">dark mode</label>\n\n <md-radio id=\"light-mode\" name=\"theme-mode\" value=\"light\" ?checked=${themeMode == 'light'}></md-radio>\n <label for=\"light-mode\">light mode</label>\n\n <md-radio id=\"auto-mode\" name=\"theme-mode\" value=\"auto\" ?checked=${themeMode == 'auto'}></md-radio>\n <label for=\"auto-mode\">auto mode</label>\n </div>\n </setting-let>\n `\n }\n\n async firstUpdated() {\n this.themeMode = ((await clientSettingStore.get('theme'))?.value || {}).mode || 'light'\n }\n\n async onChangeThemeMode(e: Event) {\n const target = e.target as MdRadio\n const value = target.value\n const mode = (this.querySelector('md-radio[checked]') as MdRadio)?.value || value\n\n if (mode) {\n try {\n await clientSettingStore.put({\n key: 'theme',\n value: {\n mode\n }\n })\n\n setThemeMode(mode)\n } catch (e) {\n console.error(e)\n }\n }\n }\n}\n"]}