@tipp/ui 2.3.11 → 2.3.12

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 (144) hide show
  1. package/dist/app/index.cjs +42 -39
  2. package/dist/app/index.cjs.map +1 -1
  3. package/dist/app/index.js +23 -23
  4. package/dist/app/platform/edit-coaching-time.cjs +15 -12
  5. package/dist/app/platform/edit-coaching-time.cjs.map +1 -1
  6. package/dist/app/platform/edit-coaching-time.js +19 -19
  7. package/dist/app/platform/edit-service-type.cjs +10 -7
  8. package/dist/app/platform/edit-service-type.cjs.map +1 -1
  9. package/dist/app/platform/edit-service-type.js +19 -19
  10. package/dist/app/platform/goal-manage-card-edit.cjs +12 -9
  11. package/dist/app/platform/goal-manage-card-edit.cjs.map +1 -1
  12. package/dist/app/platform/goal-manage-card-edit.js +19 -19
  13. package/dist/app/platform/on-offline-radio-card.cjs +34 -31
  14. package/dist/app/platform/on-offline-radio-card.cjs.map +1 -1
  15. package/dist/app/platform/on-offline-radio-card.js +19 -19
  16. package/dist/app/platform/reservation-card.cjs +17 -14
  17. package/dist/app/platform/reservation-card.cjs.map +1 -1
  18. package/dist/app/platform/reservation-card.js +19 -19
  19. package/dist/app/platform/session-card.cjs +21 -18
  20. package/dist/app/platform/session-card.cjs.map +1 -1
  21. package/dist/app/platform/session-card.js +19 -19
  22. package/dist/app/platform/userInfos/coaching-customer-info/index.js +4 -4
  23. package/dist/chunk-2QFLNAGL.js +100 -0
  24. package/dist/chunk-2QFLNAGL.js.map +1 -0
  25. package/dist/chunk-3FKAH2RB.js +105 -0
  26. package/dist/chunk-3FKAH2RB.js.map +1 -0
  27. package/dist/chunk-3OCAVV5Z.js +151 -0
  28. package/dist/chunk-3OCAVV5Z.js.map +1 -0
  29. package/dist/chunk-3PE6OFB3.js +70 -0
  30. package/dist/chunk-3PE6OFB3.js.map +1 -0
  31. package/dist/chunk-3QNIJCKK.js +98 -0
  32. package/dist/chunk-3QNIJCKK.js.map +1 -0
  33. package/dist/chunk-4OFVNWKB.js +100 -0
  34. package/dist/chunk-4OFVNWKB.js.map +1 -0
  35. package/dist/chunk-4SSWZQPC.js +89 -0
  36. package/dist/chunk-4SSWZQPC.js.map +1 -0
  37. package/dist/chunk-5JUYOJVM.js +77 -0
  38. package/dist/chunk-5JUYOJVM.js.map +1 -0
  39. package/dist/chunk-5SECMWKA.js +196 -0
  40. package/dist/chunk-5SECMWKA.js.map +1 -0
  41. package/dist/chunk-65FJZWXV.js +49 -0
  42. package/dist/chunk-65FJZWXV.js.map +1 -0
  43. package/dist/chunk-7UUHYDMJ.js +43 -0
  44. package/dist/chunk-7UUHYDMJ.js.map +1 -0
  45. package/dist/chunk-B5W5HY62.js +196 -0
  46. package/dist/chunk-B5W5HY62.js.map +1 -0
  47. package/dist/chunk-B63TOIOA.js +29 -0
  48. package/dist/chunk-B63TOIOA.js.map +1 -0
  49. package/dist/chunk-DTUYT5S2.js +98 -0
  50. package/dist/chunk-DTUYT5S2.js.map +1 -0
  51. package/dist/chunk-EI232M7E.js +196 -0
  52. package/dist/chunk-EI232M7E.js.map +1 -0
  53. package/dist/chunk-FDJPEXOU.js +222 -0
  54. package/dist/chunk-FDJPEXOU.js.map +1 -0
  55. package/dist/chunk-FGBFER5X.js +196 -0
  56. package/dist/chunk-FGBFER5X.js.map +1 -0
  57. package/dist/chunk-FNRYQLCC.js +64 -0
  58. package/dist/chunk-FNRYQLCC.js.map +1 -0
  59. package/dist/chunk-G7EN5QQR.js +64 -0
  60. package/dist/chunk-G7EN5QQR.js.map +1 -0
  61. package/dist/chunk-GDCDEPJO.js +64 -0
  62. package/dist/chunk-GDCDEPJO.js.map +1 -0
  63. package/dist/chunk-I4OEBZDH.js +64 -0
  64. package/dist/chunk-I4OEBZDH.js.map +1 -0
  65. package/dist/chunk-I5NKMQOT.js +64 -0
  66. package/dist/chunk-I5NKMQOT.js.map +1 -0
  67. package/dist/chunk-J5IKAPJM.js +69 -0
  68. package/dist/chunk-J5IKAPJM.js.map +1 -0
  69. package/dist/chunk-JJQM3MW3.js +98 -0
  70. package/dist/chunk-JJQM3MW3.js.map +1 -0
  71. package/dist/chunk-JKJUBJ65.js +70 -0
  72. package/dist/chunk-JKJUBJ65.js.map +1 -0
  73. package/dist/chunk-KLIEFXWN.js +100 -0
  74. package/dist/chunk-KLIEFXWN.js.map +1 -0
  75. package/dist/chunk-NDC72OWR.js +37 -0
  76. package/dist/chunk-NDC72OWR.js.map +1 -0
  77. package/dist/chunk-NMGLSEZ3.js +152 -0
  78. package/dist/chunk-NMGLSEZ3.js.map +1 -0
  79. package/dist/chunk-NMKIFFKE.js +63 -0
  80. package/dist/chunk-NMKIFFKE.js.map +1 -0
  81. package/dist/chunk-OX4OPOPI.js +82 -0
  82. package/dist/chunk-OX4OPOPI.js.map +1 -0
  83. package/dist/chunk-POFUBAXM.js +77 -0
  84. package/dist/chunk-POFUBAXM.js.map +1 -0
  85. package/dist/chunk-QBBF5V24.js +70 -0
  86. package/dist/chunk-QBBF5V24.js.map +1 -0
  87. package/dist/chunk-QPTWBPAQ.js +87 -0
  88. package/dist/chunk-QPTWBPAQ.js.map +1 -0
  89. package/dist/chunk-R7NTFLYB.js +98 -0
  90. package/dist/chunk-R7NTFLYB.js.map +1 -0
  91. package/dist/chunk-RAK5LEBO.js +70 -0
  92. package/dist/chunk-RAK5LEBO.js.map +1 -0
  93. package/dist/chunk-RWXNQPE7.js +151 -0
  94. package/dist/chunk-RWXNQPE7.js.map +1 -0
  95. package/dist/chunk-SGJFPJMV.js +100 -0
  96. package/dist/chunk-SGJFPJMV.js.map +1 -0
  97. package/dist/chunk-SYUWHIFX.js +98 -0
  98. package/dist/chunk-SYUWHIFX.js.map +1 -0
  99. package/dist/chunk-TDBCQSTJ.js +61 -0
  100. package/dist/chunk-TDBCQSTJ.js.map +1 -0
  101. package/dist/chunk-TGCLWLPY.js +51 -0
  102. package/dist/chunk-TGCLWLPY.js.map +1 -0
  103. package/dist/chunk-UFWZAT6E.js +89 -0
  104. package/dist/chunk-UFWZAT6E.js.map +1 -0
  105. package/dist/chunk-VN7IU4XW.js +64 -0
  106. package/dist/chunk-VN7IU4XW.js.map +1 -0
  107. package/dist/chunk-W3NTNHA4.js +196 -0
  108. package/dist/chunk-W3NTNHA4.js.map +1 -0
  109. package/dist/chunk-XDPRIBTV.js +101 -0
  110. package/dist/chunk-XDPRIBTV.js.map +1 -0
  111. package/dist/chunk-XU7H43IG.js +196 -0
  112. package/dist/chunk-XU7H43IG.js.map +1 -0
  113. package/dist/chunk-ZFWZAZPG.js +153 -0
  114. package/dist/chunk-ZFWZAZPG.js.map +1 -0
  115. package/dist/index.cjs +136 -89
  116. package/dist/index.cjs.map +1 -1
  117. package/dist/index.css +4 -2
  118. package/dist/index.js +40 -40
  119. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/index.js +2 -2
  120. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-ai-traning.cjs.map +1 -1
  121. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-ai-traning.js +2 -2
  122. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-review.cjs.map +1 -1
  123. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-review.js +4 -4
  124. package/dist/molecules/curriculumV2/CurriculumContents/index.cjs.map +1 -1
  125. package/dist/molecules/curriculumV2/CurriculumContents/index.js +7 -7
  126. package/dist/molecules/curriculumV2/CurriculumSidebar/index.cjs +54 -17
  127. package/dist/molecules/curriculumV2/CurriculumSidebar/index.cjs.map +1 -1
  128. package/dist/molecules/curriculumV2/CurriculumSidebar/index.js +2 -2
  129. package/dist/molecules/curriculumV2/curriculum-context.cjs +29 -21
  130. package/dist/molecules/curriculumV2/curriculum-context.cjs.map +1 -1
  131. package/dist/molecules/curriculumV2/curriculum-context.d.cts +7 -1
  132. package/dist/molecules/curriculumV2/curriculum-context.d.ts +7 -1
  133. package/dist/molecules/curriculumV2/curriculum-context.js +1 -1
  134. package/dist/molecules/curriculumV2/curriculum-sub-nav.cjs.map +1 -1
  135. package/dist/molecules/curriculumV2/curriculum-sub-nav.js +2 -2
  136. package/dist/molecules/curriculumV2/index.cjs +85 -38
  137. package/dist/molecules/curriculumV2/index.cjs.map +1 -1
  138. package/dist/molecules/curriculumV2/index.js +16 -16
  139. package/dist/molecules/index.cjs +115 -68
  140. package/dist/molecules/index.cjs.map +1 -1
  141. package/dist/molecules/index.js +33 -33
  142. package/package.json +3 -3
  143. package/src/molecules/curriculumV2/CurriculumSidebar/index.tsx +47 -13
  144. package/src/molecules/curriculumV2/curriculum-context.tsx +62 -39
