@dssp/project 1.0.0-alpha.5 → 1.0.0-alpha.7

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 (32) hide show
  1. package/dist-client/pages/lib/waether.d.ts +2 -1
  2. package/dist-client/pages/lib/waether.js +7 -3
  3. package/dist-client/pages/lib/waether.js.map +1 -1
  4. package/dist-client/pages/project/popup/popup-plan-export.d.ts +10 -0
  5. package/dist-client/pages/project/popup/popup-plan-export.js +236 -0
  6. package/dist-client/pages/project/popup/popup-plan-export.js.map +1 -0
  7. package/dist-client/pages/project/popup/popup-plan-upload.d.ts +3 -0
  8. package/dist-client/pages/project/popup/popup-plan-upload.js +130 -4
  9. package/dist-client/pages/project/popup/popup-plan-upload.js.map +1 -1
  10. package/dist-client/pages/project/project-detail.d.ts +2 -1
  11. package/dist-client/pages/project/project-detail.js +193 -80
  12. package/dist-client/pages/project/project-detail.js.map +1 -1
  13. package/dist-client/pages/project/project-list.d.ts +12 -0
  14. package/dist-client/pages/project/project-list.js +6 -0
  15. package/dist-client/pages/project/project-list.js.map +1 -1
  16. package/dist-client/pages/project/project-plan-management.js +29 -13
  17. package/dist-client/pages/project/project-plan-management.js.map +1 -1
  18. package/dist-client/pages/project/project-update.d.ts +1 -0
  19. package/dist-client/pages/project/project-update.js +128 -17
  20. package/dist-client/pages/project/project-update.js.map +1 -1
  21. package/dist-client/tsconfig.tsbuildinfo +1 -1
  22. package/dist-server/service/project/project-mutation.d.ts +1 -0
  23. package/dist-server/service/project/project-mutation.js +102 -3
  24. package/dist-server/service/project/project-mutation.js.map +1 -1
  25. package/dist-server/service/project/project-type.d.ts +1 -0
  26. package/dist-server/service/project/project-type.js +5 -1
  27. package/dist-server/service/project/project-type.js.map +1 -1
  28. package/dist-server/service/project/project.d.ts +3 -1
  29. package/dist-server/service/project/project.js +6 -0
  30. package/dist-server/service/project/project.js.map +1 -1
  31. package/dist-server/tsconfig.tsbuildinfo +1 -1
  32. package/package.json +13 -12
