@dssp/project 1.0.0-alpha.0 → 1.0.0-alpha.14

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 (259) hide show
  1. package/dist-client/pages/lib/select2-component.js +1 -1
  2. package/dist-client/pages/lib/select2-component.js.map +1 -1
  3. package/dist-client/pages/lib/waether.d.ts +2 -1
  4. package/dist-client/pages/lib/waether.js +7 -3
  5. package/dist-client/pages/lib/waether.js.map +1 -1
  6. package/dist-client/pages/project/component/project-update-header.js.map +1 -1
  7. package/dist-client/pages/project/popup/checklist/attachment-list-popup.d.ts +1 -0
  8. package/dist-client/pages/project/popup/checklist/attachment-list-popup.js +309 -0
  9. package/dist-client/pages/project/popup/checklist/attachment-list-popup.js.map +1 -0
  10. package/dist-client/pages/project/popup/checklist/comment-list-popup.d.ts +1 -0
  11. package/dist-client/pages/project/popup/checklist/comment-list-popup.js +357 -0
  12. package/dist-client/pages/project/popup/checklist/comment-list-popup.js.map +1 -0
  13. package/dist-client/pages/project/popup/checklist/schedule-checklist-create-popup.d.ts +2 -0
  14. package/dist-client/pages/project/popup/checklist/schedule-checklist-create-popup.js +684 -0
  15. package/dist-client/pages/project/popup/checklist/schedule-checklist-create-popup.js.map +1 -0
  16. package/dist-client/pages/project/popup/checklist/schedule-checklist-view.d.ts +37 -0
  17. package/dist-client/pages/project/popup/checklist/schedule-checklist-view.js +627 -0
  18. package/dist-client/pages/project/popup/checklist/schedule-checklist-view.js.map +1 -0
  19. package/dist-client/pages/project/popup/popup-plan-export.d.ts +10 -0
  20. package/dist-client/pages/project/popup/popup-plan-export.js +236 -0
  21. package/dist-client/pages/project/popup/popup-plan-export.js.map +1 -0
  22. package/dist-client/pages/project/popup/popup-plan-upload.d.ts +3 -0
  23. package/dist-client/pages/project/popup/popup-plan-upload.js +130 -4
  24. package/dist-client/pages/project/popup/popup-plan-upload.js.map +1 -1
  25. package/dist-client/pages/project/popup/popup-project-create.js.map +1 -1
  26. package/dist-client/pages/project/popup/popup-schedule-upload.js.map +1 -1
  27. package/dist-client/pages/project/project-completed-list.js +0 -1
  28. package/dist-client/pages/project/project-completed-list.js.map +1 -1
  29. package/dist-client/pages/project/project-detail.d.ts +2 -1
  30. package/dist-client/pages/project/project-detail.js +269 -80
  31. package/dist-client/pages/project/project-detail.js.map +1 -1
  32. package/dist-client/pages/project/project-list.d.ts +12 -0
  33. package/dist-client/pages/project/project-list.js +15 -8
  34. package/dist-client/pages/project/project-list.js.map +1 -1
  35. package/dist-client/pages/project/project-plan-management.js +29 -13
  36. package/dist-client/pages/project/project-plan-management.js.map +1 -1
  37. package/dist-client/pages/project/project-schedule-list.js.map +1 -1
  38. package/dist-client/pages/project/project-schedule.d.ts +2 -0
  39. package/dist-client/pages/project/project-schedule.js +16 -1
  40. package/dist-client/pages/project/project-schedule.js.map +1 -1
  41. package/dist-client/pages/project/project-setting-list.js +25 -24
  42. package/dist-client/pages/project/project-setting-list.js.map +1 -1
  43. package/dist-client/pages/project/project-update.d.ts +1 -0
  44. package/dist-client/pages/project/project-update.js +128 -17
  45. package/dist-client/pages/project/project-update.js.map +1 -1
  46. package/dist-client/pages/resource/construction-detail-type-popup.js.map +1 -1
  47. package/dist-client/pages/resource/construction-type-management.js.map +1 -1
  48. package/dist-client/pages/resource/inspection-drawing-type-management.js.map +1 -1
  49. package/dist-client/pages/resource/inspection-part-popup.js.map +1 -1
  50. package/dist-client/pages/resource/resource-importer.js.map +1 -1
  51. package/dist-client/pages/resource/resource-list-page.js.map +1 -1
  52. package/dist-client/pages/resource/worker-type-management.js.map +1 -1
  53. package/dist-client/pages/task/task-importer.js.map +1 -1
  54. package/dist-client/pages/task/task-list-page.js.map +1 -1
  55. package/dist-client/pages/task-resource/task-resource-importer.js.map +1 -1
  56. package/dist-client/pages/task-resource/task-resource-list-page.js.map +1 -1
  57. package/dist-client/route.js.map +1 -1
  58. package/dist-client/tsconfig.tsbuildinfo +1 -1
  59. package/dist-server/controllers/export-tasks.js +1 -2
  60. package/dist-server/controllers/export-tasks.js.map +1 -1
  61. package/dist-server/controllers/import-task.js +1 -2
  62. package/dist-server/controllers/import-task.js.map +1 -1
  63. package/dist-server/controllers/parse-excel.d.ts +0 -2
  64. package/dist-server/controllers/parse-excel.js +1 -2
  65. package/dist-server/controllers/parse-excel.js.map +1 -1
  66. package/dist-server/middlewares/index.js +1 -2
  67. package/dist-server/middlewares/index.js.map +1 -1
  68. package/dist-server/migrations/1723861466413-seed-roles.js.map +1 -1
  69. package/dist-server/migrations/1723861466414-seed-codes.js.map +1 -1
  70. package/dist-server/migrations/1723861476419-seed-resources.js.map +1 -1
  71. package/dist-server/migrations/1723861478420-seed-/bsample-project.js.map +1 -1
  72. package/dist-server/migrations/1723861478421-seed-/bsample-tasks.js.map +1 -1
  73. package/dist-server/service/construction-detail-type/construction-detail-type-mutation.js +2 -2
  74. package/dist-server/service/construction-detail-type/construction-detail-type-mutation.js.map +1 -1
  75. package/dist-server/service/construction-detail-type/construction-detail-type-query.js +2 -2
  76. package/dist-server/service/construction-detail-type/construction-detail-type-query.js.map +1 -1
  77. package/dist-server/service/construction-detail-type/construction-detail-type-type.js +4 -4
  78. package/dist-server/service/construction-detail-type/construction-detail-type-type.js.map +1 -1
  79. package/dist-server/service/construction-detail-type/construction-detail-type.js +2 -2
  80. package/dist-server/service/construction-detail-type/construction-detail-type.js.map +1 -1
  81. package/dist-server/service/construction-type/construction-type-mutation.js +2 -2
  82. package/dist-server/service/construction-type/construction-type-mutation.js.map +1 -1
  83. package/dist-server/service/construction-type/construction-type-query.js +2 -2
  84. package/dist-server/service/construction-type/construction-type-query.js.map +1 -1
  85. package/dist-server/service/construction-type/construction-type-type.js +4 -4
  86. package/dist-server/service/construction-type/construction-type-type.js.map +1 -1
  87. package/dist-server/service/construction-type/construction-type.js +2 -2
  88. package/dist-server/service/construction-type/construction-type.js.map +1 -1
  89. package/dist-server/service/index.d.ts +1 -0
  90. package/dist-server/service/index.js +1 -0
  91. package/dist-server/service/index.js.map +1 -1
  92. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-mutation.js +2 -2
  93. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-mutation.js.map +1 -1
  94. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-query.js +2 -2
  95. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-query.js.map +1 -1
  96. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-type.js +4 -4
  97. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-type.js.map +1 -1
  98. package/dist-server/service/inspection-drawing-type/inspection-drawing-type.js +2 -2
  99. package/dist-server/service/inspection-drawing-type/inspection-drawing-type.js.map +1 -1
  100. package/dist-server/service/inspection-part/inspection-part-mutation.js +2 -2
  101. package/dist-server/service/inspection-part/inspection-part-mutation.js.map +1 -1
  102. package/dist-server/service/inspection-part/inspection-part-query.js +2 -2
  103. package/dist-server/service/inspection-part/inspection-part-query.js.map +1 -1
  104. package/dist-server/service/inspection-part/inspection-part-type.js +4 -4
  105. package/dist-server/service/inspection-part/inspection-part-type.js.map +1 -1
  106. package/dist-server/service/inspection-part/inspection-part.js +2 -2
  107. package/dist-server/service/inspection-part/inspection-part.js.map +1 -1
  108. package/dist-server/service/manager/index.d.ts +2 -0
  109. package/dist-server/service/manager/index.js +3 -1
  110. package/dist-server/service/manager/index.js.map +1 -1
  111. package/dist-server/service/manager/manager-mutation.js +2 -2
  112. package/dist-server/service/manager/manager-mutation.js.map +1 -1
  113. package/dist-server/service/manager/manager-query.js +3 -3
  114. package/dist-server/service/manager/manager-query.js.map +1 -1
  115. package/dist-server/service/manager/manager-type.js +4 -4
  116. package/dist-server/service/manager/manager-type.js.map +1 -1
  117. package/dist-server/service/manager/manager.js +2 -2
  118. package/dist-server/service/manager/manager.js.map +1 -1
  119. package/dist-server/service/project/project-mutation.d.ts +1 -0
  120. package/dist-server/service/project/project-mutation.js +109 -15
  121. package/dist-server/service/project/project-mutation.js.map +1 -1
  122. package/dist-server/service/project/project-query.d.ts +1 -0
  123. package/dist-server/service/project/project-query.js +14 -3
  124. package/dist-server/service/project/project-query.js.map +1 -1
  125. package/dist-server/service/project/project-type.d.ts +1 -0
  126. package/dist-server/service/project/project-type.js +13 -9
  127. package/dist-server/service/project/project-type.js.map +1 -1
  128. package/dist-server/service/project/project.d.ts +6 -0
  129. package/dist-server/service/project/project.js +15 -4
  130. package/dist-server/service/project/project.js.map +1 -1
  131. package/dist-server/service/resource/resource-mutation.js +2 -2
  132. package/dist-server/service/resource/resource-mutation.js.map +1 -1
  133. package/dist-server/service/resource/resource-query.js +2 -2
  134. package/dist-server/service/resource/resource-query.js.map +1 -1
  135. package/dist-server/service/resource/resource-type.js +6 -6
  136. package/dist-server/service/resource/resource-type.js.map +1 -1
  137. package/dist-server/service/resource/resource.js +3 -3
  138. package/dist-server/service/resource/resource.js.map +1 -1
  139. package/dist-server/service/task/task-mutation.js +2 -2
  140. package/dist-server/service/task/task-mutation.js.map +1 -1
  141. package/dist-server/service/task/task-query.js +4 -4
  142. package/dist-server/service/task/task-query.js.map +1 -1
  143. package/dist-server/service/task/task-type.js +10 -10
  144. package/dist-server/service/task/task-type.js.map +1 -1
  145. package/dist-server/service/task/task.js +7 -8
  146. package/dist-server/service/task/task.js.map +1 -1
  147. package/dist-server/service/task-resource/task-resource-mutation.js +2 -2
  148. package/dist-server/service/task-resource/task-resource-mutation.js.map +1 -1
  149. package/dist-server/service/task-resource/task-resource-query.js +2 -2
  150. package/dist-server/service/task-resource/task-resource-query.js.map +1 -1
  151. package/dist-server/service/task-resource/task-resource-type.js +6 -6
  152. package/dist-server/service/task-resource/task-resource-type.js.map +1 -1
  153. package/dist-server/service/task-resource/task-resource.js +2 -2
  154. package/dist-server/service/task-resource/task-resource.js.map +1 -1
  155. package/dist-server/service/worker-type/worker-type-mutation.js +2 -2
  156. package/dist-server/service/worker-type/worker-type-mutation.js.map +1 -1
  157. package/dist-server/service/worker-type/worker-type-query.js +2 -2
  158. package/dist-server/service/worker-type/worker-type-query.js.map +1 -1
  159. package/dist-server/service/worker-type/worker-type-type.js +4 -4
  160. package/dist-server/service/worker-type/worker-type-type.js.map +1 -1
  161. package/dist-server/service/worker-type/worker-type.js +2 -2
  162. package/dist-server/service/worker-type/worker-type.js.map +1 -1
  163. package/dist-server/tsconfig.tsbuildinfo +1 -1
  164. package/package.json +13 -11
  165. package/client/bootstrap.ts +0 -0
  166. package/client/index.ts +0 -0
  167. package/client/pages/lib/select2-component.ts +0 -175
  168. package/client/pages/lib/waether.ts +0 -159
  169. package/client/pages/project/component/project-update-header.ts +0 -88
  170. package/client/pages/project/popup/popup-plan-upload.ts +0 -138
  171. package/client/pages/project/popup/popup-project-create.ts +0 -147
  172. package/client/pages/project/popup/popup-schedule-upload.ts +0 -102
  173. package/client/pages/project/project-completed-list.ts +0 -281
  174. package/client/pages/project/project-detail.ts +0 -738
  175. package/client/pages/project/project-list.ts +0 -418
  176. package/client/pages/project/project-plan-management.ts +0 -476
  177. package/client/pages/project/project-schedule-list.ts +0 -294
  178. package/client/pages/project/project-schedule.ts +0 -393
  179. package/client/pages/project/project-setting-list.ts +0 -393
  180. package/client/pages/project/project-update.ts +0 -876
  181. package/client/pages/resource/construction-detail-type-popup.ts +0 -201
  182. package/client/pages/resource/construction-type-management.ts +0 -212
  183. package/client/pages/resource/inspection-drawing-type-management.ts +0 -245
  184. package/client/pages/resource/inspection-part-popup.ts +0 -201
  185. package/client/pages/resource/resource-importer.ts +0 -97
  186. package/client/pages/resource/resource-list-page.ts +0 -356
  187. package/client/pages/resource/worker-type-management.ts +0 -192
  188. package/client/pages/task/task-importer.ts +0 -94
  189. package/client/pages/task/task-list-page.ts +0 -340
  190. package/client/pages/task-resource/task-resource-importer.ts +0 -97
  191. package/client/pages/task-resource/task-resource-list-page.ts +0 -356
  192. package/client/route.ts +0 -55
  193. package/client/tsconfig.json +0 -11
  194. package/server/controllers/export-tasks.ts +0 -40
  195. package/server/controllers/import-task.ts +0 -134
  196. package/server/controllers/index.ts +0 -0
  197. package/server/controllers/parse-excel.ts +0 -86
  198. package/server/controllers/types.ts +0 -20
  199. package/server/index.ts +0 -4
  200. package/server/middlewares/index.ts +0 -3
  201. package/server/migrations/1723861466413-seed-roles.ts +0 -128
  202. package/server/migrations/1723861466414-seed-codes.ts +0 -157
  203. package/server/migrations/1723861476419-seed-resources.ts +0 -62
  204. package/server/migrations/1723861478420-seed-/bsample-project.ts +0 -87
  205. package/server/migrations/1723861478421-seed-/bsample-tasks.ts +0 -194
  206. package/server/migrations/index.ts +0 -9
  207. package/server/routes.ts +0 -108
  208. package/server/service/construction-detail-type/construction-detail-type-mutation.ts +0 -57
  209. package/server/service/construction-detail-type/construction-detail-type-query.ts +0 -31
  210. package/server/service/construction-detail-type/construction-detail-type-type.ts +0 -26
  211. package/server/service/construction-detail-type/construction-detail-type.ts +0 -52
  212. package/server/service/construction-detail-type/index.ts +0 -6
  213. package/server/service/construction-type/construction-type-mutation.ts +0 -66
  214. package/server/service/construction-type/construction-type-query.ts +0 -56
  215. package/server/service/construction-type/construction-type-type.ts +0 -26
  216. package/server/service/construction-type/construction-type.ts +0 -74
  217. package/server/service/construction-type/index.ts +0 -6
  218. package/server/service/index.ts +0 -56
  219. package/server/service/inspection-drawing-type/index.ts +0 -6
  220. package/server/service/inspection-drawing-type/inspection-drawing-type-mutation.ts +0 -69
  221. package/server/service/inspection-drawing-type/inspection-drawing-type-query.ts +0 -55
  222. package/server/service/inspection-drawing-type/inspection-drawing-type-type.ts +0 -23
  223. package/server/service/inspection-drawing-type/inspection-drawing-type.ts +0 -68
  224. package/server/service/inspection-part/index.ts +0 -6
  225. package/server/service/inspection-part/inspection-part-mutation.ts +0 -52
  226. package/server/service/inspection-part/inspection-part-query.ts +0 -41
  227. package/server/service/inspection-part/inspection-part-type.ts +0 -26
  228. package/server/service/inspection-part/inspection-part.ts +0 -51
  229. package/server/service/manager/index.ts +0 -6
  230. package/server/service/manager/manager-mutation.ts +0 -42
  231. package/server/service/manager/manager-query.ts +0 -28
  232. package/server/service/manager/manager-type.ts +0 -40
  233. package/server/service/manager/manager.ts +0 -29
  234. package/server/service/project/index.ts +0 -6
  235. package/server/service/project/project-mutation.ts +0 -255
  236. package/server/service/project/project-query.ts +0 -105
  237. package/server/service/project/project-type.ts +0 -72
  238. package/server/service/project/project.ts +0 -134
  239. package/server/service/resource/index.ts +0 -7
  240. package/server/service/resource/resource-mutation.ts +0 -137
  241. package/server/service/resource/resource-query.ts +0 -50
  242. package/server/service/resource/resource-type.ts +0 -41
  243. package/server/service/resource/resource.ts +0 -82
  244. package/server/service/task/index.ts +0 -6
  245. package/server/service/task/task-mutation.ts +0 -135
  246. package/server/service/task/task-query.ts +0 -169
  247. package/server/service/task/task-type.ts +0 -75
  248. package/server/service/task/task.ts +0 -130
  249. package/server/service/task-resource/index.ts +0 -7
  250. package/server/service/task-resource/task-resource-mutation.ts +0 -140
  251. package/server/service/task-resource/task-resource-query.ts +0 -36
  252. package/server/service/task-resource/task-resource-type.ts +0 -41
  253. package/server/service/task-resource/task-resource.ts +0 -51
  254. package/server/service/worker-type/index.ts +0 -6
  255. package/server/service/worker-type/worker-type-mutation.ts +0 -66
  256. package/server/service/worker-type/worker-type-query.ts +0 -47
  257. package/server/service/worker-type/worker-type-type.ts +0 -26
  258. package/server/service/worker-type/worker-type.ts +0 -68
  259. package/server/tsconfig.json +0 -10
