@tipp/ui 2.3.6 → 2.3.8

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 (241) hide show
  1. package/dist/app/index.cjs.map +1 -1
  2. package/dist/app/index.js +85 -85
  3. package/dist/app/platform/coach-question-list.cjs.map +1 -1
  4. package/dist/app/platform/coach-question-list.js +32 -32
  5. package/dist/app/platform/contents-card.cjs.map +1 -1
  6. package/dist/app/platform/contents-card.js +32 -32
  7. package/dist/app/platform/curriculum-card.cjs.map +1 -1
  8. package/dist/app/platform/curriculum-card.js +6 -6
  9. package/dist/app/platform/edit-coaching-time.cjs.map +1 -1
  10. package/dist/app/platform/edit-coaching-time.js +69 -69
  11. package/dist/app/platform/edit-service-type.cjs.map +1 -1
  12. package/dist/app/platform/edit-service-type.js +70 -70
  13. package/dist/app/platform/goal-manage-card-edit.cjs.map +1 -1
  14. package/dist/app/platform/goal-manage-card-edit.js +69 -69
  15. package/dist/app/platform/goal-manage-card-read.cjs.map +1 -1
  16. package/dist/app/platform/goal-manage-card-read.js +32 -32
  17. package/dist/app/platform/on-offline-radio-card.cjs.map +1 -1
  18. package/dist/app/platform/on-offline-radio-card.js +69 -69
  19. package/dist/app/platform/report-card.cjs.map +1 -1
  20. package/dist/app/platform/report-card.js +32 -32
  21. package/dist/app/platform/reservation-card.cjs.map +1 -1
  22. package/dist/app/platform/reservation-card.js +70 -70
  23. package/dist/app/platform/session-card.cjs.map +1 -1
  24. package/dist/app/platform/session-card.js +72 -72
  25. package/dist/app/platform/session-review-simple-read.cjs.map +1 -1
  26. package/dist/app/platform/session-review-simple-read.js +32 -32
  27. package/dist/app/platform/userInfos/coaching-customer-info/index.cjs.map +1 -1
  28. package/dist/app/platform/userInfos/coaching-customer-info/index.js +35 -35
  29. package/dist/app/platform/userInfos/coaching-customer-info/large.cjs.map +1 -1
  30. package/dist/app/platform/userInfos/coaching-customer-info/large.js +32 -32
  31. package/dist/app/platform/userInfos/coaching-customer-info/medium.cjs.map +1 -1
  32. package/dist/app/platform/userInfos/coaching-customer-info/medium.js +32 -32
  33. package/dist/app/platform/userInfos/coaching-customer-info/small.cjs.map +1 -1
  34. package/dist/app/platform/userInfos/coaching-customer-info/small.js +32 -32
  35. package/dist/app/platform/userInfos/session-user-info-detail.cjs.map +1 -1
  36. package/dist/app/platform/userInfos/session-user-info-detail.js +32 -32
  37. package/dist/app/platform/userInfos/utils.cjs.map +1 -1
  38. package/dist/app/platform/userInfos/utils.js +31 -31
  39. package/dist/atoms/bullet-text.js +2 -2
  40. package/dist/atoms/dialog.js +2 -2
  41. package/dist/atoms/field-error-wrapper.js +2 -2
  42. package/dist/atoms/index.cjs.map +1 -1
  43. package/dist/atoms/index.js +63 -63
  44. package/dist/atoms/list.js +2 -2
  45. package/dist/atoms/pagination.cjs.map +1 -1
  46. package/dist/atoms/pagination.js +4 -4
  47. package/dist/chunk-27MOXAR2.js +64 -0
  48. package/dist/chunk-27MOXAR2.js.map +1 -0
  49. package/dist/chunk-2LRQWOIG.js +63 -0
  50. package/dist/chunk-2LRQWOIG.js.map +1 -0
  51. package/dist/chunk-3SCBKVQQ.js +51 -0
  52. package/dist/chunk-3SCBKVQQ.js.map +1 -0
  53. package/dist/chunk-43FK4CS3.js +196 -0
  54. package/dist/chunk-43FK4CS3.js.map +1 -0
  55. package/dist/chunk-4ETFHDG5.js +174 -0
  56. package/dist/chunk-4ETFHDG5.js.map +1 -0
  57. package/dist/chunk-5ZBSW4UW.js +64 -0
  58. package/dist/chunk-5ZBSW4UW.js.map +1 -0
  59. package/dist/chunk-6DR4EIVU.js +196 -0
  60. package/dist/chunk-6DR4EIVU.js.map +1 -0
  61. package/dist/chunk-6V47NXW5.js +64 -0
  62. package/dist/chunk-6V47NXW5.js.map +1 -0
  63. package/dist/chunk-7FRK5KLV.js +89 -0
  64. package/dist/chunk-7FRK5KLV.js.map +1 -0
  65. package/dist/chunk-A3DYXUDV.js +144 -0
  66. package/dist/chunk-A3DYXUDV.js.map +1 -0
  67. package/dist/chunk-AZE4QTZI.js +165 -0
  68. package/dist/chunk-AZE4QTZI.js.map +1 -0
  69. package/dist/chunk-DDFCVUO2.js +196 -0
  70. package/dist/chunk-DDFCVUO2.js.map +1 -0
  71. package/dist/chunk-E72OTAC6.js +89 -0
  72. package/dist/chunk-E72OTAC6.js.map +1 -0
  73. package/dist/chunk-FVTBDVT4.js +233 -0
  74. package/dist/chunk-FVTBDVT4.js.map +1 -0
  75. package/dist/chunk-GFBHPXDF.js +196 -0
  76. package/dist/chunk-GFBHPXDF.js.map +1 -0
  77. package/dist/chunk-HDXQXNCG.js +99 -0
  78. package/dist/chunk-HDXQXNCG.js.map +1 -0
  79. package/dist/chunk-I46J2XHG.js +75 -0
  80. package/dist/chunk-I46J2XHG.js.map +1 -0
  81. package/dist/chunk-IB7IFIYY.js +165 -0
  82. package/dist/chunk-IB7IFIYY.js.map +1 -0
  83. package/dist/chunk-IH6VDQ6C.js +61 -0
  84. package/dist/chunk-IH6VDQ6C.js.map +1 -0
  85. package/dist/chunk-IPEAJLS3.js +169 -0
  86. package/dist/chunk-IPEAJLS3.js.map +1 -0
  87. package/dist/chunk-JAMNT4FG.js +125 -0
  88. package/dist/chunk-JAMNT4FG.js.map +1 -0
  89. package/dist/chunk-K7ERERDQ.js +174 -0
  90. package/dist/chunk-K7ERERDQ.js.map +1 -0
  91. package/dist/chunk-KD6EXWP7.js +74 -0
  92. package/dist/chunk-KD6EXWP7.js.map +1 -0
  93. package/dist/chunk-KXCFAFL3.js +151 -0
  94. package/dist/chunk-KXCFAFL3.js.map +1 -0
  95. package/dist/chunk-LHKGSKKG.js +70 -0
  96. package/dist/chunk-LHKGSKKG.js.map +1 -0
  97. package/dist/chunk-LTGEHFFG.js +363 -0
  98. package/dist/chunk-LTGEHFFG.js.map +1 -0
  99. package/dist/chunk-N45T3WWG.js +139 -0
  100. package/dist/chunk-N45T3WWG.js.map +1 -0
  101. package/dist/chunk-NIIMYTIK.js +117 -0
  102. package/dist/chunk-NIIMYTIK.js.map +1 -0
  103. package/dist/chunk-OUJ7TDIH.js +100 -0
  104. package/dist/chunk-OUJ7TDIH.js.map +1 -0
  105. package/dist/chunk-OX3N37YY.js +89 -0
  106. package/dist/chunk-OX3N37YY.js.map +1 -0
  107. package/dist/chunk-P6DHFQXU.js +30 -0
  108. package/dist/chunk-P6DHFQXU.js.map +1 -0
  109. package/dist/chunk-PB4O3U6O.js +49 -0
  110. package/dist/chunk-PB4O3U6O.js.map +1 -0
  111. package/dist/chunk-PBWH6CMJ.js +217 -0
  112. package/dist/chunk-PBWH6CMJ.js.map +1 -0
  113. package/dist/chunk-PYGTM7ML.js +79 -0
  114. package/dist/chunk-PYGTM7ML.js.map +1 -0
  115. package/dist/chunk-QDTII3D4.js +87 -0
  116. package/dist/chunk-QDTII3D4.js.map +1 -0
  117. package/dist/chunk-QIRUYN3K.js +69 -0
  118. package/dist/chunk-QIRUYN3K.js.map +1 -0
  119. package/dist/chunk-QIXJ27DM.js +99 -0
  120. package/dist/chunk-QIXJ27DM.js.map +1 -0
  121. package/dist/chunk-QQVXNMUF.js +192 -0
  122. package/dist/chunk-QQVXNMUF.js.map +1 -0
  123. package/dist/chunk-RAKVKAXI.js +144 -0
  124. package/dist/chunk-RAKVKAXI.js.map +1 -0
  125. package/dist/chunk-RFXVHZAN.js +64 -0
  126. package/dist/chunk-RFXVHZAN.js.map +1 -0
  127. package/dist/chunk-SP24KOSH.js +228 -0
  128. package/dist/chunk-SP24KOSH.js.map +1 -0
  129. package/dist/chunk-T4HTYL5M.js +139 -0
  130. package/dist/chunk-T4HTYL5M.js.map +1 -0
  131. package/dist/chunk-TYBX7Q7B.js +64 -0
  132. package/dist/chunk-TYBX7Q7B.js.map +1 -0
  133. package/dist/chunk-UMBRV35P.js +217 -0
  134. package/dist/chunk-UMBRV35P.js.map +1 -0
  135. package/dist/chunk-W3TY3SYU.js +63 -0
  136. package/dist/chunk-W3TY3SYU.js.map +1 -0
  137. package/dist/chunk-W5TPOFOO.js +141 -0
  138. package/dist/chunk-W5TPOFOO.js.map +1 -0
  139. package/dist/chunk-Y3JWP7C5.js +145 -0
  140. package/dist/chunk-Y3JWP7C5.js.map +1 -0
  141. package/dist/chunk-YPIM3E25.js +68 -0
  142. package/dist/chunk-YPIM3E25.js.map +1 -0
  143. package/dist/chunk-ZDMAVBNK.js +89 -0
  144. package/dist/chunk-ZDMAVBNK.js.map +1 -0
  145. package/dist/chunk-ZE3LSQUW.js +54 -0
  146. package/dist/chunk-ZE3LSQUW.js.map +1 -0
  147. package/dist/context/dynamic-form-context.cjs +3 -1
  148. package/dist/context/dynamic-form-context.cjs.map +1 -1
  149. package/dist/context/dynamic-form-context.d.cts +3 -1
  150. package/dist/context/dynamic-form-context.d.ts +3 -1
  151. package/dist/context/dynamic-form-context.js +1 -1
  152. package/dist/context/index.cjs +3 -1
  153. package/dist/context/index.cjs.map +1 -1
  154. package/dist/context/index.js +6 -6
  155. package/dist/icon.cjs +2 -0
  156. package/dist/icon.cjs.map +1 -1
  157. package/dist/icon.d.cts +1 -1
  158. package/dist/icon.d.ts +1 -1
  159. package/dist/icon.js +3 -1
  160. package/dist/index.cjs +25 -14
  161. package/dist/index.cjs.map +1 -1
  162. package/dist/index.css +0 -1
  163. package/dist/index.d.cts +1 -1
  164. package/dist/index.d.ts +1 -1
  165. package/dist/index.js +133 -131
  166. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/index.cjs.map +1 -1
  167. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/index.js +19 -19
  168. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-comp.cjs.map +1 -1
  169. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-comp.js +5 -5
  170. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-body.cjs.map +1 -1
  171. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-body.js +12 -12
  172. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-footer.cjs.map +1 -1
  173. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-footer.js +3 -3
  174. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-header.js +3 -3
  175. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-layout.js +2 -2
  176. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-radio.cjs.map +1 -1
  177. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-radio.js +7 -7
  178. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-satisfaction-option.cjs.map +1 -1
  179. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-satisfaction-option.js +6 -6
  180. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-satisfaction-text.cjs.map +1 -1
  181. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-satisfaction-text.js +6 -6
  182. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-text.cjs.map +1 -1
  183. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/ReviewQuestion/review-question-text.js +6 -6
  184. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/complete-review.cjs.map +1 -1
  185. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/complete-review.js +5 -5
  186. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/index.cjs.map +1 -1
  187. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/index.js +22 -22
  188. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/start-review.cjs.map +1 -1
  189. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/start-review.js +7 -7
  190. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-ai-traning.cjs.map +1 -1
  191. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-ai-traning.js +4 -4
  192. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-review.cjs.map +1 -1
  193. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-review.js +24 -24
  194. package/dist/molecules/curriculumV2/CurriculumContents/index.cjs.map +1 -1
  195. package/dist/molecules/curriculumV2/CurriculumContents/index.js +27 -27
  196. package/dist/molecules/curriculumV2/CurriculumSidebar/Items/curriculum-item-title.js +2 -2
  197. package/dist/molecules/curriculumV2/CurriculumSidebar/Items/section-item.cjs.map +1 -1
  198. package/dist/molecules/curriculumV2/CurriculumSidebar/Items/section-item.js +5 -5
  199. package/dist/molecules/curriculumV2/CurriculumSidebar/index.cjs.map +1 -1
  200. package/dist/molecules/curriculumV2/CurriculumSidebar/index.js +8 -8
  201. package/dist/molecules/curriculumV2/CurriculumSidebar/sidebar-item.cjs.map +1 -1
  202. package/dist/molecules/curriculumV2/CurriculumSidebar/sidebar-item.js +6 -6
  203. package/dist/molecules/curriculumV2/curriculum-sub-nav.cjs.map +1 -1
  204. package/dist/molecules/curriculumV2/curriculum-sub-nav.js +5 -5
  205. package/dist/molecules/curriculumV2/curriculum-v2-layout.js +2 -2
  206. package/dist/molecules/curriculumV2/index.cjs.map +1 -1
  207. package/dist/molecules/curriculumV2/index.js +36 -36
  208. package/dist/molecules/date-picker/date-picker-button.cjs.map +1 -1
  209. package/dist/molecules/date-picker/date-picker-button.js +7 -7
  210. package/dist/molecules/date-picker/index.cjs.map +1 -1
  211. package/dist/molecules/date-picker/index.js +6 -6
  212. package/dist/molecules/download-card.js +2 -2
  213. package/dist/molecules/dynamic-field.cjs +15 -9
  214. package/dist/molecules/dynamic-field.cjs.map +1 -1
  215. package/dist/molecules/dynamic-field.js +5 -5
  216. package/dist/molecules/dynamic-form.cjs +23 -14
  217. package/dist/molecules/dynamic-form.cjs.map +1 -1
  218. package/dist/molecules/dynamic-form.d.cts +2 -1
  219. package/dist/molecules/dynamic-form.d.ts +2 -1
  220. package/dist/molecules/dynamic-form.js +6 -6
  221. package/dist/molecules/expand-table/index.cjs.map +1 -1
  222. package/dist/molecules/expand-table/index.js +6 -6
  223. package/dist/molecules/force-refresh.js +2 -2
  224. package/dist/molecules/ghost-post.js +4 -4
  225. package/dist/molecules/index.cjs +23 -14
  226. package/dist/molecules/index.cjs.map +1 -1
  227. package/dist/molecules/index.js +64 -64
  228. package/dist/molecules/learning-post.js +6 -6
  229. package/dist/molecules/navigation.js +3 -3
  230. package/dist/molecules/one-on-one-guide-list.js +3 -3
  231. package/dist/molecules/stepper.cjs.map +1 -1
  232. package/dist/molecules/stepper.js +5 -5
  233. package/dist/molecules/tag-selector.cjs.map +1 -1
  234. package/dist/molecules/tag-selector.js +6 -6
  235. package/dist/utils/curriculum.utils.cjs.map +1 -1
  236. package/dist/utils/curriculum.utils.js +1 -1
  237. package/package.json +1 -1
  238. package/src/context/dynamic-form-context.tsx +4 -0
  239. package/src/icon.ts +2 -1
  240. package/src/molecules/dynamic-field.tsx +12 -6
  241. package/src/molecules/dynamic-form.tsx +5 -3
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/app/platform/contents-card.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport { Heading } from '@/atoms/heading';\nimport { Button } from '@/atoms/button';\nimport { DropdownMenu } from '@/atoms/dropdown-menu';\nimport { Box } from '@/atoms/box';\nimport { Flex } from '@/atoms/flex';\nimport { Grid } from '@/atoms/grid';\nimport { Skeleton } from '@/atoms/skeleton';\nimport { Typo } from '@/atoms/typo';\nimport { DotsVerticalIcon } from '@/icon';\nimport { Card, Inset } from '@/atoms';\n\nexport interface ContentsCardProps {\n title?: React.ReactNode;\n description?: string;\n id?: string;\n imageSrc?: string | null;\n imageAlt?: string;\n footer?: React.ReactNode;\n dropdownItems?: {\n label: string;\n onClick: () => void;\n }[];\n onClickCard?: () => void;\n isLoading?: boolean;\n}\n\nexport const ContentsCard = forwardRef<HTMLDivElement, ContentsCardProps>(\n (\n {\n title,\n description,\n imageSrc,\n footer,\n dropdownItems,\n onClickCard,\n isLoading = false,\n },\n ref\n ): React.ReactNode => {\n return (\n <Card\n onClick={onClickCard}\n ref={ref}\n style={{\n height: '100%',\n width: '100%',\n display: 'grid',\n cursor: 'pointer',\n maxHeight: '450px',\n }}\n >\n {/* 섬네일 */}\n <Inset clip=\"padding-box\" pb=\"0\" side=\"top\">\n <Skeleton loading={isLoading}>\n <Box\n height=\"210px\"\n style={{\n backgroundImage: `url(${imageSrc})`,\n backgroundSize: 'cover',\n backgroundPosition: 'center',\n }}\n width=\"100%\"\n />\n </Skeleton>\n </Inset>\n {/* 제목, 설명 */}\n <Flex direction=\"column\" p=\"4\" pb=\"3\">\n <Box>\n <Skeleton loading={isLoading}>\n <Heading mb=\"3\" variant=\"heading5\">\n {title}\n </Heading>\n </Skeleton>\n <Skeleton loading={isLoading}>\n <Typo as=\"p\" variant=\"caption\">\n {description}\n </Typo>\n </Skeleton>\n </Box>\n <Grid\n align=\"center\"\n columns=\"1fr auto\"\n justify=\"between\"\n pt=\"2\"\n style={{ marginTop: 'auto' }}\n width=\"100%\"\n >\n <Skeleton loading={isLoading}>\n <Flex gap=\"3\" overflow=\"hidden\">\n {footer}\n </Flex>\n </Skeleton>\n {Boolean(dropdownItems?.length) && (\n <DropdownMenu.Root>\n <DropdownMenu.Trigger>\n <Button size=\"large\" variant=\"transparent\">\n <DotsVerticalIcon color=\"gray\" height=\"20px\" width=\"20px\" />\n </Button>\n </DropdownMenu.Trigger>\n <DropdownMenu.Content>\n {dropdownItems?.map((item) => (\n <DropdownMenu.Item\n key={item.label}\n onClick={(e) => {\n e.stopPropagation();\n item.onClick();\n }}\n >\n {item.label}\n </DropdownMenu.Item>\n ))}\n </DropdownMenu.Content>\n </DropdownMenu.Root>\n )}\n </Grid>\n </Flex>\n </Card>\n );\n }\n);\nContentsCard.displayName = 'ContentsCard';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,kBAAkB;AAuDtB,cAaF,YAbE;AA5BL,IAAM,eAAe;AAAA,EAC1B,CACE;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,YAAY;AAAA,EACd,GACA,QACoB;AACpB,WACE;AAAA,MAAC;AAAA;AAAA,QACC,SAAS;AAAA,QACT;AAAA,QACA,OAAO;AAAA,UACL,QAAQ;AAAA,UACR,OAAO;AAAA,UACP,SAAS;AAAA,UACT,QAAQ;AAAA,UACR,WAAW;AAAA,QACb;AAAA,QAGA;AAAA,8BAAC,SAAM,MAAK,eAAc,IAAG,KAAI,MAAK,OACpC,8BAAC,YAAS,SAAS,WACjB;AAAA,YAAC;AAAA;AAAA,cACC,QAAO;AAAA,cACP,OAAO;AAAA,gBACL,iBAAiB,OAAO,QAAQ;AAAA,gBAChC,gBAAgB;AAAA,gBAChB,oBAAoB;AAAA,cACtB;AAAA,cACA,OAAM;AAAA;AAAA,UACR,GACF,GACF;AAAA,UAEA,qBAAC,QAAK,WAAU,UAAS,GAAE,KAAI,IAAG,KAChC;AAAA,iCAAC,OACC;AAAA,kCAAC,YAAS,SAAS,WACjB,8BAAC,WAAQ,IAAG,KAAI,SAAQ,YACrB,iBACH,GACF;AAAA,cACA,oBAAC,YAAS,SAAS,WACjB,8BAAC,QAAK,IAAG,KAAI,SAAQ,WAClB,uBACH,GACF;AAAA,eACF;AAAA,YACA;AAAA,cAAC;AAAA;AAAA,gBACC,OAAM;AAAA,gBACN,SAAQ;AAAA,gBACR,SAAQ;AAAA,gBACR,IAAG;AAAA,gBACH,OAAO,EAAE,WAAW,OAAO;AAAA,gBAC3B,OAAM;AAAA,gBAEN;AAAA,sCAAC,YAAS,SAAS,WACjB,8BAAC,QAAK,KAAI,KAAI,UAAS,UACpB,kBACH,GACF;AAAA,kBACC,QAAQ,+CAAe,MAAM,KAC5B,qBAAC,aAAa,MAAb,EACC;AAAA,wCAAC,aAAa,SAAb,EACC,8BAAC,UAAO,MAAK,SAAQ,SAAQ,eAC3B,8BAAC,oBAAiB,OAAM,QAAO,QAAO,QAAO,OAAM,QAAO,GAC5D,GACF;AAAA,oBACA,oBAAC,aAAa,SAAb,EACE,yDAAe,IAAI,CAAC,SACnB;AAAA,sBAAC,aAAa;AAAA,sBAAb;AAAA,wBAEC,SAAS,CAAC,MAAM;AACd,4BAAE,gBAAgB;AAClB,+BAAK,QAAQ;AAAA,wBACf;AAAA,wBAEC,eAAK;AAAA;AAAA,sBAND,KAAK;AAAA,oBAOZ,IAEJ;AAAA,qBACF;AAAA;AAAA;AAAA,YAEJ;AAAA,aACF;AAAA;AAAA;AAAA,IACF;AAAA,EAEJ;AACF;AACA,aAAa,cAAc;","names":[]}
@@ -0,0 +1,100 @@
1
+ import {
2
+ useCurriculumContext
3
+ } from "./chunk-IYQJIEVM.js";
4
+ import {
5
+ Grid
6
+ } from "./chunk-EGEQY3KT.js";
7
+ import {
8
+ IconButton
9
+ } from "./chunk-XK6VEVOK.js";
10
+ import {
11
+ Box
12
+ } from "./chunk-4Y5BEXVN.js";
13
+ import {
14
+ ChevronLeftIcon,
15
+ ChevronRightIcon
16
+ } from "./chunk-W5TPOFOO.js";
17
+ import {
18
+ Heading
19
+ } from "./chunk-BESTU2AY.js";
20
+ import {
21
+ Typo
22
+ } from "./chunk-PMJIFLDT.js";
23
+
24
+ // src/molecules/curriculumV2/curriculum-sub-nav.tsx
25
+ import { useCallback } from "react";
26
+ import { jsx, jsxs } from "react/jsx-runtime";
27
+ function CurriculumSubNav() {
28
+ const {
29
+ selectedItem,
30
+ selectedSectionTitle,
31
+ hasPrev,
32
+ hasNext,
33
+ selectPrev,
34
+ selectNext,
35
+ scrollNavItem
36
+ } = useCurriculumContext();
37
+ const onClickPrev = useCallback(() => {
38
+ selectPrev((moveIndex) => {
39
+ scrollNavItem(moveIndex.toString());
40
+ });
41
+ }, [selectPrev, scrollNavItem]);
42
+ const onClickNext = useCallback(() => {
43
+ selectNext((moveIndex) => {
44
+ scrollNavItem(moveIndex.toString());
45
+ });
46
+ }, [selectNext, scrollNavItem]);
47
+ return /* @__PURE__ */ jsxs(
48
+ Grid,
49
+ {
50
+ align: "center",
51
+ columns: { initial: "32px 1fr 32px", md: "48px 1fr 48px" },
52
+ pb: { initial: "2", md: "3" },
53
+ px: { initial: "1", md: "2" },
54
+ py: "2",
55
+ rows: "auto",
56
+ children: [
57
+ hasPrev ? /* @__PURE__ */ jsx(
58
+ IconButton,
59
+ {
60
+ color: "gray",
61
+ onClick: onClickPrev,
62
+ size: { initial: "medium", md: "large" },
63
+ variant: "ghost",
64
+ children: /* @__PURE__ */ jsx(ChevronLeftIcon, { height: "16px", width: "16px" })
65
+ }
66
+ ) : /* @__PURE__ */ jsx(Box, {}),
67
+ /* @__PURE__ */ jsxs(Box, { width: "100%", children: [
68
+ /* @__PURE__ */ jsx(Box, { display: { initial: "none", md: "block" }, children: /* @__PURE__ */ jsx(Heading, { style: { textOverflow: "ellipsis" }, variant: "heading5", children: selectedItem.title }) }),
69
+ /* @__PURE__ */ jsx(Box, { display: { initial: "block", md: "none" }, children: /* @__PURE__ */ jsx(Typo, { weight: "bold", children: selectedItem.title }) }),
70
+ /* @__PURE__ */ jsx(
71
+ Typo,
72
+ {
73
+ as: "p",
74
+ color: "gray",
75
+ mt: "1",
76
+ style: { textOverflow: "ellipsis" },
77
+ variant: "caption",
78
+ children: selectedSectionTitle == null ? void 0 : selectedSectionTitle.title
79
+ }
80
+ )
81
+ ] }),
82
+ hasNext ? /* @__PURE__ */ jsx(
83
+ IconButton,
84
+ {
85
+ color: "gray",
86
+ onClick: onClickNext,
87
+ size: { initial: "medium", md: "large" },
88
+ variant: "ghost",
89
+ children: /* @__PURE__ */ jsx(ChevronRightIcon, { height: "16px", width: "16px" })
90
+ }
91
+ ) : /* @__PURE__ */ jsx(Box, {})
92
+ ]
93
+ }
94
+ );
95
+ }
96
+
97
+ export {
98
+ CurriculumSubNav
99
+ };
100
+ //# sourceMappingURL=chunk-OUJ7TDIH.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/curriculum-sub-nav.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport { Box, } from '@/atoms/box';\nimport { Grid } from '@/atoms/grid';\nimport { Heading } from '@/atoms/heading';\nimport { IconButton } from '@/atoms/icon-button';\nimport { Typo } from '@/atoms/typo';\nimport { ChevronLeftIcon, ChevronRightIcon } from '@/icon';\nimport { useCurriculumContext } from './curriculum-context';\n\nexport function CurriculumSubNav(): React.ReactNode {\n const {\n selectedItem,\n selectedSectionTitle,\n hasPrev,\n hasNext,\n selectPrev,\n selectNext,\n scrollNavItem,\n } = useCurriculumContext();\n\n const onClickPrev = useCallback(() => {\n selectPrev((moveIndex) => {\n scrollNavItem(moveIndex.toString());\n });\n }, [selectPrev, scrollNavItem]);\n\n const onClickNext = useCallback(() => {\n selectNext((moveIndex) => {\n scrollNavItem(moveIndex.toString());\n });\n }, [selectNext, scrollNavItem]);\n\n return (\n <Grid\n align=\"center\"\n columns={{ initial: '32px 1fr 32px', md: '48px 1fr 48px' }}\n pb={{ initial: '2', md: '3' }}\n px={{ initial: '1', md: '2' }}\n py=\"2\"\n rows=\"auto\"\n >\n {hasPrev ? (\n <IconButton\n color=\"gray\"\n onClick={onClickPrev}\n size={{ initial: 'medium', md: 'large' }}\n variant=\"ghost\"\n >\n <ChevronLeftIcon height=\"16px\" width=\"16px\" />\n </IconButton>\n ) : (\n <Box />\n )}\n <Box width=\"100%\">\n {/* 데스크탑 타이틀 */}\n <Box display={{ initial: 'none', md: 'block' }}>\n <Heading style={{ textOverflow: 'ellipsis' }} variant=\"heading5\">\n {selectedItem.title}\n </Heading>\n </Box>\n\n {/* 모바일 타이틀 */}\n <Box display={{ initial: 'block', md: 'none' }}>\n <Typo weight=\"bold\">{selectedItem.title}</Typo>\n </Box>\n\n <Typo\n as=\"p\"\n color=\"gray\"\n mt=\"1\"\n style={{ textOverflow: 'ellipsis' }}\n variant=\"caption\"\n >\n {selectedSectionTitle?.title}\n </Typo>\n </Box>\n {hasNext ? (\n <IconButton\n color=\"gray\"\n onClick={onClickNext}\n size={{ initial: 'medium', md: 'large' }}\n variant=\"ghost\"\n >\n <ChevronRightIcon height=\"16px\" width=\"16px\" />\n </IconButton>\n ) : (\n <Box />\n )}\n </Grid>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,mBAAmB;AAgDzB,cAKJ,YALI;AAvCH,SAAS,mBAAoC;AAClD,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,qBAAqB;AAEzB,QAAM,cAAc,YAAY,MAAM;AACpC,eAAW,CAAC,cAAc;AACxB,oBAAc,UAAU,SAAS,CAAC;AAAA,IACpC,CAAC;AAAA,EACH,GAAG,CAAC,YAAY,aAAa,CAAC;AAE9B,QAAM,cAAc,YAAY,MAAM;AACpC,eAAW,CAAC,cAAc;AACxB,oBAAc,UAAU,SAAS,CAAC;AAAA,IACpC,CAAC;AAAA,EACH,GAAG,CAAC,YAAY,aAAa,CAAC;AAE9B,SACE;AAAA,IAAC;AAAA;AAAA,MACC,OAAM;AAAA,MACN,SAAS,EAAE,SAAS,iBAAiB,IAAI,gBAAgB;AAAA,MACzD,IAAI,EAAE,SAAS,KAAK,IAAI,IAAI;AAAA,MAC5B,IAAI,EAAE,SAAS,KAAK,IAAI,IAAI;AAAA,MAC5B,IAAG;AAAA,MACH,MAAK;AAAA,MAEJ;AAAA,kBACC;AAAA,UAAC;AAAA;AAAA,YACC,OAAM;AAAA,YACN,SAAS;AAAA,YACT,MAAM,EAAE,SAAS,UAAU,IAAI,QAAQ;AAAA,YACvC,SAAQ;AAAA,YAER,8BAAC,mBAAgB,QAAO,QAAO,OAAM,QAAO;AAAA;AAAA,QAC9C,IAEA,oBAAC,OAAI;AAAA,QAEP,qBAAC,OAAI,OAAM,QAET;AAAA,8BAAC,OAAI,SAAS,EAAE,SAAS,QAAQ,IAAI,QAAQ,GAC3C,8BAAC,WAAQ,OAAO,EAAE,cAAc,WAAW,GAAG,SAAQ,YACnD,uBAAa,OAChB,GACF;AAAA,UAGA,oBAAC,OAAI,SAAS,EAAE,SAAS,SAAS,IAAI,OAAO,GAC3C,8BAAC,QAAK,QAAO,QAAQ,uBAAa,OAAM,GAC1C;AAAA,UAEA;AAAA,YAAC;AAAA;AAAA,cACC,IAAG;AAAA,cACH,OAAM;AAAA,cACN,IAAG;AAAA,cACH,OAAO,EAAE,cAAc,WAAW;AAAA,cAClC,SAAQ;AAAA,cAEP,uEAAsB;AAAA;AAAA,UACzB;AAAA,WACF;AAAA,QACC,UACC;AAAA,UAAC;AAAA;AAAA,YACC,OAAM;AAAA,YACN,SAAS;AAAA,YACT,MAAM,EAAE,SAAS,UAAU,IAAI,QAAQ;AAAA,YACvC,SAAQ;AAAA,YAER,8BAAC,oBAAiB,QAAO,QAAO,OAAM,QAAO;AAAA;AAAA,QAC/C,IAEA,oBAAC,OAAI;AAAA;AAAA;AAAA,EAET;AAEJ;","names":[]}
@@ -0,0 +1,89 @@
1
+ import {
2
+ ReviewQuestion_default
3
+ } from "./chunk-W3TY3SYU.js";
4
+ import {
5
+ complete_review_default
6
+ } from "./chunk-PYGTM7ML.js";
7
+ import {
8
+ start_review_default
9
+ } from "./chunk-JNYTH4BZ.js";
10
+ import {
11
+ CurriculumReviewProvider,
12
+ useCurriculumReviewContext
13
+ } from "./chunk-GMKRNFH5.js";
14
+
15
+ // src/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/index.tsx
16
+ import { jsx } from "react/jsx-runtime";
17
+ function CurriculumReviewStepsInner() {
18
+ const {
19
+ formik,
20
+ step,
21
+ handleStart,
22
+ handleNext,
23
+ handlePrev,
24
+ onClickReviewMyAnswer,
25
+ handleSubmit,
26
+ currentQuestion,
27
+ currentAnswer,
28
+ currentError,
29
+ reviewContents,
30
+ handleAnswerChange
31
+ } = useCurriculumReviewContext();
32
+ const { questions } = reviewContents;
33
+ if (step === 0) {
34
+ return /* @__PURE__ */ jsx(start_review_default, { onStart: handleStart });
35
+ }
36
+ if (step > 0 && step <= questions.length && currentQuestion) {
37
+ return /* @__PURE__ */ jsx(
38
+ ReviewQuestion_default,
39
+ {
40
+ answer: currentAnswer,
41
+ error: currentError,
42
+ index: step - 1,
43
+ isLast: step === questions.length,
44
+ isLoading: formik.isSubmitting,
45
+ isNextDisabled: currentError !== void 0,
46
+ onChange: handleAnswerChange,
47
+ onNext: handleNext,
48
+ onPrev: handlePrev,
49
+ onSubmit: handleSubmit,
50
+ question: currentQuestion,
51
+ total: questions.length
52
+ }
53
+ );
54
+ }
55
+ return /* @__PURE__ */ jsx(complete_review_default, { onClickReviewMyAnswer });
56
+ }
57
+ function CurriculumReviewSteps({
58
+ contents,
59
+ title,
60
+ onClickEndReview,
61
+ onSubmit,
62
+ defaultValues,
63
+ curriculum,
64
+ onReviewValueChange,
65
+ mode,
66
+ done
67
+ }) {
68
+ return /* @__PURE__ */ jsx(
69
+ CurriculumReviewProvider,
70
+ {
71
+ curriculum,
72
+ defaultValues,
73
+ done,
74
+ mode,
75
+ onClickEndReview,
76
+ onReviewValueChange,
77
+ onSubmit,
78
+ reviewContents: contents,
79
+ sectionTitle: title,
80
+ children: /* @__PURE__ */ jsx(CurriculumReviewStepsInner, {})
81
+ }
82
+ );
83
+ }
84
+ var CurriculumReviewSteps_default = CurriculumReviewSteps;
85
+
86
+ export {
87
+ CurriculumReviewSteps_default
88
+ };
89
+ //# sourceMappingURL=chunk-OX3N37YY.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/index.tsx"],"sourcesContent":["import React from 'react';\nimport { type CurriculumReviewContents } from '@/types/curriculumContents.type';\nimport type { Curriculum } from '@/types'; \nimport {\n CurriculumReviewProvider,\n useCurriculumReviewContext,\n} from './curriculum-review-context';\nimport StartReview from './start-review';\nimport CompleteReview from './complete-review';\nimport ReviewQuestion from './ReviewQuestion';\n \nfunction CurriculumReviewStepsInner(): React.ReactNode {\n const {\n formik,\n step,\n handleStart,\n handleNext,\n handlePrev,\n onClickReviewMyAnswer,\n handleSubmit,\n currentQuestion,\n currentAnswer,\n currentError,\n reviewContents,\n handleAnswerChange,\n } = useCurriculumReviewContext();\n const { questions } = reviewContents;\n\n if (step === 0) {\n return <StartReview onStart={handleStart} />;\n }\n if (step > 0 && step <= questions.length && currentQuestion) {\n return (\n <ReviewQuestion\n answer={currentAnswer}\n error={currentError}\n index={step - 1}\n isLast={step === questions.length}\n isLoading={formik.isSubmitting}\n isNextDisabled={currentError !== undefined}\n onChange={handleAnswerChange}\n onNext={handleNext}\n onPrev={handlePrev}\n onSubmit={handleSubmit}\n question={currentQuestion}\n total={questions.length}\n />\n );\n }\n return <CompleteReview onClickReviewMyAnswer={onClickReviewMyAnswer} />;\n}\n\ninterface CurriculumReviewStepsProps {\n contents: CurriculumReviewContents;\n title: string | undefined;\n onClickEndReview: () => void;\n onSubmit: (values: Record<string, string>) => Promise<boolean>;\n defaultValues?: Record<string, string>;\n curriculum: Curriculum;\n onReviewValueChange: ({\n reviewId,\n answer,\n }: {\n reviewId: string;\n answer: Record<string, string>;\n }) => void;\n mode: 'edit' | 'create';\n done: boolean; \n}\n\nfunction CurriculumReviewSteps({\n contents,\n title,\n onClickEndReview,\n onSubmit,\n defaultValues,\n curriculum,\n onReviewValueChange,\n mode,\n done,\n}: CurriculumReviewStepsProps): React.ReactNode { \n\n return (\n <CurriculumReviewProvider\n curriculum={curriculum}\n defaultValues={defaultValues}\n done={done}\n mode={mode}\n onClickEndReview={onClickEndReview}\n onReviewValueChange={onReviewValueChange}\n onSubmit={onSubmit}\n reviewContents={contents}\n sectionTitle={title}\n >\n <CurriculumReviewStepsInner />\n </CurriculumReviewProvider>\n );\n}\n\nexport default CurriculumReviewSteps;\n"],"mappings":";;;;;;;;;;;;;;;AA6BW;AAlBX,SAAS,6BAA8C;AACrD,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,2BAA2B;AAC/B,QAAM,EAAE,UAAU,IAAI;AAEtB,MAAI,SAAS,GAAG;AACd,WAAO,oBAAC,wBAAY,SAAS,aAAa;AAAA,EAC5C;AACA,MAAI,OAAO,KAAK,QAAQ,UAAU,UAAU,iBAAiB;AAC3D,WACE;AAAA,MAAC;AAAA;AAAA,QACC,QAAQ;AAAA,QACR,OAAO;AAAA,QACP,OAAO,OAAO;AAAA,QACd,QAAQ,SAAS,UAAU;AAAA,QAC3B,WAAW,OAAO;AAAA,QAClB,gBAAgB,iBAAiB;AAAA,QACjC,UAAU;AAAA,QACV,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR,UAAU;AAAA,QACV,UAAU;AAAA,QACV,OAAO,UAAU;AAAA;AAAA,IACnB;AAAA,EAEJ;AACA,SAAO,oBAAC,2BAAe,uBAA8C;AACvE;AAoBA,SAAS,sBAAsB;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAgD;AAE9C,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,gBAAgB;AAAA,MAChB,cAAc;AAAA,MAEd,8BAAC,8BAA2B;AAAA;AAAA,EAC9B;AAEJ;AAEA,IAAO,gCAAQ;","names":[]}
@@ -0,0 +1,30 @@
1
+ import {
2
+ CoachingCustomerInfoSmall
3
+ } from "./chunk-YADSNPMG.js";
4
+ import {
5
+ CoachingCustomerInfoLarge
6
+ } from "./chunk-RFXVHZAN.js";
7
+ import {
8
+ CoachingCustomerInfoMedium
9
+ } from "./chunk-KD6EXWP7.js";
10
+ import {
11
+ Box
12
+ } from "./chunk-4Y5BEXVN.js";
13
+ import {
14
+ __spreadValues
15
+ } from "./chunk-CRTRMMJ7.js";
16
+
17
+ // src/app/platform/userInfos/coaching-customer-info/index.tsx
18
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
19
+ function CoachingCustomerInfo(props) {
20
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
21
+ /* @__PURE__ */ jsx(Box, { display: { initial: "block", sm: "none", md: "none" }, children: /* @__PURE__ */ jsx(CoachingCustomerInfoSmall, __spreadValues({}, props)) }),
22
+ /* @__PURE__ */ jsx(Box, { display: { initial: "none", sm: "block", md: "none" }, children: /* @__PURE__ */ jsx(CoachingCustomerInfoMedium, __spreadValues({}, props)) }),
23
+ /* @__PURE__ */ jsx(Box, { display: { initial: "none", sm: "none", md: "block" }, children: /* @__PURE__ */ jsx(CoachingCustomerInfoLarge, __spreadValues({}, props)) })
24
+ ] });
25
+ }
26
+
27
+ export {
28
+ CoachingCustomerInfo
29
+ };
30
+ //# sourceMappingURL=chunk-P6DHFQXU.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/app/platform/userInfos/coaching-customer-info/index.tsx"],"sourcesContent":["import React from 'react';\nimport { Box } from '../../../../atoms';\nimport type { CoachingCustomerInfoProps } from '../utils';\nimport { CoachingCustomerInfoSmall } from './small';\nimport { CoachingCustomerInfoMedium } from './medium';\nimport { CoachingCustomerInfoLarge } from './large';\n\nexport {\n CoachingCustomerInfoLarge,\n CoachingCustomerInfoMedium,\n CoachingCustomerInfoSmall,\n};\n\nexport { type CoachingCustomerInfoProps };\n\nexport function CoachingCustomerInfo(\n props: CoachingCustomerInfoProps\n): React.ReactNode {\n return (\n <>\n <Box display={{ initial: 'block', sm: 'none', md: 'none' }}>\n <CoachingCustomerInfoSmall {...props} />\n </Box>\n <Box display={{ initial: 'none', sm: 'block', md: 'none' }}>\n <CoachingCustomerInfoMedium {...props} />\n </Box>\n <Box display={{ initial: 'none', sm: 'none', md: 'block' }}>\n <CoachingCustomerInfoLarge {...props} />\n </Box>\n </>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAmBI,mBAEI,KAFJ;AAJG,SAAS,qBACd,OACiB;AACjB,SACE,iCACE;AAAA,wBAAC,OAAI,SAAS,EAAE,SAAS,SAAS,IAAI,QAAQ,IAAI,OAAO,GACvD,8BAAC,8CAA8B,MAAO,GACxC;AAAA,IACA,oBAAC,OAAI,SAAS,EAAE,SAAS,QAAQ,IAAI,SAAS,IAAI,OAAO,GACvD,8BAAC,+CAA+B,MAAO,GACzC;AAAA,IACA,oBAAC,OAAI,SAAS,EAAE,SAAS,QAAQ,IAAI,QAAQ,IAAI,QAAQ,GACvD,8BAAC,8CAA8B,MAAO,GACxC;AAAA,KACF;AAEJ;","names":[]}
@@ -0,0 +1,49 @@
1
+ import {
2
+ Form
3
+ } from "./chunk-2OMSNCRH.js";
4
+ import {
5
+ __async
6
+ } from "./chunk-CRTRMMJ7.js";
7
+
8
+ // src/context/dynamic-form-context.tsx
9
+ import { createContext, useContext } from "react";
10
+ import { jsx } from "react/jsx-runtime";
11
+ var DynamicFormContext = createContext(null);
12
+ function DynamicFormProvider({
13
+ children,
14
+ fields,
15
+ formik,
16
+ readonly = false
17
+ }) {
18
+ const contextValue = {
19
+ formik,
20
+ fields,
21
+ readonly,
22
+ getFieldValue: (name) => formik.values[name],
23
+ getFieldError: (name) => {
24
+ const error = formik.errors[name];
25
+ const touched = formik.touched[name];
26
+ return touched && error ? String(error) : void 0;
27
+ },
28
+ getFieldTouched: (name) => Boolean(formik.touched[name]),
29
+ setFieldValue: (field, value) => __async(null, null, function* () {
30
+ yield formik.setFieldValue(field, value);
31
+ }),
32
+ handleChange: formik.handleChange,
33
+ handleBlur: formik.handleBlur
34
+ };
35
+ return /* @__PURE__ */ jsx(DynamicFormContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx(Form.Root, { onSubmit: formik.handleSubmit, children }) });
36
+ }
37
+ function useDynamicForm() {
38
+ const context = useContext(DynamicFormContext);
39
+ if (!context) {
40
+ throw new Error("useDynamicForm must be used within a DynamicFormProvider");
41
+ }
42
+ return context;
43
+ }
44
+
45
+ export {
46
+ DynamicFormProvider,
47
+ useDynamicForm
48
+ };
49
+ //# sourceMappingURL=chunk-PB4O3U6O.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/context/dynamic-form-context.tsx"],"sourcesContent":["import React, { createContext, useContext } from 'react';\nimport type { FormikProps } from 'formik';\nimport { Form } from '@/molecules/form/form';\nimport type { DynamicFormFieldSchema } from '@/types/dynamic-form-schema-generated';\n\nexport interface DynamicFormContextValue {\n formik: FormikProps<Record<string, unknown>>;\n fields: DynamicFormFieldSchema[];\n readonly: boolean;\n getFieldValue: (name: string) => unknown;\n getFieldError: (name: string) => string | undefined;\n getFieldTouched: (name: string) => boolean;\n setFieldValue: (field: string, value: unknown) => Promise<void>;\n handleChange: (e: React.ChangeEvent<unknown>) => void;\n handleBlur: (e: React.FocusEvent<unknown>) => void;\n}\n\nconst DynamicFormContext = createContext<DynamicFormContextValue | null>(null);\n\ninterface DynamicFormProviderProps {\n children: React.ReactNode;\n fields: DynamicFormFieldSchema[];\n formik: FormikProps<Record<string, unknown>>;\n readonly?: boolean;\n}\n\nexport function DynamicFormProvider({\n children,\n fields,\n formik,\n readonly = false,\n}: DynamicFormProviderProps): React.ReactElement {\n const contextValue: DynamicFormContextValue = {\n formik,\n fields,\n readonly,\n getFieldValue: (name: string): unknown => formik.values[name],\n getFieldError: (name: string): string | undefined => {\n const error = formik.errors[name];\n const touched = formik.touched[name];\n return touched && error ? String(error) : undefined;\n },\n getFieldTouched: (name: string): boolean => Boolean(formik.touched[name]),\n setFieldValue: async (field: string, value: unknown): Promise<void> => {\n await formik.setFieldValue(field, value);\n },\n handleChange: formik.handleChange,\n handleBlur: formik.handleBlur, \n };\n\n return (\n <DynamicFormContext.Provider value={contextValue}>\n <Form.Root onSubmit={formik.handleSubmit}>{children}</Form.Root>\n </DynamicFormContext.Provider>\n );\n}\n\nexport function useDynamicForm(): DynamicFormContextValue {\n const context = useContext(DynamicFormContext);\n\n if (!context) {\n throw new Error('useDynamicForm must be used within a DynamicFormProvider');\n }\n\n return context;\n}\n"],"mappings":";;;;;;;;AAAA,SAAgB,eAAe,kBAAkB;AAoD3C;AAnCN,IAAM,qBAAqB,cAA8C,IAAI;AAStE,SAAS,oBAAoB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA,WAAW;AACb,GAAiD;AAC/C,QAAM,eAAwC;AAAA,IAC5C;AAAA,IACA;AAAA,IACA;AAAA,IACA,eAAe,CAAC,SAA0B,OAAO,OAAO,IAAI;AAAA,IAC5D,eAAe,CAAC,SAAqC;AACnD,YAAM,QAAQ,OAAO,OAAO,IAAI;AAChC,YAAM,UAAU,OAAO,QAAQ,IAAI;AACnC,aAAO,WAAW,QAAQ,OAAO,KAAK,IAAI;AAAA,IAC5C;AAAA,IACA,iBAAiB,CAAC,SAA0B,QAAQ,OAAO,QAAQ,IAAI,CAAC;AAAA,IACxE,eAAe,CAAO,OAAe,UAAkC;AACrE,YAAM,OAAO,cAAc,OAAO,KAAK;AAAA,IACzC;AAAA,IACA,cAAc,OAAO;AAAA,IACrB,YAAY,OAAO;AAAA,EACrB;AAEA,SACE,oBAAC,mBAAmB,UAAnB,EAA4B,OAAO,cAClC,8BAAC,KAAK,MAAL,EAAU,UAAU,OAAO,cAAe,UAAS,GACtD;AAEJ;AAEO,SAAS,iBAA0C;AACxD,QAAM,UAAU,WAAW,kBAAkB;AAE7C,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,MAAM,0DAA0D;AAAA,EAC5E;AAEA,SAAO;AACT;","names":[]}
@@ -0,0 +1,217 @@
1
+ import {
2
+ DynamicFormField
3
+ } from "./chunk-T4HTYL5M.js";
4
+ import {
5
+ DynamicFormProvider,
6
+ useDynamicForm
7
+ } from "./chunk-PB4O3U6O.js";
8
+ import {
9
+ Form
10
+ } from "./chunk-2OMSNCRH.js";
11
+ import {
12
+ Typo
13
+ } from "./chunk-PMJIFLDT.js";
14
+ import {
15
+ __async
16
+ } from "./chunk-CRTRMMJ7.js";
17
+
18
+ // src/molecules/dynamic-form.tsx
19
+ import { useMemo, useCallback, useEffect } from "react";
20
+ import { useFormik } from "formik";
21
+ import * as Yup from "yup";
22
+ import { Box } from "@radix-ui/themes";
23
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
24
+ function scrollToFirstError(errors, _fields) {
25
+ const firstErrorFieldName = Object.keys(errors)[0];
26
+ if (!firstErrorFieldName) return;
27
+ let fieldElement = document.querySelector(`[name="${firstErrorFieldName}"]`);
28
+ if (!fieldElement) {
29
+ fieldElement = document.querySelector(`[data-field-name="${firstErrorFieldName}"]`);
30
+ }
31
+ if (!fieldElement) {
32
+ fieldElement = document.querySelector(`[data-error-field="${firstErrorFieldName}"]`);
33
+ }
34
+ if (fieldElement) {
35
+ fieldElement.scrollIntoView({
36
+ behavior: "smooth",
37
+ block: "nearest"
38
+ });
39
+ }
40
+ }
41
+ function DynamicFormRoot({
42
+ fields,
43
+ initialValues = {},
44
+ onSubmit,
45
+ children,
46
+ readonly = false
47
+ }) {
48
+ const validationSchema = useMemo(() => {
49
+ const schema = {};
50
+ fields.forEach((field) => {
51
+ if (field.validation) {
52
+ const validation = createYupValidation(field, field.validation);
53
+ if (validation) {
54
+ schema[field.name] = validation;
55
+ }
56
+ } else if (field.required) {
57
+ if (field.type === "choices") {
58
+ schema[field.name] = Yup.array().min(1, `${field.label}\uC744(\uB97C) \uD558\uB098 \uC774\uC0C1 \uC120\uD0DD\uD574\uC8FC\uC138\uC694`).required(`${field.label}\uC740(\uB294) \uD544\uC218\uC785\uB2C8\uB2E4`);
59
+ } else if (field.type === "yes_no") {
60
+ schema[field.name] = Yup.boolean().oneOf([true], `${field.label}\uC5D0 \uB3D9\uC758\uD574\uC8FC\uC138\uC694`);
61
+ } else {
62
+ schema[field.name] = Yup.string().required(
63
+ `${field.label}\uC740(\uB294) \uD544\uC218\uC785\uB2C8\uB2E4`
64
+ );
65
+ }
66
+ }
67
+ });
68
+ return Object.keys(schema).length > 0 ? Yup.object(schema) : void 0;
69
+ }, [fields]);
70
+ const handleSubmit = useCallback((values) => __async(null, null, function* () {
71
+ yield onSubmit(values);
72
+ }), [onSubmit]);
73
+ const formik = useFormik({
74
+ initialValues: fields.reduce((acc, field) => {
75
+ if (field.type === "choices") {
76
+ acc[field.name] = initialValues[field.name] || [];
77
+ } else if (field.type === "yes_no") {
78
+ acc[field.name] = initialValues[field.name] || false;
79
+ } else {
80
+ acc[field.name] = initialValues[field.name] || "";
81
+ }
82
+ return acc;
83
+ }, {}),
84
+ validationSchema,
85
+ validateOnBlur: true,
86
+ validateOnChange: true,
87
+ onSubmit: handleSubmit
88
+ });
89
+ useEffect(() => {
90
+ if (formik.submitCount > 0 && Object.keys(formik.errors).length > 0) {
91
+ const timeoutId = setTimeout(() => {
92
+ scrollToFirstError(formik.errors, fields);
93
+ }, 100);
94
+ return () => {
95
+ clearTimeout(timeoutId);
96
+ };
97
+ }
98
+ }, [formik.submitCount, formik.errors, fields]);
99
+ return /* @__PURE__ */ jsx(DynamicFormProvider, { fields, formik, readonly, children });
100
+ }
101
+ function DynamicFormFieldList({
102
+ fields: fieldsProp,
103
+ labelVariant
104
+ }) {
105
+ const { formik, fields: fieldsFromContext, readonly } = useDynamicForm();
106
+ const fields = fieldsProp || fieldsFromContext;
107
+ return /* @__PURE__ */ jsx(Fragment, { children: fields.map((field) => {
108
+ const errorMessage = !readonly && formik.touched[field.name] && formik.errors[field.name] ? String(formik.errors[field.name]) : void 0;
109
+ return /* @__PURE__ */ jsx(
110
+ Box,
111
+ {
112
+ "data-error-field": errorMessage ? field.name : void 0,
113
+ "data-field-name": field.name,
114
+ mb: "2",
115
+ children: /* @__PURE__ */ jsxs(
116
+ Form.FormItem,
117
+ {
118
+ errorMessage,
119
+ label: field.label,
120
+ labelVariant,
121
+ name: field.name,
122
+ required: field.required,
123
+ children: [
124
+ /* @__PURE__ */ jsx(DynamicFormField, { field }),
125
+ field.description ? /* @__PURE__ */ jsx(Typo, { children: field.description }) : null
126
+ ]
127
+ }
128
+ )
129
+ },
130
+ field.name
131
+ );
132
+ }) });
133
+ }
134
+ var DynamicForm = {
135
+ Root: DynamicFormRoot,
136
+ FieldList: DynamicFormFieldList
137
+ };
138
+ function createYupValidation(field, validation) {
139
+ if (!validation) return void 0;
140
+ let schema;
141
+ if (field.type === "number") {
142
+ schema = Yup.number();
143
+ } else if (field.type === "email") {
144
+ schema = Yup.string().email(
145
+ validation.message || "\uC62C\uBC14\uB978 \uC774\uBA54\uC77C \uD615\uC2DD\uC774 \uC544\uB2D9\uB2C8\uB2E4"
146
+ );
147
+ } else if (field.type === "choices") {
148
+ schema = Yup.array();
149
+ } else if (field.type === "yes_no") {
150
+ schema = Yup.boolean();
151
+ } else {
152
+ schema = Yup.string();
153
+ }
154
+ if (validation.min !== void 0) {
155
+ if (field.type === "number") {
156
+ schema = schema.min(
157
+ validation.min,
158
+ validation.message || `\uCD5C\uC18C ${validation.min}\uC774\uC5B4\uC57C \uD569\uB2C8\uB2E4`
159
+ );
160
+ } else if (field.type === "choices") {
161
+ schema = schema.min(
162
+ validation.min,
163
+ validation.message || `\uCD5C\uC18C ${validation.min}\uAC1C \uC774\uC0C1 \uC120\uD0DD\uD574\uC8FC\uC138\uC694`
164
+ );
165
+ } else if (field.type === "yes_no") {
166
+ } else {
167
+ schema = schema.min(
168
+ validation.min,
169
+ validation.message || `\uCD5C\uC18C ${validation.min}\uC790 \uC774\uC0C1\uC774\uC5B4\uC57C \uD569\uB2C8\uB2E4`
170
+ );
171
+ }
172
+ }
173
+ if (validation.max !== void 0) {
174
+ if (field.type === "number") {
175
+ schema = schema.max(
176
+ validation.max,
177
+ validation.message || `\uCD5C\uB300 ${validation.max}\uC774\uC5B4\uC57C \uD569\uB2C8\uB2E4`
178
+ );
179
+ } else if (field.type === "choices") {
180
+ schema = schema.max(
181
+ validation.max,
182
+ validation.message || `\uCD5C\uB300 ${validation.max}\uAC1C\uAE4C\uC9C0 \uC120\uD0DD \uAC00\uB2A5\uD569\uB2C8\uB2E4`
183
+ );
184
+ } else if (field.type === "yes_no") {
185
+ } else {
186
+ schema = schema.max(
187
+ validation.max,
188
+ validation.message || `\uCD5C\uB300 ${validation.max}\uC790 \uC774\uD558\uC5EC\uC57C \uD569\uB2C8\uB2E4`
189
+ );
190
+ }
191
+ }
192
+ if (validation.pattern) {
193
+ if (field.type === "yes_no") {
194
+ } else {
195
+ schema = schema.matches(
196
+ new RegExp(validation.pattern),
197
+ validation.message || "\uC62C\uBC14\uB978 \uD615\uC2DD\uC774 \uC544\uB2D9\uB2C8\uB2E4"
198
+ );
199
+ }
200
+ }
201
+ if (field.required) {
202
+ if (field.type === "yes_no") {
203
+ schema = schema.oneOf([true], validation.message || `${field.label}\uC5D0 \uB3D9\uC758\uD574\uC8FC\uC138\uC694`);
204
+ } else if (field.type === "choices") {
205
+ schema = schema.min(1, validation.message || `${field.label}\uC744(\uB97C) \uD558\uB098 \uC774\uC0C1 \uC120\uD0DD\uD574\uC8FC\uC138\uC694`);
206
+ } else {
207
+ schema = schema.required(validation.message || `${field.label}\uC740(\uB294) \uD544\uC218\uC785\uB2C8\uB2E4`);
208
+ }
209
+ }
210
+ return schema;
211
+ }
212
+
213
+ export {
214
+ DynamicForm,
215
+ createYupValidation
216
+ };
217
+ //# sourceMappingURL=chunk-PBWH6CMJ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/dynamic-form.tsx"],"sourcesContent":["import React, { useMemo, useCallback, useEffect } from 'react';\nimport { useFormik, type FormikProps } from 'formik';\nimport * as Yup from 'yup';\nimport { Box } from '@radix-ui/themes';\nimport { Typo } from '@/atoms/typo';\nimport {\n DynamicFormProvider,\n useDynamicForm,\n} from '@/context/dynamic-form-context';\nimport type {\n DynamicFormFieldSchema,\n ValidationRule,\n} from '@/types/dynamic-form-schema-generated';\nimport { Form } from './form/form';\nimport { DynamicFormField } from './dynamic-field';\n\nexport interface DynamicFormProps {\n fields: DynamicFormFieldSchema[];\n initialValues?: Record<string, unknown>;\n onSubmit: (values: Record<string, unknown>) => void | Promise<void>;\n children: React.ReactNode;\n readonly?: boolean;\n}\n\n/**\n * 첫 번째 에러 필드로 스크롤하는 함수\n */\nfunction scrollToFirstError(errors: Record<string, unknown>, _fields: DynamicFormFieldSchema[]): void {\n const firstErrorFieldName = Object.keys(errors)[0];\n if (!firstErrorFieldName) return;\n\n // 해당 필드의 DOM 요소를 찾기 (여러 선택자 시도)\n let fieldElement = document.querySelector(`[name=\"${firstErrorFieldName}\"]`);\n \n // input 요소를 찾지 못한 경우, 해당 필드의 컨테이너를 찾기\n if (!fieldElement) {\n fieldElement = document.querySelector(`[data-field-name=\"${firstErrorFieldName}\"]`);\n }\n \n // 여전히 찾지 못한 경우, FormItem의 에러 메시지 영역을 찾기\n if (!fieldElement) {\n fieldElement = document.querySelector(`[data-error-field=\"${firstErrorFieldName}\"]`);\n }\n\n if (fieldElement) {\n fieldElement.scrollIntoView({\n behavior: 'smooth',\n block: 'nearest',\n });\n }\n}\n\nfunction DynamicFormRoot({\n fields,\n initialValues = {},\n onSubmit,\n children,\n readonly = false,\n}: DynamicFormProps): React.ReactElement {\n const validationSchema = useMemo(() => {\n const schema: Record<string, Yup.Schema<unknown>> = {};\n fields.forEach((field) => {\n if (field.validation) {\n const validation = createYupValidation(field, field.validation);\n if (validation) {\n schema[field.name] = validation;\n }\n } else if (field.required) {\n // choices 타입은 배열 스키마로 처리\n if (field.type === 'choices') {\n schema[field.name] = Yup.array()\n .min(1, `${field.label}을(를) 하나 이상 선택해주세요`)\n .required(`${field.label}은(는) 필수입니다`);\n } else if (field.type === 'yes_no') {\n // yes_no 타입은 boolean 스키마로 처리\n schema[field.name] = Yup.boolean().oneOf([true], `${field.label}에 동의해주세요`);\n } else {\n // choice, dropdown, short_text, long_text, number, email 타입은 문자열 스키마로 처리\n schema[field.name] = Yup.string().required(\n `${field.label}은(는) 필수입니다`\n );\n }\n }\n });\n return Object.keys(schema).length > 0 ? Yup.object(schema) : undefined;\n }, [fields]);\n\n const handleSubmit = useCallback(async (values: Record<string, unknown>) => {\n await onSubmit(values);\n }, [onSubmit]);\n\n const formik: FormikProps<Record<string, unknown>> = useFormik({\n initialValues: fields.reduce<Record<string, unknown>>((acc, field) => {\n if (field.type === 'choices') {\n acc[field.name] = initialValues[field.name] || [];\n } else if (field.type === 'yes_no') {\n acc[field.name] = initialValues[field.name] || false;\n } else {\n acc[field.name] = initialValues[field.name] || '';\n }\n return acc;\n }, {}),\n validationSchema,\n validateOnBlur: true,\n validateOnChange: true,\n onSubmit: handleSubmit,\n });\n\n // submit 시 validation 에러가 있으면 첫 번째 에러 필드로 스크롤\n useEffect(() => {\n if (formik.submitCount > 0 && Object.keys(formik.errors).length > 0) {\n // 약간의 지연을 두어 DOM 업데이트 후 스크롤 실행\n const timeoutId = setTimeout(() => {\n scrollToFirstError(formik.errors, fields);\n }, 100);\n \n return () => {\n clearTimeout(timeoutId);\n };\n }\n }, [formik.submitCount, formik.errors, fields]);\n\n return (\n <DynamicFormProvider fields={fields} formik={formik} readonly={readonly}>\n {children}\n </DynamicFormProvider>\n );\n}\n\ninterface DynamicFormFieldListProps {\n fields?: DynamicFormFieldSchema[];\n labelVariant?: 'title' | 'body' | 'caption';\n}\nfunction DynamicFormFieldList({\n fields: fieldsProp,\n labelVariant,\n}: DynamicFormFieldListProps): React.ReactElement {\n const { formik, fields: fieldsFromContext, readonly } = useDynamicForm();\n const fields = fieldsProp || fieldsFromContext;\n\n return (\n <>\n {fields.map((field) => {\n const errorMessage =\n !readonly && formik.touched[field.name] && formik.errors[field.name]\n ? String(formik.errors[field.name])\n : undefined;\n\n return (\n <Box\n data-error-field={errorMessage ? field.name : undefined}\n data-field-name={field.name}\n key={field.name}\n mb=\"2\"\n >\n <Form.FormItem\n errorMessage={errorMessage}\n label={field.label}\n labelVariant={labelVariant}\n name={field.name}\n required={field.required}\n >\n <DynamicFormField field={field} />\n {field.description ? <Typo>{field.description}</Typo> : null}\n </Form.FormItem>\n </Box>\n );\n })}\n </>\n );\n}\n\nexport const DynamicForm = {\n Root: DynamicFormRoot,\n FieldList: DynamicFormFieldList,\n};\n\nexport function createYupValidation(\n field: DynamicFormFieldSchema,\n validation?: ValidationRule\n): Yup.Schema<unknown> | undefined {\n if (!validation) return undefined;\n\n let schema: Yup.Schema<unknown>;\n\n // field.type을 기준으로 기본 스키마 생성\n if (field.type === 'number') {\n schema = Yup.number();\n } else if (field.type === 'email') {\n schema = Yup.string().email(\n validation.message || '올바른 이메일 형식이 아닙니다'\n );\n } else if (field.type === 'choices') {\n schema = Yup.array();\n } else if (field.type === 'yes_no') {\n schema = Yup.boolean();\n } else {\n // choice, dropdown, short_text, long_text 타입은 문자열 스키마로 처리\n schema = Yup.string();\n }\n\n if (validation.min !== undefined) {\n if (field.type === 'number') {\n schema = (schema as Yup.NumberSchema).min(\n validation.min,\n validation.message || `최소 ${validation.min}이어야 합니다`\n );\n } else if (field.type === 'choices') {\n schema = (schema as ReturnType<typeof Yup.array>).min(\n validation.min,\n validation.message || `최소 ${validation.min}개 이상 선택해주세요`\n );\n } else if (field.type === 'yes_no') {\n // yes_no 타입은 boolean이므로 min/max 검증 불가\n // 대신 required 검증만 적용\n } else {\n schema = (schema as Yup.StringSchema).min(\n validation.min,\n validation.message || `최소 ${validation.min}자 이상이어야 합니다`\n );\n }\n }\n\n if (validation.max !== undefined) {\n if (field.type === 'number') {\n schema = (schema as Yup.NumberSchema).max(\n validation.max,\n validation.message || `최대 ${validation.max}이어야 합니다`\n );\n } else if (field.type === 'choices') {\n schema = (schema as ReturnType<typeof Yup.array>).max(\n validation.max,\n validation.message || `최대 ${validation.max}개까지 선택 가능합니다`\n );\n } else if (field.type === 'yes_no') {\n // yes_no 타입은 boolean이므로 min/max 검증 불가\n // 대신 required 검증만 적용\n } else {\n schema = (schema as Yup.StringSchema).max(\n validation.max,\n validation.message || `최대 ${validation.max}자 이하여야 합니다`\n );\n }\n }\n\n if (validation.pattern) {\n if (field.type === 'yes_no') {\n // yes_no 타입은 boolean이므로 pattern 검증 불가\n // 대신 required 검증만 적용\n } else {\n schema = (schema as Yup.StringSchema).matches(\n new RegExp(validation.pattern),\n validation.message || '올바른 형식이 아닙니다'\n );\n }\n }\n\n // field.required가 true인 경우 required 검증 추가\n if (field.required) {\n if (field.type === 'yes_no') {\n schema = (schema as Yup.BooleanSchema).oneOf([true], validation.message || `${field.label}에 동의해주세요`);\n } else if (field.type === 'choices') {\n schema = (schema as ReturnType<typeof Yup.array>).min(1, validation.message || `${field.label}을(를) 하나 이상 선택해주세요`);\n } else {\n schema = (schema as Yup.StringSchema).required(validation.message || `${field.label}은(는) 필수입니다`);\n }\n }\n\n return schema;\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,79 @@
1
+ import {
2
+ useCurriculumReviewContext
3
+ } from "./chunk-GMKRNFH5.js";
4
+ import {
5
+ Grid
6
+ } from "./chunk-EGEQY3KT.js";
7
+ import {
8
+ Flex
9
+ } from "./chunk-25HMMI7R.js";
10
+ import {
11
+ Button
12
+ } from "./chunk-ZVDAEY5Q.js";
13
+ import {
14
+ HomeIcon,
15
+ ResetIcon
16
+ } from "./chunk-W5TPOFOO.js";
17
+ import {
18
+ Heading
19
+ } from "./chunk-BESTU2AY.js";
20
+ import {
21
+ Typo
22
+ } from "./chunk-PMJIFLDT.js";
23
+
24
+ // src/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/complete-review.tsx
25
+ import { jsx, jsxs } from "react/jsx-runtime";
26
+ var THANKS_IMAGE_S3_URL = "https://tipp-coaching-live.s3.ap-northeast-2.amazonaws.com/images/curriculum_review_thanks.svg";
27
+ function CompleteReview(props) {
28
+ const { onClickReviewMyAnswer } = props;
29
+ const { reviewContents, sectionTitle, curriculum, onClickEndReview: onClickNextContents } = useCurriculumReviewContext();
30
+ const { reviewMeta } = curriculum.contents;
31
+ return /* @__PURE__ */ jsxs(
32
+ Flex,
33
+ {
34
+ align: "center",
35
+ direction: "column",
36
+ height: "100%",
37
+ justify: "between",
38
+ maxHeight: "550px",
39
+ maxWidth: "650px",
40
+ mx: "4",
41
+ my: "6",
42
+ width: "100%",
43
+ children: [
44
+ /* @__PURE__ */ jsxs(Flex, { align: "center", direction: "column", children: [
45
+ /* @__PURE__ */ jsx(Heading, { mb: "6", variant: "heading5", weight: "regular", children: (reviewMeta == null ? void 0 : reviewMeta.endReviewTopTitle) || "\uC751\uB2F5\uC744 \uC131\uACF5\uC801\uC73C\uB85C \uC81C\uCD9C\uD588\uC2B5\uB2C8\uB2E4" }),
46
+ /* @__PURE__ */ jsx(
47
+ "img",
48
+ {
49
+ alt: "complete-review",
50
+ height: 141,
51
+ src: THANKS_IMAGE_S3_URL,
52
+ width: 118
53
+ }
54
+ ),
55
+ /* @__PURE__ */ jsx(Typo, { color: "gray", mt: "6", variant: "caption", children: sectionTitle }),
56
+ /* @__PURE__ */ jsx(Heading, { variant: "heading5", children: reviewContents.title }),
57
+ /* @__PURE__ */ jsx(Typo, { align: "center", color: "gray", mt: "6", children: (reviewMeta == null ? void 0 : reviewMeta.endReviewDescription) || `\uC774\uBC88 \uD559\uC2B5\uC774 \uB9AC\uB354\uC2ED\uC5D0 \uB3C4\uC6C0\uC774 \uB418\uC5C8\uAE30\uB97C \uBC14\uB78D\uB2C8\uB2E4.
58
+ \uC55E\uC73C\uB85C \uC788\uC744 \uB9AC\uB354\uB2D8\uC758 \uC131\uC7A5\uC744 \uAE30\uB300\uD569\uB2C8\uB2E4.` })
59
+ ] }),
60
+ /* @__PURE__ */ jsxs(Grid, { columns: { initial: "1fr", md: "2" }, gap: "3", width: "100%", children: [
61
+ /* @__PURE__ */ jsxs(Button, { onClick: onClickReviewMyAnswer, variant: "outline", children: [
62
+ (reviewMeta == null ? void 0 : reviewMeta.endReviewBackButtonTitle) || "\uB098\uC758 \uC751\uB2F5 \uB2E4\uC2DC \uBCF4\uAE30",
63
+ /* @__PURE__ */ jsx(ResetIcon, {})
64
+ ] }),
65
+ /* @__PURE__ */ jsxs(Button, { onClick: onClickNextContents, children: [
66
+ "\uCEE4\uB9AC\uD058\uB7FC\uC73C\uB85C \uB3CC\uC544\uAC00\uAE30",
67
+ /* @__PURE__ */ jsx(HomeIcon, {})
68
+ ] })
69
+ ] })
70
+ ]
71
+ }
72
+ );
73
+ }
74
+ var complete_review_default = CompleteReview;
75
+
76
+ export {
77
+ complete_review_default
78
+ };
79
+ //# sourceMappingURL=chunk-PYGTM7ML.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/complete-review.tsx"],"sourcesContent":["import React from 'react';\nimport { Button } from '@/atoms/button';\nimport { Flex } from '@/atoms/flex';\nimport { Grid } from '@/atoms/grid';\nimport { Heading } from '@/atoms/heading';\nimport { Typo } from '@/atoms/typo';\nimport { HomeIcon, ResetIcon } from '@/icon';\nimport { useCurriculumReviewContext } from './curriculum-review-context';\n\nconst THANKS_IMAGE_S3_URL = 'https://tipp-coaching-live.s3.ap-northeast-2.amazonaws.com/images/curriculum_review_thanks.svg';\n\nfunction CompleteReview(props: {\n onClickReviewMyAnswer: () => void;\n}): React.ReactNode {\n const { onClickReviewMyAnswer } = props;\n const { reviewContents, sectionTitle, curriculum, onClickEndReview: onClickNextContents } =\n useCurriculumReviewContext();\n\n const { reviewMeta } = curriculum.contents;\n\n return (\n <Flex\n align=\"center\"\n direction=\"column\"\n height=\"100%\"\n justify=\"between\"\n maxHeight=\"550px\"\n maxWidth=\"650px\"\n mx=\"4\"\n my=\"6\"\n width=\"100%\"\n >\n <Flex align=\"center\" direction=\"column\">\n <Heading mb=\"6\" variant=\"heading5\" weight=\"regular\">\n {reviewMeta?.endReviewTopTitle || '응답을 성공적으로 제출했습니다'}\n </Heading>\n <img\n alt=\"complete-review\"\n height={141}\n src={THANKS_IMAGE_S3_URL}\n width={118}\n />\n <Typo color=\"gray\" mt=\"6\" variant=\"caption\">\n {sectionTitle}\n </Typo>\n <Heading variant=\"heading5\">{reviewContents.title}</Heading>\n <Typo align=\"center\" color=\"gray\" mt=\"6\">\n {reviewMeta?.endReviewDescription ||\n `이번 학습이 리더십에 도움이 되었기를 바랍니다.\\n 앞으로 있을 리더님의 성장을 기대합니다.`}\n </Typo>\n </Flex>\n\n <Grid columns={{ initial: '1fr', md: '2' }} gap=\"3\" width=\"100%\">\n <Button onClick={onClickReviewMyAnswer} variant=\"outline\">\n {reviewMeta?.endReviewBackButtonTitle || '나의 응답 다시 보기'}\n <ResetIcon />\n </Button>\n <Button onClick={onClickNextContents}>\n 커리큘럼으로 돌아가기 \n <HomeIcon />\n </Button>\n </Grid>\n </Flex>\n );\n}\n\nexport default CompleteReview;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAgCM,SACE,KADF;AAvBN,IAAM,sBAAsB;AAE5B,SAAS,eAAe,OAEJ;AAClB,QAAM,EAAE,sBAAsB,IAAI;AAClC,QAAM,EAAE,gBAAgB,cAAc,YAAY,kBAAkB,oBAAoB,IACtF,2BAA2B;AAE7B,QAAM,EAAE,WAAW,IAAI,WAAW;AAElC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,OAAM;AAAA,MACN,WAAU;AAAA,MACV,QAAO;AAAA,MACP,SAAQ;AAAA,MACR,WAAU;AAAA,MACV,UAAS;AAAA,MACT,IAAG;AAAA,MACH,IAAG;AAAA,MACH,OAAM;AAAA,MAEN;AAAA,6BAAC,QAAK,OAAM,UAAS,WAAU,UAC7B;AAAA,8BAAC,WAAQ,IAAG,KAAI,SAAQ,YAAW,QAAO,WACvC,oDAAY,sBAAqB,0FACpC;AAAA,UACA;AAAA,YAAC;AAAA;AAAA,cACC,KAAI;AAAA,cACJ,QAAQ;AAAA,cACR,KAAK;AAAA,cACL,OAAO;AAAA;AAAA,UACT;AAAA,UACA,oBAAC,QAAK,OAAM,QAAO,IAAG,KAAI,SAAQ,WAC/B,wBACH;AAAA,UACA,oBAAC,WAAQ,SAAQ,YAAY,yBAAe,OAAM;AAAA,UAClD,oBAAC,QAAK,OAAM,UAAS,OAAM,QAAO,IAAG,KAClC,oDAAY,yBACX;AAAA,+GACJ;AAAA,WACF;AAAA,QAEA,qBAAC,QAAK,SAAS,EAAE,SAAS,OAAO,IAAI,IAAI,GAAG,KAAI,KAAI,OAAM,QACxD;AAAA,+BAAC,UAAO,SAAS,uBAAuB,SAAQ,WAC7C;AAAA,sDAAY,6BAA4B;AAAA,YACzC,oBAAC,aAAU;AAAA,aACb;AAAA,UACA,qBAAC,UAAQ,SAAS,qBAAqB;AAAA;AAAA,YAErC,oBAAC,YAAS;AAAA,aACZ;AAAA,WACF;AAAA;AAAA;AAAA,EACF;AAEJ;AAEA,IAAO,0BAAQ;","names":[]}