@things-factory/worklist 5.0.7 → 5.0.13

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 (255) hide show
  1. package/client/{bootstrap.js → bootstrap.ts} +0 -0
  2. package/client/components/activity-/bowner-view.js +0 -1
  3. package/client/components/activity-instance-preview.js +1 -2
  4. package/client/components/{activity-intro-view.js → activity-intro-view.ts} +29 -42
  5. package/client/components/activity-reporter-view.js +0 -1
  6. package/client/components/activity-starter-form.js +2 -3
  7. package/client/{index.js → index.ts} +0 -0
  8. package/client/pages/activity/{activity-list-page.js → activity-list-page.ts} +26 -36
  9. package/client/pages/activity/activity-model-item-list.js +4 -1
  10. package/client/pages/activity/activity-page.js +2 -3
  11. package/client/pages/activity/starter-list-page.js +1 -1
  12. package/client/pages/activity-instance/activity-instance-list-page.js +1 -1
  13. package/client/pages/activity-instance/activity-instance-page.js +2 -2
  14. package/client/pages/activity-store/activity-store-page.js +1 -1
  15. package/client/pages/activity-supervisor/reporter-list-page.js +1 -1
  16. package/client/pages/activity-template/activity-template-list-page.js +1 -1
  17. package/client/pages/activity-thread/activity-thread-list-page.js +1 -1
  18. package/client/pages/activity-thread/activity-thread-page.js +2 -2
  19. package/client/pages/todo/assigned-list-page.js +1 -1
  20. package/client/pages/todo/draft-list-page.js +4 -2
  21. package/client/pages/todo/pickable-list-page.js +2 -2
  22. package/client/pages/todo/todo-list-page.js +2 -2
  23. package/client/pages/{worklist-home.js → worklist-home.ts} +2 -6
  24. package/client/{route.js → route.ts} +1 -1
  25. package/client/tsconfig.json +11 -0
  26. package/dist-client/bootstrap.d.ts +1 -0
  27. package/dist-client/bootstrap.js +12 -0
  28. package/dist-client/bootstrap.js.map +1 -0
  29. package/dist-client/components/activity-/bowner-view.d.ts +1 -0
  30. package/dist-client/components/activity-/bowner-view.js +96 -0
  31. package/dist-client/components/activity-/bowner-view.js.map +1 -0
  32. package/dist-client/components/activity-instance-preview.d.ts +1 -0
  33. package/dist-client/components/activity-instance-preview.js +180 -0
  34. package/dist-client/components/activity-instance-preview.js.map +1 -0
  35. package/dist-client/components/activity-intro-view.d.ts +1 -0
  36. package/dist-client/components/activity-intro-view.js +104 -0
  37. package/dist-client/components/activity-intro-view.js.map +1 -0
  38. package/dist-client/components/activity-reporter-view.d.ts +1 -0
  39. package/dist-client/components/activity-reporter-view.js +96 -0
  40. package/dist-client/components/activity-reporter-view.js.map +1 -0
  41. package/dist-client/components/activity-starter-form.d.ts +1 -0
  42. package/dist-client/components/activity-starter-form.js +293 -0
  43. package/dist-client/components/activity-starter-form.js.map +1 -0
  44. package/dist-client/index.d.ts +1 -0
  45. package/dist-client/index.js +2 -0
  46. package/dist-client/index.js.map +1 -0
  47. package/dist-client/pages/activity/activity-list-page.d.ts +47 -0
  48. package/dist-client/pages/activity/activity-list-page.js +479 -0
  49. package/dist-client/pages/activity/activity-list-page.js.map +1 -0
  50. package/dist-client/pages/activity/activity-model-item-list.d.ts +194 -0
  51. package/dist-client/pages/activity/activity-model-item-list.js +288 -0
  52. package/dist-client/pages/activity/activity-model-item-list.js.map +1 -0
  53. package/dist-client/pages/activity/activity-page.d.ts +49 -0
  54. package/dist-client/pages/activity/activity-page.js +367 -0
  55. package/dist-client/pages/activity/activity-page.js.map +1 -0
  56. package/dist-client/pages/activity/starter-list-page.d.ts +143 -0
  57. package/dist-client/pages/activity/starter-list-page.js +209 -0
  58. package/dist-client/pages/activity/starter-list-page.js.map +1 -0
  59. package/dist-client/pages/activity-instance/activity-instance-list-page.d.ts +137 -0
  60. package/dist-client/pages/activity-instance/activity-instance-list-page.js +202 -0
  61. package/dist-client/pages/activity-instance/activity-instance-list-page.js.map +1 -0
  62. package/dist-client/pages/activity-instance/activity-instance-page.d.ts +49 -0
  63. package/dist-client/pages/activity-instance/activity-instance-page.js +365 -0
  64. package/dist-client/pages/activity-instance/activity-instance-page.js.map +1 -0
  65. package/dist-client/pages/activity-store/activity-store-page.d.ts +174 -0
  66. package/dist-client/pages/activity-store/activity-store-page.js +211 -0
  67. package/dist-client/pages/activity-store/activity-store-page.js.map +1 -0
  68. package/dist-client/pages/activity-supervisor/reporter-list-page.d.ts +143 -0
  69. package/dist-client/pages/activity-supervisor/reporter-list-page.js +209 -0
  70. package/dist-client/pages/activity-supervisor/reporter-list-page.js.map +1 -0
  71. package/dist-client/pages/activity-template/activity-template-importer.d.ts +24 -0
  72. package/dist-client/pages/activity-template/activity-template-importer.js +98 -0
  73. package/dist-client/pages/activity-template/activity-template-importer.js.map +1 -0
  74. package/dist-client/pages/activity-template/activity-template-list-page.d.ts +263 -0
  75. package/dist-client/pages/activity-template/activity-template-list-page.js +402 -0
  76. package/dist-client/pages/activity-template/activity-template-list-page.js.map +1 -0
  77. package/dist-client/pages/activity-template/activity-template-model-item-list.d.ts +1 -0
  78. package/dist-client/pages/activity-template/activity-template-model-item-list.js +36 -0
  79. package/dist-client/pages/activity-template/activity-template-model-item-list.js.map +1 -0
  80. package/dist-client/pages/activity-thread/activity-thread-importer.d.ts +24 -0
  81. package/dist-client/pages/activity-thread/activity-thread-importer.js +98 -0
  82. package/dist-client/pages/activity-thread/activity-thread-importer.js.map +1 -0
  83. package/dist-client/pages/activity-thread/activity-thread-list-page.d.ts +145 -0
  84. package/dist-client/pages/activity-thread/activity-thread-list-page.js +284 -0
  85. package/dist-client/pages/activity-thread/activity-thread-list-page.js.map +1 -0
  86. package/dist-client/pages/activity-thread/activity-thread-page.d.ts +46 -0
  87. package/dist-client/pages/activity-thread/activity-thread-page.js +331 -0
  88. package/dist-client/pages/activity-thread/activity-thread-page.js.map +1 -0
  89. package/dist-client/pages/dashboard/dashboard-home.d.ts +1 -0
  90. package/dist-client/pages/dashboard/dashboard-home.js +17 -0
  91. package/dist-client/pages/dashboard/dashboard-home.js.map +1 -0
  92. package/dist-client/pages/todo/assigned-list-page.d.ts +124 -0
  93. package/dist-client/pages/todo/assigned-list-page.js +233 -0
  94. package/dist-client/pages/todo/assigned-list-page.js.map +1 -0
  95. package/dist-client/pages/todo/draft-list-page.d.ts +198 -0
  96. package/dist-client/pages/todo/draft-list-page.js +312 -0
  97. package/dist-client/pages/todo/draft-list-page.js.map +1 -0
  98. package/dist-client/pages/todo/pickable-list-page.d.ts +150 -0
  99. package/dist-client/pages/todo/pickable-list-page.js +260 -0
  100. package/dist-client/pages/todo/pickable-list-page.js.map +1 -0
  101. package/dist-client/pages/todo/todo-list-page.d.ts +232 -0
  102. package/dist-client/pages/todo/todo-list-page.js +333 -0
  103. package/dist-client/pages/todo/todo-list-page.js.map +1 -0
  104. package/dist-client/pages/worklist-home.d.ts +1 -0
  105. package/dist-client/pages/worklist-home.js +18 -0
  106. package/dist-client/pages/worklist-home.js.map +1 -0
  107. package/dist-client/route.d.ts +1 -0
  108. package/dist-client/route.js +53 -0
  109. package/dist-client/route.js.map +1 -0
  110. package/dist-client/tsconfig.tsbuildinfo +1 -0
  111. package/dist-client/types.d.ts +19 -0
  112. package/dist-client/types.js +37 -0
  113. package/dist-client/types.js.map +1 -0
  114. package/dist-server/controllers/activity-extension-controller.js.map +1 -1
  115. package/dist-server/controllers/activity-instance/abort.js +4 -5
  116. package/dist-server/controllers/activity-instance/abort.js.map +1 -1
  117. package/dist-server/controllers/activity-instance/adjust.js +3 -2
  118. package/dist-server/controllers/activity-instance/adjust.js.map +1 -1
  119. package/dist-server/controllers/activity-instance/assign.js +9 -25
  120. package/dist-server/controllers/activity-instance/assign.js.map +1 -1
  121. package/dist-server/controllers/activity-instance/delegate.js +5 -6
  122. package/dist-server/controllers/activity-instance/delegate.js.map +1 -1
  123. package/dist-server/controllers/activity-instance/draft.js +6 -7
  124. package/dist-server/controllers/activity-instance/draft.js.map +1 -1
  125. package/dist-server/controllers/activity-instance/end.js +5 -6
  126. package/dist-server/controllers/activity-instance/end.js.map +1 -1
  127. package/dist-server/controllers/activity-instance/index.js +11 -24
  128. package/dist-server/controllers/activity-instance/index.js.map +1 -1
  129. package/dist-server/controllers/activity-instance/pick.js +6 -6
  130. package/dist-server/controllers/activity-instance/pick.js.map +1 -1
  131. package/dist-server/controllers/activity-instance/post.js +10 -6
  132. package/dist-server/controllers/activity-instance/post.js.map +1 -1
  133. package/dist-server/controllers/activity-instance/start.js +3 -2
  134. package/dist-server/controllers/activity-instance/start.js.map +1 -1
  135. package/dist-server/controllers/activity-instance/terminate.js +5 -6
  136. package/dist-server/controllers/activity-instance/terminate.js.map +1 -1
  137. package/dist-server/controllers/activity-thread/abort.js +3 -4
  138. package/dist-server/controllers/activity-thread/abort.js.map +1 -1
  139. package/dist-server/controllers/activity-thread/adjust.js +2 -1
  140. package/dist-server/controllers/activity-thread/adjust.js.map +1 -1
  141. package/dist-server/controllers/activity-thread/delegate.js +4 -5
  142. package/dist-server/controllers/activity-thread/delegate.js.map +1 -1
  143. package/dist-server/controllers/activity-thread/end.js +4 -5
  144. package/dist-server/controllers/activity-thread/end.js.map +1 -1
  145. package/dist-server/controllers/activity-thread/index.js +8 -21
  146. package/dist-server/controllers/activity-thread/index.js.map +1 -1
  147. package/dist-server/controllers/activity-thread/save.js +2 -1
  148. package/dist-server/controllers/activity-thread/save.js.map +1 -1
  149. package/dist-server/controllers/activity-thread/start.js +4 -5
  150. package/dist-server/controllers/activity-thread/start.js.map +1 -1
  151. package/dist-server/controllers/activity-thread/terminate.js +3 -4
  152. package/dist-server/controllers/activity-thread/terminate.js.map +1 -1
  153. package/dist-server/controllers/common.js +23 -6
  154. package/dist-server/controllers/common.js.map +1 -1
  155. package/dist-server/controllers/index.js.map +1 -1
  156. package/dist-server/index.js +4 -17
  157. package/dist-server/index.js.map +1 -1
  158. package/dist-server/middlewares/index.js.map +1 -1
  159. package/dist-server/migrations/index.js.map +1 -1
  160. package/dist-server/routes.js +0 -1
  161. package/dist-server/routes.js.map +1 -1
  162. package/dist-server/service/activity/activity-history.js +68 -76
  163. package/dist-server/service/activity/activity-history.js.map +1 -1
  164. package/dist-server/service/activity/activity-model-type.js +51 -60
  165. package/dist-server/service/activity/activity-model-type.js.map +1 -1
  166. package/dist-server/service/activity/activity-mutation.js +39 -50
  167. package/dist-server/service/activity/activity-mutation.js.map +1 -1
  168. package/dist-server/service/activity/activity-query.js +61 -72
  169. package/dist-server/service/activity/activity-query.js.map +1 -1
  170. package/dist-server/service/activity/activity-type.js +91 -102
  171. package/dist-server/service/activity/activity-type.js.map +1 -1
  172. package/dist-server/service/activity/activity.js +68 -76
  173. package/dist-server/service/activity/activity.js.map +1 -1
  174. package/dist-server/service/activity/event-subscriber.js +2 -7
  175. package/dist-server/service/activity/event-subscriber.js.map +1 -1
  176. package/dist-server/service/activity/index.js.map +1 -1
  177. package/dist-server/service/activity-instance/activity-instance-history.js +81 -89
  178. package/dist-server/service/activity-instance/activity-instance-history.js.map +1 -1
  179. package/dist-server/service/activity-instance/activity-instance-mutation.js +71 -85
  180. package/dist-server/service/activity-instance/activity-instance-mutation.js.map +1 -1
  181. package/dist-server/service/activity-instance/activity-instance-query.js +67 -78
  182. package/dist-server/service/activity-instance/activity-instance-query.js.map +1 -1
  183. package/dist-server/service/activity-instance/activity-instance-subscription.js +8 -21
  184. package/dist-server/service/activity-instance/activity-instance-subscription.js.map +1 -1
  185. package/dist-server/service/activity-instance/activity-instance-type.js +106 -106
  186. package/dist-server/service/activity-instance/activity-instance-type.js.map +1 -1
  187. package/dist-server/service/activity-instance/activity-instance.js +85 -93
  188. package/dist-server/service/activity-instance/activity-instance.js.map +1 -1
  189. package/dist-server/service/activity-instance/event-subscriber.js +3 -8
  190. package/dist-server/service/activity-instance/event-subscriber.js.map +1 -1
  191. package/dist-server/service/activity-instance/index.js.map +1 -1
  192. package/dist-server/service/activity-template/activity-template-history.js +50 -58
  193. package/dist-server/service/activity-template/activity-template-history.js.map +1 -1
  194. package/dist-server/service/activity-template/activity-template-mutation.js +39 -50
  195. package/dist-server/service/activity-template/activity-template-mutation.js.map +1 -1
  196. package/dist-server/service/activity-template/activity-template-query.js +48 -45
  197. package/dist-server/service/activity-template/activity-template-query.js.map +1 -1
  198. package/dist-server/service/activity-template/activity-template-type.js +65 -76
  199. package/dist-server/service/activity-template/activity-template-type.js.map +1 -1
  200. package/dist-server/service/activity-template/activity-template.js +48 -56
  201. package/dist-server/service/activity-template/activity-template.js.map +1 -1
  202. package/dist-server/service/activity-template/event-subscriber.js +2 -7
  203. package/dist-server/service/activity-template/event-subscriber.js.map +1 -1
  204. package/dist-server/service/activity-template/index.js.map +1 -1
  205. package/dist-server/service/activity-thread/activity-thread-mutation.js +84 -95
  206. package/dist-server/service/activity-thread/activity-thread-mutation.js.map +1 -1
  207. package/dist-server/service/activity-thread/activity-thread-query.js +45 -56
  208. package/dist-server/service/activity-thread/activity-thread-query.js.map +1 -1
  209. package/dist-server/service/activity-thread/activity-thread-subscription.js +7 -20
  210. package/dist-server/service/activity-thread/activity-thread-subscription.js.map +1 -1
  211. package/dist-server/service/activity-thread/activity-thread-type.js +25 -34
  212. package/dist-server/service/activity-thread/activity-thread-type.js.map +1 -1
  213. package/dist-server/service/activity-thread/activity-thread.js +43 -51
  214. package/dist-server/service/activity-thread/activity-thread.js.map +1 -1
  215. package/dist-server/service/activity-thread/event-subscriber.js +5 -10
  216. package/dist-server/service/activity-thread/event-subscriber.js.map +1 -1
  217. package/dist-server/service/activity-thread/index.js.map +1 -1
  218. package/dist-server/service/index.js +5 -18
  219. package/dist-server/service/index.js.map +1 -1
  220. package/dist-server/tsconfig.tsbuildinfo +1 -0
  221. package/package.json +13 -11
  222. package/server/controllers/activity-instance/abort.ts +5 -10
  223. package/server/controllers/activity-instance/adjust.ts +5 -7
  224. package/server/controllers/activity-instance/assign.ts +13 -45
  225. package/server/controllers/activity-instance/delegate.ts +6 -8
  226. package/server/controllers/activity-instance/draft.ts +7 -13
  227. package/server/controllers/activity-instance/end.ts +6 -9
  228. package/server/controllers/activity-instance/pick.ts +12 -9
  229. package/server/controllers/activity-instance/post.ts +14 -12
  230. package/server/controllers/activity-instance/start.ts +5 -3
  231. package/server/controllers/activity-instance/terminate.ts +6 -8
  232. package/server/controllers/activity-thread/abort.ts +3 -9
  233. package/server/controllers/activity-thread/adjust.ts +3 -6
  234. package/server/controllers/activity-thread/delegate.ts +4 -7
  235. package/server/controllers/activity-thread/end.ts +4 -7
  236. package/server/controllers/activity-thread/save.ts +3 -6
  237. package/server/controllers/activity-thread/start.ts +4 -11
  238. package/server/controllers/activity-thread/terminate.ts +3 -7
  239. package/server/controllers/common.ts +33 -14
  240. package/server/routes.ts +0 -2
  241. package/server/service/activity/activity-model-type.ts +4 -4
  242. package/server/service/activity-instance/activity-instance-history.ts +2 -2
  243. package/server/service/activity-instance/activity-instance-mutation.ts +11 -15
  244. package/server/service/activity-instance/activity-instance-subscription.ts +1 -5
  245. package/server/service/activity-instance/activity-instance-type.ts +17 -11
  246. package/server/service/activity-instance/activity-instance.ts +2 -2
  247. package/server/service/activity-template/activity-template-query.ts +10 -0
  248. package/server/service/activity-thread/activity-thread-mutation.ts +7 -7
  249. package/server/service/activity-thread/activity-thread-subscription.ts +0 -4
  250. package/server/service/activity-thread/activity-thread-type.ts +1 -1
  251. package/server/service/activity-thread/activity-thread.ts +1 -1
  252. package/server/service/activity-thread/event-subscriber.ts +3 -3
  253. package/server/tsconfig.json +10 -0
  254. package/things-factory.config.js +2 -2
  255. package/tsconfig.json +0 -9
