@things-factory/worklist 9.0.0-beta.8 → 9.0.0

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 (186) hide show
  1. package/README.md +30 -5
  2. package/dist-client/activity-summary-generator.js +17 -22
  3. package/dist-client/activity-summary-generator.js.map +1 -1
  4. package/dist-client/components/activity-/bowner-view.js +24 -24
  5. package/dist-client/components/activity-/bowner-view.js.map +1 -1
  6. package/dist-client/components/activity-approval-ribon.js +47 -48
  7. package/dist-client/components/activity-approval-ribon.js.map +1 -1
  8. package/dist-client/components/activity-instance-preview.js +34 -32
  9. package/dist-client/components/activity-instance-preview.js.map +1 -1
  10. package/dist-client/components/activity-instance-ribon.js +41 -41
  11. package/dist-client/components/activity-instance-ribon.js.map +1 -1
  12. package/dist-client/components/activity-intro-view.js +24 -24
  13. package/dist-client/components/activity-intro-view.js.map +1 -1
  14. package/dist-client/components/activity-reporter-view.js +24 -24
  15. package/dist-client/components/activity-reporter-view.js.map +1 -1
  16. package/dist-client/components/activity-starter-form.js +53 -54
  17. package/dist-client/components/activity-starter-form.js.map +1 -1
  18. package/dist-client/components/activity-thread-ribon.js +38 -38
  19. package/dist-client/components/activity-thread-ribon.js.map +1 -1
  20. package/dist-client/components/activity-thread-timeline.js +74 -74
  21. package/dist-client/components/activity-thread-timeline.js.map +1 -1
  22. package/dist-client/grist-editor/grist-editor-activity-search-key.js +2 -3
  23. package/dist-client/grist-editor/grist-editor-activity-search-key.js.map +1 -1
  24. package/dist-client/grist-editor/popup-activity-search-keys-input.js +19 -19
  25. package/dist-client/grist-editor/popup-activity-search-keys-input.js.map +1 -1
  26. package/dist-client/pages/activity/activity-list-page.js +34 -34
  27. package/dist-client/pages/activity/activity-list-page.js.map +1 -1
  28. package/dist-client/pages/activity/activity-model-item-list.js +18 -20
  29. package/dist-client/pages/activity/activity-model-item-list.js.map +1 -1
  30. package/dist-client/pages/activity/activity-page.js +64 -46
  31. package/dist-client/pages/activity/activity-page.js.map +1 -1
  32. package/dist-client/pages/activity/activity-partial-view.js +18 -18
  33. package/dist-client/pages/activity/activity-partial-view.js.map +1 -1
  34. package/dist-client/pages/activity/starter-list-page.js +22 -25
  35. package/dist-client/pages/activity/starter-list-page.js.map +1 -1
  36. package/dist-client/pages/activity-approval/activity-approval-importer.js +16 -17
  37. package/dist-client/pages/activity-approval/activity-approval-importer.js.map +1 -1
  38. package/dist-client/pages/activity-approval/activity-approval-list-page.js +30 -23
  39. package/dist-client/pages/activity-approval/activity-approval-list-page.js.map +1 -1
  40. package/dist-client/pages/activity-approval/activity-approval-page.js +105 -78
  41. package/dist-client/pages/activity-approval/activity-approval-page.js.map +1 -1
  42. package/dist-client/pages/activity-instance/activity-instance-list-page.d.ts +17 -2
  43. package/dist-client/pages/activity-instance/activity-instance-list-page.js +235 -40
  44. package/dist-client/pages/activity-instance/activity-instance-list-page.js.map +1 -1
  45. package/dist-client/pages/activity-instance/activity-instance-search-page.js +38 -38
  46. package/dist-client/pages/activity-instance/activity-instance-search-page.js.map +1 -1
  47. package/dist-client/pages/activity-instance/activity-instance-start-page.js +54 -41
  48. package/dist-client/pages/activity-instance/activity-instance-start-page.js.map +1 -1
  49. package/dist-client/pages/activity-instance/activity-instance-view.js +211 -213
  50. package/dist-client/pages/activity-instance/activity-instance-view.js.map +1 -1
  51. package/dist-client/pages/activity-stats/activity-stats-importer.js +16 -17
  52. package/dist-client/pages/activity-stats/activity-stats-importer.js.map +1 -1
  53. package/dist-client/pages/activity-stats/activity-stats-list-page.js +30 -23
  54. package/dist-client/pages/activity-stats/activity-stats-list-page.js.map +1 -1
  55. package/dist-client/pages/activity-store/activity-store-page.js +27 -26
  56. package/dist-client/pages/activity-store/activity-store-page.js.map +1 -1
  57. package/dist-client/pages/activity-supervisor/reporter-list-page.js +26 -29
  58. package/dist-client/pages/activity-supervisor/reporter-list-page.js.map +1 -1
  59. package/dist-client/pages/activity-template/activity-template-importer.js +16 -17
  60. package/dist-client/pages/activity-template/activity-template-importer.js.map +1 -1
  61. package/dist-client/pages/activity-template/activity-template-list-page.js +38 -37
  62. package/dist-client/pages/activity-template/activity-template-list-page.js.map +1 -1
  63. package/dist-client/pages/activity-template/activity-template-model-item-list.js +2 -3
  64. package/dist-client/pages/activity-template/activity-template-model-item-list.js.map +1 -1
  65. package/dist-client/pages/activity-thread/activity-thread-importer.js +16 -17
  66. package/dist-client/pages/activity-thread/activity-thread-importer.js.map +1 -1
  67. package/dist-client/pages/activity-thread/activity-thread-list-page.d.ts +1 -1
  68. package/dist-client/pages/activity-thread/activity-thread-list-page.js +38 -36
  69. package/dist-client/pages/activity-thread/activity-thread-list-page.js.map +1 -1
  70. package/dist-client/pages/activity-thread/activity-thread-page.js +71 -51
  71. package/dist-client/pages/activity-thread/activity-thread-page.js.map +1 -1
  72. package/dist-client/pages/activity-thread/activity-thread-view-page.js +69 -60
  73. package/dist-client/pages/activity-thread/activity-thread-view-page.js.map +1 -1
  74. package/dist-client/pages/activity-thread/activity-thread-view.js +150 -151
  75. package/dist-client/pages/activity-thread/activity-thread-view.js.map +1 -1
  76. package/dist-client/pages/installable-activity/installable-activity-list-page.js +25 -30
  77. package/dist-client/pages/installable-activity/installable-activity-list-page.js.map +1 -1
  78. package/dist-client/pages/todo/approval-done-list-page.js +39 -35
  79. package/dist-client/pages/todo/approval-done-list-page.js.map +1 -1
  80. package/dist-client/pages/todo/approval-pending-list-page.js +58 -53
  81. package/dist-client/pages/todo/approval-pending-list-page.js.map +1 -1
  82. package/dist-client/pages/todo/done-list-calendar-page.js +17 -17
  83. package/dist-client/pages/todo/done-list-calendar-page.js.map +1 -1
  84. package/dist-client/pages/todo/done-list-page.js +40 -35
  85. package/dist-client/pages/todo/done-list-page.js.map +1 -1
  86. package/dist-client/pages/todo/draft-list-page.js +27 -30
  87. package/dist-client/pages/todo/draft-list-page.js.map +1 -1
  88. package/dist-client/pages/todo/pickable-list-page.js +31 -37
  89. package/dist-client/pages/todo/pickable-list-page.js.map +1 -1
  90. package/dist-client/pages/todo/todo-list-page.js +55 -54
  91. package/dist-client/pages/todo/todo-list-page.js.map +1 -1
  92. package/dist-client/templates/activity-approval-context-template.js +49 -49
  93. package/dist-client/templates/activity-approval-context-template.js.map +1 -1
  94. package/dist-client/templates/activity-instance-context-template.js +104 -104
  95. package/dist-client/templates/activity-instance-context-template.js.map +1 -1
  96. package/dist-client/templates/activity-thread-context-template.js +41 -41
  97. package/dist-client/templates/activity-thread-context-template.js.map +1 -1
  98. package/dist-client/tsconfig.tsbuildinfo +1 -1
  99. package/dist-server/controllers/activity-approval/_abort.js +18 -2
  100. package/dist-server/controllers/activity-approval/_abort.js.map +1 -1
  101. package/dist-server/controllers/activity-approval/approve.js +25 -3
  102. package/dist-server/controllers/activity-approval/approve.js.map +1 -1
  103. package/dist-server/controllers/activity-approval/check-authority.js +2 -3
  104. package/dist-server/controllers/activity-approval/check-authority.js.map +1 -1
  105. package/dist-server/controllers/activity-approval/delegate.js +17 -3
  106. package/dist-server/controllers/activity-approval/delegate.js.map +1 -1
  107. package/dist-server/controllers/activity-approval/reject.js +16 -2
  108. package/dist-server/controllers/activity-approval/reject.js.map +1 -1
  109. package/dist-server/controllers/activity-approval/save.js +6 -2
  110. package/dist-server/controllers/activity-approval/save.js.map +1 -1
  111. package/dist-server/controllers/activity-installation/activity-installation-controller.js +1 -1
  112. package/dist-server/controllers/activity-installation/activity-installation-controller.js.map +1 -1
  113. package/dist-server/controllers/activity-installation/call-webhook.js +3 -1
  114. package/dist-server/controllers/activity-installation/call-webhook.js.map +1 -1
  115. package/dist-server/controllers/activity-instance/abort.js +9 -1
  116. package/dist-server/controllers/activity-instance/abort.js.map +1 -1
  117. package/dist-server/controllers/activity-instance/draft.js +19 -2
  118. package/dist-server/controllers/activity-instance/draft.js.map +1 -1
  119. package/dist-server/controllers/activity-instance/end.js +10 -2
  120. package/dist-server/controllers/activity-instance/end.js.map +1 -1
  121. package/dist-server/controllers/activity-instance/issue.js +30 -5
  122. package/dist-server/controllers/activity-instance/issue.js.map +1 -1
  123. package/dist-server/controllers/activity-instance/pick.js +5 -1
  124. package/dist-server/controllers/activity-instance/pick.js.map +1 -1
  125. package/dist-server/controllers/activity-thread/_abort.js +9 -1
  126. package/dist-server/controllers/activity-thread/_abort.js.map +1 -1
  127. package/dist-server/controllers/activity-thread/check-authority.js +2 -3
  128. package/dist-server/controllers/activity-thread/check-authority.js.map +1 -1
  129. package/dist-server/controllers/activity-thread/delegate.js +9 -1
  130. package/dist-server/controllers/activity-thread/delegate.js.map +1 -1
  131. package/dist-server/controllers/activity-thread/end.js +9 -2
  132. package/dist-server/controllers/activity-thread/end.js.map +1 -1
  133. package/dist-server/controllers/activity-thread/restart.js +9 -1
  134. package/dist-server/controllers/activity-thread/restart.js.map +1 -1
  135. package/dist-server/controllers/activity-thread/save.js +7 -1
  136. package/dist-server/controllers/activity-thread/save.js.map +1 -1
  137. package/dist-server/controllers/activity-thread/start.js +8 -1
  138. package/dist-server/controllers/activity-thread/start.js.map +1 -1
  139. package/dist-server/controllers/activity-thread/submit.js +18 -4
  140. package/dist-server/controllers/activity-thread/submit.js.map +1 -1
  141. package/dist-server/controllers/common.js +5 -5
  142. package/dist-server/controllers/common.js.map +1 -1
  143. package/dist-server/routes.js +5 -2
  144. package/dist-server/routes.js.map +1 -1
  145. package/dist-server/service/activity/activity-mutation.js +43 -13
  146. package/dist-server/service/activity/activity-mutation.js.map +1 -1
  147. package/dist-server/service/activity/activity-query.js +3 -3
  148. package/dist-server/service/activity/activity-query.js.map +1 -1
  149. package/dist-server/service/activity-approval/activity-approval-subscription.js +3 -4
  150. package/dist-server/service/activity-approval/activity-approval-subscription.js.map +1 -1
  151. package/dist-server/service/activity-instance/activity-instance-mutation.d.ts +1 -0
  152. package/dist-server/service/activity-instance/activity-instance-mutation.js +36 -3
  153. package/dist-server/service/activity-instance/activity-instance-mutation.js.map +1 -1
  154. package/dist-server/service/activity-instance/activity-instance-query.d.ts +1 -0
  155. package/dist-server/service/activity-instance/activity-instance-query.js +25 -5
  156. package/dist-server/service/activity-instance/activity-instance-query.js.map +1 -1
  157. package/dist-server/service/activity-instance/activity-instance-subscription.js +3 -4
  158. package/dist-server/service/activity-instance/activity-instance-subscription.js.map +1 -1
  159. package/dist-server/service/activity-template/activity-template-mutation.js +25 -7
  160. package/dist-server/service/activity-template/activity-template-mutation.js.map +1 -1
  161. package/dist-server/service/activity-template/activity-template-query.js +1 -1
  162. package/dist-server/service/activity-template/activity-template-query.js.map +1 -1
  163. package/dist-server/service/activity-thread/activity-thread-subscription.js +3 -4
  164. package/dist-server/service/activity-thread/activity-thread-subscription.js.map +1 -1
  165. package/dist-server/service/installable-activity/installable-activity-mutation.js +19 -3
  166. package/dist-server/service/installable-activity/installable-activity-mutation.js.map +1 -1
  167. package/dist-server/tsconfig.tsbuildinfo +1 -1
  168. package/helps/worklist/activity-instance-list-page.md +90 -0
  169. package/helps/worklist/activity-instance-search-page.md +83 -0
  170. package/helps/worklist/activity-instance-start-page.md +92 -0
  171. package/helps/worklist/activity-thread-list-page.md +87 -0
  172. package/helps/worklist/activity-thread-page.md +93 -0
  173. package/helps/worklist/activity-thread-view-page.md +86 -0
  174. package/helps/worklist/approval-done-list-page.md +72 -0
  175. package/helps/worklist/approval-pending-list-page.md +89 -0
  176. package/helps/worklist/done-list-calendar-page.md +66 -0
  177. package/helps/worklist/done-list-page.md +76 -0
  178. package/helps/worklist/draft-list-page.md +80 -0
  179. package/helps/worklist/pickable-list-page.md +75 -0
  180. package/helps/worklist/todo-list-page.md +90 -0
  181. package/package.json +16 -15
  182. package/translations/en.json +3 -1
  183. package/translations/ja.json +2 -0
  184. package/translations/ko.json +2 -0
  185. package/translations/ms.json +2 -0
  186. package/translations/zh.json +2 -0
