From 9bf961441b024f8a07c7f5da3c7b9100ab5d6d51 Mon Sep 17 00:00:00 2001 From: ysCha Date: Fri, 25 Apr 2025 14:02:35 +0900 Subject: [PATCH] =?UTF-8?q?1018=20-=20=EC=BA=94=EB=B2=84=EC=8A=A4=ED=8C=9D?= =?UTF-8?q?=EC=97=85=EC=83=81=ED=83=9C=20=EB=B3=B5=EC=82=AC=EC=A0=80?= =?UTF-8?q?=EC=9E=A5,=20=EC=A1=B0=ED=9A=8C=20:=20unescapeString()=20if=20?= =?UTF-8?q?=3D>=20while=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/hooks/usePlan.js | 3 ++- src/util/common-utils.js | 10 ++++++++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/src/hooks/usePlan.js b/src/hooks/usePlan.js index f812f00e..74c03296 100644 --- a/src/hooks/usePlan.js +++ b/src/hooks/usePlan.js @@ -21,6 +21,7 @@ import { moduleSelectionDataState, selectedModuleState } from '@/store/selectedM import { useCanvasPopupStatusController } from './common/useCanvasPopupStatusController' import { useCanvasMenu } from './common/useCanvasMenu' import { QcastContext } from '@/app/QcastProvider' +import { unescapeString } from '@/util/common-utils' /** * 플랜 처리 훅 @@ -264,7 +265,7 @@ export function usePlan(params = {}) { objectNo, planNo: parseInt(newPlan.planNo), popupType: 1, - popupStatus: sourceDegree.popupStatus, + popupStatus: unescapeString(sourceDegree.popupStatus), } console.log('🚀 ~ postObjectPlan ~ degreeData:', degreeData) await post({ url: `/api/v1/canvas-popup-status`, data: degreeData }) diff --git a/src/util/common-utils.js b/src/util/common-utils.js index 842eace0..0a1265fe 100644 --- a/src/util/common-utils.js +++ b/src/util/common-utils.js @@ -145,9 +145,19 @@ export const unescapeString = (str) => { ''': "'", } + /* + 1. 한번 변환은 {" 로 변환됨 : 에러 발생 => while 변경 + 2. 변환할 내용이 없으면 리턴값이 undefined + if (regex.test(str)) { return str.replace(regex, (matched) => chars[matched] || matched) } + */ + + while (regex.test(str)) { + str = str.replace(regex, (matched) => chars[matched] || matched); + } + return str } export const isNullOrUndefined = (value) => {