@dssp/dkpi 1.0.0-alpha.5 → 1.0.0-alpha.50

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 (128) hide show
  1. package/assets/favicon.ico +0 -0
  2. package/assets/manifest/apple-1024.png +0 -0
  3. package/assets/manifest/apple-120.png +0 -0
  4. package/assets/manifest/apple-152.png +0 -0
  5. package/assets/manifest/apple-167.png +0 -0
  6. package/assets/manifest/apple-180.png +0 -0
  7. package/assets/manifest/apple-touch-icon.png +0 -0
  8. package/assets/manifest/badge-128x128.png +0 -0
  9. package/assets/manifest/chrome-splashscreen-icon-384x384.png +0 -0
  10. package/assets/manifest/chrome-touch-icon-192x192.png +0 -0
  11. package/assets/manifest/icon-128x128.png +0 -0
  12. package/assets/manifest/icon-192x192.png +0 -0
  13. package/assets/manifest/icon-512x512.png +0 -0
  14. package/assets/manifest/icon-72x72.png +0 -0
  15. package/assets/manifest/icon-96x96.png +0 -0
  16. package/assets/manifest/image-metaog.png +0 -0
  17. package/assets/manifest/maskable_icon.png +0 -0
  18. package/assets/manifest/ms-icon-144x144.png +0 -0
  19. package/assets/manifest/ms-touch-icon-144x144-precomposed.png +0 -0
  20. package/assets/videos/intro.mp4 +0 -0
  21. package/dist-client/bootstrap.js +64 -4
  22. package/dist-client/bootstrap.js.map +1 -1
  23. package/dist-client/components/kpi-single-boxplot-chart.d.ts +24 -0
  24. package/dist-client/components/kpi-single-boxplot-chart.js +317 -0
  25. package/dist-client/components/kpi-single-boxplot-chart.js.map +1 -0
  26. package/dist-client/components/sv-pagenation-control.d.ts +18 -0
  27. package/dist-client/components/sv-pagenation-control.js +142 -0
  28. package/dist-client/components/sv-pagenation-control.js.map +1 -0
  29. package/dist-client/icons/menu-icons.d.ts +6 -0
  30. package/dist-client/icons/menu-icons.js +42 -0
  31. package/dist-client/icons/menu-icons.js.map +1 -1
  32. package/dist-client/menu.d.ts +23 -1
  33. package/dist-client/menu.js +57 -2
  34. package/dist-client/menu.js.map +1 -1
  35. package/dist-client/pages/kpi-metric-value/kpi-metric-value-editor-page.d.ts +58 -0
  36. package/dist-client/pages/kpi-metric-value/kpi-metric-value-editor-page.js +731 -0
  37. package/dist-client/pages/kpi-metric-value/kpi-metric-value-editor-page.js.map +1 -0
  38. package/dist-client/pages/kpi-metric-value/kpi-metric-value-importer.d.ts +23 -0
  39. package/dist-client/pages/kpi-metric-value/kpi-metric-value-importer.js +76 -0
  40. package/dist-client/pages/kpi-metric-value/kpi-metric-value-importer.js.map +1 -0
  41. package/dist-client/pages/kpi-metric-value/kpi-metric-value-list-page.d.ts +69 -0
  42. package/dist-client/pages/kpi-metric-value/kpi-metric-value-list-page.js +385 -0
  43. package/dist-client/pages/kpi-metric-value/kpi-metric-value-list-page.js.map +1 -0
  44. package/dist-client/pages/kpi-metric-value/kpi-metric-value-manual-entry-form.d.ts +12 -0
  45. package/dist-client/pages/kpi-metric-value/kpi-metric-value-manual-entry-form.js +174 -0
  46. package/dist-client/pages/kpi-metric-value/kpi-metric-value-manual-entry-form.js.map +1 -0
  47. package/dist-client/pages/kpi-metric-value/kpi-metric-value-manual-entry-page.d.ts +41 -0
  48. package/dist-client/pages/kpi-metric-value/kpi-metric-value-manual-entry-page.js +191 -0
  49. package/dist-client/pages/kpi-metric-value/kpi-metric-value-manual-entry-page.js.map +1 -0
  50. package/dist-client/pages/kpi-value/kpi-value-importer.d.ts +23 -0
  51. package/dist-client/pages/kpi-value/kpi-value-importer.js +93 -0
  52. package/dist-client/pages/kpi-value/kpi-value-importer.js.map +1 -0
  53. package/dist-client/pages/kpi-value/kpi-value-list-page.d.ts +72 -0
  54. package/dist-client/pages/kpi-value/kpi-value-list-page.js +465 -0
  55. package/dist-client/pages/kpi-value/kpi-value-list-page.js.map +1 -0
  56. package/dist-client/pages/project-complete-tabs/pc-tab1-plan.d.ts +13 -0
  57. package/dist-client/pages/project-complete-tabs/pc-tab1-plan.js +248 -0
  58. package/dist-client/pages/project-complete-tabs/pc-tab1-plan.js.map +1 -0
  59. package/dist-client/pages/project-complete-tabs/pc-tab2-rating.d.ts +10 -0
  60. package/dist-client/pages/project-complete-tabs/pc-tab2-rating.js +229 -0
  61. package/dist-client/pages/project-complete-tabs/pc-tab2-rating.js.map +1 -0
  62. package/dist-client/pages/project-complete-tabs/pc-tab3-upload.d.ts +12 -0
  63. package/dist-client/pages/project-complete-tabs/pc-tab3-upload.js +213 -0
  64. package/dist-client/pages/project-complete-tabs/pc-tab3-upload.js.map +1 -0
  65. package/dist-client/pages/sv-project-complete.d.ts +22 -0
  66. package/dist-client/pages/sv-project-complete.js +213 -0
  67. package/dist-client/pages/sv-project-complete.js.map +1 -0
  68. package/dist-client/pages/sv-project-completed-list.d.ts +24 -0
  69. package/dist-client/pages/sv-project-completed-list.js +357 -0
  70. package/dist-client/pages/sv-project-completed-list.js.map +1 -0
  71. package/dist-client/pages/sv-project-detail.d.ts +13 -0
  72. package/dist-client/pages/sv-project-detail.js +494 -0
  73. package/dist-client/pages/sv-project-detail.js.map +1 -0
  74. package/dist-client/pages/sv-project-list.d.ts +157 -0
  75. package/dist-client/pages/sv-project-list.js +431 -0
  76. package/dist-client/pages/sv-project-list.js.map +1 -0
  77. package/dist-client/route.d.ts +1 -1
  78. package/dist-client/route.js +22 -1
  79. package/dist-client/route.js.map +1 -1
  80. package/dist-client/shared/complete-api.d.ts +5 -0
  81. package/dist-client/shared/complete-api.js +125 -0
  82. package/dist-client/shared/complete-api.js.map +1 -0
  83. package/dist-client/shared/func.d.ts +2 -0
  84. package/dist-client/shared/func.js +22 -0
  85. package/dist-client/shared/func.js.map +1 -0
  86. package/dist-client/themes/dark.css +24 -24
  87. package/dist-client/themes/light.css +23 -23
  88. package/dist-client/tsconfig.tsbuildinfo +1 -1
  89. package/dist-client/viewparts/menu-tools.d.ts +37 -1
  90. package/dist-client/viewparts/menu-tools.js +348 -15
  91. package/dist-client/viewparts/menu-tools.js.map +1 -1
  92. package/dist-server/index.d.ts +2 -0
  93. package/dist-server/index.js +5 -0
  94. package/dist-server/index.js.map +1 -1
  95. package/dist-server/migrations/index.d.ts +1 -0
  96. package/dist-server/migrations/index.js +12 -0
  97. package/dist-server/migrations/index.js.map +1 -0
  98. package/dist-server/scripts/calculate-kpi-scores.d.ts +10 -0
  99. package/dist-server/scripts/calculate-kpi-scores.js +271 -0
  100. package/dist-server/scripts/calculate-kpi-scores.js.map +1 -0
  101. package/dist-server/scripts/load-grade-data-migration.d.ts +10 -0
  102. package/dist-server/scripts/load-grade-data-migration.js +194 -0
  103. package/dist-server/scripts/load-grade-data-migration.js.map +1 -0
  104. package/dist-server/scripts/propagate-parent-kpi-values.d.ts +10 -0
  105. package/dist-server/scripts/propagate-parent-kpi-values.js +440 -0
  106. package/dist-server/scripts/propagate-parent-kpi-values.js.map +1 -0
  107. package/dist-server/service/index.d.ts +6 -0
  108. package/dist-server/service/index.js +21 -0
  109. package/dist-server/service/index.js.map +1 -0
  110. package/dist-server/service/kpi-metric-value/index.d.ts +4 -0
  111. package/dist-server/service/kpi-metric-value/index.js +8 -0
  112. package/dist-server/service/kpi-metric-value/index.js.map +1 -0
  113. package/dist-server/service/kpi-metric-value/kpi-metric-value-mutation.d.ts +7 -0
  114. package/dist-server/service/kpi-metric-value/kpi-metric-value-mutation.js +112 -0
  115. package/dist-server/service/kpi-metric-value/kpi-metric-value-mutation.js.map +1 -0
  116. package/dist-server/service/kpi-metric-value/kpi-metric-value-query.d.ts +7 -0
  117. package/dist-server/service/kpi-metric-value/kpi-metric-value-query.js +47 -0
  118. package/dist-server/service/kpi-metric-value/kpi-metric-value-query.js.map +1 -0
  119. package/dist-server/service/kpi-value/index.d.ts +3 -0
  120. package/dist-server/service/kpi-value/index.js +7 -0
  121. package/dist-server/service/kpi-value/index.js.map +1 -0
  122. package/dist-server/service/kpi-value/kpi-value-query.d.ts +7 -0
  123. package/dist-server/service/kpi-value/kpi-value-query.js +47 -0
  124. package/dist-server/service/kpi-value/kpi-value-query.js.map +1 -0
  125. package/dist-server/tsconfig.tsbuildinfo +1 -1
  126. package/package.json +62 -51
  127. package/schema.graphql +11497 -3215
  128. package/things-factory.config.js +7 -1
