@things-factory/auth-ui 9.1.13 → 10.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/dist-client/bootstrap.js +24 -0
  2. package/dist-client/bootstrap.js.map +1 -1
  3. package/dist-client/components/domain-switch.d.ts +2 -12
  4. package/dist-client/components/domain-switch.js +5 -18
  5. package/dist-client/components/domain-switch.js.map +1 -1
  6. package/dist-client/components/user-role-editor.js +13 -4
  7. package/dist-client/components/user-role-editor.js.map +1 -1
  8. package/dist-client/pages/app-binding/app-binding.js +66 -111
  9. package/dist-client/pages/app-binding/app-binding.js.map +1 -1
  10. package/dist-client/pages/app-binding/app-bindings.js +38 -59
  11. package/dist-client/pages/app-binding/app-bindings.js.map +1 -1
  12. package/dist-client/pages/appliance/appliance.js +72 -120
  13. package/dist-client/pages/appliance/appliance.js.map +1 -1
  14. package/dist-client/pages/appliance/home.js +39 -61
  15. package/dist-client/pages/appliance/home.js.map +1 -1
  16. package/dist-client/pages/appliance/register.js +33 -52
  17. package/dist-client/pages/appliance/register.js.map +1 -1
  18. package/dist-client/pages/application/application.js +67 -107
  19. package/dist-client/pages/application/application.js.map +1 -1
  20. package/dist-client/pages/application/applications.js +38 -59
  21. package/dist-client/pages/application/applications.js.map +1 -1
  22. package/dist-client/pages/application/register.js +41 -64
  23. package/dist-client/pages/application/register.js.map +1 -1
  24. package/dist-client/pages/attribute/attribute-set-management.d.ts +0 -6
  25. package/dist-client/pages/attribute/attribute-set-management.js +46 -87
  26. package/dist-client/pages/attribute/attribute-set-management.js.map +1 -1
  27. package/dist-client/pages/auth-provider/auth-provider-management.d.ts +0 -6
  28. package/dist-client/pages/auth-provider/auth-provider-management.js +67 -127
  29. package/dist-client/pages/auth-provider/auth-provider-management.js.map +1 -1
  30. package/dist-client/pages/domain/domain-management.d.ts +0 -6
  31. package/dist-client/pages/domain/domain-management.js +64 -119
  32. package/dist-client/pages/domain/domain-management.js.map +1 -1
  33. package/dist-client/pages/domain-link/domain-link-management.d.ts +1 -7
  34. package/dist-client/pages/domain-link/domain-link-management.js +67 -125
  35. package/dist-client/pages/domain-link/domain-link-management.js.map +1 -1
  36. package/dist-client/pages/env-var/env-var-list-page.d.ts +0 -6
  37. package/dist-client/pages/env-var/env-var-list-page.js +44 -82
  38. package/dist-client/pages/env-var/env-var-list-page.js.map +1 -1
  39. package/dist-client/pages/partner/partner-management.js +17 -28
  40. package/dist-client/pages/partner/partner-management.js.map +1 -1
  41. package/dist-client/pages/role/role-management.js +20 -33
  42. package/dist-client/pages/role/role-management.js.map +1 -1
  43. package/dist-client/tsconfig.tsbuildinfo +1 -1
  44. package/dist-server/tsconfig.tsbuildinfo +1 -1
  45. package/package.json +12 -12
  46. package/views/auth-page.html +1 -1
  47. package/views/oauth2-page.html +1 -1
@@ -5,7 +5,7 @@ import '@operato/data-grist/ox-grist.js';
5
5
  import '@operato/data-grist/ox-filters-form.js';
6
6
  import '@operato/data-grist/ox-record-creator.js';