@@ -0,0 +1,209 @@
1
+ import '@operato/data-grist';
2
+ import '../../components/activity-starter-form.js';
3
+ import gql from 'graphql-tag';
4
+ import { css, html } from 'lit';
5
+ import { connect } from 'pwa-helpers/connect-mixin.js';
6
+ import { client } from '@operato/graphql';
7
+ import { i18next, localize } from '@operato/i18n';
8
+ import { openPopup } from '@operato/layout';
9
+ import { PageView, store } from '@operato/shell';
10
+ import { CommonGristStyles, ScrollbarStyles } from '@operato/styles';
11
+ import { isMobileDevice } from '@operato/utils';
12
+ export class StarterListPage extends connect(store)(localize(i18next)(PageView)) {
13
+ static get properties() {
14
+ return {
15
+ gristConfig: Object,
16
+ mode: String
17
+ };
18
+ }
19
+ static get styles() {
20
+ return [
21
+ ScrollbarStyles,
22
+ CommonGristStyles,
23
+ css `
24
+ :host {
25
+ display: flex;
26
+
27
+ width: 100%;
28
+
29
+ --grid-record-emphasized-background-color: red;
30
+ --grid-record-emphasized-color: yellow;
31
+ }
32
+ `
33
+ ];
34
+ }
35
+ get context() {
36
+ return {
37
+ title: i18next.t('title.activity starter list'),
38
+ help: 'worklist/activity-starter-list'
39
+ };
40
+ }
41
+ render() {
42
+ const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID');
43
+ return html `
44
+ <ox-grist .mode=${mode} .config=${this.gristConfig} .fetchHandler=${this.fetchHandler.bind(this)}>
45
+ <div slot="headroom">
46
+ <div id="filters">
47
+ <ox-filters-form autofocus></ox-filters-form>
48
+ </div>
49
+
50
+ <div id="sorters">
51
+ Sort
52
+ <mwc-icon
53
+ @click=${e => {
54
+ const target = e.currentTarget;
55
+ this.renderRoot.querySelector('#sorter-control').open({
56
+ right: 0,
57
+ top: target.offsetTop + target.offsetHeight
58
+ });
59
+ }}
60
+ >expand_more</mwc-icon
61
+ >
62
+ <ox-popup id="sorter-control">
63
+ <ox-sorters-control> </ox-sorters-control>
64
+ </ox-popup>
65
+ </div>
66
+
67
+ <div id="modes">
68
+ <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>
69
+ <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>
70
+ <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>
71
+ </div>
72
+ </div>
73
+ </ox-grist>
74
+ `;
75
+ }
76
+ get grist() {
77
+ return this.renderRoot.querySelector('ox-grist');
78
+ }
79
+ async pageInitialized(lifecycle) {
80
+ this.gristConfig = {
81
+ list: {
82
+ thumbnail: 'thumbnail',
83
+ fields: ['name', 'description'],
84
+ details: ['updatedAt']
85
+ },
86
+ columns: [
87
+ { type: 'gutter', gutterName: 'sequence' },
88
+ {
89
+ type: 'gutter',
90
+ gutterName: 'button',
91
+ name: 'start',
92
+ icon: 'add_task',
93
+ handlers: {
94
+ click: (columns, data, column, record, rowIndex) => {
95
+ if (!record.id) {
96
+ return;
97
+ }
98
+ const popup = openPopup(html ` <activity-starter-form .activityId=${record.id}></activity-starter-form> `, {
99
+ backdrop: true,
100
+ help: 'worklist/activity-starter-form',
101
+ size: 'large',
102
+ title: i18next.t('title.activity starter')
103
+ });
104
+ popup.onclosed = () => {
105
+ this.grist.fetch();
106
+ };
107
+ }
108
+ }
109
+ },
110
+ {
111
+ type: 'string',
112
+ name: 'name',
113
+ header: i18next.t('field.name'),
114
+ filter: 'search',
115
+ sortable: true,
116
+ width: 150
117
+ },
118
+ {
119
+ type: 'string',
120
+ name: 'description',
121
+ header: i18next.t('field.description'),
122
+ filter: 'search',
123
+ width: 240
124
+ },
125
+ {
126
+ type: 'string',
127
+ name: 'activityType',
128
+ label: true,
129
+ header: i18next.t('field.activity-type'),
130
+ sortable: true,
131
+ // filter: {
132
+ // type: 'select',
133
+ // options: ActivityTypes
134
+ // },
135
+ width: 100
136
+ },
137
+ {
138
+ type: 'resource-object',
139
+ name: 'updater',
140
+ header: i18next.t('field.updater'),
141
+ sortable: true,
142
+ width: 120
143
+ },
144
+ {
145
+ type: 'datetime',
146
+ name: 'updatedAt',
147
+ header: i18next.t('field.updated_at'),
148
+ sortable: true,
149
+ width: 180
150
+ },
151
+ {
152
+ type: 'image',
153
+ name: 'thumbnail',
154
+ header: i18next.t('field.thumbnail'),
155
+ record: { editable: false },
156
+ hidden: true
157
+ }
158
+ ],
159
+ rows: {
160
+ appendable: false
161
+ },
162
+ sorters: [
163
+ {
164
+ name: 'name'
165
+ }
166
+ ]
167
+ };
168
+ }
169
+ async pageUpdated(changes, lifecycle, changedBefore) {
170
+ if (this.active) {
171
+ this.grist.fetch();
172
+ }
173
+ }
174
+ async fetchHandler({ page, limit, sortings = [], filters = [] }) {
175
+ const response = await client.query({
176
+ query: gql `
177
+ query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
178
+ responses: startableActivities(filters: $filters, pagination: $pagination, sortings: $sortings) {
179
+ items {
180
+ id
181
+ name
182
+ description
183
+ activityType
184
+ priority
185
+ thumbnail
186
+ updater {
187
+ id
188
+ name
189
+ }
190
+ updatedAt
191
+ }
192
+ total
193
+ }
194
+ }
195
+ `,
196
+ variables: {
197
+ filters,
198
+ pagination: { page, limit },
199
+ sortings
200
+ }
201
+ });
202
+ return {
203
+ total: response.data.responses.total || 0,
204
+ records: response.data.responses.items || []
205
+ };
206
+ }
207
+ }
208
+ window.customElements.define('starter-list-page', StarterListPage);
209
+ //# sourceMappingURL=starter-list-page.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"starter-list-page.js","sourceRoot":"","sources":["../../../client/pages/activity/starter-list-page.js"],"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 { connect } from 'pwa-helpers/connect-mixin.js'\n\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { openPopup } from '@operato/layout'\nimport { PageView, store } from '@operato/shell'\nimport { CommonGristStyles, ScrollbarStyles } from '@operato/styles'\nimport { isMobileDevice } from '@operato/utils'\n\nexport class StarterListPage extends connect(store)(localize(i18next)(PageView)) {\n static get properties() {\n return {\n gristConfig: Object,\n mode: String\n }\n }\n\n static get styles() {\n return [\n ScrollbarStyles,\n CommonGristStyles,\n css`\n :host {\n display: flex;\n\n width: 100%;\n\n --grid-record-emphasized-background-color: red;\n --grid-record-emphasized-color: yellow;\n }\n `\n ]\n }\n\n get context() {\n return {\n title: i18next.t('title.activity starter list'),\n help: 'worklist/activity-starter-list'\n }\n }\n\n render() {\n const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID')\n\n return html`\n <ox-grist .mode=${mode} .config=${this.gristConfig} .fetchHandler=${this.fetchHandler.bind(this)}>\n <div slot=\"headroom\">\n <div id=\"filters\">\n <ox-filters-form autofocus></ox-filters-form>\n </div>\n\n <div id=\"sorters\">\n Sort\n <mwc-icon\n @click=${e => {\n const target = e.currentTarget\n this.renderRoot.querySelector('#sorter-control').open({\n right: 0,\n top: target.offsetTop + target.offsetHeight\n })\n }}\n >expand_more</mwc-icon\n >\n <ox-popup id=\"sorter-control\">\n <ox-sorters-control> </ox-sorters-control>\n </ox-popup>\n </div>\n\n <div id=\"modes\">\n <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>\n <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>\n <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>\n </div>\n </div>\n </ox-grist>\n `\n }\n\n get grist() {\n return this.renderRoot.querySelector('ox-grist')\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 {\n type: 'gutter',\n gutterName: 'button',\n name: 'start',\n icon: 'add_task',\n handlers: {\n click: (columns, data, column, record, rowIndex) => {\n if (!record.id) {\n return\n }\n\n const popup = openPopup(\n html` <activity-starter-form .activityId=${record.id}></activity-starter-form> `,\n {\n backdrop: true,\n help: 'worklist/activity-starter-form',\n size: 'large',\n title: i18next.t('title.activity starter')\n }\n )\n popup.onclosed = () => {\n this.grist.fetch()\n }\n }\n }\n },\n {\n type: 'string',\n name: 'name',\n header: i18next.t('field.name'),\n filter: 'search',\n sortable: true,\n width: 150\n },\n {\n type: 'string',\n name: 'description',\n header: i18next.t('field.description'),\n filter: 'search',\n width: 240\n },\n {\n type: 'string',\n name: 'activityType',\n label: true,\n header: i18next.t('field.activity-type'),\n sortable: true,\n // filter: {\n // type: 'select',\n // options: ActivityTypes\n // },\n width: 100\n },\n {\n type: 'resource-object',\n name: 'updater',\n header: i18next.t('field.updater'),\n sortable: true,\n width: 120\n },\n {\n type: 'datetime',\n name: 'updatedAt',\n header: i18next.t('field.updated_at'),\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 },\n sorters: [\n {\n name: 'name'\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 = [] }) {\n const response = await client.query({\n query: gql`\n query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {\n responses: startableActivities(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n description\n activityType\n priority\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\nwindow.customElements.define('starter-list-page', StarterListPage)\n"]}
@@ -0,0 +1,137 @@
1
+ declare const ActivityInstanceListPage_base: (new (...args: any[]) => {
2
+ _storeUnsubscribe: import("redux").Unsubscribe;
3
+ connectedCallback(): void;
4
+ disconnectedCallback(): void;
5
+ stateChanged(_state: unknown): void;
6
+ readonly isConnected: boolean;
7
+ }) & (new (...args: any[]) => import("lit").LitElement) & typeof PageView;
8
+ export class ActivityInstanceListPage extends ActivityInstanceListPage_base {
9
+ static get properties(): {
10
+ gristConfig: ObjectConstructor;
11
+ mode: StringConstructor;
12
+ };
13
+ static get styles(): import("lit").CSSResult[];
14
+ get context(): {
15
+ title: string;
16
+ help: string;
17
+ actions: never[];
18
+ };
19
+ render(): import("lit-html").TemplateResult<1>;
20
+ mode: string | undefined;
21
+ get grist(): Element | null;
22
+ pageInitialized(lifecycle: any): Promise<void>;
23
+ gristConfig: {
24
+ list: {
25
+ thumbnail: string;
26
+ fields: string[];
27
+ details: string[];
28
+ };
29
+ columns: ({
30
+ type: string;
31
+ gutterName: string;
32
+ multiple?: undefined;
33
+ name?: undefined;
34
+ header?: undefined;
35
+ record?: undefined;
36
+ filter?: undefined;
37
+ sortable?: undefined;
38
+ width?: undefined;
39
+ hidden?: undefined;
40
+ } | {
41
+ type: string;
42
+ gutterName: string;
43
+ multiple: boolean;
44
+ name?: undefined;
45
+ header?: undefined;
46
+ record?: undefined;
47
+ filter?: undefined;
48
+ sortable?: undefined;
49
+ width?: undefined;
50
+ hidden?: undefined;
51
+ } | {
52
+ type: string;
53
+ name: string;
54
+ header: string;
55
+ record: {
56
+ editable: boolean;
57
+ };
58
+ filter: string;
59
+ sortable: boolean;
60
+ width: number;
61
+ gutterName?: undefined;
62
+ multiple?: undefined;
63
+ hidden?: undefined;
64
+ } | {
65
+ type: string;
66
+ name: string;
67
+ header: string;
68
+ record: {
69
+ editable: boolean;
70
+ };
71
+ filter: string;
72
+ width: number;
73
+ gutterName?: undefined;
74
+ multiple?: undefined;
75
+ sortable?: undefined;
76
+ hidden?: undefined;
77
+ } | {
78
+ type: string;
79
+ name: string;
80
+ header: string;
81
+ record: {
82
+ editable: boolean;
83
+ };
84
+ width: number;
85
+ gutterName?: undefined;
86
+ multiple?: undefined;
87
+ filter?: undefined;
88
+ sortable?: undefined;
89
+ hidden?: undefined;
90
+ } | {
91
+ type: string;
92
+ name: string;
93
+ header: string;
94
+ record: {
95
+ editable: boolean;
96
+ };
97
+ sortable: boolean;
98
+ width: number;
99
+ gutterName?: undefined;
100
+ multiple?: undefined;
101
+ filter?: undefined;
102
+ hidden?: undefined;
103
+ } | {
104
+ type: string;
105
+ name: string;
106
+ header: string;
107
+ record: {
108
+ editable: boolean;
109
+ };
110
+ hidden: boolean;
111
+ gutterName?: undefined;
112
+ multiple?: undefined;
113
+ filter?: undefined;
114
+ sortable?: undefined;
115
+ width?: undefined;
116
+ })[];
117
+ rows: {
118
+ selectable: {
119
+ multiple: boolean;
120
+ };
121
+ };
122
+ sorters: {
123
+ name: string;
124
+ }[];
125
+ } | undefined;
126
+ fetchHandler({ page, limit, sortings, filters }: {
127
+ page: any;
128
+ limit: any;
129
+ sortings?: any[] | undefined;
130
+ filters?: any[] | undefined;
131
+ }): Promise<{
132
+ total: any;
133
+ records: any;
134
+ }>;
135
+ }
136
+ import { PageView } from "@operato/shell/page-view";
137
+ export {};
@@ -0,0 +1,202 @@
1
+ import '@operato/data-grist';
2
+ import gql from 'graphql-tag';
3
+ import { css, html } from 'lit';
4
+ import { connect } from 'pwa-helpers/connect-mixin.js';
5
+ import { client } from '@operato/graphql';
6
+ import { i18next, localize } from '@operato/i18n';
7
+ import { PageView, store } from '@operato/shell';
8
+ import { CommonGristStyles, ScrollbarStyles } from '@operato/styles';
9
+ import { isMobileDevice } from '@operato/utils';
10
+ export class ActivityInstanceListPage extends connect(store)(localize(i18next)(PageView)) {
11
+ static get properties() {
12
+ return {
13
+ gristConfig: Object,
14
+ mode: String
15
+ };
16
+ }
17
+ static get styles() {
18
+ return [
19
+ ScrollbarStyles,
20
+ CommonGristStyles,
21
+ css `
22
+ :host {
23
+ display: flex;
24
+
25
+ width: 100%;
26
+
27
+ --grid-record-emphasized-background-color: red;
28
+ --grid-record-emphasized-color: yellow;
29
+ }
30
+ `
31
+ ];
32
+ }
33
+ get context() {
34
+ return {
35
+ title: i18next.t('title.activity instance list'),
36
+ help: 'worklist/activity-instance-list',
37
+ actions: []
38
+ };
39
+ }
40
+ render() {
41
+ const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID');
42
+ return html `
43
+ <ox-grist .mode=${mode} .config=${this.gristConfig} .fetchHandler=${this.fetchHandler.bind(this)}>
44
+ <div slot="headroom">
45
+ <div id="filters">
46
+ <ox-filters-form autofocus></ox-filters-form>
47
+ </div>
48
+
49
+ <div id="sorters">
50
+ Sort
51
+ <mwc-icon
52
+ @click=${e => {
53
+ const target = e.currentTarget;
54
+ this.renderRoot.querySelector('#sorter-control').open({
55
+ right: 0,
56
+ top: target.offsetTop + target.offsetHeight
57
+ });
58
+ }}
59
+ >expand_more</mwc-icon
60
+ >
61
+ <ox-popup id="sorter-control">
62
+ <ox-sorters-control> </ox-sorters-control>
63
+ </ox-popup>
64
+ </div>
65
+
66
+ <div id="modes">
67
+ <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>
68
+ <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>
69
+ <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>
70
+ </div>
71
+ </div>
72
+ </ox-grist>
73
+ `;
74
+ }
75
+ get grist() {
76
+ return this.renderRoot.querySelector('ox-grist');
77
+ }
78
+ async pageInitialized(lifecycle) {
79
+ this.gristConfig = {
80
+ list: {
81
+ thumbnail: 'thumbnail',
82
+ fields: ['name', 'description'],
83
+ details: ['updatedAt']
84
+ },
85
+ columns: [
86
+ { type: 'gutter', gutterName: 'sequence' },
87
+ { type: 'gutter', gutterName: 'row-selector', multiple: true },
88
+ {
89
+ type: 'string',
90
+ name: 'name',
91
+ header: i18next.t('field.name'),
92
+ record: {
93
+ editable: false
94
+ },
95
+ filter: 'search',
96
+ sortable: true,
97
+ width: 150
98
+ },
99
+ {
100
+ type: 'string',
101
+ name: 'description',
102
+ header: i18next.t('field.description'),
103
+ record: {
104
+ editable: false
105
+ },
106
+ filter: 'search',
107
+ width: 200
108
+ },
109
+ {
110
+ type: 'number',
111
+ name: 'priority',
112
+ header: i18next.t('field.priority'),
113
+ record: {
114
+ editable: false
115
+ },
116
+ width: 30
117
+ },
118
+ {
119
+ type: 'string',
120
+ name: 'state',
121
+ header: i18next.t('field.status'),
122
+ record: {
123
+ editable: false
124
+ },
125
+ width: 60
126
+ },
127
+ {
128
+ type: 'resource-object',
129
+ name: 'updater',
130
+ header: i18next.t('field.updater'),
131
+ record: {
132
+ editable: false
133
+ },
134
+ sortable: true,
135
+ width: 120
136
+ },
137
+ {
138
+ type: 'datetime',
139
+ name: 'updatedAt',
140
+ header: i18next.t('field.updated_at'),
141
+ record: {
142
+ editable: false
143
+ },
144
+ sortable: true,
145
+ width: 180
146
+ },
147
+ {
148
+ type: 'image',
149
+ name: 'thumbnail',
150
+ header: i18next.t('field.thumbnail'),
151
+ record: { editable: false },
152
+ hidden: true
153
+ }
154
+ ],
155
+ rows: {
156
+ selectable: {
157
+ multiple: true
158
+ }
159
+ },
160
+ sorters: [
161
+ {
162
+ name: 'name'
163
+ }
164
+ ]
165
+ };
166
+ }
167
+ async fetchHandler({ page, limit, sortings = [], filters = [] }) {
168
+ const response = await client.query({
169
+ query: gql `
170
+ query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
171
+ responses: activityInstances(filters: $filters, pagination: $pagination, sortings: $sortings) {
172
+ items {
173
+ id
174
+ name
175
+ description
176
+ priority
177
+ state
178
+ thumbnail
179
+ updater {
180
+ id
181
+ name
182
+ }
183
+ updatedAt
184
+ }
185
+ total
186
+ }
187
+ }
188
+ `,
189
+ variables: {
190
+ filters,
191
+ pagination: { page, limit },
192
+ sortings
193
+ }
194
+ });
195
+ return {
196
+ total: response.data.responses.total || 0,
197
+ records: response.data.responses.items || []
198
+ };
199
+ }
200
+ }
201
+ window.customElements.define('activity-instance-list-page', ActivityInstanceListPage);
202
+ //# sourceMappingURL=activity-instance-list-page.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"activity-instance-list-page.js","sourceRoot":"","sources":["../../../client/pages/activity-instance/activity-instance-list-page.js"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\n\nimport gql from 'graphql-tag'\nimport { css, html } from 'lit'\nimport { connect } from 'pwa-helpers/connect-mixin.js'\n\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { PageView, store } from '@operato/shell'\nimport { CommonGristStyles, ScrollbarStyles } from '@operato/styles'\nimport { isMobileDevice } from '@operato/utils'\n\nexport class ActivityInstanceListPage extends connect(store)(localize(i18next)(PageView)) {\n static get properties() {\n return {\n gristConfig: Object,\n mode: String\n }\n }\n\n static get styles() {\n return [\n ScrollbarStyles,\n CommonGristStyles,\n css`\n :host {\n display: flex;\n\n width: 100%;\n\n --grid-record-emphasized-background-color: red;\n --grid-record-emphasized-color: yellow;\n }\n `\n ]\n }\n\n get context() {\n return {\n title: i18next.t('title.activity instance list'),\n help: 'worklist/activity-instance-list',\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\">\n <div id=\"filters\">\n <ox-filters-form autofocus></ox-filters-form>\n </div>\n\n <div id=\"sorters\">\n Sort\n <mwc-icon\n @click=${e => {\n const target = e.currentTarget\n this.renderRoot.querySelector('#sorter-control').open({\n right: 0,\n top: target.offsetTop + target.offsetHeight\n })\n }}\n >expand_more</mwc-icon\n >\n <ox-popup id=\"sorter-control\">\n <ox-sorters-control> </ox-sorters-control>\n </ox-popup>\n </div>\n\n <div id=\"modes\">\n <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>\n <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>\n <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>\n </div>\n </div>\n </ox-grist>\n `\n }\n\n get grist() {\n return this.renderRoot.querySelector('ox-grist')\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 },\n width: 30\n },\n {\n type: 'string',\n name: 'state',\n header: i18next.t('field.status'),\n record: {\n editable: false\n },\n width: 60\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 = [] }) {\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\nwindow.customElements.define('activity-instance-list-page', ActivityInstanceListPage)\n"]}
@@ -0,0 +1,49 @@
1
+ export namespace ActivityInstanceStatus {
2
+ const Draft: string;
3
+ const Posted: string;
4
+ const WaitingAssignment: string;
5
+ const Assigned: string;
6
+ const Started: string;
7
+ const Pending: string;
8
+ const Ended: string;
9
+ const Aborted: string;
10
+ }
11
+ declare const ActivityInstancePage_base: (new (...args: any[]) => {
12
+ _storeUnsubscribe: import("redux").Unsubscribe;
13
+ connectedCallback(): void;
14
+ disconnectedCallback(): void;
15
+ stateChanged(_state: unknown): void;
16
+ readonly isConnected: boolean;
17
+ }) & (new (...args: any[]) => import("lit").LitElement) & typeof PageView;
18
+ export class ActivityInstancePage extends ActivityInstancePage_base {
19
+ static get properties(): {
20
+ activityInstance: ObjectConstructor;
21
+ board: ObjectConstructor;
22
+ };
23
+ static get styles(): import("lit").CSSResult[];
24
+ get context(): {
25
+ title: any;
26
+ help: string;
27
+ actions: any[];
28
+ };
29
+ render(): import("lit-html").TemplateResult<1>;
30
+ activityContent(): import("lit-html/directive").DirectiveResult<typeof import("lit-html/directives/unsafe-html.js").UnsafeHTMLDirective>;
31
+ templateContent(): import("lit-html/directive").DirectiveResult<typeof import("lit-html/directives/unsafe-html.js").UnsafeHTMLDirective>;
32
+ getInputSpec(): any;
33
+ getOutputSpec(): any;
34
+ generatedContent(): import("lit-html").TemplateResult<1>;
35
+ boardContent(): import("lit-html").TemplateResult<1>;
36
+ board: {
37
+ id: any;
38
+ } | undefined;
39
+ getOutputFromBoard(): any;
40
+ updated(changes: any): void;
41
+ pageUpdated(changes: any, lifecycle: any, changedBefore: any): Promise<void>;
42
+ fetchActivityInstance(id: any): Promise<void>;
43
+ activityInstance: any;
44
+ _startActivityInstance(): Promise<void>;
45
+ _saveActivityInstance(): Promise<void>;
46
+ _endActivityInstance(): Promise<void>;
47
+ }
48
+ import { PageView } from "@operato/shell/page-view";
49
+ export {};