@@ -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 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 sortings: [{ name: 'createdAt', desc: true }]\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":"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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 enum ProjectType {\n DSSP = 'DSSP',\n DCSP = 'DCSP',\n DKPI = 'DKPI'\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 robotCount?: number\n scheduleTable?: Attachment\n buildingComplex: BuildingComplex\n projectType?: ProjectType\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 hasBasement?: boolean\n basementFloorCount?: number\n drawing?: Attachment\n drawingUpload?: FileUpload\n buildingLevels?: BuildingLevel[]\n}\n\nexport interface BuildingLevel {\n id?: string\n floor?: number\n floorDisplayName?: string\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 etcDrawings?: Attachment[]\n etcDrawingsUpload?: 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 sortings: [{ name: 'createdAt', desc: true }]\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"]}
@@ -95,7 +95,7 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
95
95
  idx=${idx}
96
96
  @click=${this._onClickImage}
97
97
  />
98
- <div floor-name>${buildingLevel.floor}층</div>
98
+ <div floor-name>${buildingLevel.floorDisplayName}층</div>
99
99
  </span>
100
100
  `
101
101
  : html `
@@ -105,7 +105,7 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
105
105
  <div bold>도면 파일</div>
106
106
  <div>업로드</div>
107
107
  </a>
108
- <div floor-name no-data>${buildingLevel.floor}층</div>
108
+ <div floor-name no-data>${buildingLevel.floorDisplayName}층</div>
109
109
  </span>
110
110
  `;
111
111
  })}
@@ -170,6 +170,7 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
170
170
  buildingLevels {
171
171
  id
172
172
  floor
173
+ floorDisplayName
173
174
  mainDrawing {
174
175
  id
175
176
  name
@@ -182,9 +183,18 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
182
183
  id
183
184
  name
184
185
  }
186
+ etcDrawings {
187
+ id
188
+ name
189
+ }
185
190
  mainDrawingThumbnail
186
191
  elevationDrawingThumbnail
187
192
  rebarDistributionDrawingThumbnail
193
+
194
+ building {
195
+ id
196
+ name
197
+ }
188
198
  }
189
199
  }
190
200
  }
@@ -198,11 +208,17 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
198
208
  this.project = (_a = response.data) === null || _a === void 0 ? void 0 : _a.project;
199
209
  }
200
210
  async _saveProject() {
211
+ var _a;
201
212
  // 첨부 파일 필드 제거 (첨부 파일은 {filename}Upload 로 전송)
202
213
  for (let buildingKey in this.project.buildingComplex.buildings) {
203
214
  const building = this.project.buildingComplex.buildings[buildingKey];
204
215
  delete this.project.buildingComplex.buildings[buildingKey].drawing;
205
216
  for (let levelKey in building.buildingLevels) {
217
+ // 멀티 파일인 etcDrawings은 제거되지 않은 id 리스트 생성
218
+ const etcDrawingIds = (_a = this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey]) === null || _a === void 0 ? void 0 : _a.etcDrawings.filter(v => v.id).map(v => v.id);
219
+ this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].etcDrawingIds = etcDrawingIds;
220
+ delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].building;
221
+ delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].floorDisplayName;
206
222
  delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawing;
207
223
  delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawingImage;
208
224
  delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].mainDrawingThumbnail;
@@ -210,6 +226,7 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
210
226
  delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].elevationDrawingThumbnail;
211
227
  delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].rebarDistributionDrawing;
212
228
  delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].rebarDistributionDrawingThumbnail;
229
+ delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].etcDrawings;
213
230
  }
214
231
  }
215
232
  const response = await client.mutate({
@@ -252,11 +269,10 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
252
269
  this.selectedBuildingIdx = idx;
253
270
  }
254
271
  _onClickImage(e) {
255
- var _a;
256
272
  const target = e.currentTarget;
257
273
  const idx = Number(target.getAttribute('idx')) || 0;
258
274
  const buildingLevel = this.project.buildingComplex.buildings[this.selectedBuildingIdx].buildingLevels[idx];
259
- const title = ((_a = buildingLevel.floor) === null || _a === void 0 ? void 0 : _a.toString()) + '층' || '';
275
+ const title = buildingLevel.floorDisplayName + '층' || '';
260
276
  // 팝업 오픈
261
277
  this._openPopup(title, buildingLevel, idx);
262
278
  }
@@ -267,7 +283,7 @@ let ProjectPlanManagement = class ProjectPlanManagement extends ScopedElementsMi
267
283
  @file_change=${this._onChangeAdditionalDrawing.bind(this)}
268
284
  ></popup-plan-upload>`, {
269
285
  backdrop: true,
270
- size: 'medium',
286
+ size: 'large',
271
287
  title: `${title} 도면 관리`
272
288
  });
273
289
  }
