@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,211 @@
1
+ import '@operato/data-grist';
2
+ import '../../components/activity-intro-view';
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 { CommonButtonStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles';
11
+ import { ActivityTypes } from '../../types.js';
12
+ export class ActivityStorePage extends connect(store)(localize(i18next)(PageView)) {
13
+ static get properties() {
14
+ return {
15
+ gristConfig: Object
16
+ };
17
+ }
18
+ static get styles() {
19
+ return [
20
+ ScrollbarStyles,
21
+ CommonGristStyles,
22
+ css `
23
+ :host {
24
+ display: flex;
25
+
26
+ width: 100%;
27
+
28
+ --grid-record-emphasized-background-color: red;
29
+ --grid-record-emphasized-color: yellow;
30
+ }
31
+ `
32
+ ];
33
+ }
34
+ get context() {
35
+ return {
36
+ title: i18next.t('title.activity store'),
37
+ help: 'worklist/activity-store',
38
+ actions: [
39
+ Object.assign({ title: i18next.t('button.buy'), action: this._buyActivityTemplate.bind(this) }, CommonButtonStyles.buy)
40
+ ]
41
+ };
42
+ }
43
+ render() {
44
+ return html `
45
+ <ox-grist mode="CARD" .config=${this.gristConfig} .fetchHandler=${this.fetchHandler.bind(this)}>
46
+ <div slot="headroom">
47
+ <div id="filters">
48
+ <ox-filters-form autofocus></ox-filters-form>
49
+ </div>
50
+
51
+ <div id="sorters">
52
+ Sort
53
+ <mwc-icon
54
+ @click=${e => {
55
+ const target = e.currentTarget;
56
+ this.renderRoot.querySelector('#sorter-control').open({
57
+ right: 0,
58
+ top: target.offsetTop + target.offsetHeight
59
+ });
60
+ }}
61
+ >expand_more</mwc-icon
62
+ >
63
+ <ox-popup id="sorter-control">
64
+ <ox-sorters-control> </ox-sorters-control>
65
+ </ox-popup>
66
+ </div>
67
+ </div>
68
+ </ox-grist>
69
+ `;
70
+ }
71
+ get grist() {
72
+ return this.renderRoot.querySelector('ox-grist');
73
+ }
74
+ async pageInitialized(lifecycle) {
75
+ this.gristConfig = {
76
+ list: {
77
+ thumbnail: 'thumbnail',
78
+ fields: ['name', 'description'],
79
+ details: ['activityType', 'updatedAt']
80
+ },
81
+ columns: [
82
+ { type: 'gutter', gutterName: 'sequence' },
83
+ { type: 'gutter', gutterName: 'row-selector', multiple: true },
84
+ {
85
+ type: 'gutter',
86
+ gutterName: 'button',
87
+ icon: 'reorder',
88
+ handlers: {
89
+ click: (columns, data, column, record, rowIndex) => {
90
+ if (!record.id) {
91
+ return;
92
+ }
93
+ const popup = openPopup(html ` <activity-intro-view .activityTemplateId=${record.id}></activity-intro-view> `, {
94
+ backdrop: true,
95
+ help: 'worklist/activity-intro',
96
+ size: 'large',
97
+ title: i18next.t('title.activity intro')
98
+ });
99
+ popup.onclosed = () => {
100
+ this.grist.fetch();
101
+ };
102
+ }
103
+ }
104
+ },
105
+ {
106
+ type: 'string',
107
+ name: 'name',
108
+ header: i18next.t('field.name'),
109
+ record: {
110
+ editable: true
111
+ },
112
+ filter: 'search',
113
+ sortable: true,
114
+ width: 150
115
+ },
116
+ {
117
+ type: 'string',
118
+ name: 'description',
119
+ header: i18next.t('field.description'),
120
+ record: {
121
+ editable: true
122
+ },
123
+ filter: 'search',
124
+ width: 200
125
+ },
126
+ {
127
+ type: 'select',
128
+ name: 'activityType',
129
+ label: true,
130
+ header: i18next.t('field.activity-type'),
131
+ record: {
132
+ editable: true,
133
+ options: ActivityTypes
134
+ },
135
+ sortable: true,
136
+ // filter: true,
137
+ width: 60
138
+ },
139
+ {
140
+ type: 'image',
141
+ name: 'thumbnail',
142
+ header: i18next.t('field.thumbnail'),
143
+ record: { editable: true },
144
+ width: 120
145
+ },
146
+ {
147
+ type: 'datetime',
148
+ name: 'updatedAt',
149
+ header: i18next.t('field.updated_at'),
150
+ record: {
151
+ editable: false
152
+ },
153
+ sortable: true,
154
+ width: 180
155
+ }
156
+ ],
157
+ rows: {
158
+ selectable: {
159
+ multiple: true
160
+ }
161
+ },
162
+ sorters: [
163
+ {
164
+ name: 'name'
165
+ }
166
+ ]
167
+ };
168
+ }
169
+ async pageUpdated(changes, lifecycle) {
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: activityTemplates(filters: $filters, pagination: $pagination, sortings: $sortings) {
179
+ items {
180
+ id
181
+ name
182
+ description
183
+ activityType
184
+ thumbnail
185
+ updater {
186
+ id
187
+ name
188
+ }
189
+ updatedAt
190
+ }
191
+ total
192
+ }
193
+ }
194
+ `,
195
+ variables: {
196
+ filters,
197
+ pagination: { page, limit },
198
+ sortings
199
+ }
200
+ });
201
+ return {
202
+ total: response.data.responses.total || 0,
203
+ records: response.data.responses.items || []
204
+ };
205
+ }
206
+ _buyActivityTemplate() {
207
+ console.log('bought');
208
+ }
209
+ }
210
+ window.customElements.define('activity-store-page', ActivityStorePage);
211
+ //# sourceMappingURL=activity-store-page.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"activity-store-page.js","sourceRoot":"","sources":["../../../client/pages/activity-store/activity-store-page.js"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\nimport '../../components/activity-intro-view'\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 { CommonButtonStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'\n\nimport { ActivityTypes } from '../../types.js'\n\nexport class ActivityStorePage extends connect(store)(localize(i18next)(PageView)) {\n static get properties() {\n return {\n gristConfig: Object\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 store'),\n help: 'worklist/activity-store',\n actions: [\n {\n title: i18next.t('button.buy'),\n action: this._buyActivityTemplate.bind(this),\n ...CommonButtonStyles.buy\n }\n ]\n }\n }\n\n render() {\n return html`\n <ox-grist mode=\"CARD\" .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 </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: ['activityType', 'updatedAt']\n },\n columns: [\n { type: 'gutter', gutterName: 'sequence' },\n { type: 'gutter', gutterName: 'row-selector', multiple: true },\n {\n type: 'gutter',\n gutterName: 'button',\n icon: 'reorder',\n handlers: {\n click: (columns, data, column, record, rowIndex) => {\n if (!record.id) {\n return\n }\n\n const popup = openPopup(\n html` <activity-intro-view .activityTemplateId=${record.id}></activity-intro-view> `,\n {\n backdrop: true,\n help: 'worklist/activity-intro',\n size: 'large',\n title: i18next.t('title.activity intro')\n }\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 record: {\n editable: true\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: true\n },\n filter: 'search',\n width: 200\n },\n {\n type: 'select',\n name: 'activityType',\n label: true,\n header: i18next.t('field.activity-type'),\n record: {\n editable: true,\n options: ActivityTypes\n },\n sortable: true,\n // filter: true,\n width: 60\n },\n {\n type: 'image',\n name: 'thumbnail',\n header: i18next.t('field.thumbnail'),\n record: { editable: true },\n width: 120\n },\n {\n type: 'datetime',\n name: 'updatedAt',\n header: i18next.t('field.updated_at'),\n record: {\n editable: false\n },\n sortable: true,\n width: 180\n }\n ],\n rows: {\n selectable: {\n multiple: true\n }\n },\n sorters: [\n {\n name: 'name'\n }\n ]\n }\n }\n\n async pageUpdated(changes, lifecycle) {\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: activityTemplates(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n description\n activityType\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 _buyActivityTemplate() {\n console.log('bought')\n }\n}\n\nwindow.customElements.define('activity-store-page', ActivityStorePage)\n"]}
@@ -0,0 +1,143 @@
1
+ declare const ReporterListPage_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 ReporterListPage extends ReporterListPage_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
+ };
18
+ render(): import("lit-html").TemplateResult<1>;
19
+ mode: string | undefined;
20
+ get grist(): Element | null;
21
+ pageInitialized(lifecycle: any): Promise<void>;
22
+ gristConfig: {
23
+ list: {
24
+ thumbnail: string;
25
+ fields: string[];
26
+ details: string[];
27
+ };
28
+ columns: ({
29
+ type: string;
30
+ gutterName: string;
31
+ name?: undefined;
32
+ icon?: undefined;
33
+ handlers?: undefined;
34
+ header?: undefined;
35
+ filter?: undefined;
36
+ sortable?: undefined;
37
+ width?: undefined;
38
+ label?: undefined;
39
+ record?: undefined;
40
+ hidden?: undefined;
41
+ } | {
42
+ type: string;
43
+ gutterName: string;
44
+ name: string;
45
+ icon: string;
46
+ handlers: {
47
+ click: (columns: any, data: any, column: any, record: any, rowIndex: any) => void;
48
+ };
49
+ header?: undefined;
50
+ filter?: undefined;
51
+ sortable?: undefined;
52
+ width?: undefined;
53
+ label?: undefined;
54
+ record?: undefined;
55
+ hidden?: undefined;
56
+ } | {
57
+ type: string;
58
+ name: string;
59
+ header: string;
60
+ filter: string;
61
+ sortable: boolean;
62
+ width: number;
63
+ gutterName?: undefined;
64
+ icon?: undefined;
65
+ handlers?: undefined;
66
+ label?: undefined;
67
+ record?: undefined;
68
+ hidden?: undefined;
69
+ } | {
70
+ type: string;
71
+ name: string;
72
+ header: string;
73
+ filter: string;
74
+ width: number;
75
+ gutterName?: undefined;
76
+ icon?: undefined;
77
+ handlers?: undefined;
78
+ sortable?: undefined;
79
+ label?: undefined;
80
+ record?: undefined;
81
+ hidden?: undefined;
82
+ } | {
83
+ type: string;
84
+ name: string;
85
+ label: boolean;
86
+ header: string;
87
+ sortable: boolean;
88
+ width: number;
89
+ gutterName?: undefined;
90
+ icon?: undefined;
91
+ handlers?: undefined;
92
+ filter?: undefined;
93
+ record?: undefined;
94
+ hidden?: undefined;
95
+ } | {
96
+ type: string;
97
+ name: string;
98
+ header: string;
99
+ sortable: boolean;
100
+ width: number;
101
+ gutterName?: undefined;
102
+ icon?: undefined;
103
+ handlers?: undefined;
104
+ filter?: undefined;
105
+ label?: undefined;
106
+ record?: undefined;
107
+ hidden?: undefined;
108
+ } | {
109
+ type: string;
110
+ name: string;
111
+ header: string;
112
+ record: {
113
+ editable: boolean;
114
+ };
115
+ hidden: boolean;
116
+ gutterName?: undefined;
117
+ icon?: undefined;
118
+ handlers?: undefined;
119
+ filter?: undefined;
120
+ sortable?: undefined;
121
+ width?: undefined;
122
+ label?: undefined;
123
+ })[];
124
+ rows: {
125
+ appendable: boolean;
126
+ };
127
+ sorters: {
128
+ name: string;
129
+ }[];
130
+ } | undefined;
131
+ pageUpdated(changes: any, lifecycle: any, changedBefore: any): Promise<void>;
132
+ fetchHandler({ page, limit, sortings, filters }: {
133
+ page: any;
134
+ limit: any;
135
+ sortings?: any[] | undefined;
136
+ filters?: any[] | undefined;
137
+ }): Promise<{
138
+ total: any;
139
+ records: any;
140
+ }>;
141
+ }
142
+ import { PageView } from "@operato/shell/page-view.js";
143
+ export {};
@@ -0,0 +1,209 @@
1
+ import '@operato/data-grist';
2
+ import '../../components/activity-reporter-view.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 ReporterListPage 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 reporter list'),
38
+ help: 'worklist/activity-reporter-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: 'dashboard',
93
+ handlers: {
94
+ click: (columns, data, column, record, rowIndex) => {
95
+ if (!record.id) {
96
+ return;
97
+ }
98
+ const popup = openPopup(html ` <activity-reporter-view .activityId=${record.id}></activity-reporter-view> `, {
99
+ backdrop: true,
100
+ help: 'worklist/activity-reporter-view',
101
+ size: 'large',
102
+ title: i18next.t('title.activity summary')
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: supervisableActivities(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('reporter-list-page', ReporterListPage);
209
+ //# sourceMappingURL=reporter-list-page.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reporter-list-page.js","sourceRoot":"","sources":["../../../client/pages/activity-supervisor/reporter-list-page.js"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\nimport '../../components/activity-reporter-view.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 ReporterListPage 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 reporter list'),\n help: 'worklist/activity-reporter-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: 'dashboard',\n handlers: {\n click: (columns, data, column, record, rowIndex) => {\n if (!record.id) {\n return\n }\n\n const popup = openPopup(\n html` <activity-reporter-view .activityId=${record.id}></activity-reporter-view> `,\n {\n backdrop: true,\n help: 'worklist/activity-reporter-view',\n size: 'large',\n title: i18next.t('title.activity summary')\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: supervisableActivities(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('reporter-list-page', ReporterListPage)\n"]}
@@ -0,0 +1,24 @@
1
+ export class ActivityTemplateImporter extends LitElement {
2
+ static get properties(): {
3
+ columns: ObjectConstructor;
4
+ activityTemplates: ArrayConstructor;
5
+ };
6
+ static get styles(): import("lit").CSSResult[];
7
+ columns: {
8
+ list: {
9
+ fields: string[];
10
+ };
11
+ pagination: {
12
+ infinite: boolean;
13
+ };
14
+ columns: {
15
+ type: string;
16
+ name: string;
17
+ header: string;
18
+ width: number;
19
+ }[];
20
+ };
21
+ render(): import("lit-html").TemplateResult<1>;
22
+ save(): Promise<void>;
23
+ }
24
+ import { LitElement } from "lit-element/lit-element";