7
7
  import { CommonButtonStyles, CommonHeaderStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles';
8
- import { PageView, store } from '@operato/shell';
8
+ import { PageView } from '@operato/shell';
9
9
  import { css, html } from 'lit';
10
10
  import { customElement, property, query } from 'lit/decorators.js';
11
11
  import { DataGrist } from '@operato/data-grist';
@@ -14,9 +14,8 @@ import { i18next, localize } from '@operato/i18n';
14
14
  import { notify } from '@operato/layout';
15
15
  import { OxPrompt } from '@operato/popup';
16
16
  import { isMobileDevice } from '@operato/utils';
17
- import { connect } from 'pwa-helpers/connect-mixin';
18
17
  import gql from 'graphql-tag';
19
- let DomainLinkLManagement = class DomainLinkLManagement extends connect(store)(localize(i18next)(PageView)) {
18
+ let DomainLinkLManagement = class DomainLinkLManagement extends localize(i18next)(PageView) {
20
19
  constructor() {
21
20
  super(...arguments);
22
21
  this.mode = isMobileDevice() ? 'CARD' : 'GRID';
@@ -26,53 +25,43 @@ let DomainLinkLManagement = class DomainLinkLManagement extends connect(store)(l
26
25
  CommonGristStyles,
27
26
  CommonHeaderStyles,
28
27
  css `
29
- :host {
30
- display: flex;
28
+ :host { display: flex;
31
29
 
32
30
  width: 100%;
33
31
 
34
32
  --grid-record-emphasized-background-color: #8b0000;
35
33
  --grid-record-emphasized-color: #ff6b6b;
36
- }
34
+ }
37
35
 
38
- ox-grist {
39
- overflow-y: auto;
36
+ ox-grist { overflow-y: auto;
40
37
  flex: 1;
41
- }
38
+ }
42
39
 
43
- ox-filters-form {
44
- flex: 1;
45
- }
40
+ ox-filters-form { flex: 1;
41
+ }
46
42
  `
47
43
  ]; }
48
44
  get context() {
49
- return {
50
- title: i18next.t('title.domain-link management'),
51
- search: {
52
- handler: (search) => {
45
+ return { title: i18next.t('title.domain-link management'),
46
+ search: { handler: (search) => {
53
47
  this.grist.searchText = search;
54
48
  },
55
- value: this.grist.searchText
56
- },
57
- filter: {
58
- handler: () => {
49
+ value: this.grist.searchText },
50
+ filter: { handler: () => {
59
51
  this.grist.toggleHeadroom();
60
52
  }
61
53
  },
62
54
  help: 'auth/domain-link',
63
55
  actions: [
64
- {
65
- title: i18next.t('button.save'),
56
+ { title: i18next.t('button.save'),
66
57
  action: this.updateDomainLink.bind(this),
67
58
  ...CommonButtonStyles.save
68
59
  },
69
- {
70
- title: i18next.t('button.delete'),
60
+ { title: i18next.t('button.delete'),
71
61
  action: this.deleteDomainLink.bind(this),
72
62
  ...CommonButtonStyles.delete
73
63
  }
74
- ]
75
- };
64
+ ] };
76
65
  }
77
66
  render() {
78
67
  const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID');
@@ -99,23 +88,18 @@ let DomainLinkLManagement = class DomainLinkLManagement extends connect(store)(l
99
88
  `;
100
89
  }
101
90
  async pageInitialized(lifecycle) {
102
- this.gristConfig = {
103
- list: {
104
- fields: ['sourceDomain', 'targetDomain'],
91
+ this.gristConfig = { list: { fields: ['sourceDomain', 'targetDomain'],
105
92
  details: ['type', 'updatedAt']
106
93
  },
107
94
  columns: [
108
95
  { type: 'gutter', gutterName: 'sequence' },
109
96
  { type: 'gutter', gutterName: 'row-selector', multiple: true },
110
- {
111
- type: 'resource-object',
97
+ { type: 'resource-object',
112
98
  name: 'sourceDomain',
113
99
  header: i18next.t('field.source-domain'),
114
- record: {
115
- editable: true,
100
+ record: { editable: true,
116
101
  mandatory: true,
117
- options: {
118
- title: i18next.t('title.lookup domains'),
102
+ options: { title: i18next.t('title.lookup domains'),
119
103
  queryName: 'domains'
120
104
  }
121
105
  },
@@ -123,27 +107,22 @@ let DomainLinkLManagement = class DomainLinkLManagement extends connect(store)(l
123
107
  sortable: true,
124
108
  width: 150
125
109
  },
126
- {
127
- type: 'select',
110
+ { type: 'select',
128
111
  name: 'type',
129
112
  header: i18next.t('field.type'),
130
- record: {
131
- editable: true,
113
+ record: { editable: true,
132
114
  mandatory: true,
133
115
  options: () => ['', 'has', 'maintains', 'owns']
134
116
  },
135
117
  filter: 'search',
136
118
  width: 200
137
119
  },
138
- {
139
- type: 'resource-object',
120
+ { type: 'resource-object',
140
121
  name: 'targetDomain',
141
122
  header: i18next.t('field.target-domain'),
142
- record: {
143
- editable: true,
123
+ record: { editable: true,
144
124
  mandatory: true,
145
- options: {
146
- title: i18next.t('title.lookup domains'),
125
+ options: { title: i18next.t('title.lookup domains'),
147
126
  queryName: 'domains'
148
127
  }
149
128
  },
@@ -151,107 +130,85 @@ let DomainLinkLManagement = class DomainLinkLManagement extends connect(store)(l
151
130
  sortable: true,
152
131
  width: 150
153
132
  },
154
- {
155
- type: 'resource-object',
133
+ { type: 'resource-object',
156
134
  name: 'updater',
157
135
  header: i18next.t('field.updater'),
158
- record: {
159
- editable: false
136
+ record: { editable: false
160
137
  },
161
138
  sortable: true,
162
139
  width: 120
163
140
  },
164
- {
165
- type: 'datetime',
141
+ { type: 'datetime',
166
142
  name: 'updatedAt',
167
143
  header: i18next.t('field.updated_at'),
168
- record: {
169
- editable: false
144
+ record: { editable: false
170
145
  },
171
146
  sortable: true,
172
147
  width: 180
173
148
  }
174
149
  ],
175
- rows: {
176
- appendable: false,
177
- selectable: {
178
- multiple: true
150
+ rows: { appendable: false,
151
+ selectable: { multiple: true
179
152
  }
180
153
  },
181
154
  sorters: [
182
- {
183
- name: 'sourceDomain'
155
+ { name: 'sourceDomain'
184
156
  }
185
157
  ]
186
158
  };
187
159
  }
188
160
  async pageUpdated(changes, lifecycle) {
189
- if (this.active) {
190
- // do something here when this page just became as active
161
+ if (this.active) { // do something here when this page just became as active
191
162
  }
192
163
  }
193
164
  async fetchHandler({ page = 1, limit = 100, sortings = [], filters = [] }) {
194
- const response = await client.query({
195
- query: gql `
196
- query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
197
- responses: domainLinks(filters: $filters, pagination: $pagination, sortings: $sortings) {
198
- items {
199
- id
200
- sourceDomain {
201
- id
165
+ const response = await client.query({ query: gql `
166
+ query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) { responses: domainLinks(filters: $filters, pagination: $pagination, sortings: $sortings) { items { id
167
+ sourceDomain { id
202
168
  name
203
169
  subdomain
204
- }
205
- targetDomain {
206
- id
170
+ }
171
+ targetDomain { id
207
172
  name
208
173
  subdomain
209
- }
174
+ }
210
175
  type
211
- updater {
212
- id
176
+ updater { id
213
177
  name
214
- }
178
+ }
215
179
  updatedAt
216
- }
180
+ }
217
181
  total
218
- }
219
- }
182
+ }
183
+ }
220
184
  `,
221
- variables: {
222
- filters,
185
+ variables: { filters,
223
186
  pagination: { page, limit },
224
187
  sortings
225
188
  }
226
189
  });
227
- return {
228
- total: response.data.responses.total || 0,
190
+ return { total: response.data.responses.total || 0,
229
191
  records: response.data.responses.items || []
230
192
  };
231
193
  }
232
194
  async deleteDomainLink() {
233
- if (await OxPrompt.open({
234
- title: i18next.t('text.are_you_sure'),
195
+ if (await OxPrompt.open({ title: i18next.t('text.are_you_sure'),
235
196
  text: i18next.t('text.sure_to_x', { x: i18next.t('text.delete') }),
236
197
  confirmButton: { text: i18next.t('button.confirm') },
237
198
  cancelButton: { text: i18next.t('button.cancel') }
238
199
  })) {
239
200
  const ids = this.grist.selected.map(record => record.id);
240
201
  if (ids && ids.length > 0) {
241
- const response = await client.mutate({
242
- mutation: gql `
243
- mutation ($ids: [String!]!) {
244
- deleteDomainLinks(ids: $ids)
245
- }
202
+ const response = await client.mutate({ mutation: gql `
203
+ mutation ($ids: [String!]!) { deleteDomainLinks(ids: $ids)
204
+ }
246
205
  `,
247
- variables: {
248
- ids
206
+ variables: { ids
249
207
  }
250
208
  });
251
209
  if (!response.errors) {
252
210
  this.grist.fetch();
253
- notify({
254
- message: i18next.t('text.info_x_successfully', { x: i18next.t('text.delete') })
211
+ notify({ message: i18next.t('text.info_x_successfully', { x: i18next.t('text.delete') })
255
212
  });
256
213
  }
257
214
  }
@@ -269,26 +226,20 @@ let DomainLinkLManagement = class DomainLinkLManagement extends connect(store)(l
269
226
  patchField.cuFlag = patch.__dirty__;
270
227
  return patchField;
271
228
  });
272
- const response = await client.mutate({
273
- mutation: gql `
274
- mutation ($patches: [DomainLinkPatch!]!) {
275
- updateMultipleDomainLink(patches: $patches) {
276
- sourceDomain {
277
- id
229
+ const response = await client.mutate({ mutation: gql `
230
+ mutation ($patches: [DomainLinkPatch!]!) { updateMultipleDomainLink(patches: $patches) { sourceDomain { id
278
231
  name
279
232
  subdomain
280
- }
281
- targetDomain {
282
- id
233
+ }
234
+ targetDomain { id
283
235
  name
284
236
  subdomain
285
- }
237
+ }
286
238
  type
287
- }
288
- }
239
+ }
240
+ }
289
241
  `,
290
- variables: {
291
- patches
242
+ variables: { patches
292
243
  }
293
244
  });
294
245
  if (!response.errors) {
@@ -305,26 +256,19 @@ let DomainLinkLManagement = class DomainLinkLManagement extends connect(store)(l
305
256
  if (domainLink.sourceDomain.id === domainLink.targetDomain.id) {
306
257
  throw new Error(i18next.t('text.source_and_target_domain_cannot_be_same'));
307
258
  }
308
- const response = await client.query({
309
- query: gql `
310
- mutation ($domainLink: NewDomainLink!) {
311
- createDomainLink(domainLink: $domainLink) {
312
- id
313
- }
314
- }
259
+ const response = await client.query({ query: gql `
260
+ mutation ($domainLink: NewDomainLink!) { createDomainLink(domainLink: $domainLink) { id
261
+ }
262
+ }
315
263
  `,
316
- variables: {
317
- domainLink
264
+ variables: { domainLink
318
265
  },
319
- context: {
320
- hasUpload: true
266
+ context: { hasUpload: true
321
267
  }
322
268
  });
323
269
  if (!response.errors) {
324
270
  this.grist.fetch();
325
- document.dispatchEvent(new CustomEvent('notify', {
326
- detail: {
327
- message: i18next.t('text.data_created_successfully')
271
+ document.dispatchEvent(new CustomEvent('notify', { detail: { message: i18next.t('text.data_created_successfully')
328
272
  }
329
273
  }));
330
274
  }
@@ -332,9 +276,7 @@ let DomainLinkLManagement = class DomainLinkLManagement extends connect(store)(l
332
276
  }
333
277
  catch (ex) {
334
278
  console.error(ex);
335
- document.dispatchEvent(new CustomEvent('notify', {
336
- detail: {
337
- type: 'error',
279
+ document.dispatchEvent(new CustomEvent('notify', { detail: { type: 'error',
338
280
  message: ex.message || String(ex)
339
281
  }
340
282
  }));
@@ -1 +1 @@
1
- {"version":3,"file":"domain-link-management.js","sourceRoot":"","sources":["../../../client/pages/domain-link/domain-link-management.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@material/web/button/elevated-button.js'\nimport '@operato/data-grist/ox-grist.js'\nimport '@operato/data-grist/ox-filters-form.js'\nimport '@operato/data-grist/ox-record-creator.js'\n\nimport { CommonButtonStyles, CommonHeaderStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'\nimport { PageView, store } from '@operato/shell'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { DataGrist, FetchOption } from '@operato/data-grist'\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { notify } from '@operato/layout'\nimport { OxPrompt } from '@operato/popup'\nimport { isMobileDevice } from '@operato/utils'\n\nimport { connect } from 'pwa-helpers/connect-mixin'\nimport gql from 'graphql-tag'\n\n@customElement('domain-link-management')\nexport class DomainLinkLManagement extends connect(store)(localize(i18next)(PageView)) {\n static styles = [\n ScrollbarStyles,\n CommonGristStyles,\n CommonHeaderStyles,\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 ox-filters-form {\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\n get context() {\n return {\n title: i18next.t('title.domain-link management'),\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: 'auth/domain-link',\n actions: [\n {\n title: i18next.t('button.save'),\n action: this.updateDomainLink.bind(this),\n ...CommonButtonStyles.save\n },\n {\n title: i18next.t('button.delete'),\n action: this.deleteDomainLink.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\" class=\"header\">\n <div class=\"filters\">\n <ox-filters-form autofocus without-search></ox-filters-form>\n\n <div id=\"modes\">\n <md-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</md-icon>\n <md-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</md-icon>\n <md-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</md-icon>\n </div>\n\n <ox-record-creator id=\"add\" .callback=${this.creationCallback.bind(this)}>\n <button>\n <md-icon>add</md-icon>\n </button>\n </ox-record-creator>\n </div>\n </div>\n </ox-grist>\n `\n }\n\n async pageInitialized(lifecycle: any) {\n this.gristConfig = {\n list: {\n fields: ['sourceDomain', 'targetDomain'],\n details: ['type', 'updatedAt']\n },\n columns: [\n { type: 'gutter', gutterName: 'sequence' },\n { type: 'gutter', gutterName: 'row-selector', multiple: true },\n {\n type: 'resource-object',\n name: 'sourceDomain',\n header: i18next.t('field.source-domain'),\n record: {\n editable: true,\n mandatory: true,\n options: {\n title: i18next.t('title.lookup domains'),\n queryName: 'domains'\n }\n },\n filter: 'search',\n sortable: true,\n width: 150\n },\n {\n type: 'select',\n name: 'type',\n header: i18next.t('field.type'),\n record: {\n editable: true,\n mandatory: true,\n options: () => ['', 'has', 'maintains', 'owns']\n },\n filter: 'search',\n width: 200\n },\n {\n type: 'resource-object',\n name: 'targetDomain',\n header: i18next.t('field.target-domain'),\n record: {\n editable: true,\n mandatory: true,\n options: {\n title: i18next.t('title.lookup domains'),\n queryName: 'domains'\n }\n },\n filter: 'search',\n sortable: true,\n width: 150\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 appendable: false,\n selectable: {\n multiple: true\n }\n },\n sorters: [\n {\n name: 'sourceDomain'\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: domainLinks(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n sourceDomain {\n id\n name\n subdomain\n }\n targetDomain {\n id\n name\n subdomain\n }\n type\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 private async deleteDomainLink() {\n if (\n await OxPrompt.open({\n title: i18next.t('text.are_you_sure'),\n text: i18next.t('text.sure_to_x', { x: i18next.t('text.delete') }),\n confirmButton: { text: i18next.t('button.confirm') },\n cancelButton: { text: i18next.t('button.cancel') }\n })\n ) {\n const ids = this.grist.selected.map(record => record.id)\n if (ids && ids.length > 0) {\n const response = await client.mutate({\n mutation: gql`\n mutation ($ids: [String!]!) {\n deleteDomainLinks(ids: $ids)\n }\n `,\n variables: {\n ids\n }\n })\n\n if (!response.errors) {\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 private async updateDomainLink() {\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 response = await client.mutate({\n mutation: gql`\n mutation ($patches: [DomainLinkPatch!]!) {\n updateMultipleDomainLink(patches: $patches) {\n sourceDomain {\n id\n name\n subdomain\n }\n targetDomain {\n id\n name\n subdomain\n }\n type\n }\n }\n `,\n variables: {\n patches\n }\n })\n\n if (!response.errors) {\n this.grist.fetch()\n }\n }\n }\n\n async creationCallback(domainLink) {\n try {\n const { sourceDomain, targetDomain, type } = domainLink\n if (!sourceDomain || !targetDomain || !type) {\n throw new Error(i18next.t('text.please_fill_all_required_fields'))\n }\n\n if (domainLink.sourceDomain.id === domainLink.targetDomain.id) {\n throw new Error(i18next.t('text.source_and_target_domain_cannot_be_same'))\n }\n\n const response = await client.query({\n query: gql`\n mutation ($domainLink: NewDomainLink!) {\n createDomainLink(domainLink: $domainLink) {\n id\n }\n }\n `,\n variables: {\n domainLink\n },\n context: {\n hasUpload: true\n }\n })\n\n if (!response.errors) {\n this.grist.fetch()\n document.dispatchEvent(\n new CustomEvent('notify', {\n detail: {\n message: i18next.t('text.data_created_successfully')\n }\n })\n )\n }\n\n return true\n } catch (ex) {\n console.error(ex)\n document.dispatchEvent(\n new CustomEvent('notify', {\n detail: {\n type: 'error',\n message: (ex as Error).message || String(ex)\n }\n })\n )\n return false\n }\n }\n}\n"]}
1
+ {"version":3,"file":"domain-link-management.js","sourceRoot":"","sources":["../../../client/pages/domain-link/domain-link-management.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@material/web/button/elevated-button.js'\nimport '@operato/data-grist/ox-grist.js'\nimport '@operato/data-grist/ox-filters-form.js'\nimport '@operato/data-grist/ox-record-creator.js'\n\nimport { CommonButtonStyles, CommonHeaderStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'\nimport { PageView } from '@operato/shell'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { DataGrist, FetchOption } from '@operato/data-grist'\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { notify } from '@operato/layout'\nimport { OxPrompt } from '@operato/popup'\nimport { isMobileDevice } from '@operato/utils'\n\nimport gql from 'graphql-tag'\n\n@customElement('domain-link-management')\nexport class DomainLinkLManagement extends localize(i18next)(PageView) { static styles = [\n ScrollbarStyles,\n CommonGristStyles,\n CommonHeaderStyles,\n css`\n :host { 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 { overflow-y: auto;\n flex: 1;\n }\n\n ox-filters-form { 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\n get context() { return { title: i18next.t('title.domain-link management'),\n search: { handler: (search: string) => { this.grist.searchText = search\n },\n value: this.grist.searchText\n },\n filter: { handler: () => { this.grist.toggleHeadroom()\n }\n },\n help: 'auth/domain-link',\n actions: [\n { title: i18next.t('button.save'),\n action: this.updateDomainLink.bind(this),\n ...CommonButtonStyles.save\n },\n { title: i18next.t('button.delete'),\n action: this.deleteDomainLink.bind(this),\n ...CommonButtonStyles.delete\n }\n ]\n }\n }\n\n render() { 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\" class=\"header\">\n <div class=\"filters\">\n <ox-filters-form autofocus without-search></ox-filters-form>\n\n <div id=\"modes\">\n <md-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</md-icon>\n <md-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</md-icon>\n <md-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</md-icon>\n </div>\n\n <ox-record-creator id=\"add\" .callback=${this.creationCallback.bind(this)}>\n <button>\n <md-icon>add</md-icon>\n </button>\n </ox-record-creator>\n </div>\n </div>\n </ox-grist>\n `\n }\n\n async pageInitialized(lifecycle: any) { this.gristConfig = { list: { fields: ['sourceDomain', 'targetDomain'],\n details: ['type', 'updatedAt']\n },\n columns: [\n { type: 'gutter', gutterName: 'sequence' },\n { type: 'gutter', gutterName: 'row-selector', multiple: true },\n { type: 'resource-object',\n name: 'sourceDomain',\n header: i18next.t('field.source-domain'),\n record: { editable: true,\n mandatory: true,\n options: { title: i18next.t('title.lookup domains'),\n queryName: 'domains'\n }\n },\n filter: 'search',\n sortable: true,\n width: 150\n },\n { type: 'select',\n name: 'type',\n header: i18next.t('field.type'),\n record: { editable: true,\n mandatory: true,\n options: () => ['', 'has', 'maintains', 'owns']\n },\n filter: 'search',\n width: 200\n },\n { type: 'resource-object',\n name: 'targetDomain',\n header: i18next.t('field.target-domain'),\n record: { editable: true,\n mandatory: true,\n options: { title: i18next.t('title.lookup domains'),\n queryName: 'domains'\n }\n },\n filter: 'search',\n sortable: true,\n width: 150\n },\n { type: 'resource-object',\n name: 'updater',\n header: i18next.t('field.updater'),\n record: { editable: false\n },\n sortable: true,\n width: 120\n },\n { type: 'datetime',\n name: 'updatedAt',\n header: i18next.t('field.updated_at'),\n record: { editable: false\n },\n sortable: true,\n width: 180\n }\n ],\n rows: { appendable: false,\n selectable: { multiple: true\n }\n },\n sorters: [\n { name: 'sourceDomain'\n }\n ]\n }\n }\n\n async pageUpdated(changes: any, lifecycle: any) { if (this.active) { // do something here when this page just became as active\n }\n }\n\n async fetchHandler({ page = 1, limit = 100, sortings = [], filters = [] }: FetchOption) { const response = await client.query({ query: gql`\n query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) { responses: domainLinks(filters: $filters, pagination: $pagination, sortings: $sortings) { items { id\n sourceDomain { id\n name\n subdomain\n }\n targetDomain { id\n name\n subdomain\n }\n type\n updater { id\n name\n }\n updatedAt\n }\n total\n }\n }\n `,\n variables: { filters,\n pagination: { page, limit },\n sortings\n }\n })\n\n return { total: response.data.responses.total || 0,\n records: response.data.responses.items || []\n }\n }\n\n private async deleteDomainLink() { if (\n await OxPrompt.open({ title: i18next.t('text.are_you_sure'),\n text: i18next.t('text.sure_to_x', { x: i18next.t('text.delete') }),\n confirmButton: { text: i18next.t('button.confirm') },\n cancelButton: { text: i18next.t('button.cancel') }\n })\n ) { const ids = this.grist.selected.map(record => record.id)\n if (ids && ids.length > 0) { const response = await client.mutate({ mutation: gql`\n mutation ($ids: [String!]!) { deleteDomainLinks(ids: $ids)\n }\n `,\n variables: { ids\n }\n })\n\n if (!response.errors) { this.grist.fetch()\n notify({ message: i18next.t('text.info_x_successfully', { x: i18next.t('text.delete') })\n })\n }\n }\n }\n }\n\n private async updateDomainLink() { let patches = this.grist.dirtyRecords\n if (patches && patches.length) { patches = patches.map(patch => { let patchField: any = patch.id ? { id: patch.id } : {}\n const dirtyFields = patch.__dirtyfields__\n for (let key in dirtyFields) { patchField[key] = dirtyFields[key].after\n }\n patchField.cuFlag = patch.__dirty__\n\n return patchField\n })\n\n const response = await client.mutate({ mutation: gql`\n mutation ($patches: [DomainLinkPatch!]!) { updateMultipleDomainLink(patches: $patches) { sourceDomain { id\n name\n subdomain\n }\n targetDomain { id\n name\n subdomain\n }\n type\n }\n }\n `,\n variables: { patches\n }\n })\n\n if (!response.errors) { this.grist.fetch()\n }\n }\n }\n\n async creationCallback(domainLink) { try { const { sourceDomain, targetDomain, type } = domainLink\n if (!sourceDomain || !targetDomain || !type) { throw new Error(i18next.t('text.please_fill_all_required_fields'))\n }\n\n if (domainLink.sourceDomain.id === domainLink.targetDomain.id) { throw new Error(i18next.t('text.source_and_target_domain_cannot_be_same'))\n }\n\n const response = await client.query({ query: gql`\n mutation ($domainLink: NewDomainLink!) { createDomainLink(domainLink: $domainLink) { id\n }\n }\n `,\n variables: { domainLink\n },\n context: { hasUpload: true\n }\n })\n\n if (!response.errors) { this.grist.fetch()\n document.dispatchEvent(\n new CustomEvent('notify', { detail: { message: i18next.t('text.data_created_successfully')\n }\n })\n )\n }\n\n return true\n } catch (ex) { console.error(ex)\n document.dispatchEvent(\n new CustomEvent('notify', { detail: { type: 'error',\n message: (ex as Error).message || String(ex)\n }\n })\n )\n return false\n }\n }\n}\n"]}
@@ -5,12 +5,6 @@ import '@operato/context/ox-context-page-toolbar.js';
5
5
  import { PageView } from '@operato/shell';
6
6
  import { FetchOption } from '@operato/data-grist';
7
7
  declare const EnvVarListPage_base: (new (...args: any[]) => {
8
- _storeUnsubscribe: import("redux").Unsubscribe;
9
- connectedCallback(): void;
10
- disconnectedCallback(): void;
11
- stateChanged(_state: unknown): void;
12
- readonly isConnected: boolean;
13
- }) & (new (...args: any[]) => {
14
8
  __preferenceProviders: {
15
9
  [element: string]: import("@operato/p13n").PagePreferenceProvider;
16
10
  };