@things-factory/worklist 9.1.19 → 10.0.0-beta.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.
Files changed (103) hide show
  1. package/dist-client/components/activity-thread-timeline.d.ts +1 -9
  2. package/dist-client/components/activity-thread-timeline.js +1 -3
  3. package/dist-client/components/activity-thread-timeline.js.map +1 -1
  4. package/dist-client/pages/activity/activity-list-page.d.ts +1 -7
  5. package/dist-client/pages/activity/activity-list-page.js +125 -234
  6. package/dist-client/pages/activity/activity-list-page.js.map +1 -1
  7. package/dist-client/pages/activity/activity-page.d.ts +1 -7
  8. package/dist-client/pages/activity/activity-page.js +51 -93
  9. package/dist-client/pages/activity/activity-page.js.map +1 -1
  10. package/dist-client/pages/activity/starter-list-page.d.ts +1 -7
  11. package/dist-client/pages/activity/starter-list-page.js +33 -62
  12. package/dist-client/pages/activity/starter-list-page.js.map +1 -1
  13. package/dist-client/pages/activity-approval/activity-approval-list-page.d.ts +1 -7
  14. package/dist-client/pages/activity-approval/activity-approval-list-page.js +50 -95
  15. package/dist-client/pages/activity-approval/activity-approval-list-page.js.map +1 -1
  16. package/dist-client/pages/activity-approval/activity-approval-page.d.ts +1 -7
  17. package/dist-client/pages/activity-approval/activity-approval-page.js +73 -119
  18. package/dist-client/pages/activity-approval/activity-approval-page.js.map +1 -1
  19. package/dist-client/pages/activity-instance/activity-instance-list-page.d.ts +0 -6
  20. package/dist-client/pages/activity-instance/activity-instance-list-page.js +63 -120
  21. package/dist-client/pages/activity-instance/activity-instance-list-page.js.map +1 -1
  22. package/dist-client/pages/activity-instance/activity-instance-search-page.d.ts +1 -7
  23. package/dist-client/pages/activity-instance/activity-instance-search-page.js +55 -101
  24. package/dist-client/pages/activity-instance/activity-instance-search-page.js.map +1 -1
  25. package/dist-client/pages/activity-instance/activity-instance-start-page.d.ts +1 -7
  26. package/dist-client/pages/activity-instance/activity-instance-start-page.js +65 -109
  27. package/dist-client/pages/activity-instance/activity-instance-start-page.js.map +1 -1
  28. package/dist-client/pages/activity-stats/activity-stats-list-page.d.ts +1 -7
  29. package/dist-client/pages/activity-stats/activity-stats-list-page.js +50 -95
  30. package/dist-client/pages/activity-stats/activity-stats-list-page.js.map +1 -1
  31. package/dist-client/pages/activity-store/activity-store-page.d.ts +1 -7
  32. package/dist-client/pages/activity-store/activity-store-page.js +2 -3
  33. package/dist-client/pages/activity-store/activity-store-page.js.map +1 -1
  34. package/dist-client/pages/activity-supervisor/reporter-list-page.d.ts +1 -7
  35. package/dist-client/pages/activity-supervisor/reporter-list-page.js +36 -66
  36. package/dist-client/pages/activity-supervisor/reporter-list-page.js.map +1 -1
  37. package/dist-client/pages/activity-template/activity-template-list-page.d.ts +1 -7
  38. package/dist-client/pages/activity-template/activity-template-list-page.js +70 -134
  39. package/dist-client/pages/activity-template/activity-template-list-page.js.map +1 -1
  40. package/dist-client/pages/activity-thread/activity-thread-list-page.d.ts +1 -7
  41. package/dist-client/pages/activity-thread/activity-thread-list-page.js +49 -93
  42. package/dist-client/pages/activity-thread/activity-thread-list-page.js.map +1 -1
  43. package/dist-client/pages/activity-thread/activity-thread-page.d.ts +1 -7
  44. package/dist-client/pages/activity-thread/activity-thread-page.js +80 -135
  45. package/dist-client/pages/activity-thread/activity-thread-page.js.map +1 -1
  46. package/dist-client/pages/activity-thread/activity-thread-view-page.d.ts +1 -7
  47. package/dist-client/pages/activity-thread/activity-thread-view-page.js +54 -80
  48. package/dist-client/pages/activity-thread/activity-thread-view-page.js.map +1 -1
  49. package/dist-client/pages/activity-thread/activity-thread-view.js +4 -0
  50. package/dist-client/pages/activity-thread/activity-thread-view.js.map +1 -1
  51. package/dist-client/pages/dashboard/dashboard-home.js +3 -5
  52. package/dist-client/pages/dashboard/dashboard-home.js.map +1 -1
  53. package/dist-client/pages/installable-activity/installable-activity-list-page.d.ts +0 -6
  54. package/dist-client/pages/installable-activity/installable-activity-list-page.js +68 -130
  55. package/dist-client/pages/installable-activity/installable-activity-list-page.js.map +1 -1
  56. package/dist-client/pages/todo/approval-done-list-page.d.ts +1 -7
  57. package/dist-client/pages/todo/approval-done-list-page.js +53 -100
  58. package/dist-client/pages/todo/approval-done-list-page.js.map +1 -1
  59. package/dist-client/pages/todo/approval-pending-list-page.d.ts +0 -6
  60. package/dist-client/pages/todo/approval-pending-list-page.js +63 -119
  61. package/dist-client/pages/todo/approval-pending-list-page.js.map +1 -1
  62. package/dist-client/pages/todo/done-list-calendar-page.d.ts +1 -7
  63. package/dist-client/pages/todo/done-list-calendar-page.js +2 -3
  64. package/dist-client/pages/todo/done-list-calendar-page.js.map +1 -1
  65. package/dist-client/pages/todo/done-list-page.d.ts +1 -7
  66. package/dist-client/pages/todo/done-list-page.js +56 -106
  67. package/dist-client/pages/todo/done-list-page.js.map +1 -1
  68. package/dist-client/pages/todo/draft-list-page.d.ts +1 -7
  69. package/dist-client/pages/todo/draft-list-page.js +49 -88
  70. package/dist-client/pages/todo/draft-list-page.js.map +1 -1
  71. package/dist-client/pages/todo/pickable-list-page.d.ts +1 -7
  72. package/dist-client/pages/todo/pickable-list-page.js +48 -91
  73. package/dist-client/pages/todo/pickable-list-page.js.map +1 -1
  74. package/dist-client/pages/todo/todo-list-page.d.ts +0 -6
  75. package/dist-client/pages/todo/todo-list-page.js +56 -106
  76. package/dist-client/pages/todo/todo-list-page.js.map +1 -1
  77. package/dist-client/pages/worklist-home.js +2 -3
  78. package/dist-client/pages/worklist-home.js.map +1 -1
  79. package/dist-client/route.d.ts +1 -1
  80. package/dist-client/templates/activity-approval-context-template.js +8 -12
  81. package/dist-client/templates/activity-approval-context-template.js.map +1 -1
  82. package/dist-client/templates/activity-instance-context-template.js +8 -12
  83. package/dist-client/templates/activity-instance-context-template.js.map +1 -1
  84. package/dist-client/templates/activity-thread-context-template.js +8 -12
  85. package/dist-client/templates/activity-thread-context-template.js.map +1 -1
  86. package/dist-client/tsconfig.tsbuildinfo +1 -1
  87. package/dist-server/controllers/activity-approval/approve.js +2 -2
  88. package/dist-server/controllers/activity-approval/approve.js.map +1 -1
  89. package/dist-server/controllers/activity-thread/submit.js +2 -2
  90. package/dist-server/controllers/activity-thread/submit.js.map +1 -1
  91. package/dist-server/service/index.d.ts +2 -2
  92. package/dist-server/tsconfig.tsbuildinfo +1 -1
  93. package/package.json +16 -16
  94. package/spec/integration/approval-mixed-types.spec.ts +491 -0
  95. package/spec/integration/approval-role-based.spec.ts +389 -0
  96. package/spec/integration/instance-lifecycle.spec.ts +406 -0
  97. package/spec/integration/role-approval-edge-cases.spec.ts +581 -0
  98. package/spec/unit/controllers/activity-instance-issue.spec.ts +360 -0
  99. package/spec/unit/controllers/activity-thread-submit.spec.ts +384 -0
  100. package/spec/unit/role-approval-escalate-logic.spec.ts +499 -0
  101. package/spec/unit/role-approval-submit-logic.spec.ts +481 -0
  102. package/spec/unit/thread-state-helpers.spec.ts +253 -0
  103. package/translations/en.json +1 -1
