@dssp/project 1.0.0-alpha.2 → 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 (150) hide show
  1. package/dist-client/pages/lib/select2-component.js +1 -1
  2. package/dist-client/pages/lib/select2-component.js.map +1 -1
  3. package/dist-client/pages/lib/waether.d.ts +2 -1
  4. package/dist-client/pages/lib/waether.js +7 -3
  5. package/dist-client/pages/lib/waether.js.map +1 -1
  6. package/dist-client/pages/project/component/project-update-header.js.map +1 -1
  7. package/dist-client/pages/project/popup/popup-plan-export.d.ts +10 -0
  8. package/dist-client/pages/project/popup/popup-plan-export.js +236 -0
  9. package/dist-client/pages/project/popup/popup-plan-export.js.map +1 -0
  10. package/dist-client/pages/project/popup/popup-plan-upload.d.ts +3 -0
  11. package/dist-client/pages/project/popup/popup-plan-upload.js +130 -4
  12. package/dist-client/pages/project/popup/popup-plan-upload.js.map +1 -1
  13. package/dist-client/pages/project/popup/popup-project-create.js.map +1 -1
  14. package/dist-client/pages/project/popup/popup-schedule-upload.js.map +1 -1
  15. package/dist-client/pages/project/project-completed-list.js +0 -1
  16. package/dist-client/pages/project/project-completed-list.js.map +1 -1
  17. package/dist-client/pages/project/project-detail.d.ts +2 -1
  18. package/dist-client/pages/project/project-detail.js +193 -80
  19. package/dist-client/pages/project/project-detail.js.map +1 -1
  20. package/dist-client/pages/project/project-list.d.ts +12 -0
  21. package/dist-client/pages/project/project-list.js +15 -8
  22. package/dist-client/pages/project/project-list.js.map +1 -1
  23. package/dist-client/pages/project/project-plan-management.js +29 -13
  24. package/dist-client/pages/project/project-plan-management.js.map +1 -1
  25. package/dist-client/pages/project/project-schedule-list.js.map +1 -1
  26. package/dist-client/pages/project/project-schedule.js.map +1 -1
  27. package/dist-client/pages/project/project-setting-list.js +25 -24
  28. package/dist-client/pages/project/project-setting-list.js.map +1 -1
  29. package/dist-client/pages/project/project-update.d.ts +1 -0
  30. package/dist-client/pages/project/project-update.js +128 -17
  31. package/dist-client/pages/project/project-update.js.map +1 -1
  32. package/dist-client/pages/resource/construction-detail-type-popup.js.map +1 -1
  33. package/dist-client/pages/resource/construction-type-management.js.map +1 -1
  34. package/dist-client/pages/resource/inspection-drawing-type-management.js.map +1 -1
  35. package/dist-client/pages/resource/inspection-part-popup.js.map +1 -1
  36. package/dist-client/pages/resource/resource-importer.js.map +1 -1
  37. package/dist-client/pages/resource/resource-list-page.js.map +1 -1
  38. package/dist-client/pages/resource/worker-type-management.js.map +1 -1
  39. package/dist-client/pages/task/task-importer.js.map +1 -1
  40. package/dist-client/pages/task/task-list-page.js.map +1 -1
  41. package/dist-client/pages/task-resource/task-resource-importer.js.map +1 -1
  42. package/dist-client/pages/task-resource/task-resource-list-page.js.map +1 -1
  43. package/dist-client/route.js.map +1 -1
  44. package/dist-client/tsconfig.tsbuildinfo +1 -1
  45. package/dist-server/controllers/export-tasks.js +1 -2
  46. package/dist-server/controllers/export-tasks.js.map +1 -1
  47. package/dist-server/controllers/import-task.js +1 -2
  48. package/dist-server/controllers/import-task.js.map +1 -1
  49. package/dist-server/controllers/parse-excel.d.ts +0 -2
  50. package/dist-server/controllers/parse-excel.js +1 -2
  51. package/dist-server/controllers/parse-excel.js.map +1 -1
  52. package/dist-server/middlewares/index.js +1 -2
  53. package/dist-server/middlewares/index.js.map +1 -1
  54. package/dist-server/migrations/1723861466413-seed-roles.js.map +1 -1
  55. package/dist-server/migrations/1723861466414-seed-codes.js.map +1 -1
  56. package/dist-server/migrations/1723861476419-seed-resources.js.map +1 -1
  57. package/dist-server/migrations/1723861478420-seed-/bsample-project.js.map +1 -1
  58. package/dist-server/migrations/1723861478421-seed-/bsample-tasks.js.map +1 -1
  59. package/dist-server/service/construction-detail-type/construction-detail-type-mutation.js +2 -2
  60. package/dist-server/service/construction-detail-type/construction-detail-type-mutation.js.map +1 -1
  61. package/dist-server/service/construction-detail-type/construction-detail-type-query.js +2 -2
  62. package/dist-server/service/construction-detail-type/construction-detail-type-query.js.map +1 -1
  63. package/dist-server/service/construction-detail-type/construction-detail-type-type.js +4 -4
  64. package/dist-server/service/construction-detail-type/construction-detail-type-type.js.map +1 -1
  65. package/dist-server/service/construction-detail-type/construction-detail-type.js +2 -2
  66. package/dist-server/service/construction-detail-type/construction-detail-type.js.map +1 -1
  67. package/dist-server/service/construction-type/construction-type-mutation.js +2 -2
  68. package/dist-server/service/construction-type/construction-type-mutation.js.map +1 -1
  69. package/dist-server/service/construction-type/construction-type-query.js +2 -2
  70. package/dist-server/service/construction-type/construction-type-query.js.map +1 -1
  71. package/dist-server/service/construction-type/construction-type-type.js +4 -4
  72. package/dist-server/service/construction-type/construction-type-type.js.map +1 -1
  73. package/dist-server/service/construction-type/construction-type.js +2 -2
  74. package/dist-server/service/construction-type/construction-type.js.map +1 -1
  75. package/dist-server/service/index.d.ts +1 -0
  76. package/dist-server/service/index.js +1 -0
  77. package/dist-server/service/index.js.map +1 -1
  78. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-mutation.js +2 -2
  79. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-mutation.js.map +1 -1
  80. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-query.js +2 -2
  81. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-query.js.map +1 -1
  82. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-type.js +4 -4
  83. package/dist-server/service/inspection-drawing-type/inspection-drawing-type-type.js.map +1 -1
  84. package/dist-server/service/inspection-drawing-type/inspection-drawing-type.js +2 -2
  85. package/dist-server/service/inspection-drawing-type/inspection-drawing-type.js.map +1 -1
  86. package/dist-server/service/inspection-part/inspection-part-mutation.js +2 -2
  87. package/dist-server/service/inspection-part/inspection-part-mutation.js.map +1 -1
  88. package/dist-server/service/inspection-part/inspection-part-query.js +2 -2
  89. package/dist-server/service/inspection-part/inspection-part-query.js.map +1 -1
  90. package/dist-server/service/inspection-part/inspection-part-type.js +4 -4
  91. package/dist-server/service/inspection-part/inspection-part-type.js.map +1 -1
  92. package/dist-server/service/inspection-part/inspection-part.js +2 -2
  93. package/dist-server/service/inspection-part/inspection-part.js.map +1 -1
  94. package/dist-server/service/manager/index.d.ts +2 -0
  95. package/dist-server/service/manager/index.js +3 -1
  96. package/dist-server/service/manager/index.js.map +1 -1
  97. package/dist-server/service/manager/manager-mutation.js +2 -2
  98. package/dist-server/service/manager/manager-mutation.js.map +1 -1
  99. package/dist-server/service/manager/manager-query.js +3 -3
  100. package/dist-server/service/manager/manager-query.js.map +1 -1
  101. package/dist-server/service/manager/manager-type.js +4 -4
  102. package/dist-server/service/manager/manager-type.js.map +1 -1
  103. package/dist-server/service/manager/manager.js +2 -2
  104. package/dist-server/service/manager/manager.js.map +1 -1
  105. package/dist-server/service/project/project-mutation.d.ts +1 -0
  106. package/dist-server/service/project/project-mutation.js +109 -15
  107. package/dist-server/service/project/project-mutation.js.map +1 -1
  108. package/dist-server/service/project/project-query.d.ts +1 -0
  109. package/dist-server/service/project/project-query.js +14 -3
  110. package/dist-server/service/project/project-query.js.map +1 -1
  111. package/dist-server/service/project/project-type.d.ts +1 -0
  112. package/dist-server/service/project/project-type.js +13 -9
  113. package/dist-server/service/project/project-type.js.map +1 -1
  114. package/dist-server/service/project/project.d.ts +6 -0
  115. package/dist-server/service/project/project.js +15 -4
  116. package/dist-server/service/project/project.js.map +1 -1
  117. package/dist-server/service/resource/resource-mutation.js +2 -2
  118. package/dist-server/service/resource/resource-mutation.js.map +1 -1
  119. package/dist-server/service/resource/resource-query.js +2 -2
  120. package/dist-server/service/resource/resource-query.js.map +1 -1
  121. package/dist-server/service/resource/resource-type.js +6 -6
  122. package/dist-server/service/resource/resource-type.js.map +1 -1
  123. package/dist-server/service/resource/resource.js +3 -3
  124. package/dist-server/service/resource/resource.js.map +1 -1
  125. package/dist-server/service/task/task-mutation.js +2 -2
  126. package/dist-server/service/task/task-mutation.js.map +1 -1
  127. package/dist-server/service/task/task-query.js +4 -4
  128. package/dist-server/service/task/task-query.js.map +1 -1
  129. package/dist-server/service/task/task-type.js +10 -10
  130. package/dist-server/service/task/task-type.js.map +1 -1
  131. package/dist-server/service/task/task.js +7 -8
  132. package/dist-server/service/task/task.js.map +1 -1
  133. package/dist-server/service/task-resource/task-resource-mutation.js +2 -2
  134. package/dist-server/service/task-resource/task-resource-mutation.js.map +1 -1
  135. package/dist-server/service/task-resource/task-resource-query.js +2 -2
  136. package/dist-server/service/task-resource/task-resource-query.js.map +1 -1
  137. package/dist-server/service/task-resource/task-resource-type.js +6 -6
  138. package/dist-server/service/task-resource/task-resource-type.js.map +1 -1
  139. package/dist-server/service/task-resource/task-resource.js +2 -2
  140. package/dist-server/service/task-resource/task-resource.js.map +1 -1
  141. package/dist-server/service/worker-type/worker-type-mutation.js +2 -2
  142. package/dist-server/service/worker-type/worker-type-mutation.js.map +1 -1
  143. package/dist-server/service/worker-type/worker-type-query.js +2 -2
  144. package/dist-server/service/worker-type/worker-type-query.js.map +1 -1
  145. package/dist-server/service/worker-type/worker-type-type.js +4 -4
  146. package/dist-server/service/worker-type/worker-type-type.js.map +1 -1
  147. package/dist-server/service/worker-type/worker-type.js +2 -2
  148. package/dist-server/service/worker-type/worker-type.js.map +1 -1
  149. package/dist-server/tsconfig.tsbuildinfo +1 -1
  150. package/package.json +13 -11