@@ -0,0 +1,152 @@
1
+ // src/molecules/curriculumV2/curriculum-context.tsx
2
+ import {
3
+ createContext,
4
+ useContext,
5
+ useState,
6
+ useMemo,
7
+ useCallback,
8
+ useRef,
9
+ useEffect
10
+ } from "react";
11
+ import { jsx } from "react/jsx-runtime";
12
+ var CurriculumContext = createContext(
13
+ void 0
14
+ );
15
+ function CurriculumProvider(props) {
16
+ const {
17
+ children,
18
+ curriculum,
19
+ onReviewSubmit,
20
+ onReviewValueChange,
21
+ curriculumReviewAnswers,
22
+ tempCurriculumReviewAnswers,
23
+ curriculumCompleteMap,
24
+ onChangeSelectedContent,
25
+ onActionButtonClick,
26
+ initialSelectedIndex
27
+ } = props;
28
+ const sidebarRef = useRef(null);
29
+ const scrollNavItem = useCallback((index) => {
30
+ var _a;
31
+ const element = (_a = sidebarRef.current) == null ? void 0 : _a.querySelector(
32
+ `[data-curriculum-item-index="${index}"]`
33
+ );
34
+ if (element) {
35
+ element.scrollIntoView({ behavior: "smooth", block: "start" });
36
+ }
37
+ }, []);
38
+ const list = curriculum.contents.list;
39
+ const selectableIndexes = useMemo(
40
+ () => list.map((item, i) => item.type !== "sectionTitle" ? i : null).filter((i) => i !== null),
41
+ [list]
42
+ );
43
+ const [selectedIndexState, setSelectedIndexState] = useState(
44
+ initialSelectedIndex != null ? initialSelectedIndex : selectableIndexes[0]
45
+ );
46
+ const setSelectedIndex = useCallback(
47
+ (idx) => {
48
+ if (selectableIndexes.includes(idx)) {
49
+ setSelectedIndexState(idx);
50
+ } else {
51
+ const next = selectableIndexes.find((i) => i > idx);
52
+ const prev = [...selectableIndexes].reverse().find((i) => i < idx);
53
+ if (next !== void 0) setSelectedIndexState(next);
54
+ else if (prev !== void 0) setSelectedIndexState(prev);
55
+ }
56
+ },
57
+ [selectableIndexes]
58
+ );
59
+ const selectablePos = useMemo(
60
+ () => selectableIndexes.indexOf(selectedIndexState),
61
+ [selectableIndexes, selectedIndexState]
62
+ );
63
+ const hasPrev = selectablePos > 0;
64
+ const hasNext = selectablePos < selectableIndexes.length - 1;
65
+ const selectPrev = useCallback(
66
+ (cb) => {
67
+ setSelectedIndexState((cur) => {
68
+ let prevIndex = cur;
69
+ const pos = selectableIndexes.indexOf(cur);
70
+ if (pos > 0) {
71
+ prevIndex = selectableIndexes[pos - 1];
72
+ }
73
+ if (cb) cb(prevIndex);
74
+ return prevIndex;
75
+ });
76
+ },
77
+ [selectableIndexes]
78
+ );
79
+ const selectNext = useCallback(
80
+ (cb) => {
81
+ setSelectedIndexState((cur) => {
82
+ let nextIndex = cur;
83
+ const pos = selectableIndexes.indexOf(cur);
84
+ if (pos < selectableIndexes.length - 1) {
85
+ nextIndex = selectableIndexes[pos + 1];
86
+ }
87
+ if (cb) cb(nextIndex);
88
+ return nextIndex;
89
+ });
90
+ },
91
+ [selectableIndexes]
92
+ );
93
+ const selectedId = useMemo(
94
+ () => {
95
+ var _a, _b;
96
+ return (_b = (_a = list[selectedIndexState]) == null ? void 0 : _a.uuid) != null ? _b : "";
97
+ },
98
+ [list, selectedIndexState]
99
+ );
100
+ const selectedItem = useMemo(() => {
101
+ return list[selectedIndexState];
102
+ }, [list, selectedIndexState]);
103
+ const selectedSectionTitle = useMemo(() => {
104
+ var _a;
105
+ const prevItems = list.slice(0, selectedIndexState).reverse();
106
+ return (_a = prevItems.find((item) => item.type === "sectionTitle")) != null ? _a : null;
107
+ }, [list, selectedIndexState]);
108
+ useEffect(() => {
109
+ onChangeSelectedContent == null ? void 0 : onChangeSelectedContent(selectedItem);
110
+ }, [selectedItem]);
111
+ return /* @__PURE__ */ jsx(
112
+ CurriculumContext.Provider,
113
+ {
114
+ value: {
115
+ curriculum,
116
+ scrollNavItem,
117
+ selectedIndex: selectedIndexState,
118
+ setSelectedIndex,
119
+ selectedId,
120
+ hasPrev,
121
+ hasNext,
122
+ selectPrev,
123
+ selectNext,
124
+ selectedSectionTitle,
125
+ selectedItem,
126
+ scrollAreaRef: sidebarRef,
127
+ onReviewSubmit,
128
+ onReviewValueChange,
129
+ curriculumReviewAnswers,
130
+ tempCurriculumReviewAnswers,
131
+ curriculumCompleteMap,
132
+ onActionButtonClick,
133
+ customTabs
134
+ },
135
+ children
136
+ }
137
+ );
138
+ }
139
+ function useCurriculumContext() {
140
+ const ctx = useContext(CurriculumContext);
141
+ if (!ctx)
142
+ throw new Error(
143
+ "useCurriculumContext must be used within CurriculumProvider"
144
+ );
145
+ return ctx;
146
+ }
147
+
148
+ export {
149
+ CurriculumProvider,
150
+ useCurriculumContext
151
+ };
152
+ //# sourceMappingURL=chunk-NMGLSEZ3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/curriculum-context.tsx"],"sourcesContent":["import React, {\n createContext,\n useContext,\n useState,\n useMemo,\n useCallback,\n useRef,\n useEffect,\n} from 'react';\nimport { type CurriculumSectionTitleContents } from '@/types/curriculumContents.type';\nimport type {\n Curriculum,\n CurriculumListContents,\n} from '@/types/curriculum.type';\n\nexport interface CurriculumContextValue {\n curriculum: Curriculum;\n selectedIndex: number;\n setSelectedIndex: (idx: number) => void;\n selectedId: string;\n hasPrev: boolean;\n hasNext: boolean;\n selectPrev: (cb?: (moveIndex: number) => void) => void;\n selectNext: (cb?: (moveIndex: number) => void) => void;\n selectedItem: CurriculumListContents;\n /** 선택된 아이템의 이전 아이템 중 가장 가까운 섹션 타이틀 */\n selectedSectionTitle: CurriculumSectionTitleContents | null;\n /** 컨텐츠 목록 스크롤 이동 함수 */\n scrollNavItem: (uuid: string) => void;\n /** 스크롤 영역 참조 */\n scrollAreaRef: React.RefObject<HTMLDivElement | null>;\n /** 리뷰 제출 함수 */\n onReviewSubmit: ({\n reviewId,\n answer,\n }: {\n reviewId: string;\n answer: Record<string, string>;\n }) => Promise<boolean>;\n /** 리뷰 응답 값 변경 시 호출 */\n onReviewValueChange: ({\n reviewId,\n answer,\n }: {\n reviewId: string;\n answer: Record<string, string>;\n }) => void;\n /** 과제 완료 후 저장된 값 */\n curriculumReviewAnswers: Record<string, string>;\n /** 과제 완료 전 임시 저장된 값 */\n tempCurriculumReviewAnswers: Record<string, string>;\n /** 항목 수강 완료 여부 */\n curriculumCompleteMap: Record<string, boolean>;\n /** action Button 클릭시 호출 */\n onActionButtonClick: (item: CurriculumListContents) => void;\n /** 초기 선택 인덱스 */\n initialSelectedIndex?: number;\n /** 커스텀 탭 주입값 */\n customTabs?: {\n content: React.ReactElement;\n label: string;\n value: string;\n }[];\n}\n\nconst CurriculumContext = createContext<CurriculumContextValue | undefined>(\n undefined\n);\n\nexport interface CurriculumProviderProps\n extends Pick<\n CurriculumContextValue,\n | 'customTabs'\n | 'curriculum'\n | 'onReviewSubmit'\n | 'onReviewValueChange'\n | 'curriculumReviewAnswers'\n | 'tempCurriculumReviewAnswers'\n | 'curriculumCompleteMap'\n | 'onActionButtonClick'\n | 'initialSelectedIndex'\n > {\n children: React.ReactNode;\n onReviewValueChange: ({\n reviewId,\n answer,\n }: {\n reviewId: string;\n answer: Record<string, string>;\n }) => void;\n\n /** 현재 화면에 표시 중인 컨텐츠 인덱스 변경 시 호출 */\n onChangeSelectedContent?: (item: CurriculumListContents) => void;\n}\n\nexport function CurriculumProvider(\n props: CurriculumProviderProps\n): React.ReactElement {\n const {\n children,\n curriculum,\n onReviewSubmit,\n onReviewValueChange,\n curriculumReviewAnswers,\n tempCurriculumReviewAnswers,\n curriculumCompleteMap,\n onChangeSelectedContent,\n onActionButtonClick,\n initialSelectedIndex,\n } = props;\n const sidebarRef = useRef<HTMLDivElement>(null);\n\n const scrollNavItem = useCallback((index: string) => {\n const element = sidebarRef.current?.querySelector(\n `[data-curriculum-item-index=\"${index}\"]`\n );\n if (element) {\n element.scrollIntoView({ behavior: 'smooth', block: 'start' });\n }\n }, []);\n\n const list = curriculum.contents.list;\n // 선택 가능한 인덱스만 추출\n const selectableIndexes = useMemo(\n () =>\n list\n .map((item, i) => (item.type !== 'sectionTitle' ? i : null))\n .filter((i): i is number => i !== null),\n [list]\n );\n // 최초 선택값: 첫 번째 선택 가능한 인덱스\n const [selectedIndexState, setSelectedIndexState] = useState<number>(\n initialSelectedIndex ?? selectableIndexes[0]\n );\n\n // 선택 인덱스 보정 함수\n const setSelectedIndex = useCallback(\n (idx: number) => {\n if (selectableIndexes.includes(idx)) {\n setSelectedIndexState(idx);\n } else {\n // idx가 선택 불가면, selectableIndexes에서 가장 가까운 다음 인덱스 선택\n const next = selectableIndexes.find((i) => i > idx);\n const prev = [...selectableIndexes].reverse().find((i) => i < idx);\n if (next !== undefined) setSelectedIndexState(next);\n else if (prev !== undefined) setSelectedIndexState(prev);\n }\n },\n [selectableIndexes]\n );\n\n // 현재 선택 인덱스가 selectableIndexes 내 몇 번째인지\n const selectablePos = useMemo(\n () => selectableIndexes.indexOf(selectedIndexState),\n [selectableIndexes, selectedIndexState]\n );\n const hasPrev = selectablePos > 0;\n const hasNext = selectablePos < selectableIndexes.length - 1;\n\n const selectPrev = useCallback(\n (cb?: (moveIndex: number) => void) => {\n setSelectedIndexState((cur) => {\n let prevIndex = cur;\n const pos = selectableIndexes.indexOf(cur);\n if (pos > 0) {\n prevIndex = selectableIndexes[pos - 1];\n }\n if (cb) cb(prevIndex);\n return prevIndex;\n });\n },\n [selectableIndexes]\n );\n const selectNext = useCallback(\n (cb?: (moveIndex: number) => void) => {\n setSelectedIndexState((cur) => {\n let nextIndex = cur;\n const pos = selectableIndexes.indexOf(cur);\n if (pos < selectableIndexes.length - 1) {\n nextIndex = selectableIndexes[pos + 1];\n }\n if (cb) cb(nextIndex);\n return nextIndex;\n });\n },\n [selectableIndexes]\n );\n\n const selectedId = useMemo(\n () => list[selectedIndexState]?.uuid ?? '',\n [list, selectedIndexState]\n );\n\n const selectedItem = useMemo(() => {\n return list[selectedIndexState];\n }, [list, selectedIndexState]);\n\n const selectedSectionTitle = useMemo(() => {\n // selectedIndexState 이전 인덱스 중 가장 가까운 섹션 타이틀 찾기\n const prevItems = list.slice(0, selectedIndexState).reverse();\n return prevItems.find((item) => item.type === 'sectionTitle') ?? null;\n }, [list, selectedIndexState]);\n\n useEffect(() => {\n onChangeSelectedContent?.(selectedItem);\n // eslint-disable-next-line react-hooks/exhaustive-deps -- 트리거 최소화\n }, [selectedItem]);\n\n return (\n <CurriculumContext.Provider\n value={{\n curriculum,\n scrollNavItem,\n selectedIndex: selectedIndexState,\n setSelectedIndex,\n selectedId,\n hasPrev,\n hasNext,\n selectPrev,\n selectNext,\n selectedSectionTitle,\n selectedItem,\n scrollAreaRef: sidebarRef,\n onReviewSubmit,\n onReviewValueChange,\n curriculumReviewAnswers,\n tempCurriculumReviewAnswers,\n curriculumCompleteMap,\n onActionButtonClick,\n customTabs,\n }}\n >\n {children}\n </CurriculumContext.Provider>\n );\n}\n\nexport function useCurriculumContext(): CurriculumContextValue {\n const ctx = useContext(CurriculumContext);\n if (!ctx)\n throw new Error(\n 'useCurriculumContext must be used within CurriculumProvider'\n );\n return ctx;\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,63 @@
1
+ import {
2
+ review_question_body_default
3
+ } from "./chunk-J5IKAPJM.js";
4
+ import {
5
+ review_question_footer_default
6
+ } from "./chunk-PLXD7ZKF.js";
7
+ import {
8
+ review_question_header_default
9
+ } from "./chunk-SAEPW5JF.js";
10
+ import {
11
+ review_question_layout_default
12
+ } from "./chunk-VK6INFSB.js";
13
+
14
+ // src/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/index.tsx
15
+ import { jsx } from "react/jsx-runtime";
16
+ function ReviewQuestion({
17
+ question,
18
+ index,
19
+ total,
20
+ answer,
21
+ error,
22
+ onChange,
23
+ onNext,
24
+ onPrev,
25
+ isLast,
26
+ isNextDisabled,
27
+ onSubmit,
28
+ isLoading
29
+ }) {
30
+ return /* @__PURE__ */ jsx(
31
+ review_question_layout_default,
32
+ {
33
+ Body: /* @__PURE__ */ jsx(
34
+ review_question_body_default,
35
+ {
36
+ answer,
37
+ error,
38
+ onChange,
39
+ question
40
+ }
41
+ ),
42
+ Footer: /* @__PURE__ */ jsx(
43
+ review_question_footer_default,
44
+ {
45
+ index,
46
+ isLast,
47
+ isLoading,
48
+ isNextButtonDisabled: isNextDisabled,
49
+ onNext,
50
+ onPrev,
51
+ onSubmit
52
+ }
53
+ ),
54
+ Header: /* @__PURE__ */ jsx(review_question_header_default, { index, total })
55
+ }
56
+ );
57
+ }
58
+ var ReviewQuestion_default = ReviewQuestion;
59
+
60
+ export {
61
+ ReviewQuestion_default
62
+ };
63
+ //# sourceMappingURL=chunk-NMKIFFKE.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/index.tsx"],"sourcesContent":["import React from 'react';\nimport type { ReviewQuestionElement } from '@/types/curriculum.type';\nimport ReviewQuestionLayout from './review-question-layout';\nimport ReviewQuestionHeader from './review-question-header';\nimport ReviewQuestionFooter from './review-question-footer';\nimport ReviewQuestionBody from './review-question-body';\n\ninterface ReviewQuestionProps {\n question: ReviewQuestionElement;\n index: number;\n total: number;\n answer: string;\n error?: string;\n onChange: (value: string) => void;\n onNext: () => void;\n onPrev: () => void;\n isLast: boolean;\n isNextDisabled?: boolean;\n onSubmit: () => void;\n isLoading?: boolean;\n}\n\nfunction ReviewQuestion({\n question,\n index,\n total,\n answer,\n error,\n onChange,\n onNext,\n onPrev,\n isLast,\n isNextDisabled,\n onSubmit,\n isLoading,\n}: ReviewQuestionProps): React.ReactElement {\n \n return (\n <ReviewQuestionLayout\n Body={\n <ReviewQuestionBody\n answer={answer}\n error={error}\n onChange={onChange}\n question={question}\n />\n }\n Footer={\n <ReviewQuestionFooter\n index={index}\n isLast={isLast}\n isLoading={isLoading}\n isNextButtonDisabled={isNextDisabled}\n onNext={onNext}\n onPrev={onPrev}\n onSubmit={onSubmit}\n />\n }\n Header={<ReviewQuestionHeader index={index} total={total} />}\n />\n );\n}\n\nexport default ReviewQuestion;\n"],"mappings":";;;;;;;;;;;;;;AAwCQ;AAlBR,SAAS,eAAe;AAAA,EACtB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA4C;AAE1C,SACE;AAAA,IAAC;AAAA;AAAA,MACC,MACE;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA;AAAA,MACF;AAAA,MAEF,QACE;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA,sBAAsB;AAAA,UACtB;AAAA,UACA;AAAA,UACA;AAAA;AAAA,MACF;AAAA,MAEF,QAAQ,oBAAC,kCAAqB,OAAc,OAAc;AAAA;AAAA,EAC5D;AAEJ;AAEA,IAAO,yBAAQ;","names":[]}
@@ -0,0 +1,82 @@
1
+ import {
2
+ sidebar_item_default
3
+ } from "./chunk-4HDV26QV.js";
4
+ import {
5
+ useCurriculumContext
6
+ } from "./chunk-3OCAVV5Z.js";
7
+ import {
8
+ Tabs
9
+ } from "./chunk-5ZITU5L7.js";
10
+ import {
11
+ Grid
12
+ } from "./chunk-EGEQY3KT.js";
13
+ import {
14
+ Box
15
+ } from "./chunk-4Y5BEXVN.js";
16
+
17
+ // src/molecules/curriculumV2/CurriculumSidebar/index.tsx
18
+ import { useMemo } from "react";
19
+ import { jsx, jsxs } from "react/jsx-runtime";
20
+ var TAB_LIST = [
21
+ {
22
+ label: "\uAC15\uC758 \uBAA9\uCC28",
23
+ value: "curriculum"
24
+ }
25
+ ];
26
+ function CurriculumSidebar() {
27
+ const {
28
+ curriculum,
29
+ selectedIndex,
30
+ setSelectedIndex,
31
+ scrollAreaRef,
32
+ curriculumCompleteMap,
33
+ customTabs
34
+ } = useCurriculumContext();
35
+ const list = curriculum.contents.list;
36
+ const tabList = useMemo(() => {
37
+ return [...TAB_LIST, ...customTabs != null ? customTabs : []];
38
+ }, [customTabs]);
39
+ return /* @__PURE__ */ jsx(Tabs.Root, { asChild: true, defaultValue: TAB_LIST[0].value, children: /* @__PURE__ */ jsxs(Grid, { height: "100%", overflowY: "auto", rows: "auto 1fr ", width: "100%", children: [
40
+ /* @__PURE__ */ jsx(Tabs.List, { style: { padding: "0 var(--space-3)" }, children: tabList.map((tab) => /* @__PURE__ */ jsx(Tabs.Trigger, { value: tab.value, children: tab.label }, tab.value)) }),
41
+ /* @__PURE__ */ jsx(
42
+ Box,
43
+ {
44
+ height: "100%",
45
+ overflowY: "auto",
46
+ position: "relative",
47
+ ref: scrollAreaRef,
48
+ width: "100%",
49
+ children: /* @__PURE__ */ jsxs(
50
+ Tabs.Content,
51
+ {
52
+ style: {
53
+ position: "absolute",
54
+ height: "100%",
55
+ width: "100%"
56
+ },
57
+ value: TAB_LIST[0].value,
58
+ children: [
59
+ list.map((item, index) => /* @__PURE__ */ jsx(
60
+ sidebar_item_default,
61
+ {
62
+ done: curriculumCompleteMap[item.uuid],
63
+ index,
64
+ item,
65
+ selectedIndex,
66
+ setSelectedIndex
67
+ },
68
+ item.uuid
69
+ )),
70
+ /* @__PURE__ */ jsx(Box, { height: "150px" })
71
+ ]
72
+ }
73
+ )
74
+ }
75
+ )
76
+ ] }) });
77
+ }
78
+
79
+ export {
80
+ CurriculumSidebar
81
+ };
82
+ //# sourceMappingURL=chunk-OX4OPOPI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/CurriculumSidebar/index.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport { Box } from '@/atoms/box';\nimport { Grid } from '@/atoms/grid';\nimport { Tabs } from '@/atoms/tabs';\nimport { useCurriculumContext } from '../curriculum-context';\nimport SidebarItem from './sidebar-item';\n\nconst TAB_LIST = [\n {\n label: '강의 목차',\n value: 'curriculum',\n },\n];\n\nexport function CurriculumSidebar(): React.ReactNode {\n const {\n curriculum,\n selectedIndex,\n setSelectedIndex,\n scrollAreaRef,\n curriculumCompleteMap,\n customTabs,\n } = useCurriculumContext();\n const list = curriculum.contents.list;\n\n const tabList = useMemo(() => {\n return [...TAB_LIST, ...(customTabs ?? [])];\n }, [customTabs]);\n\n return (\n <Tabs.Root asChild defaultValue={TAB_LIST[0].value}>\n <Grid height=\"100%\" overflowY=\"auto\" rows=\"auto 1fr \" width=\"100%\">\n <Tabs.List style={{ padding: '0 var(--space-3)' }}>\n {tabList.map((tab) => (\n <Tabs.Trigger key={tab.value} value={tab.value}>\n {tab.label}\n </Tabs.Trigger>\n ))}\n </Tabs.List>\n <Box\n height=\"100%\"\n overflowY=\"auto\"\n position=\"relative\"\n ref={scrollAreaRef}\n width=\"100%\"\n >\n <Tabs.Content\n style={{\n position: 'absolute',\n height: '100%',\n width: '100%',\n }}\n value={TAB_LIST[0].value}\n >\n {list.map((item, index) => (\n <SidebarItem\n done={curriculumCompleteMap[item.uuid]}\n index={index}\n item={item}\n key={item.uuid}\n selectedIndex={selectedIndex}\n setSelectedIndex={setSelectedIndex}\n />\n ))}\n <Box height=\"150px\" />\n </Tabs.Content>\n </Box>\n </Grid>\n </Tabs.Root>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAkCnB,cAYF,YAZE;AA3BZ,IAAM,WAAW;AAAA,EACf;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,EACT;AACF;AAEO,SAAS,oBAAqC;AACnD,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,qBAAqB;AACzB,QAAM,OAAO,WAAW,SAAS;AAEjC,QAAM,UAAU,QAAQ,MAAM;AAC5B,WAAO,CAAC,GAAG,UAAU,GAAI,kCAAc,CAAC,CAAE;AAAA,EAC5C,GAAG,CAAC,UAAU,CAAC;AAEf,SACE,oBAAC,KAAK,MAAL,EAAU,SAAO,MAAC,cAAc,SAAS,CAAC,EAAE,OAC3C,+BAAC,QAAK,QAAO,QAAO,WAAU,QAAO,MAAK,aAAY,OAAM,QAC1D;AAAA,wBAAC,KAAK,MAAL,EAAU,OAAO,EAAE,SAAS,mBAAmB,GAC7C,kBAAQ,IAAI,CAAC,QACZ,oBAAC,KAAK,SAAL,EAA6B,OAAO,IAAI,OACtC,cAAI,SADY,IAAI,KAEvB,CACD,GACH;AAAA,IACA;AAAA,MAAC;AAAA;AAAA,QACC,QAAO;AAAA,QACP,WAAU;AAAA,QACV,UAAS;AAAA,QACT,KAAK;AAAA,QACL,OAAM;AAAA,QAEN;AAAA,UAAC,KAAK;AAAA,UAAL;AAAA,YACC,OAAO;AAAA,cACL,UAAU;AAAA,cACV,QAAQ;AAAA,cACR,OAAO;AAAA,YACT;AAAA,YACA,OAAO,SAAS,CAAC,EAAE;AAAA,YAElB;AAAA,mBAAK,IAAI,CAAC,MAAM,UACf;AAAA,gBAAC;AAAA;AAAA,kBACC,MAAM,sBAAsB,KAAK,IAAI;AAAA,kBACrC;AAAA,kBACA;AAAA,kBAEA;AAAA,kBACA;AAAA;AAAA,gBAFK,KAAK;AAAA,cAGZ,CACD;AAAA,cACD,oBAAC,OAAI,QAAO,SAAQ;AAAA;AAAA;AAAA,QACtB;AAAA;AAAA,IACF;AAAA,KACF,GACF;AAEJ;","names":[]}
@@ -0,0 +1,77 @@
1
+ import {
2
+ sidebar_item_default
3
+ } from "./chunk-4HDV26QV.js";
4
+ import {
5
+ useCurriculumContext
6
+ } from "./chunk-IYQJIEVM.js";
7
+ import {
8
+ Tabs
9
+ } from "./chunk-5ZITU5L7.js";
10
+ import {
11
+ Grid
12
+ } from "./chunk-EGEQY3KT.js";
13
+ import {
14
+ Box
15
+ } from "./chunk-4Y5BEXVN.js";
16
+
17
+ // src/molecules/curriculumV2/CurriculumSidebar/index.tsx
18
+ import { jsx, jsxs } from "react/jsx-runtime";
19
+ var TAB_LIST = [
20
+ {
21
+ label: "\uAC15\uC758 \uBAA9\uCC28",
22
+ value: "curriculum"
23
+ }
24
+ ];
25
+ function CurriculumSidebar(props) {
26
+ const {
27
+ curriculum,
28
+ selectedIndex,
29
+ setSelectedIndex,
30
+ scrollAreaRef,
31
+ curriculumCompleteMap
32
+ } = useCurriculumContext();
33
+ const list = curriculum.contents.list;
34
+ return /* @__PURE__ */ jsx(Tabs.Root, { asChild: true, defaultValue: TAB_LIST[0].value, children: /* @__PURE__ */ jsxs(Grid, { height: "100%", overflowY: "auto", rows: "auto 1fr ", width: "100%", children: [
35
+ /* @__PURE__ */ jsx(Tabs.List, { style: { padding: "0 var(--space-3)" }, children: TAB_LIST.map((tab) => /* @__PURE__ */ jsx(Tabs.Trigger, { value: tab.value, children: tab.label }, tab.value)) }),
36
+ /* @__PURE__ */ jsx(
37
+ Box,
38
+ {
39
+ height: "100%",
40
+ overflowY: "auto",
41
+ position: "relative",
42
+ ref: scrollAreaRef,
43
+ width: "100%",
44
+ children: /* @__PURE__ */ jsxs(
45
+ Tabs.Content,
46
+ {
47
+ style: {
48
+ position: "absolute",
49
+ height: "100%",
50
+ width: "100%"
51
+ },
52
+ value: TAB_LIST[0].value,
53
+ children: [
54
+ list.map((item, index) => /* @__PURE__ */ jsx(
55
+ sidebar_item_default,
56
+ {
57
+ done: curriculumCompleteMap[item.uuid],
58
+ index,
59
+ item,
60
+ selectedIndex,
61
+ setSelectedIndex
62
+ },
63
+ item.uuid
64
+ )),
65
+ /* @__PURE__ */ jsx(Box, { height: "150px" })
66
+ ]
67
+ }
68
+ )
69
+ }
70
+ )
71
+ ] }) });
72
+ }
73
+
74
+ export {
75
+ CurriculumSidebar
76
+ };
77
+ //# sourceMappingURL=chunk-POFUBAXM.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/CurriculumSidebar/index.tsx"],"sourcesContent":["import React from 'react';\nimport { Box } from '@/atoms/box';\nimport { Grid } from '@/atoms/grid';\nimport { Tabs } from '@/atoms/tabs';\nimport { useCurriculumContext } from '../curriculum-context';\nimport SidebarItem from './sidebar-item';\n\nconst TAB_LIST = [\n {\n label: '강의 목차',\n value: 'curriculum',\n },\n];\n\nexport function CurriculumSidebar(props: {\n customTab?: {\n content: React.ReactElement;\n label: string;\n value: string;\n }[];\n}): React.ReactNode {\n const {\n curriculum,\n selectedIndex,\n setSelectedIndex,\n scrollAreaRef,\n curriculumCompleteMap,\n } = useCurriculumContext();\n const list = curriculum.contents.list;\n\n return (\n <Tabs.Root asChild defaultValue={TAB_LIST[0].value}>\n <Grid height=\"100%\" overflowY=\"auto\" rows=\"auto 1fr \" width=\"100%\">\n <Tabs.List style={{ padding: '0 var(--space-3)' }}>\n {TAB_LIST.map((tab) => (\n <Tabs.Trigger key={tab.value} value={tab.value}>\n {tab.label}\n </Tabs.Trigger>\n ))}\n </Tabs.List>\n <Box\n height=\"100%\"\n overflowY=\"auto\"\n position=\"relative\"\n ref={scrollAreaRef}\n width=\"100%\"\n >\n <Tabs.Content\n style={{\n position: 'absolute',\n height: '100%',\n width: '100%',\n }}\n value={TAB_LIST[0].value}\n >\n {list.map((item, index) => (\n <SidebarItem\n done={curriculumCompleteMap[item.uuid]}\n index={index}\n item={item}\n key={item.uuid}\n selectedIndex={selectedIndex}\n setSelectedIndex={setSelectedIndex}\n />\n ))}\n <Box height=\"150px\" />\n </Tabs.Content>\n </Box>\n </Grid>\n </Tabs.Root>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAmCY,cAYF,YAZE;AA5BZ,IAAM,WAAW;AAAA,EACf;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,EACT;AACF;AAEO,SAAS,kBAAkB,OAMd;AAClB,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,qBAAqB;AACzB,QAAM,OAAO,WAAW,SAAS;AAEjC,SACE,oBAAC,KAAK,MAAL,EAAU,SAAO,MAAC,cAAc,SAAS,CAAC,EAAE,OAC3C,+BAAC,QAAK,QAAO,QAAO,WAAU,QAAO,MAAK,aAAY,OAAM,QAC1D;AAAA,wBAAC,KAAK,MAAL,EAAU,OAAO,EAAE,SAAS,mBAAmB,GAC7C,mBAAS,IAAI,CAAC,QACb,oBAAC,KAAK,SAAL,EAA6B,OAAO,IAAI,OACtC,cAAI,SADY,IAAI,KAEvB,CACD,GACH;AAAA,IACA;AAAA,MAAC;AAAA;AAAA,QACC,QAAO;AAAA,QACP,WAAU;AAAA,QACV,UAAS;AAAA,QACT,KAAK;AAAA,QACL,OAAM;AAAA,QAEN;AAAA,UAAC,KAAK;AAAA,UAAL;AAAA,YACC,OAAO;AAAA,cACL,UAAU;AAAA,cACV,QAAQ;AAAA,cACR,OAAO;AAAA,YACT;AAAA,YACA,OAAO,SAAS,CAAC,EAAE;AAAA,YAElB;AAAA,mBAAK,IAAI,CAAC,MAAM,UACf;AAAA,gBAAC;AAAA;AAAA,kBACC,MAAM,sBAAsB,KAAK,IAAI;AAAA,kBACrC;AAAA,kBACA;AAAA,kBAEA;AAAA,kBACA;AAAA;AAAA,gBAFK,KAAK;AAAA,cAGZ,CACD;AAAA,cACD,oBAAC,OAAI,QAAO,SAAQ;AAAA;AAAA;AAAA,QACtB;AAAA;AAAA,IACF;AAAA,KACF,GACF;AAEJ;","names":[]}
@@ -0,0 +1,70 @@
1
+ import {
2
+ useCurriculumContext
3
+ } from "./chunk-3OCAVV5Z.js";
4
+ import {
5
+ Typo
6
+ } from "./chunk-PMJIFLDT.js";
7
+ import {
8
+ Flex
9
+ } from "./chunk-25HMMI7R.js";
10
+ import {
11
+ Button
12
+ } from "./chunk-ZVDAEY5Q.js";
13
+ import {
14
+ ResetIcon
15
+ } from "./chunk-W5TPOFOO.js";
16
+
17
+ // src/molecules/curriculumV2/CurriculumContents/curriculum-ai-traning.tsx
18
+ import { useMemo } from "react";
19
+ import { jsx, jsxs } from "react/jsx-runtime";
20
+ function CurriculumAiTraning({
21
+ item
22
+ }) {
23
+ const { title, description, buttonTitle } = item;
24
+ const { curriculumCompleteMap, onActionButtonClick } = useCurriculumContext();
25
+ const done = useMemo(() => {
26
+ return Boolean(curriculumCompleteMap[item.uuid]);
27
+ }, [curriculumCompleteMap, item.uuid]);
28
+ const bgColor = done ? "var(--color-panel-solid)" : void 0;
29
+ return /* @__PURE__ */ jsxs(
30
+ Flex,
31
+ {
32
+ align: "center",
33
+ direction: "column",
34
+ height: "100%",
35
+ justify: "center",
36
+ style: {
37
+ backgroundImage: `url(https://tipp-coaching-live.s3.ap-northeast-2.amazonaws.com/images/curriculum_ai_bg.png)`,
38
+ backgroundPosition: "center",
39
+ backgroundSize: "cover",
40
+ backgroundRepeat: "no-repeat"
41
+ },
42
+ width: "100%",
43
+ children: [
44
+ /* @__PURE__ */ jsx(Typo, { color: "gray", weight: "bold", children: title }),
45
+ /* @__PURE__ */ jsx(Typo, { align: "center", as: "p", color: "gray", children: description }),
46
+ /* @__PURE__ */ jsxs(
47
+ Button,
48
+ {
49
+ mt: "3",
50
+ onClick: () => {
51
+ onActionButtonClick(item);
52
+ },
53
+ style: { minWidth: 232, backgroundColor: bgColor },
54
+ variant: done ? "outline" : "solid",
55
+ children: [
56
+ done ? "\uB2E4\uC2DC \uC5F0\uC2B5\uD558\uAE30" : buttonTitle || "\uC2DC\uC791\uD558\uAE30",
57
+ done ? /* @__PURE__ */ jsx(ResetIcon, {}) : null
58
+ ]
59
+ }
60
+ )
61
+ ]
62
+ }
63
+ );
64
+ }
65
+ var curriculum_ai_traning_default = CurriculumAiTraning;
66
+
67
+ export {
68
+ curriculum_ai_traning_default
69
+ };
70
+ //# sourceMappingURL=chunk-QBBF5V24.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/CurriculumContents/curriculum-ai-traning.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport type { CurriculumAiTrainingContents } from '@/types/curriculumContents.type';\nimport { Button } from '@/atoms/button';\nimport { Flex } from '@/atoms/flex';\nimport { Typo } from '@/atoms/typo';\nimport { ResetIcon } from '@/icon';\nimport { useCurriculumContext } from '../curriculum-context';\n\ninterface CurriculumAiTraningProps {\n item: CurriculumAiTrainingContents;\n}\n\nfunction CurriculumAiTraning({\n item,\n}: CurriculumAiTraningProps): React.ReactNode {\n const { title, description, buttonTitle } = item;\n const { curriculumCompleteMap, onActionButtonClick } = useCurriculumContext();\n\n const done = useMemo(() => {\n return Boolean(curriculumCompleteMap[item.uuid]);\n }, [curriculumCompleteMap, item.uuid]);\n\n const bgColor= done ? 'var(--color-panel-solid)' : undefined;\n\n return (\n <Flex\n align=\"center\"\n direction=\"column\"\n height=\"100%\"\n justify=\"center\"\n style={{\n backgroundImage: `url(https://tipp-coaching-live.s3.ap-northeast-2.amazonaws.com/images/curriculum_ai_bg.png)`,\n backgroundPosition: 'center',\n backgroundSize: 'cover',\n backgroundRepeat: 'no-repeat',\n }}\n width=\"100%\"\n >\n <Typo color=\"gray\" weight=\"bold\">\n {title}\n </Typo>\n <Typo align=\"center\" as=\"p\" color=\"gray\">\n {description}\n </Typo>\n\n <Button\n mt=\"3\"\n onClick={() => { onActionButtonClick(item); }}\n style={{ minWidth: 232, backgroundColor: bgColor }}\n variant={done ? 'outline' : 'solid'}\n >\n {done ? '다시 연습하기' : buttonTitle || '시작하기'}\n {done ? <ResetIcon/> : null}\n </Button>\n \n </Flex>\n );\n}\n\nexport default CurriculumAiTraning;\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAsCzB,cAOA,YAPA;AA1BN,SAAS,oBAAoB;AAAA,EAC3B;AACF,GAA8C;AAC5C,QAAM,EAAE,OAAO,aAAa,YAAY,IAAI;AAC5C,QAAM,EAAE,uBAAuB,oBAAoB,IAAI,qBAAqB;AAE5E,QAAM,OAAO,QAAQ,MAAM;AACzB,WAAO,QAAQ,sBAAsB,KAAK,IAAI,CAAC;AAAA,EACjD,GAAG,CAAC,uBAAuB,KAAK,IAAI,CAAC;AAErC,QAAM,UAAU,OAAO,6BAA6B;AAEpD,SACE;AAAA,IAAC;AAAA;AAAA,MACC,OAAM;AAAA,MACN,WAAU;AAAA,MACV,QAAO;AAAA,MACP,SAAQ;AAAA,MACR,OAAO;AAAA,QACL,iBAAiB;AAAA,QACjB,oBAAoB;AAAA,QACpB,gBAAgB;AAAA,QAChB,kBAAkB;AAAA,MACpB;AAAA,MACA,OAAM;AAAA,MAEN;AAAA,4BAAC,QAAK,OAAM,QAAO,QAAO,QACvB,iBACH;AAAA,QACA,oBAAC,QAAK,OAAM,UAAS,IAAG,KAAI,OAAM,QAC/B,uBACH;AAAA,QAEA;AAAA,UAAC;AAAA;AAAA,YACC,IAAG;AAAA,YACH,SAAS,MAAM;AAAE,kCAAoB,IAAI;AAAA,YAAG;AAAA,YAC5C,OAAO,EAAE,UAAU,KAAK,iBAAiB,QAAQ;AAAA,YACjD,SAAS,OAAO,YAAY;AAAA,YAE3B;AAAA,qBAAO,0CAAY,eAAe;AAAA,cAClC,OAAO,oBAAC,aAAS,IAAK;AAAA;AAAA;AAAA,QACzB;AAAA;AAAA;AAAA,EAEF;AAEJ;AAEA,IAAO,gCAAQ;","names":[]}
@@ -0,0 +1,87 @@
1
+ import {
2
+ ReviewQuestionContentHeader
3
+ } from "./chunk-7UUHYDMJ.js";
4
+ import {
5
+ TextArea
6
+ } from "./chunk-5XYPLDI5.js";
7
+ import {
8
+ Grid
9
+ } from "./chunk-EGEQY3KT.js";
10
+ import {
11
+ Box
12
+ } from "./chunk-4Y5BEXVN.js";
13
+ import {
14
+ Typo
15
+ } from "./chunk-PMJIFLDT.js";
16
+ import {
17
+ Callout
18
+ } from "./chunk-B6XJN6EC.js";
19
+ import {
20
+ Card
21
+ } from "./chunk-RP2RGCAW.js";
22
+ import {
23
+ BellIcon
24
+ } from "./chunk-W5TPOFOO.js";
25
+
26
+ // src/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-text.tsx
27
+ import { jsx, jsxs } from "react/jsx-runtime";
28
+ function ReviewQuestionText(props) {
29
+ const { question, answer, onChange } = props;
30
+ const minLengthNotMet = question.minLength && answer.length < question.minLength;
31
+ const remainingLength = question.minLength && answer.length < question.minLength ? question.minLength - answer.length : 0;
32
+ return /* @__PURE__ */ jsx(
33
+ Card,
34
+ {
35
+ size: "2",
36
+ style: {
37
+ width: "100%",
38
+ height: "100%"
39
+ },
40
+ children: /* @__PURE__ */ jsxs(Grid, { height: "100%", rows: "1fr auto", children: [
41
+ /* @__PURE__ */ jsxs(Grid, { height: "100%", rows: "auto 1fr", width: "100%", children: [
42
+ /* @__PURE__ */ jsx(
43
+ ReviewQuestionContentHeader,
44
+ {
45
+ icon: question.icon,
46
+ question: question.question,
47
+ title: question.title,
48
+ type: question.type
49
+ }
50
+ ),
51
+ /* @__PURE__ */ jsx(
52
+ TextArea,
53
+ {
54
+ mt: "2",
55
+ onChange: (e) => {
56
+ onChange(e.target.value);
57
+ },
58
+ placeholder: question.placeholder,
59
+ value: answer
60
+ }
61
+ )
62
+ ] }),
63
+ minLengthNotMet ? /* @__PURE__ */ jsxs(Box, { mt: "2", children: [
64
+ /* @__PURE__ */ jsx(Typo, { align: "right", as: "p", color: "red", variant: "caption", children: `${remainingLength}\uC790 \uB354 \uC791\uC131\uD574\uC8FC\uC138\uC694.` }),
65
+ question.minLengthInfoMessage ? /* @__PURE__ */ jsxs(
66
+ Callout.Root,
67
+ {
68
+ color: "iris",
69
+ mt: "2",
70
+ style: { alignItems: "center" },
71
+ children: [
72
+ /* @__PURE__ */ jsx(Callout.Icon, { children: /* @__PURE__ */ jsx(BellIcon, {}) }),
73
+ /* @__PURE__ */ jsx(Callout.Text, { children: /* @__PURE__ */ jsx(Typo, { as: "p", variant: "caption", children: question.minLengthInfoMessage }) })
74
+ ]
75
+ }
76
+ ) : null
77
+ ] }) : null
78
+ ] })
79
+ }
80
+ );
81
+ }
82
+ var review_question_text_default = ReviewQuestionText;
83
+
84
+ export {
85
+ review_question_text_default
86
+ };
87
+ //# sourceMappingURL=chunk-QPTWBPAQ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-text.tsx"],"sourcesContent":["import React from 'react';\nimport { Box } from '@/atoms/box';\nimport { Card } from '@/atoms/card';\nimport { Grid } from '@/atoms/grid';\nimport { TextArea } from '@/atoms/text-area';\nimport { Typo } from '@/atoms/typo';\nimport { BellIcon } from '@/icon';\nimport { type CurriculumReviewQuestionText } from '@/types/curriculumContents.type';\nimport { Callout } from '@/atoms/call-out';\nimport { ReviewQuestionContentHeader } from './review-comp';\n\ninterface ReviewQuestionTextProps {\n question: CurriculumReviewQuestionText;\n answer: string;\n error?: string;\n onChange: (value: string) => void;\n}\n\nfunction ReviewQuestionText(props: ReviewQuestionTextProps): React.ReactNode {\n const { question, answer, onChange } = props;\n\n const minLengthNotMet =\n question.minLength && answer.length < question.minLength;\n\n const remainingLength =\n question.minLength && answer.length < question.minLength\n ? question.minLength - answer.length\n : 0;\n\n return (\n <Card\n size=\"2\"\n style={{\n width: '100%',\n height: '100%',\n }}\n >\n <Grid height=\"100%\" rows=\"1fr auto\">\n <Grid height=\"100%\" rows=\"auto 1fr\" width=\"100%\">\n <ReviewQuestionContentHeader\n icon={question.icon}\n question={question.question}\n title={question.title}\n type={question.type}\n />\n\n <TextArea\n mt=\"2\"\n onChange={(e) => {\n onChange(e.target.value);\n }}\n placeholder={question.placeholder}\n value={answer}\n />\n </Grid>\n {minLengthNotMet ? (\n <Box mt=\"2\">\n <Typo align=\"right\" as=\"p\" color=\"red\" variant=\"caption\">\n {`${remainingLength}자 더 작성해주세요.`}\n </Typo>\n {question.minLengthInfoMessage ? (\n <Callout.Root\n color=\"iris\"\n mt=\"2\"\n style={{ alignItems: 'center' }}\n >\n <Callout.Icon>\n <BellIcon />\n </Callout.Icon>\n <Callout.Text>\n <Typo as=\"p\" variant=\"caption\">\n {question.minLengthInfoMessage}\n </Typo>\n </Callout.Text>\n </Callout.Root>\n ) : null}\n </Box>\n ) : null}\n </Grid>\n </Card>\n );\n}\n\nexport default ReviewQuestionText;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAsCQ,SACE,KADF;AApBR,SAAS,mBAAmB,OAAiD;AAC3E,QAAM,EAAE,UAAU,QAAQ,SAAS,IAAI;AAEvC,QAAM,kBACJ,SAAS,aAAa,OAAO,SAAS,SAAS;AAEjD,QAAM,kBACJ,SAAS,aAAa,OAAO,SAAS,SAAS,YAC3C,SAAS,YAAY,OAAO,SAC5B;AAEN,SACE;AAAA,IAAC;AAAA;AAAA,MACC,MAAK;AAAA,MACL,OAAO;AAAA,QACL,OAAO;AAAA,QACP,QAAQ;AAAA,MACV;AAAA,MAEA,+BAAC,QAAK,QAAO,QAAO,MAAK,YACvB;AAAA,6BAAC,QAAK,QAAO,QAAO,MAAK,YAAW,OAAM,QACxC;AAAA;AAAA,YAAC;AAAA;AAAA,cACC,MAAM,SAAS;AAAA,cACf,UAAU,SAAS;AAAA,cACnB,OAAO,SAAS;AAAA,cAChB,MAAM,SAAS;AAAA;AAAA,UACjB;AAAA,UAEA;AAAA,YAAC;AAAA;AAAA,cACC,IAAG;AAAA,cACH,UAAU,CAAC,MAAM;AACf,yBAAS,EAAE,OAAO,KAAK;AAAA,cACzB;AAAA,cACA,aAAa,SAAS;AAAA,cACtB,OAAO;AAAA;AAAA,UACT;AAAA,WACF;AAAA,QACC,kBACC,qBAAC,OAAI,IAAG,KACN;AAAA,8BAAC,QAAK,OAAM,SAAQ,IAAG,KAAI,OAAM,OAAM,SAAQ,WAC5C,aAAG,eAAe,uDACrB;AAAA,UACC,SAAS,uBACR;AAAA,YAAC,QAAQ;AAAA,YAAR;AAAA,cACC,OAAM;AAAA,cACN,IAAG;AAAA,cACH,OAAO,EAAE,YAAY,SAAS;AAAA,cAE9B;AAAA,oCAAC,QAAQ,MAAR,EACC,8BAAC,YAAS,GACZ;AAAA,gBACA,oBAAC,QAAQ,MAAR,EACC,8BAAC,QAAK,IAAG,KAAI,SAAQ,WAClB,mBAAS,sBACZ,GACF;AAAA;AAAA;AAAA,UACF,IACE;AAAA,WACN,IACE;AAAA,SACN;AAAA;AAAA,EACF;AAEJ;AAEA,IAAO,+BAAQ;","names":[]}