@dssp/project 0.0.27 → 0.0.29
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.
- package/client/pages/lib/select2-component.ts +12 -1
- package/client/pages/project/component/project-update-header.ts +85 -0
- package/client/pages/project/popup/popup-schedule-upload.ts +102 -0
- package/client/pages/project/project-list.ts +31 -29
- package/client/pages/project/project-plan-management.ts +3 -54
- package/client/pages/project/project-schedule.ts +60 -13
- package/client/pages/project/project-setting-list.ts +46 -40
- package/client/pages/project/project-update.ts +4 -52
- package/dist-client/pages/lib/select2-component.js +12 -1
- package/dist-client/pages/lib/select2-component.js.map +1 -1
- package/dist-client/pages/project/component/project-update-header.d.ts +1 -0
- package/dist-client/pages/project/component/project-update-header.js +95 -0
- package/dist-client/pages/project/component/project-update-header.js.map +1 -0
- package/dist-client/pages/project/popup/popup-schedule-upload.d.ts +9 -0
- package/dist-client/pages/project/popup/popup-schedule-upload.js +105 -0
- package/dist-client/pages/project/popup/popup-schedule-upload.js.map +1 -0
- package/dist-client/pages/project/project-list.d.ts +1 -0
- package/dist-client/pages/project/project-list.js +30 -29
- package/dist-client/pages/project/project-list.js.map +1 -1
- package/dist-client/pages/project/project-plan-management.d.ts +1 -0
- package/dist-client/pages/project/project-plan-management.js +3 -53
- package/dist-client/pages/project/project-plan-management.js.map +1 -1
- package/dist-client/pages/project/project-schedule.d.ts +4 -0
- package/dist-client/pages/project/project-schedule.js +55 -12
- package/dist-client/pages/project/project-schedule.js.map +1 -1
- package/dist-client/pages/project/project-setting-list.js +46 -40
- package/dist-client/pages/project/project-setting-list.js.map +1 -1
- package/dist-client/pages/project/project-update.d.ts +1 -0
- package/dist-client/pages/project/project-update.js +4 -52
- package/dist-client/pages/project/project-update.js.map +1 -1
- package/dist-client/tsconfig.tsbuildinfo +1 -1
- package/dist-server/service/project/project-mutation.d.ts +2 -1
- package/dist-server/service/project/project-mutation.js +16 -0
- package/dist-server/service/project/project-mutation.js.map +1 -1
- package/dist-server/service/project/project-query.d.ts +1 -0
- package/dist-server/service/project/project-query.js +17 -0
- package/dist-server/service/project/project-query.js.map +1 -1
- package/dist-server/service/project/project-type.d.ts +4 -0
- package/dist-server/service/project/project-type.js +15 -1
- package/dist-server/service/project/project-type.js.map +1 -1
- package/dist-server/service/project/project.d.ts +1 -0
- package/dist-server/service/project/project.js +4 -0
- package/dist-server/service/project/project.js.map +1 -1
- package/dist-server/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -4
- package/server/service/project/project-mutation.ts +16 -1
- package/server/service/project/project-query.ts +13 -0
- package/server/service/project/project-type.ts +9 -0
- package/server/service/project/project.ts +4 -0
|
@@ -44,11 +44,10 @@ let ProjectListPage = class ProjectListPage extends ScopedElementsMixin(PageView
|
|
|
44
44
|
var _a;
|
|
45
45
|
return html `
|
|
46
46
|
<div header>
|
|
47
|
-
<label>프로젝트 이름</label>
|
|
48
47
|
<md-filled-text-field
|
|
49
48
|
name="projectName"
|
|
50
49
|
type="search"
|
|
51
|
-
label="
|
|
50
|
+
label="프로젝트명"
|
|
52
51
|
.value=${this.projectName}
|
|
53
52
|
@input=${this._onInputChange}
|
|
54
53
|
@keypress=${this._onKeypress}
|
|
@@ -192,7 +191,7 @@ ProjectListPage.styles = [
|
|
|
192
191
|
|
|
193
192
|
width: 100%;
|
|
194
193
|
height: 100%;
|
|
195
|
-
background-color: #
|
|
194
|
+
background-color: var(--md-sys-color-background, #f6f6f6);
|
|
196
195
|
|
|
197
196
|
--grid-record-emphasized-background-color: red;
|
|
198
197
|
--grid-record-emphasized-color: yellow;
|
|
@@ -200,24 +199,24 @@ ProjectListPage.styles = [
|
|
|
200
199
|
|
|
201
200
|
div[header] {
|
|
202
201
|
display: flex;
|
|
203
|
-
height: 100px;
|
|
204
202
|
align-items: center;
|
|
205
203
|
background-color: #2ea4df1a;
|
|
206
204
|
border: 1px solid #2ea4df33;
|
|
207
|
-
margin:
|
|
208
|
-
|
|
209
|
-
padding:
|
|
210
|
-
border-radius: 5px;
|
|
205
|
+
margin: var(--spacing-large, 12px);
|
|
206
|
+
margin-bottom:var(--spacing-small, 5px);
|
|
207
|
+
padding: var(--spacing-medium, 8px) var(--spacing-large, 12px);
|
|
208
|
+
border-radius: var(--md-sys-shape-corner-small, 5px);
|
|
211
209
|
|
|
212
210
|
md-filled-text-field[type='search'] {
|
|
213
|
-
margin-left: 5px;
|
|
214
|
-
margin-right: 26px;
|
|
215
|
-
|
|
216
211
|
--md-filled-text-field-container-shape: 0px;
|
|
217
|
-
--md-sys-color-primary: #
|
|
212
|
+
--md-sys-color-primary: #2e79be;
|
|
218
213
|
--md-sys-color-surface-container-highest: transparent;
|
|
219
214
|
--md-filled-text-field-label-text-color: #999999;
|
|
220
|
-
|
|
215
|
+
}
|
|
216
|
+
strong{
|
|
217
|
+
flex:1;
|
|
218
|
+
padding-right:var(--spacing-medium, 8px);
|
|
219
|
+
text-align:right
|
|
221
220
|
}
|
|
222
221
|
|
|
223
222
|
md-elevated-button[add-project] {
|
|
@@ -235,13 +234,15 @@ ProjectListPage.styles = [
|
|
|
235
234
|
div[body] {
|
|
236
235
|
div[project-container] {
|
|
237
236
|
height: 140px;
|
|
238
|
-
margin:
|
|
239
|
-
background-color:
|
|
237
|
+
margin: var(--spacing-large, 12px);
|
|
238
|
+
background-color: var(--md-sys-color-on-primary);
|
|
240
239
|
border: 1px solid #cccccc80;
|
|
241
|
-
border-radius: 5px;
|
|
240
|
+
border-radius: var(--md-sys-shape-corner-small, 5px);
|
|
241
|
+
overflow:hidden;
|
|
242
242
|
|
|
243
243
|
& > a {
|
|
244
244
|
display: flex;
|
|
245
|
+
gap:0 var(--spacing-large, 12px);
|
|
245
246
|
width: 100%;
|
|
246
247
|
height: 100%;
|
|
247
248
|
text-decoration: none;
|
|
@@ -249,7 +250,7 @@ ProjectListPage.styles = [
|
|
|
249
250
|
}
|
|
250
251
|
|
|
251
252
|
img[project-img] {
|
|
252
|
-
width:
|
|
253
|
+
width: 240px;
|
|
253
254
|
background-color: #cccccc80;
|
|
254
255
|
}
|
|
255
256
|
img[project-img][no-image] {
|
|
@@ -258,9 +259,9 @@ ProjectListPage.styles = [
|
|
|
258
259
|
}
|
|
259
260
|
|
|
260
261
|
span[project-info] {
|
|
261
|
-
flex: 0.
|
|
262
|
-
padding:
|
|
263
|
-
font-size:
|
|
262
|
+
flex: 0.55;
|
|
263
|
+
padding: var(--spacing-small, 4px);
|
|
264
|
+
font-size: 14px;
|
|
264
265
|
|
|
265
266
|
white-space: nowrap;
|
|
266
267
|
overflow: hidden;
|
|
@@ -269,17 +270,17 @@ ProjectListPage.styles = [
|
|
|
269
270
|
div[name] {
|
|
270
271
|
color: #2e79be;
|
|
271
272
|
font-weight: bold;
|
|
272
|
-
font-size:
|
|
273
|
-
margin
|
|
273
|
+
font-size: 18px;
|
|
274
|
+
margin: var(--spacing-small, 4px);
|
|
274
275
|
}
|
|
275
276
|
}
|
|
276
277
|
|
|
277
278
|
span[project-state] {
|
|
278
|
-
flex: 0.
|
|
279
|
-
padding:
|
|
279
|
+
flex: 0.45;
|
|
280
|
+
padding: var(--spacing-medium, 8px);
|
|
280
281
|
|
|
281
282
|
& > div {
|
|
282
|
-
margin
|
|
283
|
+
margin: var(--spacing-tiny, 2px);
|
|
283
284
|
}
|
|
284
285
|
|
|
285
286
|
div[progress] {
|
|
@@ -289,21 +290,21 @@ ProjectListPage.styles = [
|
|
|
289
290
|
--md-linear-progress-track-height: 18px;
|
|
290
291
|
--md-linear-progress-active-indicator-height: 18px;
|
|
291
292
|
--md-linear-progress-track-shape: 5px;
|
|
292
|
-
--md-sys-color-primary: #
|
|
293
|
-
--md-sys-color-surface-container-highest: #
|
|
293
|
+
--md-sys-color-primary: #0595e526;
|
|
294
|
+
--md-sys-color-surface-container-highest: #0595e52a;
|
|
294
295
|
}
|
|
295
296
|
|
|
296
297
|
span {
|
|
297
298
|
position: absolute;
|
|
298
299
|
top: 0;
|
|
299
|
-
left: 12px;
|
|
300
|
+
left: var(--spacing-large, 12px);
|
|
300
301
|
font-size: 12px;
|
|
301
302
|
font-weight: bold;
|
|
302
303
|
color: #2e79be;
|
|
303
304
|
|
|
304
305
|
&:last-child {
|
|
305
306
|
left: unset;
|
|
306
|
-
right: 12px;
|
|
307
|
+
right: var(--spacing-large, 12px);
|
|
307
308
|
}
|
|
308
309
|
}
|
|
309
310
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project-list.js","sourceRoot":"","sources":["../../../client/pages/project/project-list.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\n\nimport { PageView } from '@operato/shell'\nimport { css, html } from 'lit'\nimport { customElement, state } from 'lit/decorators.js'\nimport { ScopedElementsMixin } from '@open-wc/scoped-elements'\nimport { client } from '@operato/graphql'\nimport gql from 'graphql-tag'\nimport { Attachment } from '@things-factory/attachment-base'\nimport type { FileUpload } from 'graphql-upload/GraphQLUpload.js'\n\nexport enum ProjectState {\n 'ONGOING' = '10',\n 'COMPLETED' = '20'\n}\nexport enum BuildingInspectionStatus {\n WAIT = 'WAIT',\n OVERALL_WAIT = 'OVERALL_WAIT',\n REQUEST = 'REQUEST',\n OVERALL_REQUEST = 'OVERALL_REQUEST',\n PASS = 'PASS',\n FAIL = 'FAIL'\n}\nexport const BUILDING_INSPECTION_STATUS = {\n [BuildingInspectionStatus.WAIT]: '검측 대기',\n [BuildingInspectionStatus.OVERALL_WAIT]: '검측 대기',\n [BuildingInspectionStatus.REQUEST]: '검측 요청',\n [BuildingInspectionStatus.OVERALL_REQUEST]: '검측 요청',\n [BuildingInspectionStatus.PASS]: '합격',\n [BuildingInspectionStatus.FAIL]: '불합격'\n}\n\nexport interface Project {\n id?: string\n name: string\n startDate?: string\n endDate?: string\n mainPhoto?: Attachment\n mainPhotoUpload?: FileUpload\n totalProgress?: number\n weeklyProgress?: number\n kpi?: number\n inspPassRate?: number\n robotProgressRate?: number\n structuralSafetyRate?: number\n buildingComplex: BuildingComplex\n}\nexport interface BuildingComplex {\n id?: string\n address?: string\n latitude?: number\n longitude?: number\n area?: number\n constructionCompany?: string\n clientCompany?: string\n designCompany?: string\n supervisoryCompany?: string\n drawing?: Attachment\n drawingUpload?: FileUpload\n constructionType?: string\n constructionCost?: number\n etc?: string\n householdCount?: number\n buildingCount?: number\n notice?: string\n planXScale?: number\n planYScale?: number\n overallConstructorEmails?: string[]\n taskConstructorEmails?: string[]\n overallSupervisoryEmails?: string[]\n taskSupervisoryEmails?: string[]\n buildings?: Building[]\n}\nexport interface Building {\n id?: string\n name: string | undefined\n floorCount: number | undefined\n drawing?: Attachment\n drawingUpload?: FileUpload\n buildingLevels?: BuildingLevel[]\n}\n\nexport interface BuildingLevel {\n id?: string\n floor?: number\n mainDrawing?: Attachment\n mainDrawingImage?: string\n mainDrawingThumbnail?: string\n mainDrawingUpload?: FileUpload\n elevationDrawing?: Attachment\n elevationDrawingThumbnail?: string\n elevationDrawingUpload?: FileUpload\n rebarDistributionDrawing?: Attachment\n rebarDistributionDrawingThumbnail?: string\n rebarDistributionDrawingUpload?: FileUpload\n building?: Building\n buildingInspections?: BuildingInspection[]\n}\n\nexport interface BuildingInspection {\n id?: string\n attatchments?: Attachment[]\n // buildingInspectionAttachments?: BuildingInspectionAttachment[]\n status?: BuildingInspectionStatus\n requestDate?: Date\n buildingLevel?: BuildingLevel\n checklist?: Checklist\n createdAt?: Date\n updatedAt?: Date\n deletedAt?: Date\n}\n\nexport interface Checklist {\n id: string\n name?: string\n documentNo?: string\n constructionType?: string\n constructionDetailType?: string\n location?: string\n constructionInspectorDate?: Date\n supervisorInspectorDate?: Date\n overallConstructorSignature?: string\n taskConstructorSignature?: string\n overallSupervisorySignature?: string\n taskSupervisorySignature?: string\n inspectionParts?: string[]\n // checklistItems?: ChecklistItem[]\n}\n\n@customElement('project-list')\nexport class ProjectListPage 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: #f7f7f7;\n\n --grid-record-emphasized-background-color: red;\n --grid-record-emphasized-color: yellow;\n }\n\n div[header] {\n display: flex;\n height: 100px;\n align-items: center;\n background-color: #2ea4df1a;\n border: 1px solid #2ea4df33;\n margin: 15px 23px;\n font-size: 18px;\n padding: 7px;\n border-radius: 5px;\n\n md-filled-text-field[type='search'] {\n margin-left: 5px;\n margin-right: 26px;\n\n --md-filled-text-field-container-shape: 0px;\n --md-sys-color-primary: #006a6a;\n --md-sys-color-surface-container-highest: transparent;\n --md-filled-text-field-label-text-color: #999999;\n --md-filled-text-field-input-text-color: #4e5055;\n }\n\n md-elevated-button[add-project] {\n font-weight: bold;\n font-size: 16px;\n margin-left: 17px;\n padding: 13px 20px;\n\n --md-sys-color-surface-container-low: #24be7b;\n --md-sys-color-primary: #ffffff;\n --md-elevated-button-container-shape: 7px;\n }\n }\n\n div[body] {\n div[project-container] {\n height: 140px;\n margin: 17px 23px;\n background-color: #ffffff;\n border: 1px solid #cccccc80;\n border-radius: 5px;\n\n & > a {\n display: flex;\n width: 100%;\n height: 100%;\n text-decoration: none;\n color: #000;\n }\n\n img[project-img] {\n width: 285px;\n background-color: #cccccc80;\n }\n img[project-img][no-image] {\n object-fit: contain;\n opacity: 0.5;\n }\n\n span[project-info] {\n flex: 0.45;\n padding: 6px 15px;\n font-size: 16px;\n\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n\n div[name] {\n color: #2e79be;\n font-weight: bold;\n font-size: 19px;\n margin-bottom: 2px;\n }\n }\n\n span[project-state] {\n flex: 0.55;\n padding: 10px 20px;\n\n & > div {\n margin-bottom: 3px;\n }\n\n div[progress] {\n position: relative;\n\n md-linear-progress {\n --md-linear-progress-track-height: 18px;\n --md-linear-progress-active-indicator-height: 18px;\n --md-linear-progress-track-shape: 5px;\n --md-sys-color-primary: #0595e51a;\n --md-sys-color-surface-container-highest: #0595e533;\n }\n\n span {\n position: absolute;\n top: 0;\n left: 12px;\n font-size: 12px;\n font-weight: bold;\n color: #2e79be;\n\n &:last-child {\n left: unset;\n right: 12px;\n }\n }\n }\n }\n }\n }\n `\n ]\n\n get context() {\n return {\n title: '진행중 프로젝트'\n }\n }\n\n @state() private projectName: string = ''\n @state() private projectList: Project[] = []\n @state() private projectCount: number = 0\n\n render() {\n return html`\n <div header>\n <label>프로젝트 이름</label>\n <md-filled-text-field\n name=\"projectName\"\n type=\"search\"\n label=\"프로젝트 이름\"\n .value=${this.projectName}\n @input=${this._onInputChange}\n @keypress=${this._onKeypress}\n >\n <md-icon slot=\"leading-icon\">search</md-icon>\n </md-filled-text-field>\n\n <strong>총 ${this.projectCount}개</strong>\n </div>\n\n <div body>\n ${this.projectList?.map((project: Project) => {\n return html`\n <div project-container>\n <a href=${`project-detail/${project.id}`}>\n <img\n ?no-image=${!project.mainPhoto?.fullpath}\n project-img\n src=${project.mainPhoto?.fullpath || '/assets/images/no-image.png'}\n />\n\n <span project-info>\n <div name>${project.name}</div>\n <div content>${project.buildingComplex.address}</div>\n <div content>면적: ${project.buildingComplex?.area?.toLocaleString() || ''}㎡</div>\n <div content>착공~준공: ${project.startDate} ~ ${project.endDate}</div>\n <div content>발주처: <strong>${project.buildingComplex.clientCompany}</strong></div>\n </span>\n\n <span project-state>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.totalProgress || 0}> </md-linear-progress>\n <span>전체</span>\n <span>${project.totalProgress || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.weeklyProgress || 0}> </md-linear-progress>\n <span>주간</span>\n <span>${project.weeklyProgress || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.kpi || 0}> </md-linear-progress>\n <span>KPI</span>\n <span>${project.kpi || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.inspPassRate || 0}> </md-linear-progress>\n <span>Inspection Passing Rate</span>\n <span>${project.inspPassRate || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.robotProgressRate || 0}> </md-linear-progress>\n <span>Robot Progress</span>\n <span>${project.robotProgressRate || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.structuralSafetyRate || 0}> </md-linear-progress>\n <span>Structural safety</span>\n <span>${project.structuralSafetyRate || 0}%</span>\n </div>\n </span>\n </a>\n </div>\n `\n })}\n </div>\n `\n }\n\n async pageUpdated(changes: any, lifecycle: any) {\n if (this.active) {\n this.getProjectList()\n }\n }\n\n async getProjectList() {\n const response = await client.query({\n query: gql`\n query Projects($filters: [Filter!]) {\n projects(filters: $filters) {\n items {\n id\n name\n startDate\n endDate\n mainPhoto {\n fullpath\n }\n totalProgress\n weeklyProgress\n kpi\n inspPassRate\n robotProgressRate\n structuralSafetyRate\n buildingComplex {\n address\n area\n clientCompany\n }\n }\n total\n }\n }\n `,\n variables: {\n filters: [\n {\n name: 'name',\n operator: 'search',\n value: `%${this.projectName}%`\n },\n {\n name: 'state',\n operator: 'eq',\n value: ProjectState.ONGOING\n }\n ]\n }\n })\n\n this.projectList = response.data.projects?.items || []\n this.projectCount = response.data.projects?.total || 0\n }\n\n // Input 요소의 값이 변경될 때 호출되는 콜백 함수\n private _onInputChange(event: InputEvent) {\n const target = event.target as HTMLInputElement\n this[target.name] = target.value\n }\n\n // 검색창에서 엔터입력시 검색\n private _onKeypress(event: KeyboardEvent) {\n if (event.code === 'Enter') {\n this.getProjectList()\n }\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"project-list.js","sourceRoot":"","sources":["../../../client/pages/project/project-list.ts"],"names":[],"mappings":";AAAA,OAAO,4BAA4B,CAAA;AAEnC,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAA;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,GAAG,MAAM,aAAa,CAAA;AAI7B,MAAM,CAAN,IAAY,YAGX;AAHD,WAAY,YAAY;IACtB,8BAAgB,CAAA;IAChB,gCAAkB,CAAA;AACpB,CAAC,EAHW,YAAY,KAAZ,YAAY,QAGvB;AACD,MAAM,CAAN,IAAY,wBAOX;AAPD,WAAY,wBAAwB;IAClC,yCAAa,CAAA;IACb,yDAA6B,CAAA;IAC7B,+CAAmB,CAAA;IACnB,+DAAmC,CAAA;IACnC,yCAAa,CAAA;IACb,yCAAa,CAAA;AACf,CAAC,EAPW,wBAAwB,KAAxB,wBAAwB,QAOnC;AACD,MAAM,CAAC,MAAM,0BAA0B,GAAG;IACxC,CAAC,wBAAwB,CAAC,IAAI,CAAC,EAAE,OAAO;IACxC,CAAC,wBAAwB,CAAC,YAAY,CAAC,EAAE,OAAO;IAChD,CAAC,wBAAwB,CAAC,OAAO,CAAC,EAAE,OAAO;IAC3C,CAAC,wBAAwB,CAAC,eAAe,CAAC,EAAE,OAAO;IACnD,CAAC,wBAAwB,CAAC,IAAI,CAAC,EAAE,IAAI;IACrC,CAAC,wBAAwB,CAAC,IAAI,CAAC,EAAE,KAAK;CACvC,CAAA;AAqGM,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,mBAAmB,CAAC,QAAQ,CAAC;IAA3D;;QA2IY,gBAAW,GAAW,EAAE,CAAA;QACxB,gBAAW,GAAc,EAAE,CAAA;QAC3B,iBAAY,GAAW,CAAC,CAAA;IAiJ3C,CAAC;IAzJC,IAAI,OAAO;QACT,OAAO;YACL,KAAK,EAAE,UAAU;SAClB,CAAA;IACH,CAAC;IAMD,MAAM;;QACJ,OAAO,IAAI,CAAA;;;;;;mBAMI,IAAI,CAAC,WAAW;mBAChB,IAAI,CAAC,cAAc;sBAChB,IAAI,CAAC,WAAW;;;;;oBAKlB,IAAI,CAAC,YAAY;;;;UAI3B,MAAA,IAAI,CAAC,WAAW,0CAAE,GAAG,CAAC,CAAC,OAAgB,EAAE,EAAE;;YAC3C,OAAO,IAAI,CAAA;;wBAEG,kBAAkB,OAAO,CAAC,EAAE,EAAE;;8BAExB,CAAC,CAAA,MAAA,OAAO,CAAC,SAAS,0CAAE,QAAQ,CAAA;;wBAElC,CAAA,MAAA,OAAO,CAAC,SAAS,0CAAE,QAAQ,KAAI,6BAA6B;;;;8BAItD,OAAO,CAAC,IAAI;iCACT,OAAO,CAAC,eAAe,CAAC,OAAO;qCAC3B,CAAA,MAAA,MAAA,OAAO,CAAC,eAAe,0CAAE,IAAI,0CAAE,cAAc,EAAE,KAAI,EAAE;wCAClD,OAAO,CAAC,SAAS,MAAM,OAAO,CAAC,OAAO;8CAChC,OAAO,CAAC,eAAe,CAAC,aAAa;;;;;uEAKZ,OAAO,CAAC,aAAa,IAAI,CAAC;;4BAErE,OAAO,CAAC,aAAa,IAAI,CAAC;;;uEAGiB,OAAO,CAAC,cAAc,IAAI,CAAC;;4BAEtE,OAAO,CAAC,cAAc,IAAI,CAAC;;;uEAGgB,OAAO,CAAC,GAAG,IAAI,CAAC;;4BAE3D,OAAO,CAAC,GAAG,IAAI,CAAC;;;uEAG2B,OAAO,CAAC,YAAY,IAAI,CAAC;;4BAEpE,OAAO,CAAC,YAAY,IAAI,CAAC;;;uEAGkB,OAAO,CAAC,iBAAiB,IAAI,CAAC;;4BAEzE,OAAO,CAAC,iBAAiB,IAAI,CAAC;;;uEAGa,OAAO,CAAC,oBAAoB,IAAI,CAAC;;4BAE5E,OAAO,CAAC,oBAAoB,IAAI,CAAC;;;;;WAKlD,CAAA;QACH,CAAC,CAAC;;KAEL,CAAA;IACH,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAY,EAAE,SAAc;QAC5C,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,cAAc,EAAE,CAAA;SACtB;IACH,CAAC;IAED,KAAK,CAAC,cAAc;;QAClB,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;YAClC,KAAK,EAAE,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BT;YACD,SAAS,EAAE;gBACT,OAAO,EAAE;oBACP;wBACE,IAAI,EAAE,MAAM;wBACZ,QAAQ,EAAE,QAAQ;wBAClB,KAAK,EAAE,IAAI,IAAI,CAAC,WAAW,GAAG;qBAC/B;oBACD;wBACE,IAAI,EAAE,OAAO;wBACb,QAAQ,EAAE,IAAI;wBACd,KAAK,EAAE,YAAY,CAAC,OAAO;qBAC5B;iBACF;aACF;SACF,CAAC,CAAA;QAEF,IAAI,CAAC,WAAW,GAAG,CAAA,MAAA,QAAQ,CAAC,IAAI,CAAC,QAAQ,0CAAE,KAAK,KAAI,EAAE,CAAA;QACtD,IAAI,CAAC,YAAY,GAAG,CAAA,MAAA,QAAQ,CAAC,IAAI,CAAC,QAAQ,0CAAE,KAAK,KAAI,CAAC,CAAA;IACxD,CAAC;IAED,gCAAgC;IACxB,cAAc,CAAC,KAAiB;QACtC,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAA;QAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAA;IAClC,CAAC;IAED,iBAAiB;IACT,WAAW,CAAC,KAAoB;QACtC,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YAC1B,IAAI,CAAC,cAAc,EAAE,CAAA;SACtB;IACH,CAAC;;AA5RM,sBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAgIF;CACF,CAAA;AAQD;IAAC,KAAK,EAAE;;oDAAiC;AACzC;IAAC,KAAK,EAAE;;oDAAoC;AAC5C;IAAC,KAAK,EAAE;;qDAAiC;AA7I9B,eAAe;IAD3B,aAAa,CAAC,cAAc,CAAC;GACjB,eAAe,CA8R3B;SA9RY,eAAe","sourcesContent":["import '@material/web/icon/icon.js'\n\nimport { PageView } from '@operato/shell'\nimport { css, html } from 'lit'\nimport { customElement, state } from 'lit/decorators.js'\nimport { ScopedElementsMixin } from '@open-wc/scoped-elements'\nimport { client } from '@operato/graphql'\nimport gql from 'graphql-tag'\nimport { Attachment } from '@things-factory/attachment-base'\nimport type { FileUpload } from 'graphql-upload/GraphQLUpload.js'\n\nexport enum ProjectState {\n 'ONGOING' = '10',\n 'COMPLETED' = '20'\n}\nexport enum BuildingInspectionStatus {\n WAIT = 'WAIT',\n OVERALL_WAIT = 'OVERALL_WAIT',\n REQUEST = 'REQUEST',\n OVERALL_REQUEST = 'OVERALL_REQUEST',\n PASS = 'PASS',\n FAIL = 'FAIL'\n}\nexport const BUILDING_INSPECTION_STATUS = {\n [BuildingInspectionStatus.WAIT]: '검측 대기',\n [BuildingInspectionStatus.OVERALL_WAIT]: '검측 대기',\n [BuildingInspectionStatus.REQUEST]: '검측 요청',\n [BuildingInspectionStatus.OVERALL_REQUEST]: '검측 요청',\n [BuildingInspectionStatus.PASS]: '합격',\n [BuildingInspectionStatus.FAIL]: '불합격'\n}\n\nexport interface Project {\n id?: string\n name: string\n startDate?: string\n endDate?: string\n mainPhoto?: Attachment\n mainPhotoUpload?: FileUpload\n totalProgress?: number\n weeklyProgress?: number\n kpi?: number\n inspPassRate?: number\n robotProgressRate?: number\n structuralSafetyRate?: number\n scheduleTable?: Attachment\n buildingComplex: BuildingComplex\n}\nexport interface BuildingComplex {\n id?: string\n address?: string\n latitude?: number\n longitude?: number\n area?: number\n constructionCompany?: string\n clientCompany?: string\n designCompany?: string\n supervisoryCompany?: string\n drawing?: Attachment\n drawingUpload?: FileUpload\n constructionType?: string\n constructionCost?: number\n etc?: string\n householdCount?: number\n buildingCount?: number\n notice?: string\n planXScale?: number\n planYScale?: number\n overallConstructorEmails?: string[]\n taskConstructorEmails?: string[]\n overallSupervisoryEmails?: string[]\n taskSupervisoryEmails?: string[]\n buildings?: Building[]\n}\nexport interface Building {\n id?: string\n name: string | undefined\n floorCount: number | undefined\n drawing?: Attachment\n drawingUpload?: FileUpload\n buildingLevels?: BuildingLevel[]\n}\n\nexport interface BuildingLevel {\n id?: string\n floor?: number\n mainDrawing?: Attachment\n mainDrawingImage?: string\n mainDrawingThumbnail?: string\n mainDrawingUpload?: FileUpload\n elevationDrawing?: Attachment\n elevationDrawingThumbnail?: string\n elevationDrawingUpload?: FileUpload\n rebarDistributionDrawing?: Attachment\n rebarDistributionDrawingThumbnail?: string\n rebarDistributionDrawingUpload?: FileUpload\n building?: Building\n buildingInspections?: BuildingInspection[]\n}\n\nexport interface BuildingInspection {\n id?: string\n attatchments?: Attachment[]\n // buildingInspectionAttachments?: BuildingInspectionAttachment[]\n status?: BuildingInspectionStatus\n requestDate?: Date\n buildingLevel?: BuildingLevel\n checklist?: Checklist\n createdAt?: Date\n updatedAt?: Date\n deletedAt?: Date\n}\n\nexport interface Checklist {\n id: string\n name?: string\n documentNo?: string\n constructionType?: string\n constructionDetailType?: string\n location?: string\n constructionInspectorDate?: Date\n supervisorInspectorDate?: Date\n overallConstructorSignature?: string\n taskConstructorSignature?: string\n overallSupervisorySignature?: string\n taskSupervisorySignature?: string\n inspectionParts?: string[]\n // checklistItems?: ChecklistItem[]\n}\n\n@customElement('project-list')\nexport class ProjectListPage 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 --grid-record-emphasized-background-color: red;\n --grid-record-emphasized-color: yellow;\n }\n\n div[header] {\n display: flex;\n align-items: center;\n background-color: #2ea4df1a;\n border: 1px solid #2ea4df33;\n margin: var(--spacing-large, 12px);\n margin-bottom:var(--spacing-small, 5px);\n padding: var(--spacing-medium, 8px) var(--spacing-large, 12px);\n border-radius: var(--md-sys-shape-corner-small, 5px);\n\n md-filled-text-field[type='search'] {\n --md-filled-text-field-container-shape: 0px;\n --md-sys-color-primary: #2e79be;\n --md-sys-color-surface-container-highest: transparent;\n --md-filled-text-field-label-text-color: #999999;\n }\n strong{\n flex:1;\n padding-right:var(--spacing-medium, 8px);\n text-align:right\n }\n\n md-elevated-button[add-project] {\n font-weight: bold;\n font-size: 16px;\n margin-left: 17px;\n padding: 13px 20px;\n\n --md-sys-color-surface-container-low: #24be7b;\n --md-sys-color-primary: #ffffff;\n --md-elevated-button-container-shape: 7px;\n }\n }\n\n div[body] {\n div[project-container] {\n height: 140px;\n margin: var(--spacing-large, 12px);\n background-color: var(--md-sys-color-on-primary);\n border: 1px solid #cccccc80;\n border-radius: var(--md-sys-shape-corner-small, 5px);\n overflow:hidden;\n\n & > a {\n display: flex;\n gap:0 var(--spacing-large, 12px);\n width: 100%;\n height: 100%;\n text-decoration: none;\n color: #000;\n }\n\n img[project-img] {\n width: 240px;\n background-color: #cccccc80;\n }\n img[project-img][no-image] {\n object-fit: contain;\n opacity: 0.5;\n }\n\n span[project-info] {\n flex: 0.55;\n padding: var(--spacing-small, 4px);\n font-size: 14px;\n\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n\n div[name] {\n color: #2e79be;\n font-weight: bold;\n font-size: 18px;\n margin: var(--spacing-small, 4px);\n }\n }\n\n span[project-state] {\n flex: 0.45;\n padding: var(--spacing-medium, 8px);\n\n & > div {\n margin: var(--spacing-tiny, 2px);\n }\n\n div[progress] {\n position: relative;\n\n md-linear-progress {\n --md-linear-progress-track-height: 18px;\n --md-linear-progress-active-indicator-height: 18px;\n --md-linear-progress-track-shape: 5px;\n --md-sys-color-primary: #0595e526;\n --md-sys-color-surface-container-highest: #0595e52a;\n }\n\n span {\n position: absolute;\n top: 0;\n left: var(--spacing-large, 12px);\n font-size: 12px;\n font-weight: bold;\n color: #2e79be;\n\n &:last-child {\n left: unset;\n right: var(--spacing-large, 12px);\n }\n }\n }\n }\n }\n }\n `\n ]\n\n get context() {\n return {\n title: '진행중 프로젝트'\n }\n }\n\n @state() private projectName: string = ''\n @state() private projectList: Project[] = []\n @state() private projectCount: number = 0\n\n render() {\n return html`\n <div header>\n <md-filled-text-field\n name=\"projectName\"\n type=\"search\"\n label=\"프로젝트명\"\n .value=${this.projectName}\n @input=${this._onInputChange}\n @keypress=${this._onKeypress}\n >\n <md-icon slot=\"leading-icon\">search</md-icon>\n </md-filled-text-field>\n\n <strong>총 ${this.projectCount}개</strong>\n </div>\n\n <div body>\n ${this.projectList?.map((project: Project) => {\n return html`\n <div project-container>\n <a href=${`project-detail/${project.id}`}>\n <img\n ?no-image=${!project.mainPhoto?.fullpath}\n project-img\n src=${project.mainPhoto?.fullpath || '/assets/images/no-image.png'}\n />\n\n <span project-info>\n <div name>${project.name}</div>\n <div content>${project.buildingComplex.address}</div>\n <div content>면적: ${project.buildingComplex?.area?.toLocaleString() || ''}㎡</div>\n <div content>착공~준공: ${project.startDate} ~ ${project.endDate}</div>\n <div content>발주처: <strong>${project.buildingComplex.clientCompany}</strong></div>\n </span>\n\n <span project-state>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.totalProgress || 0}> </md-linear-progress>\n <span>전체</span>\n <span>${project.totalProgress || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.weeklyProgress || 0}> </md-linear-progress>\n <span>주간</span>\n <span>${project.weeklyProgress || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.kpi || 0}> </md-linear-progress>\n <span>KPI</span>\n <span>${project.kpi || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.inspPassRate || 0}> </md-linear-progress>\n <span>Inspection Passing Rate</span>\n <span>${project.inspPassRate || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.robotProgressRate || 0}> </md-linear-progress>\n <span>Robot Progress</span>\n <span>${project.robotProgressRate || 0}%</span>\n </div>\n <div progress>\n <md-linear-progress buffer=\"100\" max=\"100\" value=${project.structuralSafetyRate || 0}> </md-linear-progress>\n <span>Structural safety</span>\n <span>${project.structuralSafetyRate || 0}%</span>\n </div>\n </span>\n </a>\n </div>\n `\n })}\n </div>\n `\n }\n\n async pageUpdated(changes: any, lifecycle: any) {\n if (this.active) {\n this.getProjectList()\n }\n }\n\n async getProjectList() {\n const response = await client.query({\n query: gql`\n query Projects($filters: [Filter!]) {\n projects(filters: $filters) {\n items {\n id\n name\n startDate\n endDate\n mainPhoto {\n fullpath\n }\n totalProgress\n weeklyProgress\n kpi\n inspPassRate\n robotProgressRate\n structuralSafetyRate\n buildingComplex {\n address\n area\n clientCompany\n }\n }\n total\n }\n }\n `,\n variables: {\n filters: [\n {\n name: 'name',\n operator: 'search',\n value: `%${this.projectName}%`\n },\n {\n name: 'state',\n operator: 'eq',\n value: ProjectState.ONGOING\n }\n ]\n }\n })\n\n this.projectList = response.data.projects?.items || []\n this.projectCount = response.data.projects?.total || 0\n }\n\n // Input 요소의 값이 변경될 때 호출되는 콜백 함수\n private _onInputChange(event: InputEvent) {\n const target = event.target as HTMLInputElement\n this[target.name] = target.value\n }\n\n // 검색창에서 엔터입력시 검색\n private _onKeypress(event: KeyboardEvent) {\n if (event.code === 'Enter') {\n this.getProjectList()\n }\n }\n}\n"]}
|
|
@@ -7,6 +7,7 @@ import { PageView } from '@operato/shell';
|
|
|
7
7
|
import { PageLifecycle } from '@operato/shell/dist/src/app/pages/page-view';
|
|
8
8
|
import { Project } from './project-list';
|
|
9
9
|
import './popup/popup-plan-upload';
|
|
10
|
+
import './component/project-update-header';
|
|
10
11
|
declare const ProjectPlanManagement_base: typeof PageView & import("@open-wc/dedupe-mixin").Constructor<import("@open-wc/scoped-elements/types/src/types").ScopedElementsHost>;
|
|
11
12
|
export declare class ProjectPlanManagement extends ProjectPlanManagement_base {
|
|
12
13
|
static styles: import("lit").CSSResult[];
|
|
@@ -13,6 +13,7 @@ import { notify } from '@operato/layout';
|
|
|
13
13
|
import { openPopup } from '@operato/layout';
|
|
14
14
|
import gql from 'graphql-tag';
|
|
15
15
|
import './popup/popup-plan-upload';
|
|
16
|
+
import './component/project-update-header';
|
|
16
17
|
let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMixin(PageView) {
|
|
17
18
|
constructor() {
|
|
18
19
|
super(...arguments);
|
|
@@ -41,20 +42,8 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
|
|
|
41
42
|
render() {
|
|
42
43
|
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
|
|
43
44
|
return html `
|
|
44
|
-
<
|
|
45
|
-
|
|
46
|
-
<div button-container>
|
|
47
|
-
<md-elevated-button green @click=${this._saveProject}>
|
|
48
|
-
<md-icon slot="icon">save</md-icon>정보 저장
|
|
49
|
-
</md-elevated-button>
|
|
50
|
-
<md-elevated-button href=${`project-update/${this.project.id}`}>
|
|
51
|
-
<md-icon slot="icon">assignment</md-icon>프로젝트 정보 수정
|
|
52
|
-
</md-elevated-button>
|
|
53
|
-
<md-elevated-button href=${`project-task-update/${this.project.id}`}>
|
|
54
|
-
<md-icon slot="icon">event_note</md-icon>공정표 관리
|
|
55
|
-
</md-elevated-button>
|
|
56
|
-
</div>
|
|
57
|
-
</div>
|
|
45
|
+
<project-update-header .projectId=${this.project.id || ''} title="도면 관리" @custom-click=${this._saveProject}>
|
|
46
|
+
</project-update-header>
|
|
58
47
|
|
|
59
48
|
<div body>
|
|
60
49
|
<div building-container>
|
|
@@ -207,7 +196,6 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
|
|
|
207
196
|
}
|
|
208
197
|
});
|
|
209
198
|
this.project = (_a = response.data) === null || _a === void 0 ? void 0 : _a.project;
|
|
210
|
-
console.log('init project : ', this.project);
|
|
211
199
|
}
|
|
212
200
|
async _saveProject() {
|
|
213
201
|
// 첨부 파일 필드 제거 (첨부 파일은 {filename}Upload 로 전송)
|
|
@@ -324,44 +312,6 @@ ProjectPlanManagement.styles = [
|
|
|
324
312
|
font-weight: bold;
|
|
325
313
|
}
|
|
326
314
|
|
|
327
|
-
div[header] {
|
|
328
|
-
display: flex;
|
|
329
|
-
margin: 0px 20px;
|
|
330
|
-
|
|
331
|
-
h2 {
|
|
332
|
-
flex: 0.5;
|
|
333
|
-
color: #3f71a0;
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
div[button-container] {
|
|
337
|
-
display: flex;
|
|
338
|
-
align-items: center;
|
|
339
|
-
justify-content: end;
|
|
340
|
-
flex: 0.5;
|
|
341
|
-
|
|
342
|
-
md-elevated-button {
|
|
343
|
-
margin: 0px 3px;
|
|
344
|
-
|
|
345
|
-
--md-elevated-button-container-height: 35px;
|
|
346
|
-
--md-elevated-button-label-text-size: 16px;
|
|
347
|
-
--md-elevated-button-container-color: #0595e5;
|
|
348
|
-
|
|
349
|
-
--md-elevated-button-label-text-color: #fff;
|
|
350
|
-
--md-elevated-button-hover-label-text-color: #fff;
|
|
351
|
-
--md-elevated-button-pressed-label-text-color: #fff;
|
|
352
|
-
--md-elevated-button-focus-label-text-color: #fff;
|
|
353
|
-
--md-elevated-button-icon-color: #fff;
|
|
354
|
-
--md-elevated-button-hover-icon-color: #fff;
|
|
355
|
-
--md-elevated-button-pressed-icon-color: #fff;
|
|
356
|
-
--md-elevated-button-focus-icon-color: #fff;
|
|
357
|
-
|
|
358
|
-
&[green] {
|
|
359
|
-
--md-elevated-button-container-color: #42b382;
|
|
360
|
-
}
|
|
361
|
-
}
|
|
362
|
-
}
|
|
363
|
-
}
|
|
364
|
-
|
|
365
315
|
div[body] {
|
|
366
316
|
display: grid;
|
|
367
317
|
grid-template-rows: 240px 1fr 60px;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project-plan-management.js","sourceRoot":"","sources":["../../../client/pages/project/project-plan-management.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@material/web/button/elevated-button.js'\nimport '@material/web/textfield/outlined-text-field.js'\nimport '@material/web/button/filled-button.js'\nimport '@material/web/button/outlined-button.js'\n\nimport { PageView } from '@operato/shell'\nimport { PageLifecycle } from '@operato/shell/dist/src/app/pages/page-view'\nimport { css, html } from 'lit'\nimport { customElement, state } from 'lit/decorators.js'\nimport { ScopedElementsMixin } from '@open-wc/scoped-elements'\nimport { client } from '@operato/graphql'\nimport { notify } from '@operato/layout'\nimport { openPopup } from '@operato/layout'\n\nimport gql from 'graphql-tag'\nimport { Building, BuildingLevel, Project } from './project-list'\nimport './popup/popup-plan-upload'\n\n@customElement('project-plan-management')\nexport class ProjectPlanManagement extends ScopedElementsMixin(PageView) {\n static styles = [\n css`\n :host {\n display: grid;\n grid-template-rows: 75px auto;\n color: #4e5055;\n\n background-color: #f7f7f7;\n overflow: hidden;\n overflow-y: auto;\n\n --grid-record-emphasized-background-color: red;\n --grid-record-emphasized-color: yellow;\n }\n\n md-outlined-text-field {\n width: 100%;\n\n --md-outlined-text-field-container-shape: 5px;\n --md-sys-color-primary: #586878;\n --md-outlined-text-field-input-text-size: 14px;\n --md-outlined-field-bottom-space: 4px;\n --md-outlined-field-top-space: 4px;\n }\n\n ox-input-image {\n width: 100px;\n height: 100px;\n }\n\n *[bold] {\n font-weight: bold;\n }\n\n div[header] {\n display: flex;\n margin: 0px 20px;\n\n h2 {\n flex: 0.5;\n color: #3f71a0;\n }\n\n div[button-container] {\n display: flex;\n align-items: center;\n justify-content: end;\n flex: 0.5;\n\n md-elevated-button {\n margin: 0px 3px;\n\n --md-elevated-button-container-height: 35px;\n --md-elevated-button-label-text-size: 16px;\n --md-elevated-button-container-color: #0595e5;\n\n --md-elevated-button-label-text-color: #fff;\n --md-elevated-button-hover-label-text-color: #fff;\n --md-elevated-button-pressed-label-text-color: #fff;\n --md-elevated-button-focus-label-text-color: #fff;\n --md-elevated-button-icon-color: #fff;\n --md-elevated-button-hover-icon-color: #fff;\n --md-elevated-button-pressed-icon-color: #fff;\n --md-elevated-button-focus-icon-color: #fff;\n\n &[green] {\n --md-elevated-button-container-color: #42b382;\n }\n }\n }\n }\n\n div[body] {\n display: grid;\n grid-template-rows: 240px 1fr 60px;\n margin: 0px 25px 25px 25px;\n gap: 8px;\n\n & > div {\n display: grid;\n grid-template-rows: 25px auto;\n padding: 15px;\n background-color: #ffffff;\n border: 1px solid #cccccc80;\n border-radius: 5px;\n gap: 14px;\n\n h3 {\n color: #2e79be;\n font-size: 18px;\n margin: 0px;\n text-wrap: nowrap;\n }\n }\n\n & > div[building-container] > div {\n display: flex;\n gap: 16px;\n overflow-x: auto;\n overflow-y: hidden;\n\n ox-input-file {\n height: 120px;\n }\n\n span[building] {\n width: 125px;\n text-align: center;\n\n div {\n color: #586878;\n margin-top: 7px;\n }\n }\n }\n\n & > div[floor-container] {\n div[floor-title] {\n display: flex;\n justify-content: space-between;\n height: fit-content;\n gap: 50px;\n overflow: hidden;\n\n span[building-button] {\n display: flex;\n margin-left: auto;\n gap: 10px;\n overflow-x: auto;\n overflow-y: hidden;\n\n md-filled-button {\n --md-filled-button-container-color: #0595e5;\n --md-filled-button-container-height: 30px;\n --md-filled-button-trailing-space: 15px;\n --md-filled-button-leading-space: 15px;\n }\n md-outlined-button {\n --md-outlined-button-container-height: 30px;\n --md-outlined-button-trailing-space: 15px;\n --md-outlined-button-leading-space: 15px;\n }\n }\n }\n\n div[floor-plan] {\n overflow-y: auto;\n margin-top: 10px;\n\n & > span {\n display: inline-block;\n text-align: center;\n margin: 0px 10px 15px 0px;\n cursor: pointer;\n\n & > [name='building-plan'] {\n width: 150px;\n height: 100px;\n display: flex;\n flex-direction: column;\n justify-content: center;\n border: 1px solid #333;\n box-shadow: 2px 2px 2px #0000001a;\n align-items: center;\n border-radius: 7px;\n font-size: 13px;\n\n md-icon {\n margin-bottom: 6px;\n }\n }\n\n & > div[floor-name] {\n margin-top: 7px;\n\n &[no-data] {\n color: #f16154;\n font-weight: bold;\n }\n }\n }\n }\n }\n\n & > div[plan-scale-container] {\n display: flex;\n\n & > div {\n display: flex;\n align-items: center;\n gap: 12px;\n margin-left: 10px;\n\n md-outlined-text-field {\n width: 100px;\n --md-outlined-text-container-height: 30px;\n }\n }\n }\n }\n `\n ]\n\n get context() {\n return {\n title: '도면 관리'\n }\n }\n\n private defaultProject = {\n name: '',\n buildingComplex: {\n address: '',\n area: 0,\n constructionCompany: '',\n clientCompany: '',\n supervisoryCompany: '',\n designCompany: '',\n constructionType: '',\n buildings: []\n }\n }\n @state() projectId: string = ''\n @state() project: Project = { ...this.defaultProject }\n @state() selectedBuildingIdx: number = 0\n\n render() {\n return html`\n <div header>\n <h2>도면 관리</h2>\n <div button-container>\n <md-elevated-button green @click=${this._saveProject}>\n <md-icon slot=\"icon\">save</md-icon>정보 저장\n </md-elevated-button>\n <md-elevated-button href=${`project-update/${this.project.id}`}>\n <md-icon slot=\"icon\">assignment</md-icon>프로젝트 정보 수정\n </md-elevated-button>\n <md-elevated-button href=${`project-task-update/${this.project.id}`}>\n <md-icon slot=\"icon\">event_note</md-icon>공정표 관리\n </md-elevated-button>\n </div>\n </div>\n\n <div body>\n <div building-container>\n <h3>동별 도면(BIM)</h3>\n <div>\n ${this.project.buildingComplex?.buildings?.map((building, idx) => {\n return html`\n <span building>\n <ox-input-file\n name=\"building-drawing\"\n .value=${building?.drawing || undefined}\n label=\" \"\n description=\"동 도면 업로드\"\n idx=${idx}\n @change=${this._onCreateAttachment.bind(this)}\n ></ox-input-file>\n <div>${building.name}</div>\n </span>\n `\n })}\n </div>\n </div>\n\n <div floor-container>\n <div floor-title>\n <h3>${this.project.buildingComplex?.buildings?.[this.selectedBuildingIdx]?.name} 층별 도면(PDF)</h3>\n <span building-button>\n ${this.project.buildingComplex.buildings?.map((building, idx) => {\n return this.project.buildingComplex?.buildings?.[this.selectedBuildingIdx]?.id === building.id\n ? html`\n <md-filled-button @click=${() => this._onClickBuildingChange(idx)}> ${building.name} </md-filled-button>\n `\n : html`\n <md-outlined-button @click=${() => this._onClickBuildingChange(idx)}> ${building.name} </md-outlined-button>\n `\n })}\n </span>\n </div>\n\n <div floor-plan>\n ${this.project.buildingComplex?.buildings?.[this.selectedBuildingIdx]?.buildingLevels?.map((buildingLevel, idx) => {\n return buildingLevel.mainDrawingThumbnail\n ? html`\n <span plan>\n <img\n name=\"building-plan\"\n .src=${buildingLevel.mainDrawingThumbnail}\n idx=${idx}\n @click=${this._onClickImage}\n />\n <div floor-name>${buildingLevel.floor}층</div>\n </span>\n `\n : html`\n <span plan>\n <a name=\"building-plan\" idx=${idx} @click=${this._onClickImage}>\n <md-icon slot=\"icon\">image</md-icon>\n <div bold>도면 파일</div>\n <div>업로드</div>\n </a>\n <div floor-name no-data>${buildingLevel.floor}층</div>\n </span>\n `\n })}\n </div>\n </div>\n\n <div plan-scale-container>\n <h3>도면 축척 설정</h3>\n <div>\n <span>가로</span>\n <md-outlined-text-field\n type=\"text\"\n name=\"planXScale\"\n numeric\n .value=${this.project.buildingComplex.planXScale?.toString() || ''}\n @input=${this._onInputChange}\n suffix-text=\"mm\"\n >\n </md-outlined-text-field>\n <span>X</span>\n <span>세로</span>\n <md-outlined-text-field\n type=\"text\"\n name=\"planYScale\"\n numeric\n .value=${this.project.buildingComplex.planYScale?.toString() || ''}\n @input=${this._onInputChange}\n suffix-text=\"mm\"\n >\n </md-outlined-text-field>\n </div>\n </div>\n </div>\n `\n }\n\n async pageInitialized(lifecycle: PageLifecycle) {}\n\n async pageUpdated(changes: any, lifecycle: PageLifecycle) {\n if (this.active) {\n this.projectId = lifecycle.resourceId || ''\n await this.initProject(this.projectId)\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 buildingComplex {\n id\n planXScale\n planYScale\n buildings {\n id\n name\n drawing {\n id\n name\n }\n buildingLevels {\n id\n floor\n mainDrawing {\n id\n name\n }\n elevationDrawing {\n id\n name\n }\n rebarDistributionDrawing {\n id\n name\n }\n mainDrawingThumbnail\n elevationDrawingThumbnail\n rebarDistributionDrawingThumbnail\n }\n }\n }\n }\n }\n `,\n variables: {\n id: projectId\n }\n })\n\n this.project = response.data?.project\n\n console.log('init project : ', this.project)\n }\n\n private async _saveProject() {\n // 첨부 파일 필드 제거 (첨부 파일은 {filename}Upload 로 전송)\n for (let buildingKey in this.project.buildingComplex.buildings) {\n const building = this.project.buildingComplex.buildings[buildingKey]\n delete this.project.buildingComplex.buildings[buildingKey].drawing\n\n for (let levelKey in building.buildingLevels) {\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawing\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawingImage\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawingThumbnail\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].elevationDrawing\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].elevationDrawingThumbnail\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].rebarDistributionDrawing\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].rebarDistributionDrawingThumbnail\n }\n }\n\n const response = await client.mutate({\n mutation: gql`\n mutation UpdateProjectPlan($project: ProjectPatch!) {\n updateProjectPlan(project: $project) {\n id\n }\n }\n `,\n variables: {\n project: this.project\n },\n context: {\n hasUpload: true\n }\n })\n\n if (!response.errors) {\n notify({ message: '저장에 성공하였습니다.' })\n\n // 데이터 다시 조회\n this.initProject(this.project.id)\n }\n }\n\n // Input 요소의 값이 변경될 때 호출되는 콜백 함수\n private _onInputChange(event: InputEvent, idx: number) {\n const target = event.target as HTMLInputElement\n let inputVal: any = target.value\n this.project.buildingComplex![target.name] = Number(inputVal.replace(/\\D/g, ''))\n }\n\n // 이미지 업로드\n async _onCreateAttachment(e: CustomEvent) {\n const target = e.target as HTMLInputElement\n const file = e.detail[0] || null\n const idx = Number(target.getAttribute('idx')) || 0\n\n this.project.buildingComplex!.buildings![idx].drawingUpload = file\n\n // re rendering\n this.project = { ...this.project }\n }\n\n _onClickBuildingChange(idx: number) {\n this.selectedBuildingIdx = idx\n }\n\n _onClickImage(e) {\n const target = e.currentTarget as HTMLInputElement\n const idx = Number(target.getAttribute('idx')) || 0\n const buildingLevel = this.project.buildingComplex!.buildings![this.selectedBuildingIdx].buildingLevels![idx]\n const title = buildingLevel.floor?.toString() + '층' || ''\n\n // 팝업 오픈\n this._openPopup(title, buildingLevel, idx)\n }\n\n private _openPopup(title: string, buildingLevel: BuildingLevel, selectedIdx: number) {\n openPopup(\n html`<popup-plan-upload\n .buildingLevel=${buildingLevel}\n .selectedIdx=${selectedIdx}\n @file_change=${this._onChangeAdditionalDrawing.bind(this)}\n ></popup-plan-upload>`,\n {\n backdrop: true,\n size: 'medium',\n title: `${title} 도면 관리`\n }\n )\n }\n\n private _onChangeAdditionalDrawing(e) {\n const idx = e.detail?.selectedIdx || null\n const buildingLevel: BuildingLevel = e.detail?.buildingLevel || {}\n\n this.project.buildingComplex!.buildings![this.selectedBuildingIdx]!.buildingLevels![idx] = { ...buildingLevel }\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"project-plan-management.js","sourceRoot":"","sources":["../../../client/pages/project/project-plan-management.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@material/web/button/elevated-button.js'\nimport '@material/web/textfield/outlined-text-field.js'\nimport '@material/web/button/filled-button.js'\nimport '@material/web/button/outlined-button.js'\n\nimport { PageView } from '@operato/shell'\nimport { PageLifecycle } from '@operato/shell/dist/src/app/pages/page-view'\nimport { css, html } from 'lit'\nimport { customElement, state } from 'lit/decorators.js'\nimport { ScopedElementsMixin } from '@open-wc/scoped-elements'\nimport { client } from '@operato/graphql'\nimport { notify } from '@operato/layout'\nimport { openPopup } from '@operato/layout'\n\nimport gql from 'graphql-tag'\nimport { Building, BuildingLevel, Project } from './project-list'\nimport './popup/popup-plan-upload'\nimport './component/project-update-header'\n\n@customElement('project-plan-management')\nexport class ProjectPlanManagement extends ScopedElementsMixin(PageView) {\n static styles = [\n css`\n :host {\n display: grid;\n grid-template-rows: 75px auto;\n color: #4e5055;\n\n background-color: #f7f7f7;\n overflow: hidden;\n overflow-y: auto;\n\n --grid-record-emphasized-background-color: red;\n --grid-record-emphasized-color: yellow;\n }\n\n md-outlined-text-field {\n width: 100%;\n\n --md-outlined-text-field-container-shape: 5px;\n --md-sys-color-primary: #586878;\n --md-outlined-text-field-input-text-size: 14px;\n --md-outlined-field-bottom-space: 4px;\n --md-outlined-field-top-space: 4px;\n }\n\n ox-input-image {\n width: 100px;\n height: 100px;\n }\n\n *[bold] {\n font-weight: bold;\n }\n\n div[body] {\n display: grid;\n grid-template-rows: 240px 1fr 60px;\n margin: 0px 25px 25px 25px;\n gap: 8px;\n\n & > div {\n display: grid;\n grid-template-rows: 25px auto;\n padding: 15px;\n background-color: #ffffff;\n border: 1px solid #cccccc80;\n border-radius: 5px;\n gap: 14px;\n\n h3 {\n color: #2e79be;\n font-size: 18px;\n margin: 0px;\n text-wrap: nowrap;\n }\n }\n\n & > div[building-container] > div {\n display: flex;\n gap: 16px;\n overflow-x: auto;\n overflow-y: hidden;\n\n ox-input-file {\n height: 120px;\n }\n\n span[building] {\n width: 125px;\n text-align: center;\n\n div {\n color: #586878;\n margin-top: 7px;\n }\n }\n }\n\n & > div[floor-container] {\n div[floor-title] {\n display: flex;\n justify-content: space-between;\n height: fit-content;\n gap: 50px;\n overflow: hidden;\n\n span[building-button] {\n display: flex;\n margin-left: auto;\n gap: 10px;\n overflow-x: auto;\n overflow-y: hidden;\n\n md-filled-button {\n --md-filled-button-container-color: #0595e5;\n --md-filled-button-container-height: 30px;\n --md-filled-button-trailing-space: 15px;\n --md-filled-button-leading-space: 15px;\n }\n md-outlined-button {\n --md-outlined-button-container-height: 30px;\n --md-outlined-button-trailing-space: 15px;\n --md-outlined-button-leading-space: 15px;\n }\n }\n }\n\n div[floor-plan] {\n overflow-y: auto;\n margin-top: 10px;\n\n & > span {\n display: inline-block;\n text-align: center;\n margin: 0px 10px 15px 0px;\n cursor: pointer;\n\n & > [name='building-plan'] {\n width: 150px;\n height: 100px;\n display: flex;\n flex-direction: column;\n justify-content: center;\n border: 1px solid #333;\n box-shadow: 2px 2px 2px #0000001a;\n align-items: center;\n border-radius: 7px;\n font-size: 13px;\n\n md-icon {\n margin-bottom: 6px;\n }\n }\n\n & > div[floor-name] {\n margin-top: 7px;\n\n &[no-data] {\n color: #f16154;\n font-weight: bold;\n }\n }\n }\n }\n }\n\n & > div[plan-scale-container] {\n display: flex;\n\n & > div {\n display: flex;\n align-items: center;\n gap: 12px;\n margin-left: 10px;\n\n md-outlined-text-field {\n width: 100px;\n --md-outlined-text-container-height: 30px;\n }\n }\n }\n }\n `\n ]\n\n get context() {\n return {\n title: '도면 관리'\n }\n }\n\n private defaultProject = {\n name: '',\n buildingComplex: {\n address: '',\n area: 0,\n constructionCompany: '',\n clientCompany: '',\n supervisoryCompany: '',\n designCompany: '',\n constructionType: '',\n buildings: []\n }\n }\n @state() projectId: string = ''\n @state() project: Project = { ...this.defaultProject }\n @state() selectedBuildingIdx: number = 0\n\n render() {\n return html`\n <project-update-header .projectId=${this.project.id || ''} title=\"도면 관리\" @custom-click=${this._saveProject}>\n </project-update-header>\n\n <div body>\n <div building-container>\n <h3>동별 도면(BIM)</h3>\n <div>\n ${this.project.buildingComplex?.buildings?.map((building, idx) => {\n return html`\n <span building>\n <ox-input-file\n name=\"building-drawing\"\n .value=${building?.drawing || undefined}\n label=\" \"\n description=\"동 도면 업로드\"\n idx=${idx}\n @change=${this._onCreateAttachment.bind(this)}\n ></ox-input-file>\n <div>${building.name}</div>\n </span>\n `\n })}\n </div>\n </div>\n\n <div floor-container>\n <div floor-title>\n <h3>${this.project.buildingComplex?.buildings?.[this.selectedBuildingIdx]?.name} 층별 도면(PDF)</h3>\n <span building-button>\n ${this.project.buildingComplex.buildings?.map((building, idx) => {\n return this.project.buildingComplex?.buildings?.[this.selectedBuildingIdx]?.id === building.id\n ? html`\n <md-filled-button @click=${() => this._onClickBuildingChange(idx)}> ${building.name} </md-filled-button>\n `\n : html`\n <md-outlined-button @click=${() => this._onClickBuildingChange(idx)}> ${building.name} </md-outlined-button>\n `\n })}\n </span>\n </div>\n\n <div floor-plan>\n ${this.project.buildingComplex?.buildings?.[this.selectedBuildingIdx]?.buildingLevels?.map((buildingLevel, idx) => {\n return buildingLevel.mainDrawingThumbnail\n ? html`\n <span plan>\n <img\n name=\"building-plan\"\n .src=${buildingLevel.mainDrawingThumbnail}\n idx=${idx}\n @click=${this._onClickImage}\n />\n <div floor-name>${buildingLevel.floor}층</div>\n </span>\n `\n : html`\n <span plan>\n <a name=\"building-plan\" idx=${idx} @click=${this._onClickImage}>\n <md-icon slot=\"icon\">image</md-icon>\n <div bold>도면 파일</div>\n <div>업로드</div>\n </a>\n <div floor-name no-data>${buildingLevel.floor}층</div>\n </span>\n `\n })}\n </div>\n </div>\n\n <div plan-scale-container>\n <h3>도면 축척 설정</h3>\n <div>\n <span>가로</span>\n <md-outlined-text-field\n type=\"text\"\n name=\"planXScale\"\n numeric\n .value=${this.project.buildingComplex.planXScale?.toString() || ''}\n @input=${this._onInputChange}\n suffix-text=\"mm\"\n >\n </md-outlined-text-field>\n <span>X</span>\n <span>세로</span>\n <md-outlined-text-field\n type=\"text\"\n name=\"planYScale\"\n numeric\n .value=${this.project.buildingComplex.planYScale?.toString() || ''}\n @input=${this._onInputChange}\n suffix-text=\"mm\"\n >\n </md-outlined-text-field>\n </div>\n </div>\n </div>\n `\n }\n\n async pageInitialized(lifecycle: PageLifecycle) {}\n\n async pageUpdated(changes: any, lifecycle: PageLifecycle) {\n if (this.active) {\n this.projectId = lifecycle.resourceId || ''\n await this.initProject(this.projectId)\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 buildingComplex {\n id\n planXScale\n planYScale\n buildings {\n id\n name\n drawing {\n id\n name\n }\n buildingLevels {\n id\n floor\n mainDrawing {\n id\n name\n }\n elevationDrawing {\n id\n name\n }\n rebarDistributionDrawing {\n id\n name\n }\n mainDrawingThumbnail\n elevationDrawingThumbnail\n rebarDistributionDrawingThumbnail\n }\n }\n }\n }\n }\n `,\n variables: {\n id: projectId\n }\n })\n\n this.project = response.data?.project\n }\n\n private async _saveProject() {\n // 첨부 파일 필드 제거 (첨부 파일은 {filename}Upload 로 전송)\n for (let buildingKey in this.project.buildingComplex.buildings) {\n const building = this.project.buildingComplex.buildings[buildingKey]\n delete this.project.buildingComplex.buildings[buildingKey].drawing\n\n for (let levelKey in building.buildingLevels) {\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawing\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawingImage\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawingThumbnail\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].elevationDrawing\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].elevationDrawingThumbnail\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].rebarDistributionDrawing\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].rebarDistributionDrawingThumbnail\n }\n }\n\n const response = await client.mutate({\n mutation: gql`\n mutation UpdateProjectPlan($project: ProjectPatch!) {\n updateProjectPlan(project: $project) {\n id\n }\n }\n `,\n variables: {\n project: this.project\n },\n context: {\n hasUpload: true\n }\n })\n\n if (!response.errors) {\n notify({ message: '저장에 성공하였습니다.' })\n\n // 데이터 다시 조회\n this.initProject(this.project.id)\n }\n }\n\n // Input 요소의 값이 변경될 때 호출되는 콜백 함수\n private _onInputChange(event: InputEvent, idx: number) {\n const target = event.target as HTMLInputElement\n let inputVal: any = target.value\n this.project.buildingComplex![target.name] = Number(inputVal.replace(/\\D/g, ''))\n }\n\n // 이미지 업로드\n async _onCreateAttachment(e: CustomEvent) {\n const target = e.target as HTMLInputElement\n const file = e.detail[0] || null\n const idx = Number(target.getAttribute('idx')) || 0\n\n this.project.buildingComplex!.buildings![idx].drawingUpload = file\n\n // re rendering\n this.project = { ...this.project }\n }\n\n _onClickBuildingChange(idx: number) {\n this.selectedBuildingIdx = idx\n }\n\n _onClickImage(e) {\n const target = e.currentTarget as HTMLInputElement\n const idx = Number(target.getAttribute('idx')) || 0\n const buildingLevel = this.project.buildingComplex!.buildings![this.selectedBuildingIdx].buildingLevels![idx]\n const title = buildingLevel.floor?.toString() + '층' || ''\n\n // 팝업 오픈\n this._openPopup(title, buildingLevel, idx)\n }\n\n private _openPopup(title: string, buildingLevel: BuildingLevel, selectedIdx: number) {\n openPopup(\n html`<popup-plan-upload\n .buildingLevel=${buildingLevel}\n .selectedIdx=${selectedIdx}\n @file_change=${this._onChangeAdditionalDrawing.bind(this)}\n ></popup-plan-upload>`,\n {\n backdrop: true,\n size: 'medium',\n title: `${title} 도면 관리`\n }\n )\n }\n\n private _onChangeAdditionalDrawing(e) {\n const idx = e.detail?.selectedIdx || null\n const buildingLevel: BuildingLevel = e.detail?.buildingLevel || {}\n\n this.project.buildingComplex!.buildings![this.selectedBuildingIdx]!.buildingLevels![idx] = { ...buildingLevel }\n }\n}\n"]}
|
|
@@ -7,6 +7,7 @@ import { PageView } from '@operato/shell';
|
|
|
7
7
|
import { PageLifecycle } from '@operato/shell/dist/src/app/pages/page-view';
|
|
8
8
|
import { Project } from './project-list';
|
|
9
9
|
import '@operato/gantt/ox-gantt.js';
|
|
10
|
+
import './popup/popup-schedule-upload';
|
|
10
11
|
declare const ProjectSchedule_base: typeof PageView & import("@open-wc/dedupe-mixin").Constructor<import("@open-wc/scoped-elements/types/src/types").ScopedElementsHost>;
|
|
11
12
|
export declare class ProjectSchedule extends ProjectSchedule_base {
|
|
12
13
|
static styles: import("lit").CSSResult[];
|
|
@@ -18,6 +19,7 @@ export declare class ProjectSchedule extends ProjectSchedule_base {
|
|
|
18
19
|
project: Project;
|
|
19
20
|
selectedBuildingIdx: number;
|
|
20
21
|
tasks: any;
|
|
22
|
+
constructionTypeList: never[];
|
|
21
23
|
private fromDate;
|
|
22
24
|
private toDate;
|
|
23
25
|
inputStartDate: HTMLInputElement;
|
|
@@ -30,5 +32,7 @@ export declare class ProjectSchedule extends ProjectSchedule_base {
|
|
|
30
32
|
pageUpdated(changes: any, lifecycle: PageLifecycle): Promise<void>;
|
|
31
33
|
initProject(projectId?: string): Promise<void>;
|
|
32
34
|
onChangePeriodRange(): void;
|
|
35
|
+
onRangeSelected(e: CustomEvent): void;
|
|
36
|
+
private _openUploadSchedulePopup;
|
|
33
37
|
}
|
|
34
38
|
export {};
|
|
@@ -10,8 +10,11 @@ import { customElement, query, state } from 'lit/decorators.js';
|
|
|
10
10
|
import { ScopedElementsMixin } from '@open-wc/scoped-elements';
|
|
11
11
|
import { client } from '@operato/graphql';
|
|
12
12
|
import { i18next } from '@operato/i18n';
|
|
13
|
+
import { openPopup } from '@operato/layout';
|
|
13
14
|
import gql from 'graphql-tag';
|
|
15
|
+
import { ScrollbarStyles } from '@operato/styles';
|
|
14
16
|
import '@operato/gantt/ox-gantt.js';
|
|
17
|
+
import './popup/popup-schedule-upload';
|
|
15
18
|
const TaskFragment = gql `
|
|
16
19
|
fragment TaskFragment on Task {
|
|
17
20
|
type
|
|
@@ -47,6 +50,7 @@ let ProjectSchedule = class ProjectSchedule extends ScopedElementsMixin(PageView
|
|
|
47
50
|
this.projectId = '';
|
|
48
51
|
this.project = Object.assign({}, this.defaultProject);
|
|
49
52
|
this.selectedBuildingIdx = 0;
|
|
53
|
+
this.constructionTypeList = [];
|
|
50
54
|
this.fromDate = '2024-01-01';
|
|
51
55
|
this.toDate = '2024-12-31';
|
|
52
56
|
this.timeScale = 'week-day';
|
|
@@ -84,17 +88,12 @@ let ProjectSchedule = class ProjectSchedule extends ScopedElementsMixin(PageView
|
|
|
84
88
|
};
|
|
85
89
|
}
|
|
86
90
|
render() {
|
|
91
|
+
var _a;
|
|
87
92
|
return html `
|
|
88
93
|
<div header>
|
|
89
94
|
<h2>${this.project.name}</h2>
|
|
90
95
|
<div button-container>
|
|
91
|
-
<md-elevated-button
|
|
92
|
-
<md-icon slot="icon">assignment</md-icon>프로젝트 정보 수정
|
|
93
|
-
</md-elevated-button>
|
|
94
|
-
<md-elevated-button href=${`project-plan-management/${this.project.id}`}>
|
|
95
|
-
<md-icon slot="icon">description</md-icon>도면 관리
|
|
96
|
-
</md-elevated-button>
|
|
97
|
-
<md-elevated-button href=${`project-task-update/${this.project.id}`}>
|
|
96
|
+
<md-elevated-button @click=${this._openUploadSchedulePopup}>
|
|
98
97
|
<md-icon slot="icon">event_note</md-icon>공정표 관리
|
|
99
98
|
</md-elevated-button>
|
|
100
99
|
</div>
|
|
@@ -106,9 +105,7 @@ let ProjectSchedule = class ProjectSchedule extends ScopedElementsMixin(PageView
|
|
|
106
105
|
to-date=${new Date(this.toDate).toISOString().split('T')[0]}
|
|
107
106
|
.timeScale=${this.timeScale}
|
|
108
107
|
.tasks=${this.tasks}
|
|
109
|
-
@date-range-selected=${
|
|
110
|
-
console.log('date-range-selected', e.detail);
|
|
111
|
-
}}
|
|
108
|
+
@date-range-selected=${this.onRangeSelected}
|
|
112
109
|
@task-clicked=${(e) => {
|
|
113
110
|
console.log('task-clicked', e.detail);
|
|
114
111
|
}}
|
|
@@ -128,7 +125,9 @@ let ProjectSchedule = class ProjectSchedule extends ScopedElementsMixin(PageView
|
|
|
128
125
|
<input type="date" name="endDate" project .value=${this.project.endDate || ''} max="9999-12-31" />
|
|
129
126
|
</div>
|
|
130
127
|
</div>
|
|
131
|
-
<div
|
|
128
|
+
<div construction-list-container>
|
|
129
|
+
${(_a = this.constructionTypeList) === null || _a === void 0 ? void 0 : _a.map((constructionType) => html ` <md-outlined-button id=${constructionType.id}>${constructionType.title}</md-outlined-button>`)}
|
|
130
|
+
</div>
|
|
132
131
|
</div>
|
|
133
132
|
</div>
|
|
134
133
|
`;
|
|
@@ -159,6 +158,10 @@ let ProjectSchedule = class ProjectSchedule extends ScopedElementsMixin(PageView
|
|
|
159
158
|
}
|
|
160
159
|
}
|
|
161
160
|
}
|
|
161
|
+
scheduleTable {
|
|
162
|
+
id
|
|
163
|
+
name
|
|
164
|
+
}
|
|
162
165
|
buildingComplex {
|
|
163
166
|
id
|
|
164
167
|
planXScale
|
|
@@ -202,8 +205,30 @@ let ProjectSchedule = class ProjectSchedule extends ScopedElementsMixin(PageView
|
|
|
202
205
|
this.fromDate = this.inputStartDate.value;
|
|
203
206
|
this.toDate = this.inputEndDate.value;
|
|
204
207
|
}
|
|
208
|
+
onRangeSelected(e) {
|
|
209
|
+
const selectedFromDate = new Date(e.detail.start + 'T00:00:00.000Z');
|
|
210
|
+
const selectedToDate = new Date(e.detail.end + 'T23:59:59.000Z');
|
|
211
|
+
this.constructionTypeList = this.tasks.filter(constuction => {
|
|
212
|
+
const constuctionStartDate = new Date(constuction.startDate);
|
|
213
|
+
const constuctionEndDate = new Date(constuction.endDate);
|
|
214
|
+
return constuctionStartDate <= selectedToDate && constuctionEndDate >= selectedFromDate;
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
_openUploadSchedulePopup() {
|
|
218
|
+
var _a;
|
|
219
|
+
openPopup(html `<popup-schedule-upload
|
|
220
|
+
.projectId=${this.projectId}
|
|
221
|
+
.scheduleTable=${(_a = this.project) === null || _a === void 0 ? void 0 : _a.scheduleTable}
|
|
222
|
+
@uploaded=${() => this.initProject(this.projectId)}
|
|
223
|
+
></popup-schedule-upload>`, {
|
|
224
|
+
backdrop: true,
|
|
225
|
+
size: 'medium',
|
|
226
|
+
title: `공정표 업로드`
|
|
227
|
+
});
|
|
228
|
+
}
|
|
205
229
|
};
|
|
206
230
|
ProjectSchedule.styles = [
|
|
231
|
+
ScrollbarStyles,
|
|
207
232
|
css `
|
|
208
233
|
:host {
|
|
209
234
|
display: flex;
|
|
@@ -305,11 +330,25 @@ ProjectSchedule.styles = [
|
|
|
305
330
|
}
|
|
306
331
|
}
|
|
307
332
|
|
|
308
|
-
div[
|
|
333
|
+
div[construction-list-container] {
|
|
309
334
|
flex: 1;
|
|
335
|
+
display: flex;
|
|
310
336
|
border-radius: 5px;
|
|
311
337
|
border: 1px solid #cccccc80;
|
|
312
338
|
background-color: #fff;
|
|
339
|
+
padding: 8px 10px;
|
|
340
|
+
gap: 10px;
|
|
341
|
+
overflow-x: auto;
|
|
342
|
+
|
|
343
|
+
md-outlined-button {
|
|
344
|
+
--md-outlined-button-container-height: 30px;
|
|
345
|
+
--md-outlined-button-trailing-space: 15px;
|
|
346
|
+
--md-outlined-button-leading-space: 15px;
|
|
347
|
+
--md-outlined-button-label-text-color: #586878;
|
|
348
|
+
box-shadow: 1px 1px 1px #0000001a;
|
|
349
|
+
padding: 8px 16px;
|
|
350
|
+
font-weight: 700;
|
|
351
|
+
}
|
|
313
352
|
}
|
|
314
353
|
}
|
|
315
354
|
}
|
|
@@ -331,6 +370,10 @@ __decorate([
|
|
|
331
370
|
state(),
|
|
332
371
|
__metadata("design:type", Object)
|
|
333
372
|
], ProjectSchedule.prototype, "tasks", void 0);
|
|
373
|
+
__decorate([
|
|
374
|
+
state(),
|
|
375
|
+
__metadata("design:type", Object)
|
|
376
|
+
], ProjectSchedule.prototype, "constructionTypeList", void 0);
|
|
334
377
|
__decorate([
|
|
335
378
|
state(),
|
|
336
379
|
__metadata("design:type", Object)
|