@@ -1 +1 @@
1
- {"version":3,"file":"popup-plan-upload.js","sourceRoot":"","sources":["../../../../client/pages/project/popup/popup-plan-upload.ts"],"names":[],"mappings":"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","sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { BuildingLevel } from '../project-list'\n\n@customElement('popup-plan-upload')\nexport class PopupPlanUpload extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n flex-direction: column;\n background-color: #fff;\n width: 100%;\n }\n\n div[body] {\n flex: 1;\n\n div[input-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 25px;\n background-color: #f7f7f7;\n padding: 35px 27px 27px 27px;\n\n ox-input-file {\n height: 100px;\n width: 120px;\n line-height: 100%;\n }\n }\n\n div[button-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-top: 20px;\n }\n }\n `\n ]\n\n @property({ type: Object }) private buildingLevel: BuildingLevel = {}\n @property({ type: Number }) private selectedIdx: number | undefined\n\n render() {\n const noUploadStyle = '--file-uploader-icon-size: 0; --file-uploader-label-padding; 0;'\n\n // 메인 도면 스타일\n const { mainDrawing, mainDrawingThumbnail } = this.buildingLevel\n const mainDrawingIcon = mainDrawing ? '' : 'upload'\n const mainDrawingStyle = mainDrawing ? noUploadStyle : ''\n const mainDrawingLabel = mainDrawingThumbnail ? ' ' : '업로드'\n const mainDrawingDesc = mainDrawingThumbnail ? ' ' : '평면 파일'\n const mainDrawingThumbnailStyle = mainDrawingThumbnail ? this._getThumbnailStyle(mainDrawingThumbnail) : ''\n\n // 입면 도면 스타일\n const { elevationDrawing, elevationDrawingThumbnail } = this.buildingLevel\n const elevationDrawingIcon = elevationDrawing ? '' : 'upload'\n const elevationDrawingLabel = elevationDrawingThumbnail ? ' ' : '업로드'\n const elevationDrawingDesc = elevationDrawingThumbnail ? ' ' : '입면 파일'\n const elevationDrawingStyle = elevationDrawing ? noUploadStyle : ''\n const elevationDrawingThumbnailStyle = elevationDrawingThumbnail ? this._getThumbnailStyle(elevationDrawingThumbnail) : ''\n\n // 철근배근도 도면 스타일\n const { rebarDistributionDrawing, rebarDistributionDrawingThumbnail } = this.buildingLevel\n const rebarDistributionDrawingIcon = rebarDistributionDrawing ? '' : 'upload'\n const rebarDistributionDrawingStyle = rebarDistributionDrawing ? noUploadStyle : ''\n const rebarDistributionDrawingLabel = rebarDistributionDrawingThumbnail ? ' ' : '업로드'\n const rebarDistributionDrawingDesc = rebarDistributionDrawingThumbnail ? ' ' : '철근배근도 파일'\n const rebarDistributionDrawingThumbnailStyle = rebarDistributionDrawingThumbnail\n ? this._getThumbnailStyle(rebarDistributionDrawingThumbnail)\n : ''\n\n return html`\n <div body>\n <div input-container>\n <ox-input-file\n name=\"mainDrawing\"\n .value=${mainDrawing || undefined}\n icon=${mainDrawingIcon}\n label=${mainDrawingLabel}\n description=${mainDrawingDesc}\n @change=${this._onChangeAttachment.bind(this)}\n style=\"${mainDrawingStyle + mainDrawingThumbnailStyle}\"\n ></ox-input-file>\n\n <ox-input-file\n name=\"elevationDrawing\"\n .value=${elevationDrawing || undefined}\n icon=${elevationDrawingIcon}\n label=${elevationDrawingLabel}\n description=${elevationDrawingDesc}\n @change=${this._onChangeAttachment.bind(this)}\n style=\"${elevationDrawingStyle + elevationDrawingThumbnailStyle}\"\n ></ox-input-file>\n\n <ox-input-file\n name=\"rebarDistributionDrawing\"\n .value=${rebarDistributionDrawing || undefined}\n icon=${rebarDistributionDrawingIcon}\n label=${rebarDistributionDrawingLabel}\n description=${rebarDistributionDrawingDesc}\n @change=${this._onChangeAttachment.bind(this)}\n style=\"${rebarDistributionDrawingStyle + rebarDistributionDrawingThumbnailStyle}\"\n ></ox-input-file>\n </div>\n\n <div button-container>\n <md-outlined-button @click=${this._close}><md-icon slot=\"icon\">cancel</md-icon>취소</md-outlined-button>\n </div>\n </div>\n `\n }\n\n private _close() {\n history.back()\n }\n\n // 이미지 업로드\n async _onChangeAttachment(e: CustomEvent) {\n const target = e.target as HTMLInputElement\n const file = e.detail[0] || null\n\n this.buildingLevel[target.name] = file\n this.buildingLevel[`${target.name}Upload`] = file\n\n this.buildingLevel = { ...this.buildingLevel }\n\n const detail = { buildingLevel: this.buildingLevel, selectedIdx: this.selectedIdx }\n this.dispatchEvent(new CustomEvent('file_change', { bubbles: false, detail: detail }))\n }\n\n private _getThumbnailStyle(path) {\n return `background: url(${path}); background-size: cover; background-repeat: round; justify-content: flex-end;`\n }\n}\n"]}
1
+ {"version":3,"file":"popup-plan-upload.js","sourceRoot":"","sources":["../../../../client/pages/project/popup/popup-plan-upload.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE3D,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAC3C,OAAO,qBAAqB,CAAA;AAGrB,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,UAAU;IAAxC;;QA8G+B,kBAAa,GAAkB,EAAE,CAAA;IAuJvE,CAAC;IApJC,MAAM;QACJ,MAAM,aAAa,GAAG,iEAAiE,CAAA;QAEvF,YAAY;QACZ,MAAM,EAAE,WAAW,EAAE,oBAAoB,EAAE,GAAG,IAAI,CAAC,aAAa,CAAA;QAChE,MAAM,eAAe,GAAG,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAA;QACnD,MAAM,gBAAgB,GAAG,WAAW,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAA;QACzD,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAA;QAC3D,MAAM,eAAe,GAAG,oBAAoB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAA;QAC5D,MAAM,yBAAyB,GAAG,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;QAE3G,YAAY;QACZ,MAAM,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,GAAG,IAAI,CAAC,aAAa,CAAA;QAC1E,MAAM,oBAAoB,GAAG,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAA;QAC7D,MAAM,qBAAqB,GAAG,yBAAyB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAA;QACrE,MAAM,oBAAoB,GAAG,yBAAyB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAA;QACtE,MAAM,qBAAqB,GAAG,gBAAgB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAA;QACnE,MAAM,8BAA8B,GAAG,yBAAyB,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;QAE1H,eAAe;QACf,MAAM,EAAE,wBAAwB,EAAE,iCAAiC,EAAE,GAAG,IAAI,CAAC,aAAa,CAAA;QAC1F,MAAM,4BAA4B,GAAG,wBAAwB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAA;QAC7E,MAAM,6BAA6B,GAAG,wBAAwB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAA;QACnF,MAAM,6BAA6B,GAAG,iCAAiC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAA;QACrF,MAAM,4BAA4B,GAAG,iCAAiC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,UAAU,CAAA;QACzF,MAAM,sCAAsC,GAAG,iCAAiC;YAC9E,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,iCAAiC,CAAC;YAC5D,CAAC,CAAC,EAAE,CAAA;QAEN,YAAY;QACZ,MAAM,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,aAAa,CAAA;QAE1C,OAAO,IAAI,CAAA;;;;;qBAKM,WAAW,IAAI,SAAS;mBAC1B,eAAe;oBACd,gBAAgB;0BACV,eAAe;sBACnB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;qBACpC,gBAAgB,GAAG,yBAAyB;;;;;qBAK5C,gBAAgB,IAAI,SAAS;mBAC/B,oBAAoB;oBACnB,qBAAqB;0BACf,oBAAoB;sBACxB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;qBACpC,qBAAqB,GAAG,8BAA8B;;;;;qBAKtD,wBAAwB,IAAI,SAAS;mBACvC,4BAA4B;oBAC3B,6BAA6B;0BACvB,4BAA4B;sBAChC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;qBACpC,6BAA6B,GAAG,sCAAsC;;;;;;;;;;;;;sBAarE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;;;YAG7C,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,GAAG,CAChB,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAA;;;kCAGF,OAAO,CAAC,IAAI;4CACF,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;;aAE/D,CACF;;;;uCAI4B,IAAI,CAAC,MAAM;qCACb,IAAI,CAAC,gBAAgB;;;;;KAKrD,CAAA;IACH,CAAC;IAEO,MAAM;QACZ,OAAO,CAAC,IAAI,EAAE,CAAA;IAChB,CAAC;IAED,UAAU;IACV,KAAK,CAAC,mBAAmB,CAAC,CAAc;QACtC,MAAM,MAAM,GAAG,CAAC,CAAC,MAA0B,CAAA;QAC3C,MAAM,UAAU,GAAG,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,MAAM,CAAA;QAE7D,0BAA0B;QAC1B,IAAI,UAAU,EAAE,CAAC;YACf,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;YACzD,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,MAAM,CAAC,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAA;YACtE,MAAM,IAAI,GAAG,CAAC,CAAC,MAAM,IAAI,EAAE,CAAA;YAC3B,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,WAAW,EAAE,GAAG,IAAI,CAAC,CAAA;YAC3D,IAAI,CAAC,aAAa,CAAC,GAAG,MAAM,CAAC,IAAI,QAAQ,CAAC,GAAG,CAAC,GAAG,aAAa,EAAE,GAAG,IAAI,CAAC,CAAA;QAC1E,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAA;YAChC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAA;YACtC,IAAI,CAAC,aAAa,CAAC,GAAG,MAAM,CAAC,IAAI,QAAQ,CAAC,GAAG,IAAI,CAAA;QACnD,CAAC;QAED,IAAI,CAAC,aAAa,qBAAQ,IAAI,CAAC,aAAa,CAAE,CAAA;QAE9C,MAAM,MAAM,GAAG,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,CAAA;QACnF,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC,CAAA;IACxF,CAAC;IAEO,cAAc,CAAC,KAAa;QAClC,IAAI,IAAI,CAAC,aAAa,CAAC,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE,CAAC;YACpF,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;YAC/C,IAAI,CAAC,aAAa,qBAAQ,IAAI,CAAC,aAAa,CAAE,CAAA;YAE9C,MAAM,MAAM,GAAG,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,CAAA;YACnF,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC,CAAA;QACxF,CAAC;IACH,CAAC;IAEO,gBAAgB;QACtB,SAAS,CAAC,IAAI,CAAA,qCAAqC,IAAI,CAAC,aAAa,uBAAuB,EAAE;YAC5F,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,QAAQ;YACd,KAAK,EAAE,SAAS;SACjB,CAAC,CAAA;IACJ,CAAC;IAEO,kBAAkB,CAAC,IAAI;QAC7B,OAAO,mBAAmB,IAAI,iFAAiF,CAAA;IACjH,CAAC;;AAnQM,sBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAyGF;CACF,AA3GY,CA2GZ;AAEmC;IAAnC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;sDAA0C;AACjC;IAAnC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;oDAAwC;AA/GxD,eAAe;IAD3B,aAAa,CAAC,mBAAmB,CAAC;GACtB,eAAe,CAqQ3B","sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { BuildingLevel } from '../project-list'\nimport { openPopup } from '@operato/layout'\nimport './popup-plan-export'\n\n@customElement('popup-plan-upload')\nexport class PopupPlanUpload extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n flex-direction: column;\n background-color: #fff;\n width: 100%;\n }\n\n div[body] {\n flex: 1;\n\n div[input-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 25px;\n background-color: #f7f7f7;\n padding: 35px 27px 27px 27px;\n\n ox-input-file {\n height: 100px;\n width: 120px;\n line-height: 100%;\n }\n }\n\n div[etc-drawing-container] {\n display: flex;\n align-items: center;\n margin-top: 15px;\n padding: 10px;\n gap: 25px;\n background-color: #f7f7f7;\n overflow-y: auto;\n\n ox-input-file {\n height: 120px;\n width: 100px;\n min-width: 100px;\n line-height: 100%;\n }\n\n div[file-box] {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n height: 120px;\n width: 100px;\n min-width: 100px;\n background-color: #fff;\n border: 2px solid #aaa;\n border-radius: 8px;\n position: relative;\n\n span[file-name] {\n font-size: 12px;\n text-align: center;\n padding: 5px;\n word-break: break-all;\n max-width: 90px;\n color: #333;\n }\n\n button[delete-btn] {\n position: absolute;\n top: -8px;\n right: -8px;\n width: 20px;\n height: 20px;\n border-radius: 50%;\n background-color: #ff4444;\n color: white;\n border: none;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 12px;\n font-weight: bold;\n\n &:hover {\n background-color: #cc0000;\n }\n }\n }\n }\n\n div[button-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 10px;\n margin-top: 20px;\n }\n\n md-icon[outline] {\n --md-icon-size: 35px;\n font-variation-settings:\n 'FILL' 0,\n 'wght' 400,\n 'GRAD' 0,\n 'opsz' 24;\n }\n }\n `\n ]\n\n @property({ type: Object }) private buildingLevel: BuildingLevel = {}\n @property({ type: Number }) private selectedIdx: number | undefined\n\n render() {\n const noUploadStyle = '--file-uploader-icon-size: 0; --file-uploader-label-padding; 0;'\n\n // 메인 도면 스타일\n const { mainDrawing, mainDrawingThumbnail } = this.buildingLevel\n const mainDrawingIcon = mainDrawing ? '' : 'upload'\n const mainDrawingStyle = mainDrawing ? noUploadStyle : ''\n const mainDrawingLabel = mainDrawingThumbnail ? ' ' : '업로드'\n const mainDrawingDesc = mainDrawingThumbnail ? ' ' : '평면 파일'\n const mainDrawingThumbnailStyle = mainDrawingThumbnail ? this._getThumbnailStyle(mainDrawingThumbnail) : ''\n\n // 입면 도면 스타일\n const { elevationDrawing, elevationDrawingThumbnail } = this.buildingLevel\n const elevationDrawingIcon = elevationDrawing ? '' : 'upload'\n const elevationDrawingLabel = elevationDrawingThumbnail ? ' ' : '업로드'\n const elevationDrawingDesc = elevationDrawingThumbnail ? ' ' : '입면 파일'\n const elevationDrawingStyle = elevationDrawing ? noUploadStyle : ''\n const elevationDrawingThumbnailStyle = elevationDrawingThumbnail ? this._getThumbnailStyle(elevationDrawingThumbnail) : ''\n\n // 철근배근도 도면 스타일\n const { rebarDistributionDrawing, rebarDistributionDrawingThumbnail } = this.buildingLevel\n const rebarDistributionDrawingIcon = rebarDistributionDrawing ? '' : 'upload'\n const rebarDistributionDrawingStyle = rebarDistributionDrawing ? noUploadStyle : ''\n const rebarDistributionDrawingLabel = rebarDistributionDrawingThumbnail ? ' ' : '업로드'\n const rebarDistributionDrawingDesc = rebarDistributionDrawingThumbnail ? ' ' : '철근배근도 파일'\n const rebarDistributionDrawingThumbnailStyle = rebarDistributionDrawingThumbnail\n ? this._getThumbnailStyle(rebarDistributionDrawingThumbnail)\n : ''\n\n // 기타 도면 스타일\n const { etcDrawings } = this.buildingLevel\n\n return html`\n <div body>\n <div input-container>\n <ox-input-file\n name=\"mainDrawing\"\n .value=${mainDrawing || undefined}\n icon=${mainDrawingIcon}\n label=${mainDrawingLabel}\n description=${mainDrawingDesc}\n @change=${this._onChangeAttachment.bind(this)}\n style=\"${mainDrawingStyle + mainDrawingThumbnailStyle}\"\n ></ox-input-file>\n\n <ox-input-file\n name=\"elevationDrawing\"\n .value=${elevationDrawing || undefined}\n icon=${elevationDrawingIcon}\n label=${elevationDrawingLabel}\n description=${elevationDrawingDesc}\n @change=${this._onChangeAttachment.bind(this)}\n style=\"${elevationDrawingStyle + elevationDrawingThumbnailStyle}\"\n ></ox-input-file>\n\n <ox-input-file\n name=\"rebarDistributionDrawing\"\n .value=${rebarDistributionDrawing || undefined}\n icon=${rebarDistributionDrawingIcon}\n label=${rebarDistributionDrawingLabel}\n description=${rebarDistributionDrawingDesc}\n @change=${this._onChangeAttachment.bind(this)}\n style=\"${rebarDistributionDrawingStyle + rebarDistributionDrawingThumbnailStyle}\"\n ></ox-input-file>\n </div>\n\n <div etc-drawing-container>\n <ox-input-file\n name=\"etcDrawings\"\n accept=\"*/*\"\n multiple=\"true\"\n hide-filelist\n icon=\"upload\"\n label=\"업로드\"\n description=\"기타 파일\"\n @change=${this._onChangeAttachment.bind(this)}\n ></ox-input-file>\n\n ${etcDrawings?.map(\n (drawing, index) => html`\n <div file-box>\n <md-icon slot=\"icon\" outline>files</md-icon>\n <span file-name>${drawing.name}</span>\n <button delete-btn @click=${() => this._deleteDrawing(index)}>X</button>\n </div>\n `\n )}\n </div>\n\n <div button-container>\n <md-outlined-button @click=${this._close}><md-icon slot=\"icon\">cancel</md-icon>닫기</md-outlined-button>\n <md-filled-button @click=${this._openExportPopup}\n ><md-icon slot=\"icon\" outline>archive</md-icon>파일 내보내기</md-filled-button\n >\n </div>\n </div>\n `\n }\n\n private _close() {\n history.back()\n }\n\n // 이미지 업로드\n async _onChangeAttachment(e: CustomEvent) {\n const target = e.target as HTMLInputElement\n const isMultiple = target.getAttribute('multiple') === 'true'\n\n // multiple 속성이 있으면 배열로 처리\n if (isMultiple) {\n const originFiles = this.buildingLevel[target.name] || []\n const originUploads = this.buildingLevel[`${target.name}Upload`] || []\n const file = e.detail || []\n this.buildingLevel[target.name] = [...originFiles, ...file]\n this.buildingLevel[`${target.name}Upload`] = [...originUploads, ...file]\n } else {\n const file = e.detail[0] || null\n this.buildingLevel[target.name] = file\n this.buildingLevel[`${target.name}Upload`] = file\n }\n\n this.buildingLevel = { ...this.buildingLevel }\n\n const detail = { buildingLevel: this.buildingLevel, selectedIdx: this.selectedIdx }\n this.dispatchEvent(new CustomEvent('file_change', { bubbles: false, detail: detail }))\n }\n\n private _deleteDrawing(index: number) {\n if (this.buildingLevel.etcDrawings && Array.isArray(this.buildingLevel.etcDrawings)) {\n this.buildingLevel.etcDrawings.splice(index, 1)\n this.buildingLevel = { ...this.buildingLevel }\n\n const detail = { buildingLevel: this.buildingLevel, selectedIdx: this.selectedIdx }\n this.dispatchEvent(new CustomEvent('file_change', { bubbles: false, detail: detail }))\n }\n }\n\n private _openExportPopup() {\n openPopup(html`<popup-plan-export .buildingLevel=${this.buildingLevel}></popup-plan-export>`, {\n backdrop: true,\n size: 'medium',\n title: `도면 내보내기`\n })\n }\n\n private _getThumbnailStyle(path) {\n return `background: url(${path}); background-size: cover; background-repeat: round; justify-content: flex-end;`\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"popup-project-create.js","sourceRoot":"","sources":["../../../../client/pages/project/popup/popup-project-create.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAClE,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,gDAAgD,CAAA;AACvD,OAAO,yCAAyC,CAAA;AAGzC,IAAM,kBAAkB,GAAxB,MAAM,kBAAmB,SAAQ,UAAU;IAA3C;;QAmEY,gBAAW,GAAW,EAAE,CAAA;IAsE3C,CAAC;IAnEC,MAAM;QACJ,OAAO,IAAI,CAAA;;;;;;;;qBAQM,IAAI,CAAC,WAAW;qBAChB,IAAI,CAAC,cAAc;;;;;;uCAMD,IAAI,CAAC,cAAc;;;uCAGnB,IAAI,CAAC,MAAM;;;KAG7C,CAAA;IACH,CAAC;IAED,UAAU;IACF,KAAK,CAAC,cAAc;QAC1B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACrB,MAAM,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,oBAAoB,EAAE,CAAC,CAAA;YACxD,OAAM;SACP;QAED,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;YACnC,QAAQ,EAAE,GAAG,CAAA;;;;;;OAMZ;YACD,SAAS,EAAE;gBACT,OAAO,EAAE;oBACP,IAAI,EAAE,IAAI,CAAC,WAAW;iBACvB;aACF;SACF,CAAC,CAAA;QAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,MAAM,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAA;SAChC;QAED,kBAAkB;QAClB,IAAI,CAAC,SAAS,EAAE,CAAA;QAEhB,mBAAmB;QACnB,OAAO,CAAC,IAAI,EAAE,CAAA;IAChB,CAAC;IAEO,MAAM;QACZ,OAAO,CAAC,IAAI,EAAE,CAAA;IAChB,CAAC;IAED,gCAAgC;IACxB,cAAc,CAAC,KAAiB;QACtC,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAA;QAC/C,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAA;IACjC,CAAC;;AAvIM,yBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA8DF;CACF,CAAA;AAED;IAAC,KAAK,EAAE;;uDAAiC;AACzC;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;8BAAqB,QAAQ;qDAAA;AApE/C,kBAAkB;IAD9B,aAAa,CAAC,sBAAsB,CAAC;GACzB,kBAAkB,CAyI9B;SAzIY,kBAAkB","sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { client } from '@operato/graphql'\nimport { notify } from '@operato/layout'\nimport gql from 'graphql-tag'\nimport '@material/web/textfield/outlined-text-field.js'\nimport '@material/web/button/elevated-button.js'\n\n@customElement('popup-project-create')\nexport class PopupProjectCreate extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n flex-direction: column;\n background-color: #fff;\n width: 100%;\n }\n\n div[body] {\n flex: 1;\n\n label {\n color: #4e5055;\n font-size: 16px;\n }\n\n div[input-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-top: 22px;\n\n md-outlined-text-field {\n width: 60%;\n margin-left: 15px;\n\n --md-outlined-text-field-container-shape: 9px;\n --md-sys-color-primary: #586878;\n --md-sys-color-surface-container-highest: transparent;\n --md-outlined-text-field-label-text-color: #999999;\n --md-outlined-text-field-input-text-line-height: 20px;\n --md-outlined-text-field-input-text-size: 16px;\n --md-outlined-field-bottom-space: 10px;\n --md-outlined-field-top-space: 10px;\n }\n }\n\n div[button-container] {\n margin-top: 50px;\n margin-bottom: 20px;\n text-align: center;\n\n md-elevated-button {\n margin: 0px 5px;\n\n --md-elevated-button-container-height: 40px;\n --md-elevated-button-container-color: #fff;\n --md-elevated-button-label-text-size: 16px;\n }\n md-elevated-button:first-child {\n --md-elevated-button-container-color: #0595e5;\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 }\n }\n `\n ]\n\n @state() private projectName: string = ''\n @property({ type: Function }) private refreshFn!: Function\n\n render() {\n return html`\n <div body>\n <div input-container>\n <label>프로젝트 이름</label>\n <md-outlined-text-field\n name=\"projectName\"\n type=\"text\"\n placeholder=\"신규 프로젝트명\"\n .value=${this.projectName}\n @input=${this._onInputChange}\n >\n </md-outlined-text-field>\n </div>\n\n <div button-container>\n <md-elevated-button @click=${this._createProject}>\n <md-icon slot=\"icon\">add</md-icon>프로젝트 생성\n </md-elevated-button>\n <md-elevated-button @click=${this._close}> <md-icon slot=\"icon\">close</md-icon>취소 </md-elevated-button>\n </div>\n </div>\n `\n }\n\n // 프로젝트 생성\n private async _createProject() {\n if (!this.projectName) {\n notify({ level: 'warn', message: '프로젝트 이름은 필수 값 입니다.' })\n return\n }\n\n const response = await client.mutate({\n mutation: gql`\n mutation CreateProject($project: NewProject!) {\n response: createProject(project: $project) {\n id\n }\n }\n `,\n variables: {\n project: {\n name: this.projectName\n }\n }\n })\n\n if (!response.errors) {\n notify({ message: '저장되었습니다.' })\n }\n\n // 설정 정보 리스트 다시 조회\n this.refreshFn()\n\n // 팝업 템플릿을 닫기 위한 동작\n history.back()\n }\n\n private _close() {\n history.back()\n }\n\n // Input 요소의 값이 변경될 때 호출되는 콜백 함수\n private _onInputChange(event: InputEvent) {\n const target = event.target as HTMLInputElement\n this.projectName = target.value\n }\n}\n"]}
1
+ {"version":3,"file":"popup-project-create.js","sourceRoot":"","sources":["../../../../client/pages/project/popup/popup-project-create.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAClE,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,gDAAgD,CAAA;AACvD,OAAO,yCAAyC,CAAA;AAGzC,IAAM,kBAAkB,GAAxB,MAAM,kBAAmB,SAAQ,UAAU;IAA3C;;QAmEY,gBAAW,GAAW,EAAE,CAAA;IAsE3C,CAAC;IAnEC,MAAM;QACJ,OAAO,IAAI,CAAA;;;;;;;;qBAQM,IAAI,CAAC,WAAW;qBAChB,IAAI,CAAC,cAAc;;;;;;uCAMD,IAAI,CAAC,cAAc;;;uCAGnB,IAAI,CAAC,MAAM;;;KAG7C,CAAA;IACH,CAAC;IAED,UAAU;IACF,KAAK,CAAC,cAAc;QAC1B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,oBAAoB,EAAE,CAAC,CAAA;YACxD,OAAM;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;YACnC,QAAQ,EAAE,GAAG,CAAA;;;;;;OAMZ;YACD,SAAS,EAAE;gBACT,OAAO,EAAE;oBACP,IAAI,EAAE,IAAI,CAAC,WAAW;iBACvB;aACF;SACF,CAAC,CAAA;QAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;YACrB,MAAM,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAA;QACjC,CAAC;QAED,kBAAkB;QAClB,IAAI,CAAC,SAAS,EAAE,CAAA;QAEhB,mBAAmB;QACnB,OAAO,CAAC,IAAI,EAAE,CAAA;IAChB,CAAC;IAEO,MAAM;QACZ,OAAO,CAAC,IAAI,EAAE,CAAA;IAChB,CAAC;IAED,gCAAgC;IACxB,cAAc,CAAC,KAAiB;QACtC,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAA;QAC/C,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAA;IACjC,CAAC;;AAvIM,yBAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA8DF;CACF,AAhEY,CAgEZ;AAEgB;IAAhB,KAAK,EAAE;;uDAAiC;AACH;IAArC,QAAQ,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;8BAAqB,QAAQ;qDAAA;AApE/C,kBAAkB;IAD9B,aAAa,CAAC,sBAAsB,CAAC;GACzB,kBAAkB,CAyI9B","sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { client } from '@operato/graphql'\nimport { notify } from '@operato/layout'\nimport gql from 'graphql-tag'\nimport '@material/web/textfield/outlined-text-field.js'\nimport '@material/web/button/elevated-button.js'\n\n@customElement('popup-project-create')\nexport class PopupProjectCreate extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n flex-direction: column;\n background-color: #fff;\n width: 100%;\n }\n\n div[body] {\n flex: 1;\n\n label {\n color: #4e5055;\n font-size: 16px;\n }\n\n div[input-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-top: 22px;\n\n md-outlined-text-field {\n width: 60%;\n margin-left: 15px;\n\n --md-outlined-text-field-container-shape: 9px;\n --md-sys-color-primary: #586878;\n --md-sys-color-surface-container-highest: transparent;\n --md-outlined-text-field-label-text-color: #999999;\n --md-outlined-text-field-input-text-line-height: 20px;\n --md-outlined-text-field-input-text-size: 16px;\n --md-outlined-field-bottom-space: 10px;\n --md-outlined-field-top-space: 10px;\n }\n }\n\n div[button-container] {\n margin-top: 50px;\n margin-bottom: 20px;\n text-align: center;\n\n md-elevated-button {\n margin: 0px 5px;\n\n --md-elevated-button-container-height: 40px;\n --md-elevated-button-container-color: #fff;\n --md-elevated-button-label-text-size: 16px;\n }\n md-elevated-button:first-child {\n --md-elevated-button-container-color: #0595e5;\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 }\n }\n `\n ]\n\n @state() private projectName: string = ''\n @property({ type: Function }) private refreshFn!: Function\n\n render() {\n return html`\n <div body>\n <div input-container>\n <label>프로젝트 이름</label>\n <md-outlined-text-field\n name=\"projectName\"\n type=\"text\"\n placeholder=\"신규 프로젝트명\"\n .value=${this.projectName}\n @input=${this._onInputChange}\n >\n </md-outlined-text-field>\n </div>\n\n <div button-container>\n <md-elevated-button @click=${this._createProject}>\n <md-icon slot=\"icon\">add</md-icon>프로젝트 생성\n </md-elevated-button>\n <md-elevated-button @click=${this._close}> <md-icon slot=\"icon\">close</md-icon>취소 </md-elevated-button>\n </div>\n </div>\n `\n }\n\n // 프로젝트 생성\n private async _createProject() {\n if (!this.projectName) {\n notify({ level: 'warn', message: '프로젝트 이름은 필수 값 입니다.' })\n return\n }\n\n const response = await client.mutate({\n mutation: gql`\n mutation CreateProject($project: NewProject!) {\n response: createProject(project: $project) {\n id\n }\n }\n `,\n variables: {\n project: {\n name: this.projectName\n }\n }\n })\n\n if (!response.errors) {\n notify({ message: '저장되었습니다.' })\n }\n\n // 설정 정보 리스트 다시 조회\n this.refreshFn()\n\n // 팝업 템플릿을 닫기 위한 동작\n history.back()\n }\n\n private _close() {\n history.back()\n }\n\n // Input 요소의 값이 변경될 때 호출되는 콜백 함수\n private _onInputChange(event: InputEvent) {\n const target = event.target as HTMLInputElement\n this.projectName = target.value\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"popup-schedule-upload.js","sourceRoot":"","sources":["../../../../client/pages/project/popup/popup-schedule-upload.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,GAAG,MAAM,aAAa,CAAA;AAItB,IAAM,mBAAmB,GAAzB,MAAM,mBAAoB,SAAQ,UAAU;IAyCjD,MAAM;;QACJ,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAA;QAC/C,MAAM,WAAW,GAAG,CAAA,MAAA,IAAI,CAAC,aAAa,0CAAE,IAAI,EAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAA;QAE9D,OAAO,IAAI,CAAA;;;;mBAII,IAAI;oBACH,CAAA,MAAA,IAAI,CAAC,aAAa,0CAAE,IAAI,KAAI,EAAE;0BACxB,WAAW;sBACf,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;uCAKlB,IAAI,CAAC,MAAM;;;KAG7C,CAAA;IACH,CAAC;IAEO,MAAM;QACZ,OAAO,CAAC,IAAI,EAAE,CAAA;IAChB,CAAC;IAED,UAAU;IACV,KAAK,CAAC,mBAAmB,CAAC,CAAc;QACtC,MAAM,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAA;QAEhC,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;YACnC,QAAQ,EAAE,GAAG,CAAA;;;;OAIZ;YACD,SAAS,EAAE;gBACT,KAAK,EAAE;oBACL,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,aAAa,EAAE,IAAI;iBACpB;aACF;YACD,OAAO,EAAE;gBACP,SAAS,EAAE,IAAI;aAChB;SACF,CAAC,CAAA;QAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,MAAM,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,CAAC,CAAA;YACtC,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,UAAU,CAAC,CAAC,CAAA;SAChD;IACH,CAAC;;AA3FM,0BAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAiCF;CACF,CAAA;AAED;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;0DAA8C;AACzE;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;sDAAsC;AAvCtD,mBAAmB;IAD/B,aAAa,CAAC,uBAAuB,CAAC;GAC1B,mBAAmB,CA6F/B;SA7FY,mBAAmB","sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { client } from '@operato/graphql'\nimport { notify } from '@operato/layout'\nimport gql from 'graphql-tag'\nimport { Attachment } from '@things-factory/attachment-base'\n\n@customElement('popup-schedule-upload')\nexport class PopupScheduleUpload extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n flex-direction: column;\n background-color: #fff;\n width: 100%;\n }\n\n div[body] {\n flex: 1;\n\n div[input-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 25px;\n background-color: #f7f7f7;\n padding: 35px 27px 27px 27px;\n\n ox-input-file {\n height: 100px;\n width: 120px;\n line-height: 100%;\n }\n }\n\n div[button-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-top: 20px;\n }\n }\n `\n ]\n\n @property({ type: Object }) private scheduleTable: Attachment | undefined\n @property({ type: String }) private projectId: string | undefined\n\n render() {\n const icon = this.scheduleTable ? '' : 'upload'\n const description = this.scheduleTable?.name ? ' ' : '공정표 업로드'\n\n return html`\n <div body>\n <div input-container>\n <ox-input-file\n icon=${icon}\n label=${this.scheduleTable?.name || ''}\n description=${description}\n @change=${this._onChangeAttachment.bind(this)}\n ></ox-input-file>\n </div>\n\n <div button-container>\n <md-outlined-button @click=${this._close}><md-icon slot=\"icon\">cancel</md-icon>취소</md-outlined-button>\n </div>\n </div>\n `\n }\n\n private _close() {\n history.back()\n }\n\n // 공정표 업로드\n async _onChangeAttachment(e: CustomEvent) {\n const file = e.detail[0] || null\n\n const response = await client.mutate({\n mutation: gql`\n mutation UploadProjectScheduleTable($param: UploadProjectScheduleTable!) {\n uploadProjectScheduleTable(param: $param)\n }\n `,\n variables: {\n param: {\n projectId: this.projectId,\n scheduleTable: file\n }\n },\n context: {\n hasUpload: true\n }\n })\n\n if (!response.errors) {\n notify({ message: '공정표가 업로드 되었습니다.' })\n this.dispatchEvent(new CustomEvent('uploaded'))\n }\n }\n}\n"]}
1
+ {"version":3,"file":"popup-schedule-upload.js","sourceRoot":"","sources":["../../../../client/pages/project/popup/popup-schedule-upload.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,GAAG,MAAM,aAAa,CAAA;AAItB,IAAM,mBAAmB,GAAzB,MAAM,mBAAoB,SAAQ,UAAU;IAyCjD,MAAM;;QACJ,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAA;QAC/C,MAAM,WAAW,GAAG,CAAA,MAAA,IAAI,CAAC,aAAa,0CAAE,IAAI,EAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAA;QAE9D,OAAO,IAAI,CAAA;;;;mBAII,IAAI;oBACH,CAAA,MAAA,IAAI,CAAC,aAAa,0CAAE,IAAI,KAAI,EAAE;0BACxB,WAAW;sBACf,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;uCAKlB,IAAI,CAAC,MAAM;;;KAG7C,CAAA;IACH,CAAC;IAEO,MAAM;QACZ,OAAO,CAAC,IAAI,EAAE,CAAA;IAChB,CAAC;IAED,UAAU;IACV,KAAK,CAAC,mBAAmB,CAAC,CAAc;QACtC,MAAM,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAA;QAEhC,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;YACnC,QAAQ,EAAE,GAAG,CAAA;;;;OAIZ;YACD,SAAS,EAAE;gBACT,KAAK,EAAE;oBACL,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,aAAa,EAAE,IAAI;iBACpB;aACF;YACD,OAAO,EAAE;gBACP,SAAS,EAAE,IAAI;aAChB;SACF,CAAC,CAAA;QAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;YACrB,MAAM,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,CAAC,CAAA;YACtC,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,UAAU,CAAC,CAAC,CAAA;QACjD,CAAC;IACH,CAAC;;AA3FM,0BAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAiCF;CACF,AAnCY,CAmCZ;AAEmC;IAAnC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;0DAA8C;AACrC;IAAnC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;sDAAsC;AAvCtD,mBAAmB;IAD/B,aAAa,CAAC,uBAAuB,CAAC;GAC1B,mBAAmB,CA6F/B","sourcesContent":["import { css, html, LitElement } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { client } from '@operato/graphql'\nimport { notify } from '@operato/layout'\nimport gql from 'graphql-tag'\nimport { Attachment } from '@things-factory/attachment-base'\n\n@customElement('popup-schedule-upload')\nexport class PopupScheduleUpload extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n flex-direction: column;\n background-color: #fff;\n width: 100%;\n }\n\n div[body] {\n flex: 1;\n\n div[input-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 25px;\n background-color: #f7f7f7;\n padding: 35px 27px 27px 27px;\n\n ox-input-file {\n height: 100px;\n width: 120px;\n line-height: 100%;\n }\n }\n\n div[button-container] {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-top: 20px;\n }\n }\n `\n ]\n\n @property({ type: Object }) private scheduleTable: Attachment | undefined\n @property({ type: String }) private projectId: string | undefined\n\n render() {\n const icon = this.scheduleTable ? '' : 'upload'\n const description = this.scheduleTable?.name ? ' ' : '공정표 업로드'\n\n return html`\n <div body>\n <div input-container>\n <ox-input-file\n icon=${icon}\n label=${this.scheduleTable?.name || ''}\n description=${description}\n @change=${this._onChangeAttachment.bind(this)}\n ></ox-input-file>\n </div>\n\n <div button-container>\n <md-outlined-button @click=${this._close}><md-icon slot=\"icon\">cancel</md-icon>취소</md-outlined-button>\n </div>\n </div>\n `\n }\n\n private _close() {\n history.back()\n }\n\n // 공정표 업로드\n async _onChangeAttachment(e: CustomEvent) {\n const file = e.detail[0] || null\n\n const response = await client.mutate({\n mutation: gql`\n mutation UploadProjectScheduleTable($param: UploadProjectScheduleTable!) {\n uploadProjectScheduleTable(param: $param)\n }\n `,\n variables: {\n param: {\n projectId: this.projectId,\n scheduleTable: file\n }\n },\n context: {\n hasUpload: true\n }\n })\n\n if (!response.errors) {\n notify({ message: '공정표가 업로드 되었습니다.' })\n this.dispatchEvent(new CustomEvent('uploaded'))\n }\n }\n}\n"]}
@@ -162,7 +162,6 @@ ProjectCompletedListPage.styles = [
162
162
 
163
163
  div[header] {
164
164
  display: flex;
165
- height: 100px;
166
165
  align-items: center;
167
166
  background-color: #2ea4df1a;
168
167
  border: 1px solid #2ea4df33;
@@ -1 +1 @@
1
- {"version":3,"file":"project-completed-list.js","sourceRoot":"","sources":["../../../client/pages/project/project-completed-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 { Project, ProjectState } from './project-list'\n\n@customElement('project-completed-list')\nexport class ProjectCompletedListPage 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: #1bb40133;\n --md-sys-color-surface-container-highest: #0595e533;\n --md-linear-progress-track-color: #1bb4011a;\n }\n\n span {\n position: absolute;\n top: 0;\n left: 12px;\n font-size: 12px;\n font-weight: bold;\n color: #1bb401;\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>시공사: ${project.buildingComplex.constructionCompany}</div>\n <div>건설구분: ${project.buildingComplex.constructionType}</div>\n <div>세대수: ${project.buildingComplex?.householdCount?.toLocaleString() || ''}세대</div>\n <div>기타: ${project.buildingComplex.etc}</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 constructionCompany\n constructionType\n householdCount\n etc\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.COMPLETED\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-completed-list.js","sourceRoot":"","sources":["../../../client/pages/project/project-completed-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;AAC7B,OAAO,EAAW,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAG/C,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,mBAAmB,CAAC,QAAQ,CAAC;IAApE;;QAyIY,gBAAW,GAAW,EAAE,CAAA;QACxB,gBAAW,GAAc,EAAE,CAAA;QAC3B,iBAAY,GAAW,CAAC,CAAA;IAiI3C,CAAC;IAzIC,IAAI,OAAO;QACT,OAAO;YACL,KAAK,EAAE,SAAS;SACjB,CAAA;IACH,CAAC;IAMD,MAAM;;QACJ,OAAO,IAAI,CAAA;;;;;;;mBAOI,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;;8BAExB,OAAO,CAAC,eAAe,CAAC,mBAAmB;+BAC1C,OAAO,CAAC,eAAe,CAAC,gBAAgB;8BACzC,CAAA,MAAA,MAAA,OAAO,CAAC,eAAe,0CAAE,cAAc,0CAAE,cAAc,EAAE,KAAI,EAAE;6BAChE,OAAO,CAAC,eAAe,CAAC,GAAG;;;;WAI7C,CAAA;QACH,CAAC,CAAC;;KAEL,CAAA;IACH,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAY,EAAE,SAAc;QAC5C,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,cAAc,EAAE,CAAA;QACvB,CAAC;IACH,CAAC;IAED,KAAK,CAAC,cAAc;;QAClB,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;YAClC,KAAK,EAAE,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA8BT;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,SAAS;qBAC9B;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,CAAC;YAC3B,IAAI,CAAC,cAAc,EAAE,CAAA;QACvB,CAAC;IACH,CAAC;;AA1QM,+BAAM,GAAG;IACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA8HF;CACF,AAhIY,CAgIZ;AAQgB;IAAhB,KAAK,EAAE;;6DAAiC;AACxB;IAAhB,KAAK,EAAE;;6DAAoC;AAC3B;IAAhB,KAAK,EAAE;;8DAAiC;AA3I9B,wBAAwB;IADpC,aAAa,CAAC,wBAAwB,CAAC;GAC3B,wBAAwB,CA4QpC","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 { Project, ProjectState } from './project-list'\n\n@customElement('project-completed-list')\nexport class ProjectCompletedListPage 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 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: #1bb40133;\n --md-sys-color-surface-container-highest: #0595e533;\n --md-linear-progress-track-color: #1bb4011a;\n }\n\n span {\n position: absolute;\n top: 0;\n left: 12px;\n font-size: 12px;\n font-weight: bold;\n color: #1bb401;\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>시공사: ${project.buildingComplex.constructionCompany}</div>\n <div>건설구분: ${project.buildingComplex.constructionType}</div>\n <div>세대수: ${project.buildingComplex?.householdCount?.toLocaleString() || ''}세대</div>\n <div>기타: ${project.buildingComplex.etc}</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 constructionCompany\n constructionType\n householdCount\n etc\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.COMPLETED\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"]}
@@ -16,7 +16,8 @@ interface Weather {
16
16
  rain: number;
17
17
  temperature: number;
18
18
  humidity: number;
19
- wind: string;
19
+ windDirection: string;
20
+ windSpeed: number;
20
21
  }
21
22
  declare const ProjectDetail_base: typeof PageView & import("@open-wc/dedupe-mixin").Constructor<import("@open-wc/scoped-elements/types/src/types").ScopedElementsHost>;
22
23
  export declare class ProjectDetail extends ProjectDetail_base {
@@ -10,7 +10,7 @@ import { ScopedElementsMixin } from '@open-wc/scoped-elements';
10
10
  import { client } from '@operato/graphql';
11
11
  import { ScrollbarStyles } from '@operato/styles';
12
12
  import gql from 'graphql-tag';
13
- import { BUILDING_INSPECTION_STATUS } from './project-list';
13
+ import { BUILDING_INSPECTION_STATUS, ProjectType } from './project-list';
14
14
  import _getWeather from '../lib/waether';
15
15
  import '@operato/chart/ox-progress-circle.js';
16
16
  let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
@@ -42,7 +42,8 @@ let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
42
42
  rain: 0,
43
43
  temperature: 0,
44
44
  humidity: 0,
45
- wind: ''
45
+ windDirection: '',
46
+ windSpeed: 0
46
47
  };
47
48
  }
48
49
  get context() {
@@ -52,6 +53,7 @@ let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
52
53
  }
53
54
  render() {
54
55
  var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
56
+ let totalInspectionCount = this.inspectionSummary.pass + this.inspectionSummary.fail + this.inspectionSummary.request + this.inspectionSummary.wait;
55
57
  return html `
56
58
  <div header>
57
59
  <h2>${this.project.name}</h2>
@@ -148,55 +150,110 @@ let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
148
150
  <div right-top>
149
151
  <h3>프로젝트 현황</h3>
150
152
  <div state>
151
- <span progress>
152
- <ox-progress-circle
153
- .value=${this.project.totalProgress}
154
- titleText="전체"
155
- suffix="%"
156
- fontSize="27px"
157
- fontColor="#4E5055"
158
- borderStyle="none"
159
- innerCircleSize="28%"
160
- circleColor="#0595E5"
161
- shadow="#00000026 4px 4px 4px"
162
- background="#eaf5fd"
163
- ></ox-progress-circle>
164
- <div>전체공정율(%)</div>
165
- </span>
166
- <span progress>
167
- <ox-progress-circle
168
- .value=${this.project.weeklyProgress}
169
- titleText="주간"
170
- suffix="%"
171
- fontSize="27px"
172
- fontColor="#4E5055"
173
- borderStyle="none"
174
- innerCircleSize="28%"
175
- circleColor="#06B5AF"
176
- shadow="#00000026 4px 4px 4px"
177
- background="#eaf7f7"
178
- ></ox-progress-circle>
179
- <div week>주간공정율(%)</div>
180
- </span>
181
- <span weather>
182
- <div bold>현장현황</div>
183
- <div>
184
- <span><md-icon slot="icon">rainy</md-icon>강수확률</span>
185
- <span bold>${this.weather.rain}%</span>
186
- </div>
187
- <div>
188
- <span><md-icon slot="icon">humidity_percentage</md-icon> 습도</span>
189
- <span bold>${this.weather.humidity}%</span>
190
- </div>
191
- <div>
192
- <span><md-icon slot="icon">thermostat</md-icon> 온도</span>
193
- <span bold>${this.weather.temperature}°C</span>
194
- </div>
195
- <div>
196
- <span><md-icon slot="icon">air</md-icon> 풍향</span>
197
- <span bold>${this.weather.wind}</span>
153
+ <div progress-container>
154
+ <span progress>
155
+ <ox-progress-circle
156
+ .value=${this.project.totalProgress}
157
+ titleText="전체"
158
+ suffix="%"
159
+ fontSize="27px"
160
+ fontColor="#4E5055"
161
+ borderStyle="none"
162
+ innerCircleSize="28%"
163
+ circleColor="#0595E5"
164
+ shadow="#00000026 4px 4px 4px"
165
+ background="#eaf5fd"
166
+ ></ox-progress-circle>
167
+ <div>전체공정율(%)</div>
168
+ </span>
169
+ <span progress>
170
+ <ox-progress-circle
171
+ .value=${this.project.weeklyProgress}
172
+ titleText="주간"
173
+ suffix="%"
174
+ fontSize="27px"
175
+ fontColor="#4E5055"
176
+ borderStyle="none"
177
+ innerCircleSize="28%"
178
+ circleColor="#06B5AF"
179
+ shadow="#00000026 4px 4px 4px"
180
+ background="#eaf7f7"
181
+ ></ox-progress-circle>
182
+ <div week>주간공정율(%)</div>
183
+ </span>
184
+
185
+ <span progress>
186
+ <ox-progress-circle
187
+ .value=${this.project.inspPassRate}
188
+ suffix="%"
189
+ fontSize="27px"
190
+ fontColor="#4E5055"
191
+ borderStyle="none"
192
+ innerCircleSize="28%"
193
+ circleColor="#8B3F39"
194
+ shadow="#00000026 4px 4px 4px"
195
+ background="#DACCC7"
196
+ ></ox-progress-circle>
197
+ <div insp-pass-rate>시공/구조 검측 통과 비율(%)</div>
198
+ </span>
199
+ <span progress>
200
+ <ox-progress-circle
201
+ .value=${this.project.robotProgressRate}
202
+ suffix="%"
203
+ fontSize="27px"
204
+ fontColor="#4E5055"
205
+ borderStyle="none"
206
+ innerCircleSize="28%"
207
+ circleColor="#4A899B"
208
+ shadow="#00000026 4px 4px 4px"
209
+ background="#C7DFE1"
210
+ ></ox-progress-circle>
211
+ <div robot-progress-rate>로봇 작업 진행률(%)</div>
212
+ </span>
213
+ </div>
214
+
215
+ <div>
216
+ <div>KPI</div>
217
+
218
+ <div kpi-container>
219
+ <div kpi-item>
220
+ <span>KPI 지수</span>
221
+ <span kpi-value kpi-index>${this.project.kpi || 0}%</span>
222
+ </div>
223
+ <div kpi-item>
224
+ <span>검측 통과율</span>
225
+ <span kpi-value pass-rate>${this.inspectionSummary.pass || 0} / ${totalInspectionCount || 0}</span>
226
+ </div>
227
+ <div kpi-item>
228
+ <span>로봇 작업 대수</span>
229
+ <span kpi-value robot-count>${this.project.robotCount || 0}</span>
230
+ </div>
198
231
  </div>
199
- </span>
232
+
233
+ <span weather>
234
+ <div bold>현장현황</div>
235
+ <div>
236
+ <span><md-icon slot="icon">rainy</md-icon>강수확률</span>
237
+ <span bold>${this.weather.rain}%</span>
238
+ </div>
239
+ <div>
240
+ <span><md-icon slot="icon">humidity_percentage</md-icon> 습도</span>
241
+ <span bold>${this.weather.humidity}%</span>
242
+ </div>
243
+ <div>
244
+ <span><md-icon slot="icon">thermostat</md-icon> 온도</span>
245
+ <span bold>${this.weather.temperature}°C</span>
246
+ </div>
247
+ <div>
248
+ <span><md-icon slot="icon">arrows_output</md-icon> 풍향</span>
249
+ <span bold>${this.weather.windDirection}</span>
250
+ </div>
251
+ <div>
252
+ <span><md-icon slot="icon">air</md-icon> 풍속</span>
253
+ <span bold>${this.weather.windSpeed} m/s</span>
254
+ </div>
255
+ </span>
256
+ </div>
200
257
  </div>
201
258
  <div inspection>
202
259
  <span name bold>
@@ -244,13 +301,15 @@ let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
244
301
  <tbody>
245
302
  ${this.buildingInspections.map((inspection, idx) => {
246
303
  var _a, _b, _c, _d, _e, _f;
247
- return html ` <tr @click=${() => this._onClickInspection(inspection.id || '')}>
304
+ return html ` <tr @click=${() => this._onClickInspection(inspection)}>
248
305
  <td>${idx + 1}</td>
249
- <td>${(_b = (_a = inspection === null || inspection === void 0 ? void 0 : inspection.buildingLevel) === null || _a === void 0 ? void 0 : _a.building) === null || _b === void 0 ? void 0 : _b.name} ${(_c = inspection === null || inspection === void 0 ? void 0 : inspection.buildingLevel) === null || _c === void 0 ? void 0 : _c.floor}층</td>
306
+ <td>${(_b = (_a = inspection === null || inspection === void 0 ? void 0 : inspection.buildingLevel) === null || _a === void 0 ? void 0 : _a.building) === null || _b === void 0 ? void 0 : _b.name} ${(_c = inspection === null || inspection === void 0 ? void 0 : inspection.buildingLevel) === null || _c === void 0 ? void 0 : _c.floorDisplayName}층</td>
250
307
  <td bold>${(_d = inspection.checklist) === null || _d === void 0 ? void 0 : _d.constructionType}</td>
251
308
  <td>${((_f = (_e = inspection.checklist) === null || _e === void 0 ? void 0 : _e.inspectionParts) === null || _f === void 0 ? void 0 : _f.join(', ')) || ''}</td>
252
309
  <td>${this._formatDate(inspection.requestDate)}</td>
253
- <td bold>${inspection.status && BUILDING_INSPECTION_STATUS[inspection.status]}</td>
310
+ <td bold status=${inspection.status || ''}>
311
+ ${inspection.status && BUILDING_INSPECTION_STATUS[inspection.status]}
312
+ </td>
254
313
  </tr>`;
255
314
  })}
256
315
  </tbody>
@@ -278,6 +337,7 @@ let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
278
337
  name
279
338
  startDate
280
339
  endDate
340
+ projectType
281
341
  mainPhoto {
282
342
  fullpath
283
343
  }
@@ -287,6 +347,7 @@ let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
287
347
  inspPassRate
288
348
  robotProgressRate
289
349
  structuralSafetyRate
350
+ robotCount
290
351
  buildingComplex {
291
352
  id
292
353
  address
@@ -329,8 +390,11 @@ let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
329
390
  status
330
391
  requestDate
331
392
  buildingLevel {
393
+ id
332
394
  floor
395
+ floorDisplayName
333
396
  building {
397
+ id
334
398
  name
335
399
  }
336
400
  }
@@ -364,8 +428,15 @@ let ProjectDetail = class ProjectDetail extends ScopedElementsMixin(PageView) {
364
428
  this.weather = await _getWeather(latitude, longitude);
365
429
  }
366
430
  }
367
- _onClickInspection(buildingInspectionId) {
368
- navigate(`building-inspection-detail-drawing/${buildingInspectionId}`);
431
+ _onClickInspection(buildingInspection) {
432
+ var _a, _b, _c;
433
+ console.log('buildingInspection :', buildingInspection);
434
+ if (this.project.projectType === ProjectType.DSSP) {
435
+ navigate(`building-inspection-grid-detail/${this.project.id}?buildingId=${(_b = (_a = buildingInspection === null || buildingInspection === void 0 ? void 0 : buildingInspection.buildingLevel) === null || _a === void 0 ? void 0 : _a.building) === null || _b === void 0 ? void 0 : _b.id}&levelId=${(_c = buildingInspection === null || buildingInspection === void 0 ? void 0 : buildingInspection.buildingLevel) === null || _c === void 0 ? void 0 : _c.id}`);
436
+ }
437
+ else if (this.project.projectType === ProjectType.DCSP) {
438
+ navigate(`building-inspection-detail-drawing/${buildingInspection.id}`);
439
+ }
369
440
  }
370
441
  _formatDate(date) {
371
442
  return date
@@ -398,7 +469,7 @@ ProjectDetail.styles = [
398
469
  --md-outlined-button-container-height: 30px;
399
470
  --md-outlined-button-trailing-space: var(--spacing-medium, 8px);
400
471
  --md-outlined-button-leading-space: var(--spacing-medium, 8px);
401
- --md-sys-color-outline: rgba(51,51,51,.20);
472
+ --md-sys-color-outline: rgba(51, 51, 51, 0.2);
402
473
  }
403
474
 
404
475
  *[bold] {
@@ -412,7 +483,7 @@ ProjectDetail.styles = [
412
483
  h2 {
413
484
  flex: 0.5;
414
485
  color: #3f71a0;
415
- font-size:18px;
486
+ font-size: 18px;
416
487
  }
417
488
 
418
489
  div[button-container] {
@@ -443,7 +514,7 @@ ProjectDetail.styles = [
443
514
  div[body] {
444
515
  display: flex;
445
516
  margin: var(--spacing-large, 12px);
446
- margin-top:0;
517
+ margin-top: 0;
447
518
  gap: var(--spacing-medium, 8px);
448
519
 
449
520
  h3 {
@@ -529,7 +600,7 @@ ProjectDetail.styles = [
529
600
  --md-outlined-button-container-height: 30px;
530
601
  --md-outlined-button-trailing-space: var(--spacing-medium, 8px);
531
602
  --md-outlined-button-leading-space: var(--spacing-medium, 8px);
532
- --md-sys-color-outline: rgba(51,51,51,.20);
603
+ --md-sys-color-outline: rgba(51, 51, 51, 0.2);
533
604
  }
534
605
  }
535
606
  }
@@ -537,33 +608,46 @@ ProjectDetail.styles = [
537
608
  div[right-top] {
538
609
  div[state] {
539
610
  display: grid;
540
- grid-template-columns: 0.95fr 0.95fr 1.1fr;
611
+ grid-template-columns: 1.9fr 1.1fr;
541
612
  gap: var(--spacing-large, 12px);
542
613
 
543
- span[progress] {
544
- max-width: 150px;
545
- text-align: center;
546
- display: flex;
547
- justify-self: center;
548
- flex-direction: column;
549
- width: 100%;
614
+ div[progress-container] {
615
+ display: grid;
616
+ grid-template-columns: 1fr 1fr;
617
+ row-gap: 15px;
550
618
 
551
- & > div {
552
- font-weight: bold;
553
- color: #2e79be;
554
- font-size: 12px;
555
- margin-top: var(--spacing-small, 4px);
556
- }
557
- & > div[week] {
558
- color: #06b5af;
619
+ span[progress] {
620
+ max-width: 150px;
621
+ text-align: center;
622
+ display: flex;
623
+ justify-self: center;
624
+ flex-direction: column;
625
+ width: 100%;
626
+
627
+ & > div {
628
+ font-weight: bold;
629
+ color: #2e79be;
630
+ font-size: 12px;
631
+ margin-top: var(--spacing-small, 4px);
632
+ }
633
+ & > div[week] {
634
+ color: #06b5af;
635
+ }
636
+ & > div[insp-pass-rate] {
637
+ color: #8b3f39;
638
+ }
639
+ & > div[robot-progress-rate] {
640
+ color: #4a899b;
641
+ }
559
642
  }
560
643
  }
644
+
561
645
  span[weather] {
562
646
  display: flex;
563
647
  flex-direction: column;
564
648
  gap: var(--spacing-small, 4px);
565
649
  margin-left: var(--spacing-medium, 8px);
566
- font-size:14px;
650
+ font-size: 14px;
567
651
 
568
652
  & > div {
569
653
  display: flex;
@@ -573,8 +657,8 @@ ProjectDetail.styles = [
573
657
 
574
658
  & > span {
575
659
  display: flex;
576
- align-item:center;
577
- var(--spacing-tiny, 2px);
660
+ align-items: center;
661
+ gap: var(--spacing-tiny, 2px);
578
662
  }
579
663
  }
580
664
  }
@@ -610,7 +694,7 @@ ProjectDetail.styles = [
610
694
  flex-direction: row;
611
695
  text-align: right;
612
696
  gap: var(--spacing-medium, 8px);
613
- line-height:1.3;
697
+ line-height: 1.3;
614
698
 
615
699
  md-icon {
616
700
  width: 40px;
@@ -621,6 +705,31 @@ ProjectDetail.styles = [
621
705
  }
622
706
  }
623
707
  }
708
+ div[kpi-container] {
709
+ display: flex;
710
+ flex-direction: column;
711
+ gap: var(--spacing-small, 4px);
712
+ margin-bottom: var(--spacing-medium, 8px);
713
+
714
+ div[kpi-item] {
715
+ display: flex;
716
+ justify-content: space-between;
717
+ font-size: 14px;
718
+
719
+ span[kpi-value] {
720
+ font-weight: bold;
721
+ }
722
+ span[kpi-index] {
723
+ color: #2e79be;
724
+ }
725
+ span[pass-rate] {
726
+ color: #1bb401;
727
+ }
728
+ span[robot-count] {
729
+ color: #4a899b;
730
+ }
731
+ }
732
+ }
624
733
  div[notice] {
625
734
  margin-top: var(--spacing-medium, 8px);
626
735
 
@@ -679,7 +788,7 @@ ProjectDetail.styles = [
679
788
  }
680
789
 
681
790
  tbody td {
682
- border-bottom: 1px solid rgba(51,51,51,.20);
791
+ border-bottom: 1px solid rgba(51, 51, 51, 0.2);
683
792
  padding: var(--spacing-small, 4px);
684
793
  text-align: center;
685
794
  white-space: nowrap;
@@ -688,6 +797,10 @@ ProjectDetail.styles = [
688
797
  font-size: 13px;
689
798
  }
690
799
 
800
+ tbody td[status='FAIL'] {
801
+ color: #e15757;
802
+ }
803
+
691
804
  md-elevated-button {
692
805
  margin: 0 var(--spacing-small, 4px);
693
806