@@ -1,201 +0,0 @@
1
- import '@material/web/icon/icon.js'
2
- import '@operato/data-grist/ox-grist.js'
3
-
4
- import gql from 'graphql-tag'
5
- import { css, html, LitElement } from 'lit'
6
- import { customElement, property, query } from 'lit/decorators.js'
7
-
8
- import { DataGrist } from '@operato/data-grist/ox-grist.js'
9
- import { client } from '@operato/graphql'
10
- import { ButtonContainerStyles } from '@operato/styles'
11
- import { FetchOption } from '@operato/data-grist'
12
- import { notify } from '@operato/layout'
13
-
14
- @customElement('inspection-part-popup')
15
- class InspectionPartPopup extends LitElement {
16
- static styles = [
17
- ButtonContainerStyles,
18
- css`
19
- :host {
20
- display: flex;
21
- flex-direction: column;
22
-
23
- background-color: var(--md-sys-color-surface);
24
- }
25
-
26
- ox-grist {
27
- flex: 1;
28
- }
29
- `
30
- ]
31
-
32
- @property({ type: Object }) inspectionDrawingType: any
33
- @property({ type: Object }) gristConfig: any
34
-
35
- @query('ox-grist') grist!: DataGrist
36
-
37
- render() {
38
- return html`
39
- <ox-grist .mode=${'GRID'} .config=${this.gristConfig} .fetchHandler=${this.fetchHandler.bind(this)}></ox-grist>
40
- <div class="button-container">
41
- <button danger @click=${this._deleteInspectionPart.bind(this)}><md-icon>delete</md-icon>삭제</button>
42
- <button @click=${this._updateInspectionPart.bind(this)}><md-icon>save</md-icon>저장</button>
43
- </div>
44
- `
45
- }
46
-
47
- async firstUpdated() {
48
- this.gristConfig = {
49
- columns: [
50
- { type: 'gutter', gutterName: 'row-selector', multiple: true },
51
- {
52
- type: 'gutter',
53
- gutterName: 'button',
54
- fixed: true,
55
- icon: 'add',
56
- handlers: {
57
- click: 'record-copy'
58
- }
59
- },
60
- { type: 'gutter', gutterName: 'sequence' },
61
- {
62
- type: 'gutter',
63
- gutterName: 'button',
64
- icon: 'arrow_upward',
65
- handlers: {
66
- click: 'move-up'
67
- }
68
- },
69
- {
70
- type: 'gutter',
71
- gutterName: 'button',
72
- icon: 'arrow_downward',
73
- handlers: {
74
- click: 'move-down'
75
- }
76
- },
77
- {
78
- type: 'number',
79
- name: 'sequence',
80
- hidden: true
81
- },
82
- {
83
- type: 'string',
84
- name: 'id',
85
- hidden: true
86
- },
87
- {
88
- type: 'string',
89
- name: 'name',
90
- header: '검측 부위',
91
- record: {
92
- editable: true
93
- },
94
- width: 300
95
- }
96
- ],
97
- rows: {
98
- selectable: {
99
- multiple: true
100
- }
101
- },
102
- pagination: {
103
- infinite: true
104
- },
105
- sorters: [{ name: 'sequence' }]
106
- }
107
- }
108
-
109
- async fetchHandler({ page, limit, sorters = [] }: FetchOption) {
110
- const response = await client.query({
111
- query: gql`
112
- query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
113
- inspectionParts(filters: $filters, pagination: $pagination, sortings: $sortings) {
114
- items {
115
- id
116
- sequence
117
- name
118
- }
119
- }
120
- }
121
- `,
122
- variables: {
123
- filters: {
124
- name: 'inspectionDrawingTypeId',
125
- value: this.inspectionDrawingType.id,
126
- operator: 'eq'
127
- },
128
- sortings: [{ name: 'sequence' }]
129
- }
130
- })
131
-
132
- return {
133
- total: response.data.inspectionParts.total || 0,
134
- records: response.data.inspectionParts.items || []
135
- }
136
- }
137
-
138
- private async _deleteInspectionPart() {
139
- if (confirm('삭제하시겠습니까?')) {
140
- const ids = this.grist.selected.map(record => record.id)
141
- if (ids && ids.length > 0) {
142
- const response = await client.mutate({
143
- mutation: gql`
144
- mutation ($ids: [String!]!) {
145
- deleteInspectionParts(ids: $ids)
146
- }
147
- `,
148
- variables: {
149
- ids
150
- }
151
- })
152
-
153
- if (!response.errors) {
154
- this.grist.fetch()
155
- notify({ message: '삭제되었습니다.' })
156
- }
157
- }
158
- }
159
- }
160
-
161
- async _updateInspectionPart() {
162
- let patches = this.grist.dirtyData.records
163
- if (patches) {
164
- patches = patches.map(patch => {
165
- const { __origin__: { __typename, ...patchField } = {}, __dirtyfields__ } = patch
166
-
167
- for (let key in __dirtyfields__) {
168
- patchField[key] = __dirtyfields__[key].after
169
- }
170
-
171
- return patchField
172
- })
173
-
174
- const response = await client.mutate({
175
- mutation: gql`
176
- mutation UpdateMultipleInspectionPart($inspectionDrawingTypeId: String!, $patches: [InspectionPartPatch!]!) {
177
- updateMultipleInspectionPart(inspectionDrawingTypeId: $inspectionDrawingTypeId, patches: $patches) {
178
- id
179
- }
180
- }
181
- `,
182
- variables: {
183
- inspectionDrawingTypeId: this.inspectionDrawingType.id,
184
- patches
185
- }
186
- })
187
-
188
- if (!response.errors) {
189
- this.grist.fetch()
190
- notify({ message: '저장되었습니다.' })
191
- this.requestRefresh()
192
- } else {
193
- notify({ message: '저장에 실패하였습니다.', level: 'error' })
194
- }
195
- }
196
- }
197
-
198
- requestRefresh() {
199
- this.dispatchEvent(new CustomEvent('requestRefresh'))
200
- }
201
- }
@@ -1,97 +0,0 @@
1
- import '@material/web/button/elevated-button.js'
2
- import '@operato/data-grist'
3
-
4
- import gql from 'graphql-tag'
5
- import { css, html, LitElement } from 'lit'
6
- import { property, state } from 'lit/decorators.js'
7
-
8
- import { client } from '@operato/graphql'
9
- import { i18next } from '@operato/i18n'
10
- import { isMobileDevice } from '@operato/utils'
11
-
12
- export class ResourceImporter extends LitElement {
13
- static styles = [
14
- css`
15
- :host {
16
- display: flex;
17
- flex-direction: column;
18
-
19
- background-color: #fff;
20
- }
21
-
22
- ox-grist {
23
- flex: 1;
24
- }
25
-
26
- .button-container {
27
- display: flex;
28
- margin-left: auto;
29
- padding: var(--padding-default);
30
- }
31
-
32
- md-elevated-button {
33
- margin-left: var(--margin-default);
34
- }
35
- `
36
- ]
37
-
38
- @state() private resources: any[] = []
39
- @state() private columns = {
40
- list: { fields: ['name', 'description'] },
41
- pagination: { infinite: true },
42
- columns: [
43
- {
44
- type: 'string',
45
- name: 'name',
46
- header: i18next.t('field.name'),
47
- width: 150
48
- },
49
- {
50
- type: 'string',
51
- name: 'description',
52
- header: i18next.t('field.description'),
53
- width: 200
54
- },
55
- {
56
- type: 'checkbox',
57
- name: 'active',
58
- header: i18next.t('field.active'),
59
- width: 60
60
- }
61
- ]
62
- }
63
-
64
- render() {
65
- return html`
66
- <ox-grist
67
- .mode=${isMobileDevice() ? 'LIST' : 'GRID'}
68
- .config=${this.columns}
69
- .data=${
70
- {
71
- records: this.resources
72
- }
73
- }
74
- ></ox-grist>
75
-
76
- <div class="button-container">
77
- <md-elevated-button raised @click="${this.save.bind(this)}">${i18next.t('button.save')}</md-elevated-button>
78
- </div>
79
- `
80
- }
81
-
82
- private async save() {
83
- const response = await client.mutate({
84
- mutation: gql`
85
- mutation importResources($resources: [ResourcePatch!]!) {
86
- importResources(resources: $resources)
87
- }
88
- `,
89
- variables: { resources: this.resources }
90
- })
91
-
92
- if (response.errors?.length) return
93
-
94
- this.dispatchEvent(new CustomEvent('imported'))
95
- }
96
- }
97
-
@@ -1,356 +0,0 @@
1
- import '@material/web/icon/icon.js'
2
- import '@operato/data-grist'
3
-
4
- import { CommonButtonStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'
5
- import { PageView, store } from '@operato/shell'
6
- import { css, html } from 'lit'
7
- import { customElement, property, query, state } from 'lit/decorators.js'
8
- import { ScopedElementsMixin } from '@open-wc/scoped-elements'
9
- import {
10
- ColumnConfig,
11
- DataGrist,
12
- FetchOption,
13
- SortersControl
14
- } from '@operato/data-grist'
15
- import { client } from '@operato/graphql'
16
- import { i18next, localize } from '@operato/i18n'
17
- import { notify, openPopup } from '@operato/layout'
18
- import { OxPopup, OxPrompt } from '@operato/popup'
19
- import { isMobileDevice } from '@operato/utils'
20
-
21
- import { connect } from 'pwa-helpers/connect-mixin'
22
- import gql from 'graphql-tag'
23
-
24
- import { ResourceImporter } from './resource-importer'
25
-
26
- @customElement('resource-list-page')
27
- export class ResourceListPage extends connect(store)(localize(i18next)(ScopedElementsMixin(PageView))) {
28
-
29
- static styles = [
30
- ScrollbarStyles,
31
- CommonGristStyles,
32
- css`
33
- :host {
34
- display: flex;
35
-
36
- width: 100%;
37
-
38
- --grid-record-emphasized-background-color: red;
39
- --grid-record-emphasized-color: yellow;
40
- }
41
- `
42
- ]
43
-
44
- static get scopedElements() {
45
- return {
46
- 'resource-importer': ResourceImporter
47
- }
48
- }
49
-
50
- @state() private gristConfig: any
51
- @state() private mode: 'CARD' | 'GRID' | 'LIST' = isMobileDevice() ? 'CARD' : 'GRID'
52
-
53
- @query('ox-grist') private grist!: DataGrist
54
- @query('#sorter-control') private sortersControl!: OxPopup
55
-
56
- get context() {
57
- return {
58
- title: i18next.t('title.resource list'),
59
- search: {
60
- handler: (search: string) => {
61
- this.grist.searchText = search
62
- },
63
- value: this.grist.searchText
64
- },
65
- filter: {
66
- handler: () => {
67
- this.grist.toggleHeadroom()
68
- }
69
- },
70
- help: 'project/resource',
71
- actions: [
72
- {
73
- title: i18next.t('button.save'),
74
- action: this.updateResource.bind(this),
75
- ...CommonButtonStyles.save
76
- },
77
- {
78
- title: i18next.t('button.delete'),
79
- action: this.deleteResource.bind(this),
80
- ...CommonButtonStyles.delete
81
- }
82
- ],
83
- exportable: {
84
- name: i18next.t('title.resource list'),
85
- data: this.exportHandler.bind(this)
86
- },
87
- importable: {
88
- handler: this.importHandler.bind(this)
89
- }
90
- }
91
- }
92
-
93
- render() {
94
- const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID')
95
-
96
- return html`
97
- <ox-grist
98
- .mode=${mode}
99
- .config=${this.gristConfig}
100
- .fetchHandler=${this.fetchHandler.bind(this)}
101
- >
102
- <div slot="headroom">
103
- <div id="filters">
104
- <ox-filters-form autofocus></ox-filters-form>
105
- </div>
106
-
107
- <div id="sorters">
108
- Sort
109
- <md-icon
110
- @click=${e => {
111
- const target = e.currentTarget
112
- this.sortersControl.open({
113
- right: 0,
114
- top: target.offsetTop + target.offsetHeight
115
- })
116
- }}
117
- >expand_more</md-icon
118
- >
119
- <ox-popup id="sorter-control">
120
- <ox-sorters-control> </ox-sorters-control>
121
- </ox-popup>
122
- </div>
123
-
124
- <div id="modes">
125
- <md-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</md-icon>
126
- <md-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</md-icon>
127
- <md-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</md-icon>
128
- </div>
129
- </div>
130
- </ox-grist>
131
- `
132
- }
133
-
134
- async pageInitialized(lifecycle: any) {
135
- this.gristConfig = {
136
- list: {
137
- fields: ['name', 'description'],
138
- details: ['active', 'updatedAt']
139
- },
140
- columns: [
141
- { type: 'gutter', gutterName: 'sequence' },
142
- { type: 'gutter', gutterName: 'row-selector', multiple: true },
143
- {
144
- type: 'string',
145
- name: 'name',
146
- header: i18next.t('field.name'),
147
- record: {
148
- editable: true
149
- },
150
- filter: 'search',
151
- sortable: true,
152
- width: 150
153
- },
154
- {
155
- type: 'string',
156
- name: 'description',
157
- header: i18next.t('field.description'),
158
- record: {
159
- editable: true
160
- },
161
- filter: 'search',
162
- width: 200
163
- },
164
- {
165
- type: 'checkbox',
166
- name: 'active',
167
- label: true,
168
- header: i18next.t('field.active'),
169
- record: {
170
- editable: true
171
- },
172
- filter: true,
173
- sortable: true,
174
- width: 60
175
- },
176
- {
177
- type: 'resource-object',
178
- name: 'updater',
179
- header: i18next.t('field.updater'),
180
- record: {
181
- editable: false
182
- },
183
- sortable: true,
184
- width: 120
185
- },
186
- {
187
- type: 'datetime',
188
- name: 'updatedAt',
189
- header: i18next.t('field.updated_at'),
190
- record: {
191
- editable: false
192
- },
193
- sortable: true,
194
- width: 180
195
- }
196
- ],
197
- rows: {
198
- selectable: {
199
- multiple: true
200
- }
201
- },
202
- sorters: [
203
- {
204
- name: 'name'
205
- }
206
- ]
207
- }
208
- }
209
-
210
- async pageUpdated(changes: any, lifecycle: any) {
211
- if (this.active) {
212
- // do something here when this page just became as active
213
- }
214
- }
215
-
216
- async fetchHandler({ page = 1, limit = 100, sortings = [], filters = [] }: FetchOption) {
217
- const response = await client.query({
218
- query: gql`
219
- query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
220
- responses: resources(filters: $filters, pagination: $pagination, sortings: $sortings) {
221
- items {
222
- id
223
- name
224
- description
225
- active
226
- updater {
227
- id
228
- name
229
- }
230
- updatedAt
231
- }
232
- total
233
- }
234
- }
235
- `,
236
- variables: {
237
- filters,
238
- pagination: { page, limit },
239
- sortings
240
- }
241
- })
242
-
243
- return {
244
- total: response.data.responses.total || 0,
245
- records: response.data.responses.items || []
246
- }
247
- }
248
-
249
- private async deleteResource() {
250
- if (
251
- await OxPrompt.open({
252
- title: i18next.t('text.are_you_sure'),
253
- text: i18next.t('text.sure_to_x', { x: i18next.t('text.delete') }),
254
- confirmButton: { text: i18next.t('button.confirm') },
255
- cancelButton: { text: i18next.t('button.cancel') }
256
- })
257
- ) {
258
- const ids = this.grist.selected.map(record => record.id)
259
- if (ids && ids.length > 0) {
260
- const response = await client.mutate({
261
- mutation: gql`
262
- mutation ($ids: [String!]!) {
263
- deleteResources(ids: $ids)
264
- }
265
- `,
266
- variables: {
267
- ids
268
- }
269
- })
270
-
271
- if (!response.errors) {
272
- this.grist.fetch()
273
- notify({
274
- message: i18next.t('text.info_x_successfully', { x: i18next.t('text.delete') })
275
- })
276
- }
277
- }
278
- }
279
- }
280
-
281
- private async updateResource() {
282
- let patches = this.grist.dirtyRecords
283
- if (patches && patches.length) {
284
- patches = patches.map(patch => {
285
- let patchField: any = patch.id ? { id: patch.id } : {}
286
- const dirtyFields = patch.__dirtyfields__
287
- for (let key in dirtyFields) {
288
- patchField[key] = dirtyFields[key].after
289
- }
290
- patchField.cuFlag = patch.__dirty__
291
-
292
- return patchField
293
- })
294
-
295
- const response = await client.mutate({
296
- mutation: gql`
297
- mutation ($patches: [ResourcePatch!]!) {
298
- updateMultipleResource(patches: $patches) {
299
- name
300
- }
301
- }
302
- `,
303
- variables: {
304
- patches
305
- }
306
- })
307
-
308
- if (!response.errors) {
309
- this.grist.fetch()
310
- }
311
- }
312
- }
313
-
314
- private async exportHandler() {
315
- const exportTargets = this.grist.selected.length ? this.grist.selected : this.grist.dirtyData.records
316
- const targetFieldSet = new Set([
317
- 'id',
318
- 'name',
319
- 'description',
320
- 'active'
321
- ])
322
-
323
- return exportTargets.map(resource => {
324
- let tempObj = {}
325
- for (const field of targetFieldSet) {
326
- tempObj[field] = resource[field]
327
- }
328
-
329
- return tempObj
330
- })
331
- }
332
-
333
- private async importHandler(records) {
334
- const popup = openPopup(
335
- html`
336
- <resource-importer
337
- .resources=${records}
338
- @imported=${() => {
339
- history.back()
340
- this.grist.fetch()
341
- }}
342
- ></resource-importer>
343
- `,
344
- {
345
- backdrop: true,
346
- size: 'large',
347
- title: i18next.t('title.import resource')
348
- }
349
- )
350
-
351
- popup.onclosed = () => {
352
- this.grist.fetch()
353
- }
354
- }
355
- }
356
-