@@ -4,18 +4,17 @@ import '../../components/activity-starter-form.js';
4
4
  import gql from 'graphql-tag';
5
5
  import { css, html } from 'lit';
6
6
  import { customElement, property, query } from 'lit/decorators.js';
7
- import { connect } from 'pwa-helpers/connect-mixin.js';
8
7
  import { DataGrist } from '@operato/data-grist';
9
8
  import { client } from '@operato/graphql';
10
9
  import { i18next, localize } from '@operato/i18n';
11
- import { navigate, PageView, store } from '@operato/shell';
10
+ import { navigate, PageView } from '@operato/shell';
12
11
  import { CommonHeaderStyles, ScrollbarStyles } from '@operato/styles';
13
12
  import { isMobileDevice } from '@operato/utils';
14
13
  import { ActivityStartingTypes } from '../../types/types.js';
15
14
  const MIN = 60;
16
15
  const HOUR = 60 * MIN;
17
16
  const DAY = 24 * HOUR;
18
- let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)(PageView)) {
17
+ let DraftListPage = class DraftListPage extends localize(i18next)(PageView) {
19
18
  constructor() {
20
19
  super(...arguments);
21
20
  this.mode = isMobileDevice() ? 'CARD' : 'GRID';
@@ -24,42 +23,34 @@ let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)
24
23
  ScrollbarStyles,
25
24
  CommonHeaderStyles,
26
25
  css `
27
- :host {
28
- display: flex;
26
+ :host { display: flex;
29
27
 
30
28
  width: 100%;
31
29
 
32
30
  --grid-record-emphasized-background-color: #8b0000;
33
31
  --grid-record-emphasized-color: #ff6b6b;
34
- }
32
+ }
35
33
 
36
- ox-grist {
37
- overflow-y: auto;
34
+ ox-grist { overflow-y: auto;
38
35
  flex: 1;
39
- }
36
+ }
40
37
 
41
- .header {
42
- grid-template-areas: 'filters actions';
43
- }
38
+ .header { grid-template-areas: 'filters actions';
39
+ }
44
40
  `
45
41
  ]; }
