refactor: current plan 이동 시 useEffect 호출 제거, 초기 plan 저장 시 팝업 미표출하도록 수정

This commit is contained in:
Daseul Kim 2025-01-23 17:54:02 +09:00
parent b75b155646
commit 90b52abb7f
2 changed files with 25 additions and 28 deletions

View File

@ -24,15 +24,15 @@ export default function CanvasFrame() {
const currentMenu = useRecoilValue(currentMenuState)
const { floorPlanState } = useContext(FloorPlanContext)
const { contextMenu, handleClick } = useContextMenu()
const { selectedPlan } = usePlan()
const { currentCanvasPlan } = usePlan()
const totalDisplay = useRecoilValue(totalDisplaySelector) //
const { setIsGlobalLoading } = useContext(QcastContext)
const loadCanvas = () => {
if (canvas) {
canvas?.clear() // .
if (selectedPlan?.canvasStatus && floorPlanState.objectNo === selectedPlan.objectNo) {
canvas?.loadFromJSON(JSON.parse(selectedPlan.canvasStatus), function () {
if (currentCanvasPlan?.canvasStatus && floorPlanState.objectNo === currentCanvasPlan.objectNo) {
canvas?.loadFromJSON(JSON.parse(currentCanvasPlan.canvasStatus), function () {
canvasLoadInit() //config
canvas?.renderAll() // .
})
@ -43,7 +43,7 @@ export default function CanvasFrame() {
useEffect(() => {
loadCanvas()
}, [selectedPlan, canvas])
}, [currentCanvasPlan, canvas])
useEffect(() => {
setIsGlobalLoading(false)

View File

@ -128,7 +128,7 @@ export function usePlan(params = {}) {
/**
* objectNo에 해당하는 canvas 목록을 조회
*/
const getCanvasByObjectNo = async (userId, objectNo) => {
const getCanvasByObjectNo = async (userId, objectNo, planNo) => {
return await get({ url: `/api/canvas-management/canvas-statuses/by-object/${objectNo}/${userId}` }).then((res) =>
res.map((item) => ({
id: item.id,
@ -136,7 +136,7 @@ export function usePlan(params = {}) {
planNo: item.planNo,
userId: item.userId,
canvasStatus: dbToCanvasFormat(item.canvasStatus),
isCurrent: false,
isCurrent: planNo === item.planNo,
bgImageName: item.bgImageName,
mapPositionAddress: item.mapPositionAddress,
})),
@ -174,14 +174,15 @@ export function usePlan(params = {}) {
}
await promisePost({ url: '/api/canvas-management/canvas-statuses', data: planData })
.then((res) => {
const newPlan = { id: res.data, objectNo: objectNo, planNo: planNo, userId: userId, canvasStatus: canvasStatus, isCurrent: true }
setCurrentCanvasPlan(newPlan)
if (isInitPlan) {
// 초기 플랜 생성인 경우 플랜 목록 초기화
setPlans([{ id: res.data, objectNo: objectNo, planNo: planNo, userId: userId, canvasStatus: canvasStatus }])
setPlans([newPlan])
} else {
setPlans((plans) => [...plans, { id: res.data, objectNo: objectNo, planNo: planNo, userId: userId, canvasStatus: canvasStatus }])
setPlans((plans) => [...plans.map((plan) => ({ ...plan, isCurrent: false })), newPlan])
swalFire({ text: getMessage('plan.message.save') })
}
updateCurrentPlan(res.data)
swalFire({ text: getMessage('plan.message.save') })
})
.catch((error) => {
swalFire({ text: error.message, icon: 'error' })
@ -255,14 +256,16 @@ export function usePlan(params = {}) {
}
setEstimateContextState(res.data)
// 클릭한 플랜 탭으로 이동
updateCurrentPlan(newCurrentId)
setCurrentCanvasPlan(plans.find((plan) => plan.id === newCurrentId))
setPlans((plans) => plans.map((plan) => ({ ...plan, isCurrent: plan.id === newCurrentId })))
} else {
swalFire({ text: getMessage('estimate.menu.move.valid1') })
}
} else {
// 발전시뮬레이션
if (estimateDetail.tempFlg === '0') {
updateCurrentPlan(newCurrentId)
setCurrentCanvasPlan(plans.find((plan) => plan.id === newCurrentId))
setPlans((plans) => plans.map((plan) => ({ ...plan, isCurrent: plan.id === newCurrentId })))
} else {
swalFire({ text: getMessage('simulator.menu.move.valid1') })
}
@ -278,26 +281,18 @@ export function usePlan(params = {}) {
})
} else {
if (!currentCanvasPlan || currentCanvasPlan.id !== newCurrentId) {
saveCanvas()
await saveCanvas()
}
updateCurrentPlan(newCurrentId)
setCurrentCanvasPlan(plans.find((plan) => plan.id === newCurrentId))
setPlans((plans) => plans.map((plan) => ({ ...plan, isCurrent: plan.id === newCurrentId })))
}
}
const updateCurrentPlan = (newCurrentId) => {
setPlans((plans) =>
plans.map((plan) => {
return { ...plan, isCurrent: plan.id === newCurrentId }
}),
)
}
useEffect(() => {
setCurrentCanvasPlan(plans.find((plan) => plan.isCurrent) || null)
setSelectedPlan(plans.find((plan) => plan.isCurrent))
setSelectedPlan(currentCanvasPlan)
handleCurrentPlanUrl()
// setBgImage()
}, [plans])
}, [currentCanvasPlan])
const handleCurrentPlanUrl = () => {
const currentPlan = plans.find((plan) => plan.isCurrent)
@ -368,7 +363,8 @@ export function usePlan(params = {}) {
if (!lastPlan) {
setCurrentCanvasPlan(null)
} else if (targetPlan.id !== lastPlan.id) {
updateCurrentPlan(lastPlan.id)
setCurrentCanvasPlan(lastPlan)
setPlans((plans) => plans.map((plan) => ({ ...plan, isCurrent: plan.id === lastPlan.id })))
}
}
@ -377,10 +373,10 @@ export function usePlan(params = {}) {
*/
const loadCanvasPlanData = async (userId, objectNo, planNo) => {
console.log('🚀 ~ loadCanvasPlanData ~ userId, objectNo, planNo:', userId, objectNo, planNo)
await getCanvasByObjectNo(userId, objectNo).then((res) => {
await getCanvasByObjectNo(userId, objectNo, planNo).then((res) => {
if (res.length > 0) {
setCurrentCanvasPlan(res.find((plan) => plan.planNo === planNo))
setPlans(res)
updateCurrentPlan(res.find((plan) => plan.planNo === planNo).id)
} else {
postCanvasStatus(userId, objectNo, '', true)
}
@ -397,6 +393,7 @@ export function usePlan(params = {}) {
return {
canvas,
plans,
currentCanvasPlan,
selectedPlan,
saveCanvas,
handleCurrentPlan,