@@ -297,7 +313,7 @@ ProjectPlanManagement.styles = [
297
313
  width: 100%;
298
314
 
299
315
  --md-outlined-text-field-container-shape: 5px;
300
- --md-outlined-text-field-outline-color: rgba(51,51,51,.20);
316
+ --md-outlined-text-field-outline-color: rgba(51, 51, 51, 0.2);
301
317
  --md-outlined-text-field-focus-outline-color: #1f7fd9;
302
318
  --md-outlined-text-field-focus-outline-width: 1px;
303
319
  --md-sys-color-primary: #586878;
@@ -321,7 +337,7 @@ ProjectPlanManagement.styles = [
321
337
  display: grid;
322
338
  grid-template-rows: 205px 1fr 60px;
323
339
  margin: var(--spacing-large, 12px);
324
- margin-top:0;
340
+ margin-top: 0;
325
341
  gap: var(--spacing-medium, 8px);
326
342
 
327
343
  & > div {
@@ -357,7 +373,7 @@ ProjectPlanManagement.styles = [
357
373
 
358
374
  div {
359
375
  color: #586878;
360
- margin-top:var(--spacing-small, 4px);
376
+ margin-top: var(--spacing-small, 4px);
361
377
  font-size: 14px;
362
378
  }
363
379
  }
@@ -388,7 +404,7 @@ ProjectPlanManagement.styles = [
388
404
  --md-outlined-button-container-height: 30px;
389
405
  --md-outlined-button-trailing-space: var(--spacing-medium, 8px);
390
406
  --md-outlined-button-leading-space: var(--spacing-medium, 8px);
391
- --md-sys-color-outline: rgba(51,51,51,.20);
407
+ --md-sys-color-outline: rgba(51, 51, 51, 0.2);
392
408
  }
393
409
  }
394
410
  }
@@ -400,8 +416,8 @@ ProjectPlanManagement.styles = [
400
416
  & > span {
401
417
  display: inline-block;
402
418
  text-align: center;
403
- margin-right:var(--spacing-medium, 8px);
404
- margin-bottom:var(--spacing-medium, 8px);
419
+ margin-right: var(--spacing-medium, 8px);
420
+ margin-bottom: var(--spacing-medium, 8px);
405
421
  cursor: pointer;
406
422
 
407
423
  & > [name='building-plan'] {
@@ -410,7 +426,7 @@ ProjectPlanManagement.styles = [
410
426
  display: flex;
411
427
  flex-direction: column;
412
428
  justify-content: center;
413
- border: 1px solid rgba(51,51,51,.1);
429
+ border: 1px solid rgba(51, 51, 51, 0.1);
414
430
  box-shadow: 1px 1px 1px #0000001a;
415
431
  align-items: center;
416
432
  border-radius: 5px;
@@ -423,7 +439,7 @@ ProjectPlanManagement.styles = [
423
439
 
424
440
  & > div[floor-name] {
425
441
  margin-top: var(--spacing-small, 4px);
426
- font-size:14px;
442
+ font-size: 14px;
427
443
 
428
444
  &[no-data] {
429
445
  color: #f16154;
@@ -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'\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: 55px auto;\n color: #4e5055;\n\n background-color: var(--md-sys-color-background, #f6f6f6);\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-outlined-text-field-outline-color: rgba(51,51,51,.20);\n --md-outlined-text-field-focus-outline-color: #1f7fd9;\n --md-outlined-text-field-focus-outline-width: 1px;\n --md-sys-color-primary: #586878;\n --md-outlined-text-field-input-text-size: 14px;\n --md-outlined-field-bottom-space: 3px;\n --md-outlined-field-top-space: 3px;\n --md-outlined-field-leading-space: var(--spacing-medium, 8px);\n --md-outlined-field-trailing-space: var(--spacing-medium, 8px);\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: 205px 1fr 60px;\n margin: var(--spacing-large, 12px);\n margin-top:0;\n gap: var(--spacing-medium, 8px);\n\n & > div {\n display: grid;\n grid-template-rows: 25px auto;\n padding: var(--spacing-large, 12px);\n background-color: var(--md-sys-color-on-primary);\n border: 1px solid #cccccc80;\n border-radius: 5px;\n gap: var(--spacing-medium, 8px);\n\n h3 {\n color: #2e79be;\n font-size: 16px;\n margin: 0px;\n text-wrap: nowrap;\n }\n }\n\n & > div[building-container] > div {\n display: flex;\n gap: var(--spacing-medium, 8px);\n overflow-x: auto;\n overflow-y: hidden;\n\n ox-input-file {\n height: 100px;\n }\n\n span[building] {\n width: 125px;\n text-align: center;\n\n div {\n color: #586878;\n margin-top:var(--spacing-small, 4px);\n font-size: 14px;\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: var(--spacing-huge, 24px);\n overflow: hidden;\n\n span[building-button] {\n display: flex;\n margin-left: auto;\n gap: var(--spacing-small, 4px);\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: var(--spacing-medium, 8px);\n --md-filled-button-leading-space: var(--spacing-medium, 8px);\n }\n md-outlined-button {\n --md-outlined-button-container-height: 30px;\n --md-outlined-button-trailing-space: var(--spacing-medium, 8px);\n --md-outlined-button-leading-space: var(--spacing-medium, 8px);\n --md-sys-color-outline: rgba(51,51,51,.20);\n }\n }\n }\n\n div[floor-plan] {\n overflow-y: auto;\n margin-top: var(--spacing-medium, 8px);\n\n & > span {\n display: inline-block;\n text-align: center;\n margin-right:var(--spacing-medium, 8px);\n margin-bottom:var(--spacing-medium, 8px);\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 rgba(51,51,51,.1);\n box-shadow: 1px 1px 1px #0000001a;\n align-items: center;\n border-radius: 5px;\n font-size: 13px;\n\n md-icon {\n margin-bottom: var(--spacing-small, 4px);\n }\n }\n\n & > div[floor-name] {\n margin-top: var(--spacing-small, 4px);\n font-size:14px;\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: var(--spacing-medium, 8px);\n margin-left: var(--spacing-medium, 8px);\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"]}
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: 55px auto;\n color: #4e5055;\n\n background-color: var(--md-sys-color-background, #f6f6f6);\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-outlined-text-field-outline-color: rgba(51, 51, 51, 0.2);\n --md-outlined-text-field-focus-outline-color: #1f7fd9;\n --md-outlined-text-field-focus-outline-width: 1px;\n --md-sys-color-primary: #586878;\n --md-outlined-text-field-input-text-size: 14px;\n --md-outlined-field-bottom-space: 3px;\n --md-outlined-field-top-space: 3px;\n --md-outlined-field-leading-space: var(--spacing-medium, 8px);\n --md-outlined-field-trailing-space: var(--spacing-medium, 8px);\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: 205px 1fr 60px;\n margin: var(--spacing-large, 12px);\n margin-top: 0;\n gap: var(--spacing-medium, 8px);\n\n & > div {\n display: grid;\n grid-template-rows: 25px auto;\n padding: var(--spacing-large, 12px);\n background-color: var(--md-sys-color-on-primary);\n border: 1px solid #cccccc80;\n border-radius: 5px;\n gap: var(--spacing-medium, 8px);\n\n h3 {\n color: #2e79be;\n font-size: 16px;\n margin: 0px;\n text-wrap: nowrap;\n }\n }\n\n & > div[building-container] > div {\n display: flex;\n gap: var(--spacing-medium, 8px);\n overflow-x: auto;\n overflow-y: hidden;\n\n ox-input-file {\n height: 100px;\n }\n\n span[building] {\n width: 125px;\n text-align: center;\n\n div {\n color: #586878;\n margin-top: var(--spacing-small, 4px);\n font-size: 14px;\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: var(--spacing-huge, 24px);\n overflow: hidden;\n\n span[building-button] {\n display: flex;\n margin-left: auto;\n gap: var(--spacing-small, 4px);\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: var(--spacing-medium, 8px);\n --md-filled-button-leading-space: var(--spacing-medium, 8px);\n }\n md-outlined-button {\n --md-outlined-button-container-height: 30px;\n --md-outlined-button-trailing-space: var(--spacing-medium, 8px);\n --md-outlined-button-leading-space: var(--spacing-medium, 8px);\n --md-sys-color-outline: rgba(51, 51, 51, 0.2);\n }\n }\n }\n\n div[floor-plan] {\n overflow-y: auto;\n margin-top: var(--spacing-medium, 8px);\n\n & > span {\n display: inline-block;\n text-align: center;\n margin-right: var(--spacing-medium, 8px);\n margin-bottom: var(--spacing-medium, 8px);\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 rgba(51, 51, 51, 0.1);\n box-shadow: 1px 1px 1px #0000001a;\n align-items: center;\n border-radius: 5px;\n font-size: 13px;\n\n md-icon {\n margin-bottom: var(--spacing-small, 4px);\n }\n }\n\n & > div[floor-name] {\n margin-top: var(--spacing-small, 4px);\n font-size: 14px;\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: var(--spacing-medium, 8px);\n margin-left: var(--spacing-medium, 8px);\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.floorDisplayName}층</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.floorDisplayName}층</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 floorDisplayName\n mainDrawing {\n id\n name\n }\n elevationDrawing {\n id\n name\n }\n rebarDistributionDrawing {\n id\n name\n }\n etcDrawings {\n id\n name\n }\n mainDrawingThumbnail\n elevationDrawingThumbnail\n rebarDistributionDrawingThumbnail\n\n building {\n id\n name\n }\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 // 멀티 파일인 etcDrawings은 제거되지 않은 id 리스트 생성\n const etcDrawingIds = this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey]?.etcDrawings\n .filter(v => v.id)\n .map(v => v.id)\n this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].etcDrawingIds = etcDrawingIds\n\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].building\n delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].floorDisplayName\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 delete this.project.buildingComplex.buildings[buildingKey].buildingLevels[levelKey].etcDrawings\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.floorDisplayName + '층' || ''\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: 'large',\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"]}
@@ -42,5 +42,6 @@ export declare class ProjectUpdate extends ProjectUpdate_base {
42
42
  private _onInputChange;
43
43
  onCreateAttachment(e: CustomEvent): Promise<void>;
44
44
  private _handleSelectionChange;
45
+ private _toggleBasement;
45
46
  }
46
47
  export {};
@@ -41,7 +41,7 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
41
41
  };
42
42
  }
43
43
  render() {
44
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11, _12, _13, _14, _15, _16, _17, _18, _19, _20, _21, _22, _23, _24, _25, _26, _27, _28, _29, _30;
44
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11, _12, _13, _14, _15, _16, _17, _18, _19, _20, _21, _22, _23, _24, _25, _26, _27, _28, _29, _30, _31;
45
45
  return html `
46
46
  <project-update-header .projectId=${this.project.id || ''} title="프로젝트 정보 관리" @custom-click=${this._saveProject}>
47
47
  </project-update-header>
@@ -326,7 +326,7 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
326
326
  <div warn>* 동/층의 정보를 수정하면 기존의 동/층 정보는 모두 제거됩니다.</div>
327
327
  <div separate-container>
328
328
  ${(_22 = (_21 = (_20 = this.project) === null || _20 === void 0 ? void 0 : _20.buildingComplex) === null || _21 === void 0 ? void 0 : _21.buildings) === null || _22 === void 0 ? void 0 : _22.map((building, idx) => {
329
- var _a;
329
+ var _a, _b;
330
330
  return html `
331
331
  <div>
332
332
  <span>
@@ -339,7 +339,7 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
339
339
  placeholder="ooo동"
340
340
  ></md-outlined-text-field>
341
341
  </span>
342
- <span>
342
+ <span floor-row>
343
343
  <span floor-title>층수</span>
344
344
  <md-outlined-text-field
345
345
  type="text"
@@ -351,6 +351,31 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
351
351
  placeholder="oo"
352
352
  ></md-outlined-text-field>
353
353
  </span>
354
+
355
+ <div basement-container>
356
+ <div
357
+ basement-checkbox
358
+ name="hasBasement"
359
+ ?checked=${(building === null || building === void 0 ? void 0 : building.hasBasement) || false}
360
+ @click=${() => this._toggleBasement(idx)}
361
+ >
362
+ <md-icon>format_bold</md-icon>
363
+ </div>
364
+ ${(building === null || building === void 0 ? void 0 : building.hasBasement)
365
+ ? html `
366
+ <md-outlined-text-field
367
+ basement-floor
368
+ type="text"
369
+ numeric
370
+ building
371
+ name="basementFloorCount"
372
+ .value=${((_b = building === null || building === void 0 ? void 0 : building.basementFloorCount) === null || _b === void 0 ? void 0 : _b.toString()) || ''}
373
+ @input=${e => this._onInputChange(e, idx)}
374
+ placeholder="지하층수"
375
+ ></md-outlined-text-field>
376
+ `
377
+ : ''}
378
+ </div>
354
379
  </div>
355
380
  `;
356
381
  })}
@@ -449,6 +474,22 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
449
474
  </span>
450
475
  </div>
451
476
  </div>
477
+
478
+ <div row separate-container>
479
+ <div>
480
+ <span>로봇 작업 대수</span>
481
+ <span
482
+ ><md-outlined-text-field
483
+ type="text"
484
+ numeric
485
+ project
486
+ name="robotCount"
487
+ .value=${((_29 = this.project.robotCount) === null || _29 === void 0 ? void 0 : _29.toString()) || ''}
488
+ @input=${this._onInputChange}
489
+ ></md-outlined-text-field>
490
+ </span>
491
+ </div>
492
+ </div>
452
493
  </div>
453
494
 
454
495
  <div>
@@ -460,7 +501,7 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
460
501
  type="textarea"
461
502
  name="notice"
462
503
  building-complex
463
- .value=${((_30 = (_29 = this.project) === null || _29 === void 0 ? void 0 : _29.buildingComplex) === null || _30 === void 0 ? void 0 : _30.notice) || ''}
504
+ .value=${((_31 = (_30 = this.project) === null || _30 === void 0 ? void 0 : _30.buildingComplex) === null || _31 === void 0 ? void 0 : _31.notice) || ''}
464
505
  @input=${this._onInputChange}
465
506
  ></md-outlined-text-field>
466
507
  </span>
@@ -496,6 +537,7 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
496
537
  inspPassRate
497
538
  robotProgressRate
498
539
  structuralSafetyRate
540
+ robotCount
499
541
  buildingComplex {
500
542
  id
501
543
  address
@@ -524,6 +566,8 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
524
566
  id
525
567
  name
526
568
  floorCount
569
+ hasBasement
570
+ basementFloorCount
527
571
  }
528
572
  }
529
573
  }
@@ -650,6 +694,16 @@ let ProjectUpdate = class ProjectUpdate extends ScopedElementsMixin(PageView) {
650
694
  const selectedValues = e.detail.selectedValues;
651
695
  this.project.buildingComplex[name] = selectedValues;
652
696
  }
697
+ _toggleBasement(idx) {
698
+ const building = this.project.buildingComplex.buildings[idx];
699
+ building.hasBasement = !building.hasBasement;
700
+ // 층 수가 0이거나 체크 해제시 지하층수 초기화 (플레이스 홀더 나오게 하기 위함)
701
+ if (building.basementFloorCount == 0 || !building.hasBasement) {
702
+ building.basementFloorCount = undefined;
703
+ }
704
+ this.project.buildingComplex.buildings[idx]['hasBasement'] = building.hasBasement;
705
+ this.requestUpdate();
706
+ }
653
707
  };
654
708
  ProjectUpdate.styles = [
655
709
  css `
@@ -670,7 +724,7 @@ ProjectUpdate.styles = [
670
724
  width: 100%;
671
725
 
672
726
  --md-outlined-text-field-container-shape: 5px;
673
- --md-outlined-text-field-outline-color: rgba(51,51,51,.20);
727
+ --md-outlined-text-field-outline-color: rgba(51, 51, 51, 0.2);
674
728
  --md-outlined-text-field-focus-outline-color: #1f7fd9;
675
729
  --md-outlined-text-field-focus-outline-width: 1px;
676
730
  --md-sys-color-primary: #586878;
@@ -681,11 +735,11 @@ ProjectUpdate.styles = [
681
735
  --md-outlined-field-trailing-space: var(--spacing-medium, 8px);
682
736
  }
683
737
  select2-component {
684
- width:100%;
738
+ width: 100%;
685
739
  }
686
- input[type="date"] {
687
- border:1px solid rgba(51,51,51,.20);
688
- padding:var(--spacing-small, 4px) var(--spacing-medium, 8px);
740
+ input[type='date'] {
741
+ border: 1px solid rgba(51, 51, 51, 0.2);
742
+ padding: var(--spacing-small, 4px) var(--spacing-medium, 8px);
689
743
  border-radius: 5px;
690
744
  }
691
745
  md-outlined-text-field[type='textarea'] {
@@ -707,7 +761,7 @@ ProjectUpdate.styles = [
707
761
  div[body] {
708
762
  display: flex;
709
763
  margin: var(--spacing-large, 12px);
710
- margin-top:0;
764
+ margin-top: 0;
711
765
  gap: var(--spacing-medium, 8px);
712
766
 
713
767
  & > div {
@@ -780,7 +834,7 @@ ProjectUpdate.styles = [
780
834
  --md-elevated-button-label-text-size: 16px;
781
835
  }
782
836
  hr {
783
- border: 1px rgba(51,51,51,.1) dashed;
837
+ border: 1px rgba(51, 51, 51, 0.1) dashed;
784
838
  width: 100%;
785
839
  margin-bottom: var(--spacing-tiny, 2px);
786
840
  }
@@ -790,14 +844,14 @@ ProjectUpdate.styles = [
790
844
  margin-left: var(--spacing-small, 4px);
791
845
  margin-bottom: var(--spacing-small, 4px);
792
846
  }
793
-
847
+
794
848
  md-outlined-button {
795
849
  min-height: 30px;
796
850
  padding: 0 var(--spacing-large, 12px);
797
851
  box-shadow: 1px 1px 1px #0000001a;
798
852
  --md-outlined-button-label-text-color: #586878;
799
853
  --md-outlined-button-label-text-weight: bold;
800
- --md-sys-color-outline: rgba(51,51,51,.20);
854
+ --md-sys-color-outline: rgba(51, 51, 51, 0.2);
801
855
  }
802
856
 
803
857
  div[row] {
@@ -812,14 +866,22 @@ ProjectUpdate.styles = [
812
866
  div[separate-container] {
813
867
  display: grid;
814
868
  grid-template-columns: repeat(2, 1fr);
815
- gap: var(--spacing-medium, 8px);
869
+ gap: 8px 30px;
870
+ margin-left: 15px;
816
871
 
817
872
  md-outlined-text-field {
818
- width: 70px;
873
+ width: 80px;
819
874
  }
820
875
 
821
876
  & > div {
822
877
  display: flex;
878
+ gap: 15px;
879
+
880
+ span[floor-row] {
881
+ display: inline-flex;
882
+ align-items: center;
883
+ margin-left: 5px;
884
+ }
823
885
 
824
886
  span[floor-title] {
825
887
  min-width: 33px;
@@ -827,7 +889,7 @@ ProjectUpdate.styles = [
827
889
  }
828
890
  span:first-child {
829
891
  flex: 0.4;
830
- justify-content: end;
892
+ justify-content: flex-start;
831
893
  display: flex;
832
894
  }
833
895
  span:last-child {
@@ -837,13 +899,62 @@ ProjectUpdate.styles = [
837
899
  padding-left: var(--spacing-medium, 8px);
838
900
  }
839
901
  }
902
+
903
+ div[basement-container] {
904
+ display: flex;
905
+ align-items: center;
906
+ gap: 4px;
907
+
908
+ div[basement-checkbox] {
909
+ display: flex;
910
+ align-items: center;
911
+ cursor: pointer;
912
+
913
+ md-icon {
914
+ --md-icon-size: 25px;
915
+ color: #808080;
916
+ transition: opacity 0.2s ease;
917
+ }
918
+
919
+ &[disabled] {
920
+ cursor: not-allowed;
921
+ opacity: 0.4;
922
+
923
+ md-icon {
924
+ color: #cccccc;
925
+ }
926
+ }
927
+
928
+ &[checked] md-icon {
929
+ background-color: #2e79be;
930
+ color: white;
931
+ border-radius: 3px;
932
+ }
933
+ }
934
+
935
+ md-outlined-text-field[basement-floor] {
936
+ width: 70px;
937
+ margin-left: var(--spacing-small, 4px);
938
+ opacity: 1;
939
+ transition: opacity 0.2s ease;
940
+
941
+ &[disabled] {
942
+ opacity: 0.4;
943
+ pointer-events: none;
944
+ }
945
+ }
946
+ }
840
947
  }
841
948
 
842
949
  &[project] {
843
950
  div[separate-container] {
951
+ margin-left: 15px;
952
+
844
953
  & > div {
954
+ align-items: center;
955
+
845
956
  span:first-child {
846
- flex: 0.6;
957
+ flex: 0.4;
847
958
  min-width: 100px;
848
959
  }
849
960
  span:last-child {