This commit is contained in:
hyojun.choi 2025-02-19 13:38:27 +09:00
commit aafc50c6b8
6 changed files with 58 additions and 49 deletions

View File

@ -22,7 +22,7 @@ import { usePlan } from '@/hooks/usePlan'
import { usePopup } from '@/hooks/usePopup'
import { useSwal } from '@/hooks/useSwal'
import { QcastContext } from '@/app/QcastProvider'
import { useCanvasMenu } from '@/hooks/common/useCanvasMenu'
export default function Estimate({}) {
const [uniqueData, setUniqueData] = useState([])
const [handlePricingFlag, setHandlePricingFlag] = useState(false)
@ -87,7 +87,7 @@ export default function Estimate({}) {
const { getMessage } = useMessage()
const { closeAll } = usePopup()
const { setMenuNumber } = useCanvasMenu()
// props
const fileUploadProps = {
uploadFiles: files,
@ -119,8 +119,6 @@ export default function Estimate({}) {
if (estimateContextState?.itemList.length > 0) {
tempList = estimateContextState.itemList.filter((item) => !res.some((resItem) => resItem.itemId === item.itemId))
updatedRes = [...res, ...tempList]
// console.log('tempList::::::::', tempList)
// console.log('updatedRes::::::::', updatedRes)
} else {
updatedRes = [...res]
}
@ -144,6 +142,7 @@ export default function Estimate({}) {
}, [selectedPlan])
useEffect(() => {
setMenuNumber(5)
initEstimate()
}, [])

View File

@ -171,8 +171,6 @@ export default function CanvasMenu(props) {
await reloadCanvasStatus(objectNo, pid)
break
case 3:
console.log('🚀 ~ onClickNav ~ menu:', menu)
console.log('🚀 ~ onClickNav ~ menuNumber:', menuNumber)
if (menuNumber > menu.index) {
const modules = canvas.getObjects().filter((module) => module.name === POLYGON_TYPE.MODULE)
if (modules.length > 0) {
@ -199,6 +197,7 @@ export default function CanvasMenu(props) {
return
},
})
return
} else {
setType('surface')
}
@ -221,16 +220,14 @@ export default function CanvasMenu(props) {
await reloadCanvasStatus(objectNo, pid)
break
case 5:
setIsGlobalLoading(true)
// (useEstimateController.js) setIsGlobalLoading(false)
promiseGet({ url: `/api/estimate/${objectNo}/${selectedPlan.planNo}/detail` }).then((res) => {
if (res.status === 200) {
const estimateDetail = res.data
// if (estimateDetail.tempFlg === '0' && estimateDetail.estimateDate !== null) {
if (estimateDetail.estimateDate !== null) {
setMenuNumber(menu.index)
setCurrentMenu(menu.title)
setFloorPlanObjectNo({ floorPlanObjectNo: objectNo })
setIsGlobalLoading(false)
router.push(`/floor-plan/estimate/${menu.index}?pid=${selectedPlan.planNo}&objectNo=${objectNo}`)
} else {
setIsGlobalLoading(false)

View File

@ -8,7 +8,6 @@ import { useRouter, useSearchParams } from 'next/navigation'
import { useSetRecoilState } from 'recoil'
import { QcastContext } from '@/app/QcastProvider'
import { useMessage } from '@/hooks/useMessage'
import { floorPlanObjectState } from '@/store/floorPlanObjectAtom'
import { isObjectNotEmpty, queryStringFormatter } from '@/util/common-utils'
@ -24,8 +23,6 @@ export default function StuffSubHeader({ type }) {
const setFloorPlanObjectNo = useSetRecoilState(floorPlanObjectState)
const { isGlobalLoading } = useContext(QcastContext)
const { managementState } = useContext(GlobalDataContext)
const [buttonStyle, setButtonStyle] = useState('')
@ -70,7 +67,7 @@ export default function StuffSubHeader({ type }) {
<div className="sub-header-inner">
{type === 'list' && (
<>
<Link href={'#'}>
<Link href={'#'} scroll={false}>
<h1 className="sub-header-title">{getMessage('header.menus.management')}</h1>
</Link>
<ul className="sub-header-location">
@ -92,7 +89,7 @@ export default function StuffSubHeader({ type }) {
<>
<ul className="sub-header-title-wrap">
<li className="title-item">
<Link className="sub-header-title" href={'#'}>
<Link className="sub-header-title" href={'#'} scroll={false}>
{getMessage('stuff.temp.subTitle')}
</Link>
</li>
@ -116,7 +113,7 @@ export default function StuffSubHeader({ type }) {
<>
<ul className="sub-header-title-wrap">
<li className="title-item">
<Link className="sub-header-title" href={'#'}>
<Link className="sub-header-title" href={'#'} scroll={false}>
{getMessage('stuff.temp.subTitle')}
</Link>
</li>

View File

@ -1,4 +1,4 @@
import { useRecoilState, useRecoilValue } from 'recoil'
import { useRecoilState, useRecoilValue, useResetRecoilState } from 'recoil'
import { useContext, useEffect, useState } from 'react'
import { GlobalDataContext } from '@/app/GlobalDataProvider'
import { useMasterController } from '@/hooks/common/useMasterController'
@ -7,6 +7,7 @@ import { selectedModuleState, moduleSelectionInitParamsState, moduleSelectionDat
import { isObjectNotEmpty } from '@/util/common-utils'
import { canvasState } from '@/store/canvasAtom'
import { POLYGON_TYPE } from '@/common/common'
import { moduleStatisticsState } from '@/store/circuitTrestleAtom'
export function useModuleSelection(props) {
const canvas = useRecoilValue(canvasState)
@ -25,6 +26,7 @@ export function useModuleSelection(props) {
const [moduleSelectionInitParams, setModuleSelectionInitParams] = useRecoilState(moduleSelectionInitParamsState) //모듈 기본 데이터 ex) 면조도, 높이등등
const { getModuleTypeItemList } = useMasterController()
const { findCommonCode } = useCommonCode()
const resetStatisticsData = useResetRecoilState(moduleStatisticsState)
const bindInitData = () => {
setInstallHeight(managementState?.installHeight)
@ -98,6 +100,7 @@ export function useModuleSelection(props) {
canvas.remove(moduleSurface)
})
canvas.renderAll()
resetStatisticsData()
}
}, [])

View File

@ -140,8 +140,7 @@ export function useCanvasSetting() {
const selectedRoofMaterial = useRecoilValue(selectedRoofMaterialSelector) // 선택된 지붕재 정보
const { floorPlanState } = useContext(FloorPlanContext) // 플랜 상태
const { closeAll } = usePopup() // 팝업 닫기
// const previousObjectNoRef = useRef(null) // 최초 데이터 설정 확인
// const previousRoofMaterialsRef = useRef(null) // 최초 데이터 설정 확인
const [isRoofMaterialsLoaded, setIsRoofMaterialsLoaded] = useState(false) // roofMaterials 로드 상태 확인
useEffect(() => {
const tempFetchRoofMaterials = !fetchRoofMaterials
@ -153,6 +152,15 @@ export function useCanvasSetting() {
}
}, [])
/**
* roofMaterials가 변경될 때마다 로드 상태 업데이트
*/
useEffect(() => {
if (roofMaterials.length > 0) {
setIsRoofMaterialsLoaded(true)
}
}, [roofMaterials])
/**
* 지붕재 초기세팅
*/
@ -188,26 +196,6 @@ export function useCanvasSetting() {
setBasicSettings({ ...basicSetting, selectedRoofMaterial: selectedRoofMaterial })
}
// useEffect(() => {
// // 지붕재 select 정보가 존재해야 배치면초기설정 DB 정보 비교 후 지붕재 정보를 가져올 수 있음
// if (
// (!previousObjectNoRef.current && !correntObjectNo && previousObjectNoRef.current !== correntObjectNo) ||
// (roofMaterials.length !== 0 && JSON.stringify(previousRoofMaterialsRef.current) !== JSON.stringify(roofMaterials))
// ) {
// // 1회만 실행
// if (roofMaterials && previousRoofMaterialsYn === 'N') {
// if (correntObjectNo) {
// //fetchBasicSettings()
// previousRoofMaterialsYn = 'Y'
// }
// }
// // 이전 값을 업데이트
// previousObjectNoRef.current = correntObjectNo
// previousRoofMaterialsRef.current = roofMaterials
// }
// }, [roofMaterials, correntObjectNo])
/**
* 배치면 초기설정 화면이 열리지 않아도 데이터 set 하기 위해서 추가
*/
@ -330,13 +318,24 @@ export function useCanvasSetting() {
* 기본설정(PlacementShapeSetting) 조회 초기화
*/
const fetchBasicSettings = async (planNo, openPoint) => {
/* roofMaterials가 로드될 때까지 대기 */
if (!roofMaterials || roofMaterials.length === 0) {
console.log('Waiting for roofMaterials to load...')
return
}
try {
/* roofMaterials가 로드될 때까지 대기 후 실행 */
if (!isRoofMaterialsLoaded) {
/* roofMaterials가 아직 로드되지 않았다면 */
await new Promise((resolve) => {
/* 새로운 Promise 생성 */
const checkInterval = setInterval(() => {
/* 100ms마다 체크하는 인터벌 설정 */
console.log('roofMaterials loading... ', roofMaterials.length)
if (roofMaterials.length > 0) {
/* roofMaterials가 로드되었다면 */
clearInterval(checkInterval) // 인터벌 중지
resolve() // Promise 완료
}
}, 100)
})
}
await get({
url: `/api/canvas-management/canvas-basic-settings/by-object/${correntObjectNo}/${planNo}`,
}).then((res) => {
@ -433,6 +432,7 @@ export function useCanvasSetting() {
if (addRoofs.length > 0) {
setAddedRoofs(addRoofs)
setBasicSettings({
...basicSetting,
roofMaterials: addRoofs[0],
@ -442,13 +442,23 @@ export function useCanvasSetting() {
roofsData: roofsArray,
selectedRoofMaterial: addRoofs.find((roof) => roof.selected),
})
setCanvasSetting({
...basicSetting,
roofMaterials: addRoofs[0],
planNo: roofsRow[0].planNo,
roofSizeSet: roofsRow[0].roofSizeSet,
roofAngleSet: roofsRow[0].roofAngleSet,
roofsData: roofsArray,
selectedRoofMaterial: addRoofs.find((roof) => roof.selected),
})
}
})
} catch (error) {
console.error('Data fetching error:', error)
}
setCanvasSetting({ ...basicSetting })
// setCanvasSetting({ ...basicSetting })
}
/**
@ -482,12 +492,15 @@ export function useCanvasSetting() {
await post({ url: `/api/canvas-management/canvas-basic-settings`, data: patternData }).then((res) => {
swalFire({ text: getMessage(res.returnMessage) })
/* 배치면초기설정 조회 */
/* BasicSettings Recoil 설정 */
setBasicSettings({ ...params })
})
/* CanvasSetting Recoil 설정 */
setCanvasSetting({ ...basicSetting })
/* CanvasSetting Recoil 설정 - roofSizeSet을 문자열로 변환 */
setCanvasSetting({
...basicSetting,
roofSizeSet: String(params.roofSizeSet),
})
/* 배치면초기설정 조회 */
fetchBasicSettings(params.planNo, null)

View File

@ -1,2 +1,2 @@
var exec = require('child_process').exec
exec('yarn start', { windowsHide: true })
exec('yarn serve', { windowsHide: true })