@@ -0,0 +1,494 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { navigate, PageView } from '@operato/shell';
3
+ import { css, html } from 'lit';
4
+ import { customElement, state } from 'lit/decorators.js';
5
+ import { ScopedElementsMixin } from '@open-wc/scoped-elements';
6
+ import { PROJECT_STATE, ProjectState } from './sv-project-list';
7
+ import { client } from '@operato/graphql';
8
+ import gql from 'graphql-tag';
9
+ let SvProjectDetailPage = class SvProjectDetailPage extends ScopedElementsMixin(PageView) {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.project = {};
13
+ }
14
+ get context() {
15
+ return {
16
+ title: '프로젝트 상세 정보'
17
+ };
18
+ }
19
+ render() {
20
+ var _a, _b, _c, _d, _e, _f;
21
+ return html `
22
+ <div content>
23
+ <div left>
24
+ <div class="card">
25
+ <div class="card-title">
26
+ <div>${this.project.name}</div>
27
+ <div class="triangle"></div>
28
+ </div>
29
+
30
+ <div class="top-info" style="margin-top: 10px;">
31
+ <img pic src=${((_a = this.project.mainPhoto) === null || _a === void 0 ? void 0 : _a.fullpath) || '/assets/images/no-image.png'} alt="project" />
32
+ <div class="info">
33
+ <div class="address">• ${(_b = this.project.buildingComplex) === null || _b === void 0 ? void 0 : _b.address}</div>
34
+ <div class="row">
35
+ <div class="label">• 공사기간</div>
36
+ <div class="value">${this.project.startDate} ~ ${this.project.endDate}</div>
37
+ </div>
38
+ <div class="row">
39
+ <div class="label">• 현장상태</div>
40
+ <div class="value status-value">${PROJECT_STATE[this.project.state]}</div>
41
+ </div>
42
+ <div class="row">
43
+ <div class="label">• 요청상세</div>
44
+ <div class="value bold">???</div>
45
+ </div>
46
+ <div class="row">
47
+ <div class="label">• 알람</div>
48
+ <div class="value">???</div>
49
+ </div>
50
+ </div>
51
+ </div>
52
+
53
+ <div class="detail-grid">
54
+ <div class="grid-item row">
55
+ <div class="label">• 공사비</div>
56
+ <div class="value">${((_d = (_c = this.project.buildingComplex) === null || _c === void 0 ? void 0 : _c.constructionCost) === null || _d === void 0 ? void 0 : _d.toLocaleString()) || '-'} 원</div>
57
+ </div>
58
+ <div class="grid-item row">
59
+ <div class="label">• 연면적</div>
60
+ <div class="value">${((_f = (_e = this.project.buildingComplex) === null || _e === void 0 ? void 0 : _e.area) === null || _f === void 0 ? void 0 : _f.toLocaleString()) || '-'} ㎡</div>
61
+ </div>
62
+ <div class="grid-item row">
63
+ <div class="label">• 용적률</div>
64
+ <div class="value">??? %</div>
65
+ </div>
66
+ <div class="grid-item row">
67
+ <div class="label">• 투입인력</div>
68
+ <div class="value">??? 명</div>
69
+ </div>
70
+ </div>
71
+ </div>
72
+
73
+ <div class="card">
74
+ <div class="card-title">
75
+ <div>입력 대기 중</div>
76
+ <div class="triangle"></div>
77
+ </div>
78
+ <div class="sub-desc">
79
+ 현재 입력 기한이 도래했거나, 입력이 지연되고 있는 KPI 항목입니다. 해당 항목에 대한 데이터를 입력 해 주시기 바랍니다.
80
+ </div>
81
+
82
+ <div class="list-block">
83
+ <div class="list-title">• 입력 대기 중 2건</div>
84
+ <div class="list-text"># 2033312-Y5.1 : 검수자재 불합격률</div>
85
+ <div class="list-text"># 2033312-Y5.1 : 품질시험 불합격 건수</div>
86
+ </div>
87
+ <div class="list-block">
88
+ <div class="list-title">• 입력 기한 초과 1건</div>
89
+ <div class="list-text">
90
+ # 2033312-Y5.2 : 검측 불합격률 <span class="warn">2025.2.12 <md-icon>report</md-icon></span>
91
+ </div>
92
+ </div>
93
+ <div class="list-block">
94
+ <div class="list-title">• 입력 예정 4건</div>
95
+ <div class="list-text"># 2033320-Y4.32 : 연면적 대비 공기입력</div>
96
+ <div class="list-text"># 2012345-Y4.32 : 책임감리원의 일정성과 수준 평가</div>
97
+ <div class="list-text"># 2035641-Y5.22 : 설계 변경에 따른 공기 증감률</div>
98
+ <div class="list-text"># 2096412-Y5.31 : 현장별 일정 이탈 수준</div>
99
+ </div>
100
+ <div class="list-block">
101
+ <div class="list-title">• 입력 기한 없음 3건</div>
102
+ <div class="list-text"># 2033320-Y4.32 : 연면적 대비 공기입력</div>
103
+ <div class="list-text"># 2012345-Y4.32 : 책임감리원의 일정성과 수준 평가</div>
104
+ <div class="list-text"># 2035641-Y5.22 : 설계 변경에 따른 공기 증감률</div>
105
+ </div>
106
+ </div>
107
+ </div>
108
+
109
+ <div right>
110
+ ${this.project.state === ProjectState.ONGOING
111
+ ? html `
112
+ <div class="button-line">
113
+ <div class="ghost-btn" @click=${() => navigate(`project-update/${this.project.id}`)}>
114
+ <md-icon slot="">assignment</md-icon>
115
+ <div>프로젝트 수정</div>
116
+ </div>
117
+ <div class="ghost-btn" @click=${() => navigate(`project-complete/${this.project.id}`)}>
118
+ <md-icon slot="">assignment_turned_in</md-icon>
119
+ <div>프로젝트 완공 처리</div>
120
+ </div>
121
+ </div>
122
+ `
123
+ : ''}
124
+
125
+ <div class="card kpi-box">
126
+ <div class="kpi-header">
127
+ <div>종합 KPI</div>
128
+ <div class="triangle"></div>
129
+ </div>
130
+ <div class="kpi-desc">
131
+ 프로젝트의 생산성, 품질, 안전, 환경, 비용, 일정 등 6개의 성과를 종합한 종합KPI 포인트 정보와 각 지표별
132
+ 분포차트입니다.
133
+ </div>
134
+
135
+ <div class="kpi-summary">
136
+ <div class="mini-boxplot" title="boxplot placeholder">
137
+ <div class="boxplot-area">boxplot area</div>
138
+
139
+ <div class="boxplot-point">
140
+ <div class="value">???</div>
141
+ <div class="label">Point</div>
142
+ </div>
143
+ </div>
144
+
145
+ <div class="spider-area">spider chart</div>
146
+ </div>
147
+ </div>
148
+
149
+ <div class="card group-box">
150
+ <div class="kpi-header">
151
+ <div>그룹별 분포</div>
152
+ <div class="triangle"></div>
153
+ </div>
154
+ <div class="desc">
155
+ Boxplot(박스플롯)은 각 카테고리별로 값의 분포(최소, 1사분위, 중앙값, 3사분위, 최대, 평균, 이상치 등)를 보여줍니다.
156
+ 박스는 중앙 50% 구간, 수염은 전체 범위, 굵은 검정색 가로선은 중앙값(메디안), 초록색 원은 평균값(Mean)을 의미합니다.
157
+ 이 프로젝트의 값은 진한 오렌지색 원으로 별도 강조되어 표시되며, 중앙값/평균과 다를 수 있습니다.
158
+ </div>
159
+ <div class="group-chart"></div>
160
+ </div>
161
+ </div>
162
+ </div>
163
+ `;
164
+ }
165
+ async pageUpdated(changes, lifecycle) {
166
+ if (this.active) {
167
+ await this.initProject(lifecycle.resourceId);
168
+ }
169
+ }
170
+ async initProject(projectId = '') {
171
+ var _a;
172
+ const response = await client.query({
173
+ query: gql `
174
+ query Project($id: String!) {
175
+ project(id: $id) {
176
+ id
177
+ name
178
+ state
179
+ startDate
180
+ endDate
181
+ projectType
182
+ mainPhoto {
183
+ fullpath
184
+ }
185
+ totalProgress
186
+ weeklyProgress
187
+ kpi
188
+ inspPassRate
189
+ robotProgressRate
190
+ structuralSafetyRate
191
+ robotCount
192
+ buildingComplex {
193
+ id
194
+ address
195
+ latitude
196
+ longitude
197
+ area
198
+ clientCompany
199
+ constructionCompany
200
+ supervisoryCompany
201
+ designCompany
202
+ drawing {
203
+ id
204
+ name
205
+ fullpath
206
+ }
207
+ constructionType
208
+ constructionCost
209
+ etc
210
+ notice
211
+ householdCount
212
+ buildingCount
213
+ virtualTourLink
214
+ buildings {
215
+ id
216
+ name
217
+ floorCount
218
+ }
219
+ }
220
+ }
221
+ }
222
+ `,
223
+ variables: { id: projectId }
224
+ });
225
+ if (response.errors)
226
+ return;
227
+ this.project = ((_a = response.data) === null || _a === void 0 ? void 0 : _a.project) || {};
228
+ }
229
+ };
230
+ SvProjectDetailPage.styles = [
231
+ css `
232
+ :host {
233
+ display: flex;
234
+ flex-direction: column;
235
+ overflow-y: auto;
236
+
237
+ width: 100%;
238
+ height: 100%;
239
+ background-color: var(--md-sys-color-background, #f6f6f6);
240
+ }
241
+
242
+ /* content layout */
243
+ div[content] {
244
+ display: flex;
245
+ gap: 35px;
246
+ padding: 25px;
247
+ }
248
+ div[left] {
249
+ flex: 1;
250
+ display: flex;
251
+ flex-direction: column;
252
+ gap: 20px;
253
+ }
254
+ div[right] {
255
+ flex: 1;
256
+ display: flex;
257
+ flex-direction: column;
258
+ gap: 20px;
259
+ padding: 0 1px;
260
+ }
261
+
262
+ /* card */
263
+ .card {
264
+ background: #ffffff;
265
+ border-radius: 10px;
266
+ padding: 15px;
267
+ box-shadow: 3px 3px 3px 0 rgba(0, 0, 0, 0.1);
268
+ }
269
+ .card-title {
270
+ display: flex;
271
+ align-items: center;
272
+ gap: 5px;
273
+ color: #35618e;
274
+ font-weight: 700;
275
+ }
276
+ .triangle {
277
+ width: 0;
278
+ height: 0;
279
+ border-left: 6px solid transparent;
280
+ border-right: 6px solid transparent;
281
+ border-top: 8px solid #35618e;
282
+ }
283
+
284
+ /* left top info box */
285
+ .bold {
286
+ font-weight: bold;
287
+ }
288
+ .top-info {
289
+ display: flex;
290
+ gap: 10px;
291
+ }
292
+ .top-info img[pic] {
293
+ width: 284px;
294
+ height: 160px;
295
+ object-fit: fill;
296
+ background: #e5e7eb;
297
+ }
298
+ .top-info .info {
299
+ display: flex;
300
+ flex-direction: column;
301
+ gap: 15px;
302
+ padding: 10px 0;
303
+ flex: 1;
304
+ }
305
+ .row {
306
+ display: flex;
307
+ align-items: center;
308
+ gap: 10px;
309
+ }
310
+ .label {
311
+ min-width: fit-content;
312
+ color: #35618e;
313
+ font-size: 16px;
314
+ letter-spacing: -0.05em;
315
+ }
316
+ .value {
317
+ color: #212529;
318
+ font-size: 16px;
319
+ }
320
+ .status-value {
321
+ color: #4cbb49;
322
+ font-weight: 700;
323
+ }
324
+
325
+ .address {
326
+ color: #35618e;
327
+ font-size: 16px;
328
+ letter-spacing: -0.05em;
329
+ }
330
+
331
+ .detail-grid {
332
+ display: grid;
333
+ grid-template-columns: 284px 1fr;
334
+ gap: 15px 10px;
335
+ padding: 5px 0;
336
+ }
337
+ .detail-grid .grid-item .label {
338
+ width: auto;
339
+ }
340
+
341
+ /* left second card (requests) */
342
+ .sub-desc {
343
+ color: #35618e;
344
+ font-size: 14px;
345
+ letter-spacing: -0.05em;
346
+ margin-bottom: 8px;
347
+ }
348
+ .list-block {
349
+ display: flex;
350
+ flex-direction: column;
351
+ gap: 5px;
352
+ padding: 5px 25px;
353
+ }
354
+ .list-title {
355
+ color: #212529;
356
+ font-weight: 700;
357
+ font-size: 16px;
358
+ letter-spacing: -0.05em;
359
+ }
360
+ .list-text {
361
+ color: #35618e;
362
+ font-size: 16px;
363
+ letter-spacing: -0.05em;
364
+ margin-left: 8px;
365
+ }
366
+ .list-text .warn {
367
+ margin-left: 10px;
368
+ color: #e13232;
369
+
370
+ md-icon {
371
+ font-size: 17px;
372
+ width: 13px;
373
+ height: 13px;
374
+ }
375
+ }
376
+
377
+ /* right buttons */
378
+ .button-line {
379
+ display: flex;
380
+ justify-content: flex-end;
381
+ gap: 10px;
382
+ }
383
+ .ghost-btn {
384
+ display: flex;
385
+ align-items: center;
386
+ gap: 3px;
387
+ padding: 5px 10px;
388
+ background: #35618e;
389
+ color: #ffffff;
390
+ border-radius: 5px;
391
+ box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.1);
392
+ cursor: pointer;
393
+
394
+ /* Material Symbols Outlined (stroke style) */
395
+ md-icon {
396
+ font-variation-settings:
397
+ 'FILL' 0,
398
+ 'wght' 300,
399
+ 'GRAD' 0,
400
+ 'opsz' 24;
401
+ }
402
+ }
403
+
404
+ /* right KPI box */
405
+ .kpi-box {
406
+ display: flex;
407
+ flex-direction: column;
408
+ gap: 10px;
409
+ padding: 15px;
410
+ }
411
+ .kpi-header {
412
+ display: flex;
413
+ align-items: center;
414
+ gap: 5px;
415
+ color: #35618e;
416
+ font-weight: 700;
417
+ font-size: 20px;
418
+ letter-spacing: -0.05em;
419
+ }
420
+ .kpi-desc {
421
+ color: #35618e;
422
+ font-size: 13px;
423
+ letter-spacing: -0.05em;
424
+ }
425
+ .kpi-summary {
426
+ display: flex;
427
+ align-items: center;
428
+ gap: 35px;
429
+ padding: 0 30px;
430
+ }
431
+ .mini-boxplot {
432
+ width: 70px;
433
+ height: 100%;
434
+ position: relative;
435
+ }
436
+ .boxplot-area {
437
+ width: 100%;
438
+ height: 190px;
439
+ display: flex;
440
+ align-items: center;
441
+ background: #ffffff;
442
+ }
443
+
444
+ .boxplot-point {
445
+ display: flex;
446
+ flex-direction: column;
447
+ align-items: center;
448
+ gap: 6px;
449
+ color: #35618e;
450
+ }
451
+ .boxplot-point .value {
452
+ font-size: 30px;
453
+ font-weight: 700;
454
+ color: #35618e;
455
+ border-radius: 6px;
456
+ padding: 4px 8px;
457
+ }
458
+ .boxplot-point .label {
459
+ font-size: 14px;
460
+ font-weight: 300;
461
+ width: auto;
462
+ }
463
+
464
+ /* spider chart placeholder */
465
+ .spider-area {
466
+ display: flex;
467
+ align-items: center;
468
+ justify-content: center;
469
+ gap: 10px;
470
+ flex: 1;
471
+ }
472
+
473
+ /* group distribution */
474
+ .group-box .desc {
475
+ color: #35618e;
476
+ font-size: 13px;
477
+ letter-spacing: -0.05em;
478
+ margin-top: 4px;
479
+ }
480
+ .group-chart {
481
+ height: 205px;
482
+ margin-top: 25px;
483
+ }
484
+ `
485
+ ];
486
+ __decorate([
487
+ state(),
488
+ __metadata("design:type", Object)
489
+ ], SvProjectDetailPage.prototype, "project", void 0);
490
+ SvProjectDetailPage = __decorate([
491
+ customElement('sv-project-detail')
492
+ ], SvProjectDetailPage);
493
+ export { SvProjectDetailPage };
494
+ //# sourceMappingURL=sv-project-detail.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sv-project-detail.js","sourceRoot":"","sources":["../../client/pages/sv-project-detail.ts"],"names":[],"mappings":"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","sourcesContent":["import { navigate, PageLifecycle, PageView } from '@operato/shell'\nimport { css, html } from 'lit'\nimport { customElement, state } from 'lit/decorators.js'\nimport { ScopedElementsMixin } from '@open-wc/scoped-elements'\nimport { Project, PROJECT_STATE, ProjectState } from './sv-project-list'\nimport { client } from '@operato/graphql'\nimport gql from 'graphql-tag'\n\n@customElement('sv-project-detail')\nexport class SvProjectDetailPage extends ScopedElementsMixin(PageView) {\n static styles = [\n css`\n :host {\n display: flex;\n flex-direction: column;\n overflow-y: auto;\n\n width: 100%;\n height: 100%;\n background-color: var(--md-sys-color-background, #f6f6f6);\n }\n\n /* content layout */\n div[content] {\n display: flex;\n gap: 35px;\n padding: 25px;\n }\n div[left] {\n flex: 1;\n display: flex;\n flex-direction: column;\n gap: 20px;\n }\n div[right] {\n flex: 1;\n display: flex;\n flex-direction: column;\n gap: 20px;\n padding: 0 1px;\n }\n\n /* card */\n .card {\n background: #ffffff;\n border-radius: 10px;\n padding: 15px;\n box-shadow: 3px 3px 3px 0 rgba(0, 0, 0, 0.1);\n }\n .card-title {\n display: flex;\n align-items: center;\n gap: 5px;\n color: #35618e;\n font-weight: 700;\n }\n .triangle {\n width: 0;\n height: 0;\n border-left: 6px solid transparent;\n border-right: 6px solid transparent;\n border-top: 8px solid #35618e;\n }\n\n /* left top info box */\n .bold {\n font-weight: bold;\n }\n .top-info {\n display: flex;\n gap: 10px;\n }\n .top-info img[pic] {\n width: 284px;\n height: 160px;\n object-fit: fill;\n background: #e5e7eb;\n }\n .top-info .info {\n display: flex;\n flex-direction: column;\n gap: 15px;\n padding: 10px 0;\n flex: 1;\n }\n .row {\n display: flex;\n align-items: center;\n gap: 10px;\n }\n .label {\n min-width: fit-content;\n color: #35618e;\n font-size: 16px;\n letter-spacing: -0.05em;\n }\n .value {\n color: #212529;\n font-size: 16px;\n }\n .status-value {\n color: #4cbb49;\n font-weight: 700;\n }\n\n .address {\n color: #35618e;\n font-size: 16px;\n letter-spacing: -0.05em;\n }\n\n .detail-grid {\n display: grid;\n grid-template-columns: 284px 1fr;\n gap: 15px 10px;\n padding: 5px 0;\n }\n .detail-grid .grid-item .label {\n width: auto;\n }\n\n /* left second card (requests) */\n .sub-desc {\n color: #35618e;\n font-size: 14px;\n letter-spacing: -0.05em;\n margin-bottom: 8px;\n }\n .list-block {\n display: flex;\n flex-direction: column;\n gap: 5px;\n padding: 5px 25px;\n }\n .list-title {\n color: #212529;\n font-weight: 700;\n font-size: 16px;\n letter-spacing: -0.05em;\n }\n .list-text {\n color: #35618e;\n font-size: 16px;\n letter-spacing: -0.05em;\n margin-left: 8px;\n }\n .list-text .warn {\n margin-left: 10px;\n color: #e13232;\n\n md-icon {\n font-size: 17px;\n width: 13px;\n height: 13px;\n }\n }\n\n /* right buttons */\n .button-line {\n display: flex;\n justify-content: flex-end;\n gap: 10px;\n }\n .ghost-btn {\n display: flex;\n align-items: center;\n gap: 3px;\n padding: 5px 10px;\n background: #35618e;\n color: #ffffff;\n border-radius: 5px;\n box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.1);\n cursor: pointer;\n\n /* Material Symbols Outlined (stroke style) */\n md-icon {\n font-variation-settings:\n 'FILL' 0,\n 'wght' 300,\n 'GRAD' 0,\n 'opsz' 24;\n }\n }\n\n /* right KPI box */\n .kpi-box {\n display: flex;\n flex-direction: column;\n gap: 10px;\n padding: 15px;\n }\n .kpi-header {\n display: flex;\n align-items: center;\n gap: 5px;\n color: #35618e;\n font-weight: 700;\n font-size: 20px;\n letter-spacing: -0.05em;\n }\n .kpi-desc {\n color: #35618e;\n font-size: 13px;\n letter-spacing: -0.05em;\n }\n .kpi-summary {\n display: flex;\n align-items: center;\n gap: 35px;\n padding: 0 30px;\n }\n .mini-boxplot {\n width: 70px;\n height: 100%;\n position: relative;\n }\n .boxplot-area {\n width: 100%;\n height: 190px;\n display: flex;\n align-items: center;\n background: #ffffff;\n }\n\n .boxplot-point {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 6px;\n color: #35618e;\n }\n .boxplot-point .value {\n font-size: 30px;\n font-weight: 700;\n color: #35618e;\n border-radius: 6px;\n padding: 4px 8px;\n }\n .boxplot-point .label {\n font-size: 14px;\n font-weight: 300;\n width: auto;\n }\n\n /* spider chart placeholder */\n .spider-area {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 10px;\n flex: 1;\n }\n\n /* group distribution */\n .group-box .desc {\n color: #35618e;\n font-size: 13px;\n letter-spacing: -0.05em;\n margin-top: 4px;\n }\n .group-chart {\n height: 205px;\n margin-top: 25px;\n }\n `\n ]\n\n get context() {\n return {\n title: '프로젝트 상세 정보'\n }\n }\n\n @state() private project: Project = {} as Project\n\n render() {\n return html`\n <div content>\n <div left>\n <div class=\"card\">\n <div class=\"card-title\">\n <div>${this.project.name}</div>\n <div class=\"triangle\"></div>\n </div>\n\n <div class=\"top-info\" style=\"margin-top: 10px;\">\n <img pic src=${this.project.mainPhoto?.fullpath || '/assets/images/no-image.png'} alt=\"project\" />\n <div class=\"info\">\n <div class=\"address\">• ${this.project.buildingComplex?.address}</div>\n <div class=\"row\">\n <div class=\"label\">• 공사기간</div>\n <div class=\"value\">${this.project.startDate} ~ ${this.project.endDate}</div>\n </div>\n <div class=\"row\">\n <div class=\"label\">• 현장상태</div>\n <div class=\"value status-value\">${PROJECT_STATE[this.project.state]}</div>\n </div>\n <div class=\"row\">\n <div class=\"label\">• 요청상세</div>\n <div class=\"value bold\">???</div>\n </div>\n <div class=\"row\">\n <div class=\"label\">• 알람</div>\n <div class=\"value\">???</div>\n </div>\n </div>\n </div>\n\n <div class=\"detail-grid\">\n <div class=\"grid-item row\">\n <div class=\"label\">• 공사비</div>\n <div class=\"value\">${this.project.buildingComplex?.constructionCost?.toLocaleString() || '-'} 원</div>\n </div>\n <div class=\"grid-item row\">\n <div class=\"label\">• 연면적</div>\n <div class=\"value\">${this.project.buildingComplex?.area?.toLocaleString() || '-'} ㎡</div>\n </div>\n <div class=\"grid-item row\">\n <div class=\"label\">• 용적률</div>\n <div class=\"value\">??? %</div>\n </div>\n <div class=\"grid-item row\">\n <div class=\"label\">• 투입인력</div>\n <div class=\"value\">??? 명</div>\n </div>\n </div>\n </div>\n\n <div class=\"card\">\n <div class=\"card-title\">\n <div>입력 대기 중</div>\n <div class=\"triangle\"></div>\n </div>\n <div class=\"sub-desc\">\n 현재 입력 기한이 도래했거나, 입력이 지연되고 있는 KPI 항목입니다. 해당 항목에 대한 데이터를 입력 해 주시기 바랍니다.\n </div>\n\n <div class=\"list-block\">\n <div class=\"list-title\">• 입력 대기 중 2건</div>\n <div class=\"list-text\"># 2033312-Y5.1 : 검수자재 불합격률</div>\n <div class=\"list-text\"># 2033312-Y5.1 : 품질시험 불합격 건수</div>\n </div>\n <div class=\"list-block\">\n <div class=\"list-title\">• 입력 기한 초과 1건</div>\n <div class=\"list-text\">\n # 2033312-Y5.2 : 검측 불합격률 <span class=\"warn\">2025.2.12 <md-icon>report</md-icon></span>\n </div>\n </div>\n <div class=\"list-block\">\n <div class=\"list-title\">• 입력 예정 4건</div>\n <div class=\"list-text\"># 2033320-Y4.32 : 연면적 대비 공기입력</div>\n <div class=\"list-text\"># 2012345-Y4.32 : 책임감리원의 일정성과 수준 평가</div>\n <div class=\"list-text\"># 2035641-Y5.22 : 설계 변경에 따른 공기 증감률</div>\n <div class=\"list-text\"># 2096412-Y5.31 : 현장별 일정 이탈 수준</div>\n </div>\n <div class=\"list-block\">\n <div class=\"list-title\">• 입력 기한 없음 3건</div>\n <div class=\"list-text\"># 2033320-Y4.32 : 연면적 대비 공기입력</div>\n <div class=\"list-text\"># 2012345-Y4.32 : 책임감리원의 일정성과 수준 평가</div>\n <div class=\"list-text\"># 2035641-Y5.22 : 설계 변경에 따른 공기 증감률</div>\n </div>\n </div>\n </div>\n\n <div right>\n ${this.project.state === ProjectState.ONGOING\n ? html`\n <div class=\"button-line\">\n <div class=\"ghost-btn\" @click=${() => navigate(`project-update/${this.project.id}`)}>\n <md-icon slot=\"\">assignment</md-icon>\n <div>프로젝트 수정</div>\n </div>\n <div class=\"ghost-btn\" @click=${() => navigate(`project-complete/${this.project.id}`)}>\n <md-icon slot=\"\">assignment_turned_in</md-icon>\n <div>프로젝트 완공 처리</div>\n </div>\n </div>\n `\n : ''}\n\n <div class=\"card kpi-box\">\n <div class=\"kpi-header\">\n <div>종합 KPI</div>\n <div class=\"triangle\"></div>\n </div>\n <div class=\"kpi-desc\">\n 프로젝트의 생산성, 품질, 안전, 환경, 비용, 일정 등 6개의 성과를 종합한 종합KPI 포인트 정보와 각 지표별\n 분포차트입니다.\n </div>\n\n <div class=\"kpi-summary\">\n <div class=\"mini-boxplot\" title=\"boxplot placeholder\">\n <div class=\"boxplot-area\">boxplot area</div>\n\n <div class=\"boxplot-point\">\n <div class=\"value\">???</div>\n <div class=\"label\">Point</div>\n </div>\n </div>\n\n <div class=\"spider-area\">spider chart</div>\n </div>\n </div>\n\n <div class=\"card group-box\">\n <div class=\"kpi-header\">\n <div>그룹별 분포</div>\n <div class=\"triangle\"></div>\n </div>\n <div class=\"desc\">\n Boxplot(박스플롯)은 각 카테고리별로 값의 분포(최소, 1사분위, 중앙값, 3사분위, 최대, 평균, 이상치 등)를 보여줍니다.\n 박스는 중앙 50% 구간, 수염은 전체 범위, 굵은 검정색 가로선은 중앙값(메디안), 초록색 원은 평균값(Mean)을 의미합니다.\n 이 프로젝트의 값은 진한 오렌지색 원으로 별도 강조되어 표시되며, 중앙값/평균과 다를 수 있습니다.\n </div>\n <div class=\"group-chart\"></div>\n </div>\n </div>\n </div>\n `\n }\n\n async pageUpdated(changes: any, lifecycle: PageLifecycle) {\n if (this.active) {\n await this.initProject(lifecycle.resourceId)\n }\n }\n\n async initProject(projectId: string = '') {\n const response = await client.query({\n query: gql`\n query Project($id: String!) {\n project(id: $id) {\n id\n name\n state\n startDate\n endDate\n projectType\n mainPhoto {\n fullpath\n }\n totalProgress\n weeklyProgress\n kpi\n inspPassRate\n robotProgressRate\n structuralSafetyRate\n robotCount\n buildingComplex {\n id\n address\n latitude\n longitude\n area\n clientCompany\n constructionCompany\n supervisoryCompany\n designCompany\n drawing {\n id\n name\n fullpath\n }\n constructionType\n constructionCost\n etc\n notice\n householdCount\n buildingCount\n virtualTourLink\n buildings {\n id\n name\n floorCount\n }\n }\n }\n }\n `,\n variables: { id: projectId }\n })\n\n if (response.errors) return\n\n this.project = response.data?.project || ({} as Project)\n }\n}\n"]}
@@ -0,0 +1,157 @@
1
+ import '@material/web/icon/icon.js';
2
+ import '../components/kpi-single-boxplot-chart';
3
+ import { PageView } from '@operato/shell';
4
+ import { Attachment } from '@things-factory/attachment-base';
5
+ import type { FileUpload } from 'graphql-upload/GraphQLUpload.js';
6
+ import '../components/sv-pagenation-control';
7
+ import '@dssp/project/dist-client/pages/project/popup/popup-project-create';
8
+ export declare enum ProjectState {
9
+ 'ONGOING' = "10",
10
+ 'COMPLETED' = "20"
11
+ }
12
+ export declare const PROJECT_STATE: {
13
+ "10": string;
14
+ "20": string;
15
+ };
16
+ export declare enum BuildingInspectionStatus {
17
+ WAIT = "WAIT",
18
+ OVERALL_WAIT = "OVERALL_WAIT",
19
+ REQUEST = "REQUEST",
20
+ OVERALL_REQUEST = "OVERALL_REQUEST",
21
+ PASS = "PASS",
22
+ FAIL = "FAIL"
23
+ }
24
+ export declare const BUILDING_INSPECTION_STATUS: {
25
+ WAIT: string;
26
+ OVERALL_WAIT: string;
27
+ REQUEST: string;
28
+ OVERALL_REQUEST: string;
29
+ PASS: string;
30
+ FAIL: string;
31
+ };
32
+ export declare enum ProjectType {
33
+ DSSP = "DSSP",
34
+ DCSP = "DCSP",
35
+ DKPI = "DKPI"
36
+ }
37
+ export interface Project {
38
+ id?: string;
39
+ name: string;
40
+ state: ProjectState;
41
+ startDate?: string;
42
+ endDate?: string;
43
+ mainPhoto?: Attachment;
44
+ mainPhotoUpload?: FileUpload;
45
+ totalProgress?: number;
46
+ weeklyProgress?: number;
47
+ kpi?: number;
48
+ inspPassRate?: number;
49
+ robotProgressRate?: number;
50
+ structuralSafetyRate?: number;
51
+ robotCount?: number;
52
+ scheduleTable?: Attachment;
53
+ buildingComplex: BuildingComplex;
54
+ projectType?: ProjectType;
55
+ }
56
+ export interface BuildingComplex {
57
+ id?: string;
58
+ address?: string;
59
+ latitude?: number;
60
+ longitude?: number;
61
+ area?: number;
62
+ constructionCompany?: string;
63
+ clientCompany?: string;
64
+ designCompany?: string;
65
+ supervisoryCompany?: string;
66
+ drawing?: Attachment;
67
+ drawingUpload?: FileUpload;
68
+ constructionType?: string;
69
+ constructionCost?: number;
70
+ etc?: string;
71
+ householdCount?: number;
72
+ buildingCount?: number;
73
+ notice?: string;
74
+ planXScale?: number;
75
+ planYScale?: number;
76
+ overallConstructorEmails?: string[];
77
+ taskConstructorEmails?: string[];
78
+ overallSupervisoryEmails?: string[];
79
+ taskSupervisoryEmails?: string[];
80
+ buildings?: Building[];
81
+ }
82
+ export interface Building {
83
+ id?: string;
84
+ name: string | undefined;
85
+ floorCount: number | undefined;
86
+ hasBasement?: boolean;
87
+ basementFloorCount?: number;
88
+ drawing?: Attachment;
89
+ drawingUpload?: FileUpload;
90
+ buildingLevels?: BuildingLevel[];
91
+ }
92
+ export interface BuildingLevel {
93
+ id?: string;
94
+ floor?: number;
95
+ floorDisplayName?: string;
96
+ mainDrawing?: Attachment;
97
+ mainDrawingImage?: string;
98
+ mainDrawingThumbnail?: string;
99
+ mainDrawingUpload?: FileUpload;
100
+ elevationDrawing?: Attachment;
101
+ elevationDrawingThumbnail?: string;
102
+ elevationDrawingUpload?: FileUpload;
103
+ rebarDistributionDrawing?: Attachment;
104
+ rebarDistributionDrawingThumbnail?: string;
105
+ rebarDistributionDrawingUpload?: FileUpload;
106
+ etcDrawings?: Attachment[];
107
+ etcDrawingsUpload?: FileUpload[];
108
+ building?: Building;
109
+ buildingInspections?: BuildingInspection[];
110
+ }
111
+ export interface BuildingInspection {
112
+ id?: string;
113
+ attatchments?: Attachment[];
114
+ status?: BuildingInspectionStatus;
115
+ requestDate?: Date;
116
+ buildingLevel?: BuildingLevel;
117
+ checklist?: Checklist;
118
+ createdAt?: Date;
119
+ updatedAt?: Date;
120
+ deletedAt?: Date;
121
+ }
122
+ export interface Checklist {
123
+ id: string;
124
+ name?: string;
125
+ documentNo?: string;
126
+ constructionType?: string;
127
+ constructionDetailType?: string;
128
+ location?: string;
129
+ constructionInspectorDate?: Date;
130
+ supervisorInspectorDate?: Date;
131
+ overallConstructorSignature?: string;
132
+ taskConstructorSignature?: string;
133
+ overallSupervisorySignature?: string;
134
+ taskSupervisorySignature?: string;
135
+ inspectionParts?: string[];
136
+ }
137
+ declare const SvProjectListPage_base: typeof PageView & import("@open-wc/dedupe-mixin").Constructor<import("@open-wc/scoped-elements/types/src/types").ScopedElementsHost>;
138
+ export declare class SvProjectListPage extends SvProjectListPage_base {
139
+ static styles: import("lit").CSSResult[];
140
+ get context(): {
141
+ title: string;
142
+ };
143
+ private projectName;
144
+ private projectList;
145
+ private projectCount;
146
+ private currentPage;
147
+ private readonly pageLimit;
148
+ get totalPages(): number;
149
+ render(): import("lit-html").TemplateResult<1>;
150
+ pageUpdated(changes: any, lifecycle: any): Promise<void>;
151
+ getProjectList(): Promise<void>;
152
+ private _onInputChange;
153
+ private _onKeypress;
154
+ private _changePage;
155
+ private _openCreateProjectPopup;
156
+ }
157
+ export {};