46
42
  get context() {
47
- return {
48
- title: i18next.t('title.draft list'),
49
- search: {
50
- handler: (search) => {
43
+ return { title: i18next.t('title.draft list'),
44
+ search: { handler: (search) => {
51
45
  this.grist.searchText = search;
52
46
  },
53
- value: this.grist?.searchText || ''
54
- },
55
- filter: {
56
- handler: () => {
47
+ value: this.grist?.searchText || '' },
48
+ filter: { handler: () => {
57
49
  this.grist.toggleHeadroom();
58
50
  }
59
51
  },
60
52
  help: 'worklist/draft-list-page',
61
- actions: []
62
- };
53
+ actions: [] };
63
54
  }
64
55
  render() {
65
56
  const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID');
@@ -70,23 +61,19 @@ let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)
70
61
  `;
71
62
  }
72
63
  async pageInitialized(lifecycle) {
73
- this.gristConfig = {
74
- list: {
75
- thumbnail: 'thumbnail',
64
+ this.gristConfig = { list: { thumbnail: 'thumbnail',
76
65
  fields: ['name', 'description'],
77
66
  details: ['createdAt', 'due']
78
67
  },
79
68
  columns: [
80
69
  { type: 'gutter', gutterName: 'sequence' },
81
- {
82
- type: 'gutter',
70
+ { type: 'gutter',
83
71
  gutterName: 'button',
84
72
  icon: 'edit_square',
85
73
  iconOnly: false,
86
74
  title: i18next.t('button.edit'),
87
75
  width: 72,
88
- handlers: {
89
- click: (columns, data, column, record, rowIndex) => {
76
+ handlers: { click: (columns, data, column, record, rowIndex) => {
90
77
  if (!record.id) {
91
78
  return;
92
79
  }
@@ -94,44 +81,36 @@ let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)
94
81
  }
95
82
  }
96
83
  },
97
- {
98
- type: 'string',
84
+ { type: 'string',
99
85
  name: 'name',
100
86
  header: i18next.t('field.name'),
101
- record: {
102
- editable: false
87
+ record: { editable: false
103
88
  },
104
89
  filter: 'search',
105
90
  sortable: true,
106
91
  width: 375
107
92
  },
108
- {
109
- type: 'string',
93
+ { type: 'string',
110
94
  name: 'description',
111
95
  header: i18next.t('field.description'),
112
- record: {
113
- editable: false
96
+ record: { editable: false
114
97
  },
115
98
  filter: 'search',
116
99
  width: 400
117
100
  },
118
- {
119
- type: 'select',
101
+ { type: 'select',
120
102
  name: 'startingType',
121
103
  label: true,
122
104
  header: i18next.t('field.starting-type'),
123
- record: {
124
- editable: false,
105
+ record: { editable: false,
125
106
  options: ActivityStartingTypes
126
107
  },
127
108
  width: 90
128
109
  },
129
- {
130
- type: 'select',
110
+ { type: 'select',
131
111
  name: 'state',
132
112
  header: i18next.t('field.status'),
133
- record: {
134
- editable: false,
113
+ record: { editable: false,
135
114
  options: [
136
115
  { display: i18next.t('label.activity-state-draft'), value: 'draft' },
137
116
  { display: i18next.t('label.activity-state-posted'), value: 'posted' },
@@ -146,29 +125,24 @@ let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)
146
125
  },
147
126
  width: 85
148
127
  },
149
- {
150
- type: 'datetime',
128
+ { type: 'datetime',
151
129
  name: 'updatedAt',
152
130
  header: i18next.t('field.updated-at'),
153
- record: {
154
- editable: false
131
+ record: { editable: false
155
132
  },
156
133
  sortable: true,
157
134
  width: 180
158
135
  },
159
- {
160
- type: 'image',
136
+ { type: 'image',
161
137
  name: 'thumbnail',
162
138
  header: i18next.t('field.thumbnail'),
163
139
  record: { editable: false },
164
140
  hidden: true
165
141
  }
166
142
  ],
167
- rows: {
168
- appendable: false,
143
+ rows: { appendable: false,
169
144
  editable: false,
170
- handlers: {
171
- click: (columns, data, column, record, rowIndex) => {
145
+ handlers: { click: (columns, data, column, record, rowIndex) => {
172
146
  if (!record.id) {
173
147
  return;
174
148
  }
@@ -177,8 +151,7 @@ let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)
177
151
  }
178
152
  },
179
153
  sorters: [
180
- {
181
- name: 'updatedAt',
154
+ { name: 'updatedAt',
182
155
  desc: true
183
156
  }
184
157
  ]
@@ -190,12 +163,8 @@ let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)
190
163
  }
191
164
  }
192
165
  async fetchHandler({ page, limit, sortings = [], filters = [] }) {
193
- const response = await client.query({
194
- query: gql `
195
- query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
196
- responses: draftList(filters: $filters, pagination: $pagination, sortings: $sortings) {
197
- items {
198
- id
166
+ const response = await client.query({ query: gql `
167
+ query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) { responses: draftList(filters: $filters, pagination: $pagination, sortings: $sortings) { items { id
199
168
  name
200
169
  description
201
170
  priority
@@ -203,31 +172,26 @@ let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)
203
172
  input
204
173
  output
205
174
  refBy
206
- activity {
207
- id
175
+ activity { id
208
176
  startingType
209
- }
177
+ }
210
178
  activityType
211
- assignees {
212
- type
179
+ assignees { type
213
180
  value
214
- assignee {
215
- id
181
+ assignee { id
216
182
  name
217
183
  description
218
184
  controlNo
219
- }
220
- }
221
- approvalLine {
222
- type
185
+ }
186
+ }
187
+ approvalLine { type
223
188
  value
224
- approver {
225
- id
189
+ approver { id
226
190
  name
227
191
  description
228
192
  controlNo
229
- }
230
- }
193
+ }
194
+ }
231
195
  threadsMin
232
196
  threadsMax
233
197
  uiType
@@ -236,23 +200,20 @@ let DraftListPage = class DraftListPage extends connect(store)(localize(i18next)
236
200
  thumbnail
237
201
  updatedAt
238
202
  createdAt
239
- creator {
240
- id
203
+ creator { id
241
204
  name
242
- }
243
- }
205
+ }
206
+ }
244
207
  total
245
- }
246
- }
208
+ }
209
+ }
247
210
  `,
248
- variables: {
249
- filters,
211
+ variables: { filters,
250
212
  pagination: { page, limit },
251
213
  sortings
252
214
  }
253
215
  });
254
- return {
255
- total: response.data.responses.total || 0,
216
+ return { total: response.data.responses.total || 0,
256
217
  records: response.data.responses.items.map(item => {
257
218
  item['startingType'] = item.activity?.startingType;
258
219
  return item;
@@ -1 +1 @@
1
- {"version":3,"file":"draft-list-page.js","sourceRoot":"","sources":["../../../client/pages/todo/draft-list-page.ts"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\nimport '../../components/activity-starter-form.js'\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 { DataGrist, FetchOption } from '@operato/data-grist'\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { navigate, PageView, store } from '@operato/shell'\nimport { CommonHeaderStyles, ScrollbarStyles } from '@operato/styles'\nimport { isMobileDevice } from '@operato/utils'\nimport { OxPopup } from '@operato/popup'\n\nimport { ActivityStartingTypes } from '../../types/types.js'\n\nconst MIN = 60\nconst HOUR = 60 * MIN\nconst DAY = 24 * HOUR\n\n@customElement('draft-list-page')\nexport class DraftListPage 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 .header {\n grid-template-areas: 'filters actions';\n }\n `\n ]\n\n @property({ type: Object }) gristConfig?: any\n @property({ type: String }) mode: 'GRID' | 'LIST' | 'CARD' = isMobileDevice() ? 'CARD' : 'GRID'\n\n @query('ox-grist') grist!: DataGrist\n\n get context() {\n return {\n title: i18next.t('title.draft 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/draft-list-page',\n actions: []\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\"></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: ['createdAt', 'due']\n },\n columns: [\n { type: 'gutter', gutterName: 'sequence' },\n {\n type: 'gutter',\n gutterName: 'button',\n icon: 'edit_square',\n iconOnly: false,\n title: i18next.t('button.edit'),\n width: 72,\n handlers: {\n click: (columns, data, column, record, rowIndex) => {\n if (!record.id) {\n return\n }\n\n this.openActivityInstanceStart(record)\n }\n }\n },\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: 375\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: 400\n },\n {\n type: 'select',\n name: 'startingType',\n label: true,\n header: i18next.t('field.starting-type'),\n record: {\n editable: false,\n options: ActivityStartingTypes\n },\n width: 90\n },\n {\n type: 'select',\n name: 'state',\n header: i18next.t('field.status'),\n record: {\n editable: false,\n options: [\n { display: i18next.t('label.activity-state-draft'), value: 'draft' },\n { display: i18next.t('label.activity-state-posted'), value: 'posted' },\n { display: i18next.t('label.activity-state-unassigned'), value: 'unassigned' },\n { display: i18next.t('label.activity-state-assigned'), value: 'assigned' },\n { display: i18next.t('label.activity-state-started'), value: 'started' },\n { display: i18next.t('label.activity-state-pending'), value: 'pending' },\n { display: i18next.t('label.activity-state-escalated'), value: 'escalated' },\n { display: i18next.t('label.activity-state-ended'), value: 'ended' },\n { display: i18next.t('label.activity-state-aborted'), value: 'aborted' }\n ]\n },\n width: 85\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 appendable: false,\n editable: false,\n handlers: {\n click: (columns, data, column, record, rowIndex) => {\n if (!record.id) {\n return\n }\n\n this.openActivityInstanceStart(record)\n }\n }\n },\n sorters: [\n {\n name: 'updatedAt',\n desc: true\n }\n ]\n }\n }\n\n async pageUpdated(changes, lifecycle, changedBefore) {\n if (this.active) {\n this.grist?.fetch()\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: draftList(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n description\n priority\n state\n input\n output\n refBy\n activity {\n id\n startingType\n }\n activityType\n assignees {\n type\n value\n assignee {\n id\n name\n description\n controlNo\n }\n }\n approvalLine {\n type\n value\n approver {\n id\n name\n description\n controlNo\n }\n }\n threadsMin\n threadsMax\n uiType\n uiSource\n dueAt\n thumbnail\n updatedAt\n createdAt\n creator {\n id\n name\n }\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:\n response.data.responses.items.map(item => {\n item['startingType'] = item.activity?.startingType\n return item\n }) || []\n }\n }\n\n openActivityInstanceStart(activityInstance) {\n navigate(`activity-instance-start/${activityInstance.id}?title=${activityInstance.name}`)\n }\n}\n"]}
1
+ {"version":3,"file":"draft-list-page.js","sourceRoot":"","sources":["../../../client/pages/todo/draft-list-page.ts"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\nimport '../../components/activity-starter-form.js'\n\nimport gql from 'graphql-tag'\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 { navigate, PageView } from '@operato/shell'\nimport { CommonHeaderStyles, ScrollbarStyles } from '@operato/styles'\nimport { isMobileDevice } from '@operato/utils'\nimport { OxPopup } from '@operato/popup'\n\nimport { ActivityStartingTypes } from '../../types/types.js'\n\nconst MIN = 60\nconst HOUR = 60 * MIN\nconst DAY = 24 * HOUR\n\n@customElement('draft-list-page')\nexport class DraftListPage extends localize(i18next)(PageView) { static styles = [\n ScrollbarStyles,\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 .header { grid-template-areas: 'filters actions';\n }\n `\n ]\n\n @property({ type: Object }) gristConfig?: any\n @property({ type: String }) mode: 'GRID' | 'LIST' | 'CARD' = isMobileDevice() ? 'CARD' : 'GRID'\n\n @query('ox-grist') grist!: DataGrist\n\n get context() { return { title: i18next.t('title.draft list'),\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: 'worklist/draft-list-page',\n actions: []\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\"></div>\n </ox-grist>\n `\n }\n\n async pageInitialized(lifecycle) { this.gristConfig = { list: { thumbnail: 'thumbnail',\n fields: ['name', 'description'],\n details: ['createdAt', 'due']\n },\n columns: [\n { type: 'gutter', gutterName: 'sequence' },\n { type: 'gutter',\n gutterName: 'button',\n icon: 'edit_square',\n iconOnly: false,\n title: i18next.t('button.edit'),\n width: 72,\n handlers: { click: (columns, data, column, record, rowIndex) => { if (!record.id) { return\n }\n\n this.openActivityInstanceStart(record)\n }\n }\n },\n { type: 'string',\n name: 'name',\n header: i18next.t('field.name'),\n record: { editable: false\n },\n filter: 'search',\n sortable: true,\n width: 375\n },\n { type: 'string',\n name: 'description',\n header: i18next.t('field.description'),\n record: { editable: false\n },\n filter: 'search',\n width: 400\n },\n { type: 'select',\n name: 'startingType',\n label: true,\n header: i18next.t('field.starting-type'),\n record: { editable: false,\n options: ActivityStartingTypes\n },\n width: 90\n },\n { type: 'select',\n name: 'state',\n header: i18next.t('field.status'),\n record: { editable: false,\n options: [\n { display: i18next.t('label.activity-state-draft'), value: 'draft' },\n { display: i18next.t('label.activity-state-posted'), value: 'posted' },\n { display: i18next.t('label.activity-state-unassigned'), value: 'unassigned' },\n { display: i18next.t('label.activity-state-assigned'), value: 'assigned' },\n { display: i18next.t('label.activity-state-started'), value: 'started' },\n { display: i18next.t('label.activity-state-pending'), value: 'pending' },\n { display: i18next.t('label.activity-state-escalated'), value: 'escalated' },\n { display: i18next.t('label.activity-state-ended'), value: 'ended' },\n { display: i18next.t('label.activity-state-aborted'), value: 'aborted' }\n ]\n },\n width: 85\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 { type: 'image',\n name: 'thumbnail',\n header: i18next.t('field.thumbnail'),\n record: { editable: false },\n hidden: true\n }\n ],\n rows: { appendable: false,\n editable: false,\n handlers: { click: (columns, data, column, record, rowIndex) => { if (!record.id) { return\n }\n\n this.openActivityInstanceStart(record)\n }\n }\n },\n sorters: [\n { name: 'updatedAt',\n desc: true\n }\n ]\n }\n }\n\n async pageUpdated(changes, lifecycle, changedBefore) { if (this.active) { this.grist?.fetch()\n }\n }\n\n async fetchHandler({ page, limit, sortings = [], filters = [] }: FetchOption) { const response = await client.query({ query: gql`\n query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) { responses: draftList(filters: $filters, pagination: $pagination, sortings: $sortings) { items { id\n name\n description\n priority\n state\n input\n output\n refBy\n activity { id\n startingType\n }\n activityType\n assignees { type\n value\n assignee { id\n name\n description\n controlNo\n }\n }\n approvalLine { type\n value\n approver { id\n name\n description\n controlNo\n }\n }\n threadsMin\n threadsMax\n uiType\n uiSource\n dueAt\n thumbnail\n updatedAt\n createdAt\n creator { id\n name\n }\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:\n response.data.responses.items.map(item => { item['startingType'] = item.activity?.startingType\n return item\n }) || []\n }\n }\n\n openActivityInstanceStart(activityInstance) { navigate(`activity-instance-start/${activityInstance.id}?title=${activityInstance.name}`)\n }\n}\n"]}
@@ -4,13 +4,7 @@ import '@operato/context/ox-context-page-toolbar.js';
4
4
  import '../../components/activity-instance-preview.js';
5
5
  import { DataGrist, FetchOption } from '@operato/data-grist';
6
6
  import { PageView } from '@operato/shell';
7
- declare const PickableListPage_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[]) => import("lit").LitElement) & typeof PageView;
7
+ declare const PickableListPage_base: (new (...args: any[]) => import("lit").LitElement) & typeof PageView;
14
8
  export declare class PickableListPage extends PickableListPage_base {
15
9
  static styles: import("lit").CSSResult[];
16
10
  gristConfig?: any;
@@ -6,15 +6,14 @@ import '../../components/activity-instance-preview.js';
6
6
  import gql from 'graphql-tag';
7
7
  import { css, html } from 'lit';
8
8
  import { customElement, property, query, state } from 'lit/decorators.js';
9
- import { connect } from 'pwa-helpers/connect-mixin.js';
10
9
  import { DataGrist, getRenderer } from '@operato/data-grist';
11
10
  import { client } from '@operato/graphql';
12
11
  import { i18next, localize } from '@operato/i18n';
13
12
  import { openPopup } from '@operato/popup';
14
- import { PageView, store } from '@operato/shell';
13
+ import { PageView } from '@operato/shell';
15
14
  import { CommonHeaderStyles, ScrollbarStyles } from '@operato/styles';
16
15
  import { adjustFilters, isMobileDevice } from '@operato/utils';
17
- let PickableListPage = class PickableListPage extends connect(store)(localize(i18next)(PageView)) {
16
+ let PickableListPage = class PickableListPage extends localize(i18next)(PageView) {
18
17
  constructor() {
19
18
  super(...arguments);
20
19
  this.mode = isMobileDevice() ? 'CARD' : 'GRID';
@@ -23,43 +22,35 @@ let PickableListPage = class PickableListPage extends connect(store)(localize(i1
23
22
  ScrollbarStyles,
24
23
  CommonHeaderStyles,
25
24
  css `
26
- :host {
27
- display: flex;
25
+ :host { display: flex;
28
26
 
29
27
  width: 100%;
30
28
 
31
29
  --grid-record-emphasized-background-color: #8b0000;
32
30
  --grid-record-emphasized-color: #ff6b6b;
33
- }
31
+ }
34
32
 
35
- ox-grist {
36
- overflow-y: auto;
33
+ ox-grist { overflow-y: auto;
37
34
  flex: 1;
38
- }
35
+ }
39
36
 
40
- .header {
41
- grid-template-areas: 'filters actions';
42
- }
37
+ .header { grid-template-areas: 'filters actions';
38
+ }
43
39
  `
44
40
  ]; }
45
41
  get context() {
46
- return {
47
- title: i18next.t('title.activity shopping'),
48
- search: {
49
- handler: (search) => {
42
+ return { title: i18next.t('title.activity shopping'),
43
+ search: { handler: (search) => {
50
44
  this.grist.searchText = search;
51
45
  },
52
- value: this.grist?.searchText || ''
53
- },
54
- filter: {
55
- handler: () => {
46
+ value: this.grist?.searchText || '' },
47
+ filter: { handler: () => {
56
48
  this.grist.toggleHeadroom();
57
49
  }
58
50
  },
59
51
  help: 'worklist/activity-bank-page',
60
52
  actions: [],
61
- toolbar: false
62
- };
53
+ toolbar: false };
63
54
  }
64
55
  render() {
65
56
  const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID');
@@ -70,12 +61,10 @@ let PickableListPage = class PickableListPage extends connect(store)(localize(i1
70
61
  <ox-input-select-buttons
71
62
  .value=${this.filters}
72
63
  .options=${[
73
- {
74
- display: i18next.t('label.filter-important'),
64
+ { display: i18next.t('label.filter-important'),
75
65
  value: 'important'
76
66
  },
77
- {
78
- display: i18next.t('label.filter-due'),
67
+ { display: i18next.t('label.filter-due'),
79
68
  value: 'due'
80
69
  }
81
70
  ]}
@@ -93,28 +82,23 @@ let PickableListPage = class PickableListPage extends connect(store)(localize(i1
93
82
  `;
94
83
  }
95
84
  async pageInitialized(lifecycle) {
96
- this.gristConfig = {
97
- list: {
98
- thumbnail: 'thumbnail',
85
+ this.gristConfig = { list: { thumbnail: 'thumbnail',
99
86
  fields: ['name', 'description'],
100
87
  details: ['createdAt', 'due']
101
88
  },
102
89
  columns: [
103
90
  { type: 'gutter', gutterName: 'sequence' },
104
- {
105
- type: 'gutter',
91
+ { type: 'gutter',
106
92
  gutterName: 'button',
107
93
  icon: 'shop',
108
94
  iconOnly: false,
109
95
  title: i18next.t('button.view'),
110
96
  width: 72,
111
- handlers: {
112
- click: (columns, data, column, record, rowIndex) => {
97
+ handlers: { click: (columns, data, column, record, rowIndex) => {
113
98
  if (!record.id) {
114
99
  return;
115
100
  }
116
- const popup = openPopup(html ` <activity-instance-preview .activityInstanceId=${record.id}></activity-instance-preview> `, {
117
- backdrop: true,
101
+ const popup = openPopup(html ` <activity-instance-preview .activityInstanceId=${record.id}></activity-instance-preview> `, { backdrop: true,
118
102
  help: 'worklist/activity-instance-preview',
119
103
  size: 'large',
120
104
  title: i18next.t('title.activity preview')
@@ -125,33 +109,27 @@ let PickableListPage = class PickableListPage extends connect(store)(localize(i1
125
109
  }
126
110
  }
127
111
  },
128
- {
129
- type: 'string',
112
+ { type: 'string',
130
113
  name: 'name',
131
114
  header: i18next.t('field.name'),
132
- record: {
133
- editable: false
115
+ record: { editable: false
134
116
  },
135
117
  filter: 'search',
136
118
  sortable: true,
137
119
  width: 225
138
120
  },
139
- {
140
- type: 'string',
121
+ { type: 'string',
141
122
  name: 'description',
142
123
  header: i18next.t('field.description'),
143
- record: {
144
- editable: false
124
+ record: { editable: false
145
125
  },
146
126
  filter: 'search',
147
127
  width: 275
148
128
  },
149
- {
150
- type: 'string',
129
+ { type: 'string',
151
130
  name: 'uiSource',
152
131
  header: i18next.t('field.ui-source'),
153
- record: {
154
- editable: false,
132
+ record: { editable: false,
155
133
  renderer: function (value, column, record, rowIndex, field) {
156
134
  const { uiType, uiSource } = record.activity || {};
157
135
  var type = uiType !== 'board' ? 'string' : 'board';
@@ -161,64 +139,52 @@ let PickableListPage = class PickableListPage extends connect(store)(localize(i1
161
139
  width: 140,
162
140
  hidden: true
163
141
  },
164
- {
165
- type: 'resource-object',
142
+ { type: 'resource-object',
166
143
  name: 'creator',
167
144
  header: i18next.t('field.creator'),
168
- record: {
169
- editable: false
145
+ record: { editable: false
170
146
  },
171
147
  sortable: true,
172
148
  width: 85
173
149
  },
174
- {
175
- type: 'datetime',
150
+ { type: 'datetime',
176
151
  name: 'dueAt',
177
152
  header: i18next.t('field.due-at'),
178
- record: {
179
- editable: false
153
+ record: { editable: false
180
154
  },
181
155
  sortable: true,
182
156
  width: 180
183
157
  },
184
- {
185
- type: 'datetime',
158
+ { type: 'datetime',
186
159
  name: 'updatedAt',
187
160
  header: i18next.t('field.updated_at'),
188
- record: {
189
- editable: false
161
+ record: { editable: false
190
162
  },
191
163
  sortable: true,
192
164
  width: 180
193
165
  },
194
- {
195
- type: 'datetime',
166
+ { type: 'datetime',
196
167
  name: 'createdAt',
197
168
  header: i18next.t('field.created_at'),
198
- record: {
199
- editable: false
169
+ record: { editable: false
200
170
  },
201
171
  sortable: true,
202
172
  width: 180
203
173
  },
204
- {
205
- type: 'image',
174
+ { type: 'image',
206
175
  name: 'thumbnail',
207
176
  header: i18next.t('field.thumbnail'),
208
177
  record: { editable: false },
209
178
  hidden: true
210
179
  }
211
180
  ],
212
- rows: {
213
- appendable: false,
181
+ rows: { appendable: false,
214
182
  editable: false,
215
- handlers: {
216
- click: (columns, data, column, record, rowIndex) => {
183
+ handlers: { click: (columns, data, column, record, rowIndex) => {
217
184
  if (!record.id) {
218
185
  return;
219
186
  }
220
- const popup = openPopup(html ` <activity-instance-preview .activityInstanceId=${record.id}></activity-instance-preview> `, {
221
- backdrop: true,
187
+ const popup = openPopup(html ` <activity-instance-preview .activityInstanceId=${record.id}></activity-instance-preview> `, { backdrop: true,
222
188
  help: 'worklist/activity-instance-preview',
223
189
  size: 'large',
224
190
  title: i18next.t('title.activity preview')
@@ -230,8 +196,7 @@ let PickableListPage = class PickableListPage extends connect(store)(localize(i1
230
196
  }
231
197
  },
232
198
  sorters: [
233
- {
234
- name: 'name'
199
+ { name: 'name'
235
200
  }
236
201
  ]
237
202
  };
@@ -245,17 +210,12 @@ let PickableListPage = class PickableListPage extends connect(store)(localize(i1
245
210
  if (this.filters?.includes('important')) {
246
211
  filters = adjustFilters(filters, [{ name: 'priority', operator: 'gte', value: 2 }]);
247
212
  }
248
- if (this.filters?.includes('due')) {
249
- /* 24시간 이내에 만기가 도래하는 작업 */
213
+ if (this.filters?.includes('due')) { /* 24시간 이내에 만기가 도래하는 작업 */
250
214
  let tomorrow = new Date(Date.now() + 24 * 3600 * 1000).toISOString().replace('T', ' ');
251
215
  filters = adjustFilters(filters, [{ name: 'dueAt', operator: 'lte', value: tomorrow }]);
252
216
  }
253
- const response = await client.query({
254
- query: gql `
255
- query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
256
- responses: pickableActivityList(filters: $filters, pagination: $pagination, sortings: $sortings) {
257
- items {
258
- id
217
+ const response = await client.query({ query: gql `
218
+ query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) { responses: pickableActivityList(filters: $filters, pagination: $pagination, sortings: $sortings) { items { id
259
219
  name
260
220
  description
261
221
  priority
@@ -271,23 +231,20 @@ let PickableListPage = class PickableListPage extends connect(store)(localize(i1
271
231
  thumbnail
272
232
  updatedAt
273
233
  createdAt
274
- creator {
275
- id
234
+ creator { id
276
235
  name
277
- }
278
- }
236
+ }
237
+ }
279
238
  total
280
- }
281
- }
239
+ }
240
+ }
282
241
  `,
283
- variables: {
284
- filters,
242
+ variables: { filters,
285
243
  pagination: { page, limit },
286
244
  sortings
287
245
  }
288
246
  });
289
- return {
290
- total: response.data.responses.total || 0,
247
+ return { total: response.data.responses.total || 0,
291
248
  records: response.data.responses.items || []
292
249
  };
293
250
  }