@@ -1,48 +1,149 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import '@operato/data-grist';
3
+ import '@operato/input/ox-input-select-buttons.js';
3
4
  import gql from 'graphql-tag';
4
5
  import { css, html } from 'lit';
5
- import { customElement, property, query } from 'lit/decorators.js';
6
+ import { customElement, property, query, state } from 'lit/decorators.js';
7
+ import { asyncReplace } from 'lit/directives/async-replace.js';
6
8
  import { connect } from 'pwa-helpers/connect-mixin.js';
7
9
  import { DataGrist } from '@operato/data-grist';
8
10
  import { client } from '@operato/graphql';
9
11
  import { i18next, localize } from '@operato/i18n';
10
- import { PageView, store } from '@operato/shell';
11
- import { CommonHeaderStyles, ScrollbarStyles } from '@operato/styles';
12
- import { isMobileDevice } from '@operato/utils';
13
- let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(store)(localize(i18next)(PageView)) {
12
+ import { CustomAlert, PageView, store } from '@operato/shell';
13
+ import { CommonHeaderStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles';
14
+ import { isMobileDevice, sleep } from '@operato/utils';
15
+ import { p13n } from '@operato/p13n';
16
+ import { ActivityInstanceStatus } from '../../types/activity-instance.js';
17
+ const MIN = 60;
18
+ const HOUR = 60 * MIN;
19
+ const DAY = 24 * HOUR;
20
+ function getActivityInstanceStatus() {
21
+ return [
22
+ { display: '', value: '' },
23
+ {
24
+ display: i18next.t('label.activity-state-draft'),
25
+ value: ActivityInstanceStatus.Draft
26
+ },
27
+ {
28
+ display: i18next.t('label.activity-state-issued'),
29
+ value: ActivityInstanceStatus.Issued
30
+ },
31
+ {
32
+ display: i18next.t('label.activity-state-unassigned'),
33
+ value: ActivityInstanceStatus.Unassigned
34
+ },
35
+ {
36
+ display: i18next.t('label.activity-state-assigned'),
37
+ value: ActivityInstanceStatus.Assigned
38
+ },
39
+ {
40
+ display: i18next.t('label.activity-state-started'),
41
+ value: ActivityInstanceStatus.Started
42
+ },
43
+ {
44
+ display: i18next.t('label.activity-state-pending'),
45
+ value: ActivityInstanceStatus.Pending
46
+ },
47
+ {
48
+ display: i18next.t('label.activity-state-ended'),
49
+ value: ActivityInstanceStatus.Ended
50
+ },
51
+ {
52
+ display: i18next.t('label.activity-state-aborted'),
53
+ value: ActivityInstanceStatus.Aborted
54
+ }
55
+ ];
56
+ }
57
+ const isDueable = (state) => {
58
+ return (state === ActivityInstanceStatus.Issued ||
59
+ state === ActivityInstanceStatus.Assigned ||
60
+ state === ActivityInstanceStatus.Started ||
61
+ state === ActivityInstanceStatus.Pending);
62
+ };
63
+ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(store)(p13n(localize(i18next)(PageView))) {
14
64
  constructor() {
15
65
  super(...arguments);
16
66
  this.mode = isMobileDevice() ? 'CARD' : 'GRID';
67
+ this.issuedByMe = false;
17
68
  }
69
+ static { this.styles = [
70
+ ScrollbarStyles,
71
+ CommonGristStyles,
72
+ CommonHeaderStyles,
73
+ css `
74
+ :host {
75
+ display: flex;
76
+
77
+ width: 100%;
78
+
79
+ --grid-record-emphasized-background-color: #8b0000;
80
+ --grid-record-emphasized-color: #ff6b6b;
81
+
82
+ --grid-header-padding: 2px 0 2px 9px;
83
+ }
84
+
85
+ ox-grist {
86
+ overflow-y: auto;
87
+ flex: 1;
88
+ }
89
+
90
+ .header {
91
+ grid-template-areas: 'filters actions';
92
+ }
93
+ `
94
+ ]; }
18
95
  get context() {
19
- var _a;
20
96
  return {
21
97
  title: i18next.t('title.activity instance list'),
22
98
  search: {
23
99
  handler: (search) => {
24
100
  this.grist.searchText = search;
25
101
  },
26
- value: ((_a = this.grist) === null || _a === void 0 ? void 0 : _a.searchText) || ''
102
+ value: this.grist?.searchText || ''
27
103
  },
28
104
  filter: {
29
105
  handler: () => {
30
106
  this.grist.toggleHeadroom();
31
107
  }
32
108
  },
33
- help: 'worklist/activity-instance-list',
34
- actions: []
109
+ help: 'worklist/activity-instance-list-page',
110
+ actions: [
111
+ {
112
+ title: i18next.t('button.abort'),
113
+ action: this.abortActivityInstances.bind(this),
114
+ icon: 'cancel'
115
+ }
116
+ ],
117
+ toolbar: false
35
118
  };
36
119
  }
37
120
  render() {
38
121
  const mode = this.mode;
39
122
  return html `
40
- <ox-grist .mode=${mode} .config=${this.gristConfig} .fetchHandler=${this.fetchHandler.bind(this)}>
123
+ <ox-grist
124
+ .mode=${mode}
125
+ .config=${this.gristConfig}
126
+ .personalConfigProvider=${this.getPagePreferenceProvider('ox-grist')}
127
+ .fetchHandler=${this.fetchHandler.bind(this)}
128
+ >
41
129
  <div slot="headroom" class="header">
42
130
  <div class="filters">
131
+ <ox-checkbox
132
+ .checked=${this.issuedByMe}
133
+ @change=${(e) => {
134
+ this.issuedByMe = e.currentTarget?.checked;
135
+ this.grist.fetch();
136
+ }}
137
+ ></ox-checkbox>
138
+ ${i18next.t('label.issued-by-me')}
139
+
43
140
  <ox-filters-form autofocus without-search></ox-filters-form>
44
141
  </div>
142
+
143
+ <ox-context-page-toolbar class="actions" .context=${this.context}> </ox-context-page-toolbar>
45
144
  </div>
145
+
146
+ <ox-grist-personalizer slot="setting"></ox-grist-personalizer>
46
147
  </ox-grist>
47
148
  `;
48
149
  }
@@ -65,7 +166,7 @@ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(st
65
166
  },
66
167
  filter: 'search',
67
168
  sortable: true,
68
- width: 150
169
+ width: 200
69
170
  },
70
171
  {
71
172
  type: 'string',
@@ -75,7 +176,7 @@ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(st
75
176
  editable: false
76
177
  },
77
178
  filter: 'search',
78
- width: 200
179
+ width: 240
79
180
  },
80
181
  {
81
182
  type: 'number',
@@ -92,18 +193,36 @@ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(st
92
193
  width: 60
93
194
  },
94
195
  {
95
- type: 'string',
196
+ type: 'select',
96
197
  name: 'state',
198
+ label: i18next.t('field.status'),
97
199
  header: i18next.t('field.status'),
98
200
  record: {
99
- editable: false
201
+ editable: false,
202
+ options: getActivityInstanceStatus()
100
203
  },
204
+ filter: true,
101
205
  width: 80
102
206
  },
207
+ {
208
+ type: 'string',
209
+ name: 'dueIn',
210
+ header: i18next.t('field.due-in'),
211
+ record: {
212
+ editable: false,
213
+ renderer: (value, column, record, rowIndex, field) => {
214
+ if (isDueable(record.state)) {
215
+ return html ` <span>${asyncReplace(this.dueTimer(record.dueAt))}</span>`;
216
+ }
217
+ }
218
+ },
219
+ sortable: false,
220
+ width: 180
221
+ },
103
222
  {
104
223
  type: 'resource-object',
105
- name: 'updater',
106
- header: i18next.t('field.updater'),
224
+ name: 'issuer',
225
+ header: i18next.t('field.issuer'),
107
226
  record: {
108
227
  editable: false
109
228
  },
@@ -112,8 +231,38 @@ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(st
112
231
  },
113
232
  {
114
233
  type: 'datetime',
115
- name: 'updatedAt',
116
- header: i18next.t('field.updated_at'),
234
+ name: 'issuedAt',
235
+ header: i18next.t('field.issued-at'),
236
+ record: {
237
+ editable: false
238
+ },
239
+ sortable: true,
240
+ width: 180
241
+ },
242
+ {
243
+ type: 'datetime',
244
+ name: 'dueAt',
245
+ header: i18next.t('field.due-at'),
246
+ record: {
247
+ editable: false
248
+ },
249
+ sortable: true,
250
+ width: 180
251
+ },
252
+ {
253
+ type: 'datetime',
254
+ name: 'startedAt',
255
+ header: i18next.t('field.started-at'),
256
+ record: {
257
+ editable: false
258
+ },
259
+ sortable: true,
260
+ width: 180
261
+ },
262
+ {
263
+ type: 'datetime',
264
+ name: 'terminatedAt',
265
+ header: i18next.t('field.terminated-at'),
117
266
  record: {
118
267
  editable: false
119
268
  },
@@ -135,7 +284,8 @@ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(st
135
284
  },
136
285
  sorters: [
137
286
  {
138
- name: 'name'
287
+ name: 'issuedAt',
288
+ desc: true
139
289
  }
140
290
  ]
141
291
  };
@@ -144,7 +294,7 @@ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(st
144
294
  const response = await client.query({
145
295
  query: gql `
146
296
  query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
147
- responses: activityInstances(filters: $filters, pagination: $pagination, sortings: $sortings) {
297
+ responses: ${this.issuedByMe ? 'activityInstancesIssuedByMe' : 'activityInstances'}(filters: $filters, pagination: $pagination, sortings: $sortings) {
148
298
  items {
149
299
  id
150
300
  name
@@ -152,11 +302,18 @@ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(st
152
302
  priority
153
303
  state
154
304
  thumbnail
305
+ issuer {
306
+ id
307
+ name
308
+ }
155
309
  updater {
156
310
  id
157
311
  name
158
312
  }
159
- updatedAt
313
+ issuedAt
314
+ dueAt
315
+ startedAt
316
+ terminatedAt
160
317
  }
161
318
  total
162
319
  }
@@ -173,26 +330,60 @@ let ActivityInstanceListPage = class ActivityInstanceListPage extends connect(st
173
330
  records: response.data.responses.items || []
174
331
  };
175
332
  }
333
+ async abortActivityInstances() {
334
+ const ids = this.grist.selected.map(record => record.id);
335
+ if (ids && ids.length > 0) {
336
+ const answer = await CustomAlert({
337
+ type: 'warning',
338
+ title: i18next.t('button.abort'),
339
+ text: i18next.t('text.are_you_sure'),
340
+ confirmButton: { text: i18next.t('button.abort') },
341
+ cancelButton: { text: i18next.t('button.cancel') }
342
+ });
343
+ if (!answer?.value)
344
+ return;
345
+ const response = await client.query({
346
+ query: gql `
347
+ mutation ($ids: [String!]!) {
348
+ abortActivityInstances(ids: $ids)
349
+ }
350
+ `,
351
+ variables: {
352
+ ids
353
+ }
354
+ });
355
+ if (!response.errors) {
356
+ this.grist.fetch();
357
+ this.showToast(i18next.t('text.activity_instance_aborted_successfully'));
358
+ }
359
+ }
360
+ else {
361
+ CustomAlert({
362
+ title: i18next.t('text.nothing_selected'),
363
+ text: i18next.t('text.there_is_nothing_to_process')
364
+ });
365
+ }
366
+ }
367
+ showToast(message) {
368
+ document.dispatchEvent(new CustomEvent('notify', { detail: { message } }));
369
+ }
370
+ async *dueTimer(exp) {
371
+ while (exp && this.active) {
372
+ var secs = Math.round((Date.parse(exp) - Date.now()) / 1000);
373
+ var positive = secs >= 0;
374
+ secs = Math.abs(secs);
375
+ const days = Math.floor(secs / DAY);
376
+ secs -= days * DAY;
377
+ const hours = Math.floor(secs / HOUR);
378
+ secs -= hours * HOUR;
379
+ const minutes = Math.floor(secs / MIN);
380
+ const seconds = secs - minutes * MIN;
381
+ const result = `${positive ? '' : '- '}${days ? `${days}${i18next.t('label.days')} ` : ''}${hours ? `${hours}${i18next.t('label.hours')} ` : ''}${minutes ? `${minutes}${i18next.t('label.minutes')} ` : ''}`;
382
+ yield result;
383
+ await sleep(60 * 1000);
384
+ }
385
+ }
176
386
  };
177
- ActivityInstanceListPage.styles = [
178
- ScrollbarStyles,
179
- CommonHeaderStyles,
180
- css `
181
- :host {
182
- display: flex;
183
-
184
- width: 100%;
185
-
186
- --grid-record-emphasized-background-color: #8b0000;
187
- --grid-record-emphasized-color: #ff6b6b;
188
- }
189
-
190
- ox-grist {
191
- overflow-y: auto;
192
- flex: 1;
193
- }
194
- `
195
- ];
196
387
  __decorate([
197
388
  property({ type: Object }),
198
389
  __metadata("design:type", Object)
@@ -201,6 +392,10 @@ __decorate([
201
392
  property({ type: String }),
202
393
  __metadata("design:type", String)
203
394
  ], ActivityInstanceListPage.prototype, "mode", void 0);
395
+ __decorate([
396
+ state(),
397
+ __metadata("design:type", Boolean)
398
+ ], ActivityInstanceListPage.prototype, "issuedByMe", void 0);
204
399
  __decorate([
205
400
  query('ox-grist'),
206
401
  __metadata("design:type", DataGrist)
@@ -1 +1 @@
1
- {"version":3,"file":"activity-instance-list-page.js","sourceRoot":"","sources":["../../../client/pages/activity-instance/activity-instance-list-page.ts"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\n\nimport gql from 'graphql-tag'\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin.js'\n\nimport { FetchOption, DataGrist } from '@operato/data-grist'\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { PageView, store } from '@operato/shell'\nimport { CommonHeaderStyles, ScrollbarStyles } from '@operato/styles'\nimport { isMobileDevice } from '@operato/utils'\n\n@customElement('activity-instance-list-page')\nexport class ActivityInstanceListPage extends connect(store)(localize(i18next)(PageView)) {\n static styles = [\n ScrollbarStyles,\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 ]\n\n @property({ type: Object }) gristConfig: any\n @property({ type: String }) mode: string = isMobileDevice() ? 'CARD' : 'GRID'\n\n @query('ox-grist') grist!: DataGrist\n\n get context() {\n return {\n title: i18next.t('title.activity instance list'),\n search: {\n handler: (search: string) => {\n this.grist.searchText = search\n },\n value: this.grist?.searchText || ''\n },\n filter: {\n handler: () => {\n this.grist.toggleHeadroom()\n }\n },\n help: 'worklist/activity-instance-list',\n actions: []\n }\n }\n\n render() {\n const mode = this.mode\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 </div>\n </div>\n </ox-grist>\n `\n }\n\n async pageInitialized(lifecycle) {\n this.gristConfig = {\n list: {\n thumbnail: 'thumbnail',\n fields: ['name', 'description'],\n details: ['updatedAt']\n },\n columns: [\n { type: 'gutter', gutterName: 'sequence' },\n { type: 'gutter', gutterName: 'row-selector', multiple: true },\n {\n type: 'string',\n name: 'name',\n header: i18next.t('field.name'),\n record: {\n editable: false\n },\n filter: 'search',\n sortable: true,\n width: 150\n },\n {\n type: 'string',\n name: 'description',\n header: i18next.t('field.description'),\n record: {\n editable: false\n },\n filter: 'search',\n width: 200\n },\n {\n type: 'number',\n name: 'priority',\n header: i18next.t('field.priority'),\n record: {\n editable: false,\n renderer: function (value, column, record, rowIndex, field) {\n const color = ['', '#98FB98', '#87CEEB', '#FF6B6B', '#8B0000'][value || 0]\n const count = new Array(value > 4 ? 4 : value || 0).fill('')\n return html`${count.map(() => html`<md-icon style=\"color:${color};\">star</md-icon>`)}`\n }\n },\n width: 60\n },\n {\n type: 'string',\n name: 'state',\n header: i18next.t('field.status'),\n record: {\n editable: false\n },\n width: 80\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 type: 'image',\n name: 'thumbnail',\n header: i18next.t('field.thumbnail'),\n record: { editable: false },\n hidden: true\n }\n ],\n rows: {\n selectable: {\n multiple: true\n }\n },\n sorters: [\n {\n name: 'name'\n }\n ]\n }\n }\n\n async fetchHandler({ page, limit, sortings = [], filters = [] }: FetchOption) {\n const response = await client.query({\n query: gql`\n query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {\n responses: activityInstances(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n description\n priority\n state\n thumbnail\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"]}
1
+ {"version":3,"file":"activity-instance-list-page.js","sourceRoot":"","sources":["../../../client/pages/activity-instance/activity-instance-list-page.ts"],"names":[],"mappings":";AAAA,OAAO,qBAAqB,CAAA;AAC5B,OAAO,2CAA2C,CAAA;AAElD,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAA;AAEtD,OAAO,EAAe,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACjD,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AAC7D,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxF,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AACtD,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAA;AAEpC,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAA;AAEzE,MAAM,GAAG,GAAG,EAAE,CAAA;AACd,MAAM,IAAI,GAAG,EAAE,GAAG,GAAG,CAAA;AACrB,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,CAAA;AAErB,SAAS,yBAAyB;IAChC,OAAO;QACL,EAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;QAC1B;YACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,4BAA4B,CAAC;YAChD,KAAK,EAAE,sBAAsB,CAAC,KAAK;SACpC;QACD;YACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,6BAA6B,CAAC;YACjD,KAAK,EAAE,sBAAsB,CAAC,MAAM;SACrC;QACD;YACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,iCAAiC,CAAC;YACrD,KAAK,EAAE,sBAAsB,CAAC,UAAU;SACzC;QACD;YACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,+BAA+B,CAAC;YACnD,KAAK,EAAE,sBAAsB,CAAC,QAAQ;SACvC;QACD;YACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,8BAA8B,CAAC;YAClD,KAAK,EAAE,sBAAsB,CAAC,OAAO;SACtC;QACD;YACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,8BAA8B,CAAC;YAClD,KAAK,EAAE,sBAAsB,CAAC,OAAO;SACtC;QACD;YACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,4BAA4B,CAAC;YAChD,KAAK,EAAE,sBAAsB,CAAC,KAAK;SACpC;QACD;YACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,8BAA8B,CAAC;YAClD,KAAK,EAAE,sBAAsB,CAAC,OAAO;SACtC;KACF,CAAA;AACH,CAAC;AAED,MAAM,SAAS,GAAG,CAAC,KAA6B,EAAE,EAAE;IAClD,OAAO,CACL,KAAK,KAAK,sBAAsB,CAAC,MAAM;QACvC,KAAK,KAAK,sBAAsB,CAAC,QAAQ;QACzC,KAAK,KAAK,sBAAsB,CAAC,OAAO;QACxC,KAAK,KAAK,sBAAsB,CAAC,OAAO,CACzC,CAAA;AACH,CAAC,CAAA;AAGM,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;IAAxF;;QA6BuB,SAAI,GAA6B,cAAc,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAA;QAE9E,eAAU,GAAa,KAAK,CAAA;IAsT/C,CAAC;aApVQ,WAAM,GAAG;QACd,eAAe;QACf,iBAAiB;QACjB,kBAAkB;QAClB,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;KAoBF;KACF,AAzBY,CAyBZ;IASD,IAAI,OAAO;QACT,OAAO;YACL,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,8BAA8B,CAAC;YAChD,MAAM,EAAE;gBACN,OAAO,EAAE,CAAC,MAAc,EAAE,EAAE;oBAC1B,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,MAAM,CAAA;gBAChC,CAAC;gBACD,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,UAAU,IAAI,EAAE;aACpC;YACD,MAAM,EAAE;gBACN,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,CAAA;gBAC7B,CAAC;aACF;YACD,IAAI,EAAE,sCAAsC;YAC5C,OAAO,EAAE;gBACP;oBACE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC;oBAChC,MAAM,EAAE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC;oBAC9C,IAAI,EAAE,QAAQ;iBACf;aACF;YACD,OAAO,EAAE,KAAK;SACf,CAAA;IACH,CAAC;IAED,MAAM;QACJ,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAA;QAEtB,OAAO,IAAI,CAAA;;gBAEC,IAAI;kBACF,IAAI,CAAC,WAAW;kCACA,IAAI,CAAC,yBAAyB,CAAC,UAAU,CAAE;wBACrD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;yBAK3B,IAAI,CAAC,UAAU;wBAChB,CAAC,CAAc,EAAE,EAAE;YAC3B,IAAI,CAAC,UAAU,GAAI,CAAC,CAAC,aAAqB,EAAE,OAAO,CAAA;YACnD,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;QACpB,CAAC;;cAED,OAAO,CAAC,CAAC,CAAC,oBAAoB,CAAC;;;;;8DAKiB,IAAI,CAAC,OAAO;;;;;KAKrE,CAAA;IACH,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,SAAS;QAC7B,IAAI,CAAC,WAAW,GAAG;YACjB,IAAI,EAAE;gBACJ,SAAS,EAAE,WAAW;gBACtB,MAAM,EAAE,CAAC,MAAM,EAAE,aAAa,CAAC;gBAC/B,OAAO,EAAE,CAAC,WAAW,CAAC;aACvB;YACD,OAAO,EAAE;gBACP,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE;gBAC1C,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAC9D;oBACE,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,MAAM;oBACZ,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC;oBAC/B,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;qBAChB;oBACD,MAAM,EAAE,QAAQ;oBAChB,QAAQ,EAAE,IAAI;oBACd,KAAK,EAAE,GAAG;iBACX;gBACD;oBACE,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,aAAa;oBACnB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC;oBACtC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;qBAChB;oBACD,MAAM,EAAE,QAAQ;oBAChB,KAAK,EAAE,GAAG;iBACX;gBACD;oBACE,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,UAAU;oBAChB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC;oBACnC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;wBACf,QAAQ,EAAE,UAAU,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK;4BACxD,MAAM,KAAK,GAAG,CAAC,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAA;4BAC1E,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;4BAC5D,OAAO,IAAI,CAAA,GAAG,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAA,yBAAyB,KAAK,mBAAmB,CAAC,EAAE,CAAA;wBACxF,CAAC;qBACF;oBACD,KAAK,EAAE,EAAE;iBACV;gBACD;oBACE,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,OAAO;oBACb,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC;oBAChC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC;oBACjC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;wBACf,OAAO,EAAE,yBAAyB,EAAE;qBACrC;oBACD,MAAM,EAAE,IAAI;oBACZ,KAAK,EAAE,EAAE;iBACV;gBACD;oBACE,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,OAAO;oBACb,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC;oBACjC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;wBACf,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE;4BACnD,IAAI,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;gCAC5B,OAAO,IAAI,CAAA,UAAU,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,SAAS,CAAA;4BACzE,CAAC;wBACH,CAAC;qBACF;oBACD,QAAQ,EAAE,KAAK;oBACf,KAAK,EAAE,GAAG;iBACX;gBACD;oBACE,IAAI,EAAE,iBAAiB;oBACvB,IAAI,EAAE,QAAQ;oBACd,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC;oBACjC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;qBAChB;oBACD,QAAQ,EAAE,IAAI;oBACd,KAAK,EAAE,GAAG;iBACX;gBACD;oBACE,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,UAAU;oBAChB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC;oBACpC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;qBAChB;oBACD,QAAQ,EAAE,IAAI;oBACd,KAAK,EAAE,GAAG;iBACX;gBACD;oBACE,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,OAAO;oBACb,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC;oBACjC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;qBAChB;oBACD,QAAQ,EAAE,IAAI;oBACd,KAAK,EAAE,GAAG;iBACX;gBACD;oBACE,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,WAAW;oBACjB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,kBAAkB,CAAC;oBACrC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;qBAChB;oBACD,QAAQ,EAAE,IAAI;oBACd,KAAK,EAAE,GAAG;iBACX;gBACD;oBACE,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,cAAc;oBACpB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,qBAAqB,CAAC;oBACxC,MAAM,EAAE;wBACN,QAAQ,EAAE,KAAK;qBAChB;oBACD,QAAQ,EAAE,IAAI;oBACd,KAAK,EAAE,GAAG;iBACX;gBACD;oBACE,IAAI,EAAE,OAAO;oBACb,IAAI,EAAE,WAAW;oBACjB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC;oBACpC,MAAM,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE;oBAC3B,MAAM,EAAE,IAAI;iBACb;aACF;YACD,IAAI,EAAE;gBACJ,UAAU,EAAE;oBACV,QAAQ,EAAE,IAAI;iBACf;aACF;YACD,OAAO,EAAE;gBACP;oBACE,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,IAAI;iBACX;aACF;SACF,CAAA;IACH,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,GAAG,EAAE,EAAE,OAAO,GAAG,EAAE,EAAe;QAC1E,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;YAClC,KAAK,EAAE,GAAG,CAAA;;uBAEO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,6BAA6B,CAAC,CAAC,CAAC,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;OAwBrF;YACD,SAAS,EAAE;gBACT,OAAO;gBACP,UAAU,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE;gBAC3B,QAAQ;aACT;SACF,CAAC,CAAA;QAEF,OAAO;YACL,KAAK,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,CAAC;YACzC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE;SAC7C,CAAA;IACH,CAAC;IAED,KAAK,CAAC,sBAAsB;QAC1B,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;QACxD,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC1B,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC;gBAC/B,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC;gBAChC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC;gBACpC,aAAa,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC,EAAE;gBAClD,YAAY,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;aACnD,CAAC,CAAA;YAEF,IAAI,CAAC,MAAM,EAAE,KAAK;gBAAE,OAAM;YAE1B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;gBAClC,KAAK,EAAE,GAAG,CAAA;;;;SAIT;gBACD,SAAS,EAAE;oBACT,GAAG;iBACJ;aACF,CAAC,CAAA;YAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gBACrB,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;gBAClB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,6CAA6C,CAAC,CAAC,CAAA;YAC1E,CAAC;QACH,CAAC;aAAM,CAAC;YACN,WAAW,CAAC;gBACV,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,uBAAuB,CAAC;gBACzC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,kCAAkC,CAAC;aACpD,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;IAED,SAAS,CAAC,OAAO;QACf,QAAQ,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC,CAAA;IAC5E,CAAC;IAED,KAAK,CAAC,CAAC,QAAQ,CAAC,GAAG;QACjB,OAAO,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAC1B,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,CAAA;YAC5D,IAAI,QAAQ,GAAG,IAAI,IAAI,CAAC,CAAA;YAExB,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;YACrB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,CAAC,CAAA;YACnC,IAAI,IAAI,IAAI,GAAG,GAAG,CAAA;YAClB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,CAAA;YACrC,IAAI,IAAI,KAAK,GAAG,IAAI,CAAA;YACpB,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,CAAC,CAAA;YACtC,MAAM,OAAO,GAAG,IAAI,GAAG,OAAO,GAAG,GAAG,CAAA;YAEpC,MAAM,MAAM,GAAG,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAC7I,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EACzD,EAAE,CAAA;YAEF,MAAM,MAAM,CAAA;YAEZ,MAAM,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,CAAA;QACxB,CAAC;IACH,CAAC;;AAxT2B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;6DAAiB;AAChB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;sDAAoE;AAE9E;IAAhB,KAAK,EAAE;;4DAAqC;AAE1B;IAAlB,KAAK,CAAC,UAAU,CAAC;8BAAS,SAAS;uDAAA;AAjCzB,wBAAwB;IADpC,aAAa,CAAC,6BAA6B,CAAC;GAChC,wBAAwB,CAqVpC","sourcesContent":["import '@operato/data-grist'\nimport '@operato/input/ox-input-select-buttons.js'\n\nimport gql from 'graphql-tag'\nimport { css, html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { asyncReplace } from 'lit/directives/async-replace.js'\nimport { connect } from 'pwa-helpers/connect-mixin.js'\n\nimport { FetchOption, DataGrist } from '@operato/data-grist'\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { CustomAlert, PageView, store } from '@operato/shell'\nimport { CommonHeaderStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'\nimport { isMobileDevice, sleep } from '@operato/utils'\nimport { p13n } from '@operato/p13n'\n\nimport { ActivityInstanceStatus } from '../../types/activity-instance.js'\n\nconst MIN = 60\nconst HOUR = 60 * MIN\nconst DAY = 24 * HOUR\n\nfunction getActivityInstanceStatus() {\n return [\n { display: '', value: '' },\n {\n display: i18next.t('label.activity-state-draft'),\n value: ActivityInstanceStatus.Draft\n },\n {\n display: i18next.t('label.activity-state-issued'),\n value: ActivityInstanceStatus.Issued\n },\n {\n display: i18next.t('label.activity-state-unassigned'),\n value: ActivityInstanceStatus.Unassigned\n },\n {\n display: i18next.t('label.activity-state-assigned'),\n value: ActivityInstanceStatus.Assigned\n },\n {\n display: i18next.t('label.activity-state-started'),\n value: ActivityInstanceStatus.Started\n },\n {\n display: i18next.t('label.activity-state-pending'),\n value: ActivityInstanceStatus.Pending\n },\n {\n display: i18next.t('label.activity-state-ended'),\n value: ActivityInstanceStatus.Ended\n },\n {\n display: i18next.t('label.activity-state-aborted'),\n value: ActivityInstanceStatus.Aborted\n }\n ]\n}\n\nconst isDueable = (state: ActivityInstanceStatus) => {\n return (\n state === ActivityInstanceStatus.Issued ||\n state === ActivityInstanceStatus.Assigned ||\n state === ActivityInstanceStatus.Started ||\n state === ActivityInstanceStatus.Pending\n )\n}\n\n@customElement('activity-instance-list-page')\nexport class ActivityInstanceListPage extends connect(store)(p13n(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 --grid-header-padding: 2px 0 2px 9px;\n }\n\n ox-grist {\n overflow-y: auto;\n flex: 1;\n }\n\n .header {\n grid-template-areas: 'filters actions';\n }\n `\n ]\n\n @property({ type: Object }) gristConfig: any\n @property({ type: String }) mode: 'CARD' | 'GRID' | 'LIST' = isMobileDevice() ? 'CARD' : 'GRID'\n\n @state() private issuedByMe?: boolean = false\n\n @query('ox-grist') grist!: DataGrist\n\n get context() {\n return {\n title: i18next.t('title.activity instance list'),\n search: {\n handler: (search: string) => {\n this.grist.searchText = search\n },\n value: this.grist?.searchText || ''\n },\n filter: {\n handler: () => {\n this.grist.toggleHeadroom()\n }\n },\n help: 'worklist/activity-instance-list-page',\n actions: [\n {\n title: i18next.t('button.abort'),\n action: this.abortActivityInstances.bind(this),\n icon: 'cancel'\n }\n ],\n toolbar: false\n }\n }\n\n render() {\n const mode = this.mode\n\n return html`\n <ox-grist\n .mode=${mode}\n .config=${this.gristConfig}\n .personalConfigProvider=${this.getPagePreferenceProvider('ox-grist')!}\n .fetchHandler=${this.fetchHandler.bind(this)}\n >\n <div slot=\"headroom\" class=\"header\">\n <div class=\"filters\">\n <ox-checkbox\n .checked=${this.issuedByMe}\n @change=${(e: CustomEvent) => {\n this.issuedByMe = (e.currentTarget as any)?.checked\n this.grist.fetch()\n }}\n ></ox-checkbox>\n ${i18next.t('label.issued-by-me')}\n\n <ox-filters-form autofocus without-search></ox-filters-form>\n </div>\n\n <ox-context-page-toolbar class=\"actions\" .context=${this.context}> </ox-context-page-toolbar>\n </div>\n\n <ox-grist-personalizer slot=\"setting\"></ox-grist-personalizer>\n </ox-grist>\n `\n }\n\n async pageInitialized(lifecycle) {\n this.gristConfig = {\n list: {\n thumbnail: 'thumbnail',\n fields: ['name', 'description'],\n details: ['updatedAt']\n },\n columns: [\n { type: 'gutter', gutterName: 'sequence' },\n { type: 'gutter', gutterName: 'row-selector', multiple: true },\n {\n type: 'string',\n name: 'name',\n header: i18next.t('field.name'),\n record: {\n editable: false\n },\n filter: 'search',\n sortable: true,\n width: 200\n },\n {\n type: 'string',\n name: 'description',\n header: i18next.t('field.description'),\n record: {\n editable: false\n },\n filter: 'search',\n width: 240\n },\n {\n type: 'number',\n name: 'priority',\n header: i18next.t('field.priority'),\n record: {\n editable: false,\n renderer: function (value, column, record, rowIndex, field) {\n const color = ['', '#98FB98', '#87CEEB', '#FF6B6B', '#8B0000'][value || 0]\n const count = new Array(value > 4 ? 4 : value || 0).fill('')\n return html`${count.map(() => html`<md-icon style=\"color:${color};\">star</md-icon>`)}`\n }\n },\n width: 60\n },\n {\n type: 'select',\n name: 'state',\n label: i18next.t('field.status'),\n header: i18next.t('field.status'),\n record: {\n editable: false,\n options: getActivityInstanceStatus()\n },\n filter: true,\n width: 80\n },\n {\n type: 'string',\n name: 'dueIn',\n header: i18next.t('field.due-in'),\n record: {\n editable: false,\n renderer: (value, column, record, rowIndex, field) => {\n if (isDueable(record.state)) {\n return html` <span>${asyncReplace(this.dueTimer(record.dueAt))}</span>`\n }\n }\n },\n sortable: false,\n width: 180\n },\n {\n type: 'resource-object',\n name: 'issuer',\n header: i18next.t('field.issuer'),\n record: {\n editable: false\n },\n sortable: true,\n width: 120\n },\n {\n type: 'datetime',\n name: 'issuedAt',\n header: i18next.t('field.issued-at'),\n record: {\n editable: false\n },\n sortable: true,\n width: 180\n },\n {\n type: 'datetime',\n name: 'dueAt',\n header: i18next.t('field.due-at'),\n record: {\n editable: false\n },\n sortable: true,\n width: 180\n },\n {\n type: 'datetime',\n name: 'startedAt',\n header: i18next.t('field.started-at'),\n record: {\n editable: false\n },\n sortable: true,\n width: 180\n },\n {\n type: 'datetime',\n name: 'terminatedAt',\n header: i18next.t('field.terminated-at'),\n record: {\n editable: false\n },\n sortable: true,\n width: 180\n },\n {\n type: 'image',\n name: 'thumbnail',\n header: i18next.t('field.thumbnail'),\n record: { editable: false },\n hidden: true\n }\n ],\n rows: {\n selectable: {\n multiple: true\n }\n },\n sorters: [\n {\n name: 'issuedAt',\n desc: true\n }\n ]\n }\n }\n\n async fetchHandler({ page, limit, sortings = [], filters = [] }: FetchOption) {\n const response = await client.query({\n query: gql`\n query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {\n responses: ${this.issuedByMe ? 'activityInstancesIssuedByMe' : 'activityInstances'}(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n description\n priority\n state\n thumbnail\n issuer {\n id\n name\n }\n updater {\n id\n name\n }\n issuedAt\n dueAt\n startedAt\n terminatedAt\n }\n total\n }\n }\n `,\n variables: {\n filters,\n pagination: { page, limit },\n sortings\n }\n })\n\n return {\n total: response.data.responses.total || 0,\n records: response.data.responses.items || []\n }\n }\n\n async abortActivityInstances() {\n const ids = this.grist.selected.map(record => record.id)\n if (ids && ids.length > 0) {\n const answer = await CustomAlert({\n type: 'warning',\n title: i18next.t('button.abort'),\n text: i18next.t('text.are_you_sure'),\n confirmButton: { text: i18next.t('button.abort') },\n cancelButton: { text: i18next.t('button.cancel') }\n })\n\n if (!answer?.value) return\n\n const response = await client.query({\n query: gql`\n mutation ($ids: [String!]!) {\n abortActivityInstances(ids: $ids)\n }\n `,\n variables: {\n ids\n }\n })\n\n if (!response.errors) {\n this.grist.fetch()\n this.showToast(i18next.t('text.activity_instance_aborted_successfully'))\n }\n } else {\n CustomAlert({\n title: i18next.t('text.nothing_selected'),\n text: i18next.t('text.there_is_nothing_to_process')\n })\n }\n }\n\n showToast(message) {\n document.dispatchEvent(new CustomEvent('notify', { detail: { message } }))\n }\n\n async *dueTimer(exp) {\n while (exp && this.active) {\n var secs = Math.round((Date.parse(exp) - Date.now()) / 1000)\n var positive = secs >= 0\n\n secs = Math.abs(secs)\n const days = Math.floor(secs / DAY)\n secs -= days * DAY\n const hours = Math.floor(secs / HOUR)\n secs -= hours * HOUR\n const minutes = Math.floor(secs / MIN)\n const seconds = secs - minutes * MIN\n\n const result = `${positive ? '' : '- '}${days ? `${days}${i18next.t('label.days')} ` : ''}${hours ? `${hours}${i18next.t('label.hours')} ` : ''}${\n minutes ? `${minutes}${i18next.t('label.minutes')} ` : ''\n }`\n\n yield result\n\n await sleep(60 * 1000)\n }\n }\n}\n"]}
@@ -18,22 +18,42 @@ let ActivityInstanceSearchPage = class ActivityInstanceSearchPage extends connec
18
18
  this.searchKeys = [];
19
19
  this.mode = isMobileDevice() ? 'CARD' : 'GRID';
20
20
  }
21
+ static { this.styles = [
22
+ ScrollbarStyles,
23
+ CommonHeaderStyles,
24
+ css `
25
+ :host {
26
+ display: flex;
27
+ flex-direction: column;
28
+
29
+ overflow: hidden;
30
+ }
31
+
32
+ ox-grist {
33
+ overflow-y: auto;
34
+ flex: 1;
35
+ }
36
+
37
+ .header {
38
+ grid-template-areas: 'filters actions';
39
+ }
40
+ `
41
+ ]; }
21
42
  get context() {
22
- var _a;
23
43
  return {
24
44
  title: i18next.t('title.activity instance search'),
25
45
  search: {
26
46
  handler: (search) => {
27
47
  this.grist.searchText = search;
28
48
  },
29
- value: ((_a = this.grist) === null || _a === void 0 ? void 0 : _a.searchText) || ''
49
+ value: this.grist?.searchText || ''
30
50
  },
31
51
  filter: {
32
52
  handler: () => {
33
53
  this.grist.toggleHeadroom();
34
54
  }
35
55
  },
36
- help: 'dataset/activity-instance-search',
56
+ help: 'dataset/activity-instance-search-page',
37
57
  actions: [],
38
58
  exportable: {
39
59
  name: i18next.t('title.activity instance search'),
@@ -60,7 +80,6 @@ let ActivityInstanceSearchPage = class ActivityInstanceSearchPage extends connec
60
80
  }
61
81
  }
62
82
  async updated(changes) {
63
- var _a;
64
83
  if (changes.has('activityId')) {
65
84
  const response = await client.query({
66
85
  query: gql `
@@ -83,13 +102,12 @@ let ActivityInstanceSearchPage = class ActivityInstanceSearchPage extends connec
83
102
  }
84
103
  });
85
104
  this.activity = response.data.activity;
86
- this.searchKeys = (_a = this.activity) === null || _a === void 0 ? void 0 : _a.searchKeys;
105
+ this.searchKeys = this.activity?.searchKeys;
87
106
  this.refreshGristConfig();
88
107
  }
89
108
  }
90
109
  getSearchKeyColumns() {
91
- var _a;
92
- return (((_a = this.searchKeys) === null || _a === void 0 ? void 0 : _a.map((item, index) => {
110
+ return (this.searchKeys?.map((item, index) => {
93
111
  return {
94
112
  type: 'string',
95
113
  name: `key0${index + 1}`,
@@ -102,7 +120,7 @@ let ActivityInstanceSearchPage = class ActivityInstanceSearchPage extends connec
102
120
  width: 120,
103
121
  imex: true
104
122
  };
105
- })) || []);
123
+ }) || []);
106
124
  }
107
125
  refreshGristConfig() {
108
126
  this.gristConfig = {
@@ -292,40 +310,22 @@ let ActivityInstanceSearchPage = class ActivityInstanceSearchPage extends connec
292
310
  : column.imex;
293
311
  });
294
312
  var data = records.map(item => {
295
- return Object.assign({ id: item.id }, this.gristConfig.columns
296
- .filter(column => column.type !== 'gutter' && column.record !== undefined && column.imex !== undefined)
297
- .reduce((record, column) => {
298
- const key = column.imex === true ? column.name : column.imex.key;
299
- record[key] = key
300
- .split('.')
301
- .reduce((obj, key) => (obj && obj[key] !== 'undefined' ? obj[key] : undefined), item);
302
- return record;
303
- }, {}));
313
+ return {
314
+ id: item.id,
315
+ ...this.gristConfig.columns
316
+ .filter(column => column.type !== 'gutter' && column.record !== undefined && column.imex !== undefined)
317
+ .reduce((record, column) => {
318
+ const key = column.imex === true ? column.name : column.imex.key;
319
+ record[key] = key
320
+ .split('.')
321
+ .reduce((obj, key) => (obj && obj[key] !== 'undefined' ? obj[key] : undefined), item);
322
+ return record;
323
+ }, {})
324
+ };
304
325
  });
305
326
  return { header: headerSetting, data: data };
306
327
  }
307
328
  };
308
- ActivityInstanceSearchPage.styles = [
309
- ScrollbarStyles,
310
- CommonHeaderStyles,
311
- css `
312
- :host {
313
- display: flex;
314
- flex-direction: column;
315
-
316
- overflow: hidden;
317
- }
318
-
319
- ox-grist {
320
- overflow-y: auto;
321
- flex: 1;
322
- }
323
-
324
- .header {
325
- grid-template-areas: 'filters actions';
326
- }
327
- `
328
- ];
329
329
  __decorate([
330
330
  state(),
331
331
  __metadata("design:type", String)