@tipp/ui 2.3.9 → 2.3.11

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 (208) hide show
  1. package/dist/app/index.cjs +4 -3
  2. package/dist/app/index.cjs.map +1 -1
  3. package/dist/app/index.js +20 -20
  4. package/dist/app/platform/coach-question-list.cjs.map +1 -1
  5. package/dist/app/platform/coach-question-list.js +1 -1
  6. package/dist/app/platform/contents-card.cjs.map +1 -1
  7. package/dist/app/platform/contents-card.js +1 -1
  8. package/dist/app/platform/edit-coaching-time.cjs +4 -3
  9. package/dist/app/platform/edit-coaching-time.cjs.map +1 -1
  10. package/dist/app/platform/edit-coaching-time.js +17 -17
  11. package/dist/app/platform/edit-service-type.cjs +4 -3
  12. package/dist/app/platform/edit-service-type.cjs.map +1 -1
  13. package/dist/app/platform/edit-service-type.js +17 -17
  14. package/dist/app/platform/goal-manage-card-edit.cjs +4 -3
  15. package/dist/app/platform/goal-manage-card-edit.cjs.map +1 -1
  16. package/dist/app/platform/goal-manage-card-edit.js +17 -17
  17. package/dist/app/platform/goal-manage-card-read.cjs.map +1 -1
  18. package/dist/app/platform/goal-manage-card-read.js +1 -1
  19. package/dist/app/platform/on-offline-radio-card.cjs +77 -76
  20. package/dist/app/platform/on-offline-radio-card.cjs.map +1 -1
  21. package/dist/app/platform/on-offline-radio-card.js +17 -17
  22. package/dist/app/platform/report-card.cjs.map +1 -1
  23. package/dist/app/platform/report-card.js +1 -1
  24. package/dist/app/platform/reservation-card.cjs +4 -3
  25. package/dist/app/platform/reservation-card.cjs.map +1 -1
  26. package/dist/app/platform/reservation-card.js +17 -17
  27. package/dist/app/platform/session-card.cjs +4 -3
  28. package/dist/app/platform/session-card.cjs.map +1 -1
  29. package/dist/app/platform/session-card.js +17 -17
  30. package/dist/app/platform/session-review-simple-read.cjs.map +1 -1
  31. package/dist/app/platform/session-review-simple-read.js +1 -1
  32. package/dist/app/platform/userInfos/coaching-customer-info/index.cjs.map +1 -1
  33. package/dist/app/platform/userInfos/coaching-customer-info/index.js +1 -1
  34. package/dist/app/platform/userInfos/coaching-customer-info/large.cjs.map +1 -1
  35. package/dist/app/platform/userInfos/coaching-customer-info/large.js +1 -1
  36. package/dist/app/platform/userInfos/coaching-customer-info/medium.cjs.map +1 -1
  37. package/dist/app/platform/userInfos/coaching-customer-info/medium.js +1 -1
  38. package/dist/app/platform/userInfos/coaching-customer-info/small.cjs.map +1 -1
  39. package/dist/app/platform/userInfos/coaching-customer-info/small.js +1 -1
  40. package/dist/app/platform/userInfos/session-user-info-detail.cjs.map +1 -1
  41. package/dist/app/platform/userInfos/session-user-info-detail.js +1 -1
  42. package/dist/app/platform/userInfos/utils.cjs.map +1 -1
  43. package/dist/app/platform/userInfos/utils.js +1 -1
  44. package/dist/atoms/index.cjs +1 -1
  45. package/dist/atoms/index.cjs.map +1 -1
  46. package/dist/atoms/index.js +1 -1
  47. package/dist/atoms/pagination.cjs +1 -1
  48. package/dist/atoms/pagination.cjs.map +1 -1
  49. package/dist/atoms/pagination.js +1 -1
  50. package/dist/chunk-26O2ATMO.js +196 -0
  51. package/dist/chunk-26O2ATMO.js.map +1 -0
  52. package/dist/chunk-2HNIO3ZS.js +174 -0
  53. package/dist/chunk-2HNIO3ZS.js.map +1 -0
  54. package/dist/chunk-3IH2QVBB.js +37 -0
  55. package/dist/chunk-3IH2QVBB.js.map +1 -0
  56. package/dist/chunk-3PE6JQJD.js +199 -0
  57. package/dist/chunk-3PE6JQJD.js.map +1 -0
  58. package/dist/chunk-3ZWQBI3C.js +228 -0
  59. package/dist/chunk-3ZWQBI3C.js.map +1 -0
  60. package/dist/chunk-565LGGCZ.js +198 -0
  61. package/dist/chunk-565LGGCZ.js.map +1 -0
  62. package/dist/chunk-5ALF4QOO.js +51 -0
  63. package/dist/chunk-5ALF4QOO.js.map +1 -0
  64. package/dist/chunk-5I2YBHKM.js +209 -0
  65. package/dist/chunk-5I2YBHKM.js.map +1 -0
  66. package/dist/chunk-5OTWI6C5.js +124 -0
  67. package/dist/chunk-5OTWI6C5.js.map +1 -0
  68. package/dist/chunk-5QWMYOYQ.js +101 -0
  69. package/dist/chunk-5QWMYOYQ.js.map +1 -0
  70. package/dist/chunk-6MXZLFKB.js +215 -0
  71. package/dist/chunk-6MXZLFKB.js.map +1 -0
  72. package/dist/chunk-7EDFQO6G.js +145 -0
  73. package/dist/chunk-7EDFQO6G.js.map +1 -0
  74. package/dist/chunk-AE37PV3K.js +64 -0
  75. package/dist/chunk-AE37PV3K.js.map +1 -0
  76. package/dist/chunk-AWLRACTU.js +217 -0
  77. package/dist/chunk-AWLRACTU.js.map +1 -0
  78. package/dist/chunk-BAS5S6ZI.js +144 -0
  79. package/dist/chunk-BAS5S6ZI.js.map +1 -0
  80. package/dist/chunk-BBEGVL2S.js +69 -0
  81. package/dist/chunk-BBEGVL2S.js.map +1 -0
  82. package/dist/chunk-C2KPQPFR.js +209 -0
  83. package/dist/chunk-C2KPQPFR.js.map +1 -0
  84. package/dist/chunk-C3GC2Y34.js +209 -0
  85. package/dist/chunk-C3GC2Y34.js.map +1 -0
  86. package/dist/chunk-CRPH7YI5.js +221 -0
  87. package/dist/chunk-CRPH7YI5.js.map +1 -0
  88. package/dist/chunk-D7DI7CJ5.js +63 -0
  89. package/dist/chunk-D7DI7CJ5.js.map +1 -0
  90. package/dist/chunk-DG5A2RUZ.js +215 -0
  91. package/dist/chunk-DG5A2RUZ.js.map +1 -0
  92. package/dist/chunk-DLFBF5KJ.js +217 -0
  93. package/dist/chunk-DLFBF5KJ.js.map +1 -0
  94. package/dist/chunk-E2ISFADW.js +196 -0
  95. package/dist/chunk-E2ISFADW.js.map +1 -0
  96. package/dist/chunk-E3E6FV2T.js +64 -0
  97. package/dist/chunk-E3E6FV2T.js.map +1 -0
  98. package/dist/chunk-EBMQ6DIV.js +89 -0
  99. package/dist/chunk-EBMQ6DIV.js.map +1 -0
  100. package/dist/chunk-EWIRNKMR.js +49 -0
  101. package/dist/chunk-EWIRNKMR.js.map +1 -0
  102. package/dist/chunk-FG3WT6OL.js +125 -0
  103. package/dist/chunk-FG3WT6OL.js.map +1 -0
  104. package/dist/chunk-FRKPPLQP.js +223 -0
  105. package/dist/chunk-FRKPPLQP.js.map +1 -0
  106. package/dist/chunk-G6ZWPY57.js +99 -0
  107. package/dist/chunk-G6ZWPY57.js.map +1 -0
  108. package/dist/chunk-GCDGKRQQ.js +117 -0
  109. package/dist/chunk-GCDGKRQQ.js.map +1 -0
  110. package/dist/chunk-GROWIYD2.js +169 -0
  111. package/dist/chunk-GROWIYD2.js.map +1 -0
  112. package/dist/chunk-HHZ4HLP6.js +221 -0
  113. package/dist/chunk-HHZ4HLP6.js.map +1 -0
  114. package/dist/chunk-HPG6F7VM.js +165 -0
  115. package/dist/chunk-HPG6F7VM.js.map +1 -0
  116. package/dist/chunk-HQPSFOVV.js +43 -0
  117. package/dist/chunk-HQPSFOVV.js.map +1 -0
  118. package/dist/chunk-I7M6TY5G.js +64 -0
  119. package/dist/chunk-I7M6TY5G.js.map +1 -0
  120. package/dist/chunk-IFY3MMGL.js +144 -0
  121. package/dist/chunk-IFY3MMGL.js.map +1 -0
  122. package/dist/chunk-JWT2CPYX.js +221 -0
  123. package/dist/chunk-JWT2CPYX.js.map +1 -0
  124. package/dist/chunk-KTXRU3WQ.js +196 -0
  125. package/dist/chunk-KTXRU3WQ.js.map +1 -0
  126. package/dist/chunk-LVPXFDRY.js +145 -0
  127. package/dist/chunk-LVPXFDRY.js.map +1 -0
  128. package/dist/chunk-LWM3GQX2.js +89 -0
  129. package/dist/chunk-LWM3GQX2.js.map +1 -0
  130. package/dist/chunk-MCI6Y2QP.js +61 -0
  131. package/dist/chunk-MCI6Y2QP.js.map +1 -0
  132. package/dist/chunk-NMRNR5OA.js +221 -0
  133. package/dist/chunk-NMRNR5OA.js.map +1 -0
  134. package/dist/chunk-NQLHTDVA.js +209 -0
  135. package/dist/chunk-NQLHTDVA.js.map +1 -0
  136. package/dist/chunk-ODYLHCQD.js +87 -0
  137. package/dist/chunk-ODYLHCQD.js.map +1 -0
  138. package/dist/chunk-OJOTDNKG.js +69 -0
  139. package/dist/chunk-OJOTDNKG.js.map +1 -0
  140. package/dist/chunk-OVYSIME4.js +63 -0
  141. package/dist/chunk-OVYSIME4.js.map +1 -0
  142. package/dist/chunk-PNXD4FUW.js +199 -0
  143. package/dist/chunk-PNXD4FUW.js.map +1 -0
  144. package/dist/chunk-PQ7EVMOK.js +209 -0
  145. package/dist/chunk-PQ7EVMOK.js.map +1 -0
  146. package/dist/chunk-PT5BQZPO.js +124 -0
  147. package/dist/chunk-PT5BQZPO.js.map +1 -0
  148. package/dist/chunk-PV45TKNY.js +217 -0
  149. package/dist/chunk-PV45TKNY.js.map +1 -0
  150. package/dist/chunk-QMPSKZJ2.js +221 -0
  151. package/dist/chunk-QMPSKZJ2.js.map +1 -0
  152. package/dist/chunk-RDCEN45M.js +89 -0
  153. package/dist/chunk-RDCEN45M.js.map +1 -0
  154. package/dist/chunk-RYBQ4OMI.js +199 -0
  155. package/dist/chunk-RYBQ4OMI.js.map +1 -0
  156. package/dist/chunk-SBJOKO35.js +125 -0
  157. package/dist/chunk-SBJOKO35.js.map +1 -0
  158. package/dist/chunk-SPB56SRF.js +199 -0
  159. package/dist/chunk-SPB56SRF.js.map +1 -0
  160. package/dist/chunk-VGDK7BHK.js +198 -0
  161. package/dist/chunk-VGDK7BHK.js.map +1 -0
  162. package/dist/chunk-WGQGVPGZ.js +222 -0
  163. package/dist/chunk-WGQGVPGZ.js.map +1 -0
  164. package/dist/chunk-WQEMCAKF.js +198 -0
  165. package/dist/chunk-WQEMCAKF.js.map +1 -0
  166. package/dist/chunk-XK3725XB.js +87 -0
  167. package/dist/chunk-XK3725XB.js.map +1 -0
  168. package/dist/chunk-XQUM7KZW.js +29 -0
  169. package/dist/chunk-XQUM7KZW.js.map +1 -0
  170. package/dist/chunk-XXSZHE7S.js +217 -0
  171. package/dist/chunk-XXSZHE7S.js.map +1 -0
  172. package/dist/chunk-XYJ6JLAZ.js +124 -0
  173. package/dist/chunk-XYJ6JLAZ.js.map +1 -0
  174. package/dist/chunk-YEGT662X.js +221 -0
  175. package/dist/chunk-YEGT662X.js.map +1 -0
  176. package/dist/chunk-YLFGGCST.js +68 -0
  177. package/dist/chunk-YLFGGCST.js.map +1 -0
  178. package/dist/chunk-YXPMFEO5.js +151 -0
  179. package/dist/chunk-YXPMFEO5.js.map +1 -0
  180. package/dist/chunk-ZBN7YZEV.js +215 -0
  181. package/dist/chunk-ZBN7YZEV.js.map +1 -0
  182. package/dist/chunk-ZBZ7IGBT.js +222 -0
  183. package/dist/chunk-ZBZ7IGBT.js.map +1 -0
  184. package/dist/chunk-ZS44RD54.js +363 -0
  185. package/dist/chunk-ZS44RD54.js.map +1 -0
  186. package/dist/index.cjs +43 -19
  187. package/dist/index.cjs.map +1 -1
  188. package/dist/index.css +77 -38
  189. package/dist/index.js +34 -34
  190. package/dist/molecules/curriculumV2/CurriculumContents/CurriculumReviewSteps/index.js +2 -2
  191. package/dist/molecules/curriculumV2/CurriculumContents/curriculum-review.js +3 -3
  192. package/dist/molecules/curriculumV2/CurriculumContents/index.js +5 -5
  193. package/dist/molecules/curriculumV2/CurriculumSidebar/index.js +3 -3
  194. package/dist/molecules/curriculumV2/CurriculumSidebar/sidebar-item.js +2 -2
  195. package/dist/molecules/curriculumV2/index.js +13 -13
  196. package/dist/molecules/expand-table/index.cjs +35 -11
  197. package/dist/molecules/expand-table/index.cjs.map +1 -1
  198. package/dist/molecules/expand-table/index.d.cts +2 -0
  199. package/dist/molecules/expand-table/index.d.ts +2 -0
  200. package/dist/molecules/expand-table/index.js +2 -2
  201. package/dist/molecules/index.cjs +172 -148
  202. package/dist/molecules/index.cjs.map +1 -1
  203. package/dist/molecules/index.js +26 -26
  204. package/dist/molecules/time-select.js +1 -1
  205. package/dist/utils/index.js +3 -3
  206. package/package.json +1 -1
  207. package/src/atoms/pagination.tsx +1 -1
  208. package/src/molecules/expand-table/index.tsx +108 -85
@@ -0,0 +1,228 @@
1
+ import {
2
+ OnOfflineRadioCard
3
+ } from "./chunk-M2PVHXOE.js";
4
+ import {
5
+ DatePickerButton
6
+ } from "./chunk-5ZIFEE7H.js";
7
+ import {
8
+ toast
9
+ } from "./chunk-EEKOTWBE.js";
10
+ import {
11
+ Grid
12
+ } from "./chunk-EGEQY3KT.js";
13
+ import {
14
+ Inset
15
+ } from "./chunk-XQOL7UBI.js";
16
+ import {
17
+ Heading
18
+ } from "./chunk-BESTU2AY.js";
19
+ import {
20
+ Card
21
+ } from "./chunk-RP2RGCAW.js";
22
+ import {
23
+ Badge
24
+ } from "./chunk-U3BQT7ZO.js";
25
+ import {
26
+ Box
27
+ } from "./chunk-4Y5BEXVN.js";
28
+ import {
29
+ BulletText
30
+ } from "./chunk-Z34HR7RE.js";
31
+ import {
32
+ Typo
33
+ } from "./chunk-PMJIFLDT.js";
34
+ import {
35
+ Flex
36
+ } from "./chunk-25HMMI7R.js";
37
+ import {
38
+ Button
39
+ } from "./chunk-ZVDAEY5Q.js";
40
+ import {
41
+ ArrowRightIcon,
42
+ Cross1Icon
43
+ } from "./chunk-W5TPOFOO.js";
44
+ import {
45
+ __spreadProps,
46
+ __spreadValues
47
+ } from "./chunk-CRTRMMJ7.js";
48
+
49
+ // src/app/platform/reservation-card.tsx
50
+ import { useCallback, useEffect, useMemo, useState } from "react";
51
+ import { format } from "date-fns";
52
+ import { ko } from "date-fns/locale";
53
+ import { jsx, jsxs } from "react/jsx-runtime";
54
+ function ReservationCard(props) {
55
+ const {
56
+ sessionNumber,
57
+ customerName,
58
+ readonly,
59
+ defaultTime,
60
+ defaultType,
61
+ error,
62
+ minTime,
63
+ maxTime,
64
+ onClickReserve,
65
+ onClickCancel,
66
+ onClickCompleteSession
67
+ } = props;
68
+ const [editValues, setEditValues] = useState({
69
+ date: props.defaultTime,
70
+ type: props.defaultType
71
+ });
72
+ const date = readonly ? defaultTime : editValues.date;
73
+ const type = readonly ? defaultType : editValues.type;
74
+ const onClickSave = useCallback(() => {
75
+ var _a;
76
+ (_a = props.onClickSave) == null ? void 0 : _a.call(props, editValues);
77
+ }, [editValues, props]);
78
+ const onClickReset = useCallback(() => {
79
+ setEditValues({
80
+ date: defaultTime,
81
+ type: defaultType
82
+ });
83
+ }, [defaultTime, defaultType]);
84
+ const ActionButtons = useMemo(() => {
85
+ if (readonly) {
86
+ return /* @__PURE__ */ jsx(Button, { onClick: onClickReserve, size: "small", variant: "surface", children: defaultTime && defaultType ? "\uC608\uC57D \uC218\uC815\uD558\uAE30" : "\uC608\uC57D\uD558\uAE30" });
87
+ }
88
+ return /* @__PURE__ */ jsx(Button, { color: "gray", onClick: onClickCancel, variant: "transparent", children: /* @__PURE__ */ jsx(Cross1Icon, {}) });
89
+ }, [defaultTime, defaultType, onClickCancel, onClickReserve, readonly]);
90
+ const onChangeDate = useCallback((newDate) => {
91
+ if (!newDate) return;
92
+ setEditValues((prev) => {
93
+ return __spreadProps(__spreadValues({}, prev), {
94
+ date: newDate
95
+ });
96
+ });
97
+ }, []);
98
+ const onChangeType = useCallback((newType) => {
99
+ setEditValues((prev) => {
100
+ return __spreadProps(__spreadValues({}, prev), {
101
+ type: newType
102
+ });
103
+ });
104
+ }, []);
105
+ const formatDate = useCallback((v) => {
106
+ return format(v, "yyyy\uB144 MM\uC6D4 dd\uC77C(EEE) aa h:mm", { locale: ko });
107
+ }, []);
108
+ useEffect(() => {
109
+ if (!minTime || !editValues.date || readonly) return;
110
+ if (editValues.date < minTime) {
111
+ toast.warn("\uC120\uD0DD \uAC00\uB2A5\uD55C \uC2DC\uAC04\uB300\uB85C \uBCC0\uACBD\uB418\uC5C8\uC2B5\uB2C8\uB2E4.");
112
+ setEditValues((prev) => {
113
+ return __spreadProps(__spreadValues({}, prev), {
114
+ date: minTime
115
+ });
116
+ });
117
+ }
118
+ }, [editValues, minTime, readonly]);
119
+ useEffect(() => {
120
+ if (!maxTime || !editValues.date || readonly) return;
121
+ if (editValues.date > maxTime) {
122
+ toast.warn("\uC120\uD0DD \uAC00\uB2A5\uD55C \uC2DC\uAC04\uB300\uB85C \uBCC0\uACBD\uB418\uC5C8\uC2B5\uB2C8\uB2E4.");
123
+ setEditValues((prev) => {
124
+ return __spreadProps(__spreadValues({}, prev), {
125
+ date: maxTime
126
+ });
127
+ });
128
+ }
129
+ }, [editValues, maxTime, readonly]);
130
+ return /* @__PURE__ */ jsxs(
131
+ Card,
132
+ {
133
+ error: Boolean(error),
134
+ size: "3",
135
+ style: { overflow: "visible", contain: "initial" },
136
+ children: [
137
+ /* @__PURE__ */ jsxs(Flex, { gap: "3", justify: "between", mb: "5", children: [
138
+ /* @__PURE__ */ jsxs(
139
+ Grid,
140
+ {
141
+ align: "center",
142
+ columns: { initial: "1", xs: "auto 1fr" },
143
+ gapY: "2",
144
+ children: [
145
+ /* @__PURE__ */ jsxs(Flex, { align: "center", children: [
146
+ /* @__PURE__ */ jsxs(Heading, { variant: "heading4", children: [
147
+ customerName || "-",
148
+ "\uB2D8 ",
149
+ sessionNumber || "-",
150
+ "\uD68C\uCC28 \uC138\uC158"
151
+ ] }),
152
+ /* @__PURE__ */ jsx(Badge, { ml: "2", children: "\uB2E4\uC74C \uC138\uC158" })
153
+ ] }),
154
+ error ? /* @__PURE__ */ jsx(BulletText, { color: "red", variant: "caption", children: error }) : null
155
+ ]
156
+ }
157
+ ),
158
+ /* @__PURE__ */ jsx(Flex, { children: ActionButtons })
159
+ ] }),
160
+ /* @__PURE__ */ jsx(Box, { children: /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "5", children: [
161
+ /* @__PURE__ */ jsx(Heading, { mb: "2", variant: "heading5", weight: "regular", children: "\uC138\uC158 \uC77C\uC790\uC640 \uC2DC\uAC01" }),
162
+ /* @__PURE__ */ jsx(
163
+ DatePickerButton,
164
+ {
165
+ disabled: readonly,
166
+ format: formatDate,
167
+ maxDate: maxTime,
168
+ minDate: minTime,
169
+ onChange: onChangeDate,
170
+ placeholder: "\uC77C\uC790\uB97C \uC120\uD0DD\uD574\uC8FC\uC138\uC694",
171
+ selected: date,
172
+ showTimeSelect: true,
173
+ size: "large"
174
+ }
175
+ ),
176
+ /* @__PURE__ */ jsx(Heading, { mb: "2", variant: "heading5", weight: "regular", children: "\uC628/\uC624\uD504\uB77C\uC778 \uC9C4\uD589 \uC5EC\uBD80" }),
177
+ /* @__PURE__ */ jsx(
178
+ OnOfflineRadioCard,
179
+ {
180
+ disabled: readonly,
181
+ onValueChange: onChangeType,
182
+ size: "1",
183
+ value: type
184
+ }
185
+ ),
186
+ readonly ? null : /* @__PURE__ */ jsxs(Flex, { align: "center", gap: "3", justify: "end", children: [
187
+ /* @__PURE__ */ jsx(
188
+ Button,
189
+ {
190
+ color: "gray",
191
+ onClick: onClickReset,
192
+ size: "small",
193
+ variant: "transparent",
194
+ children: "\uCD08\uAE30\uD654\uD558\uAE30"
195
+ }
196
+ ),
197
+ /* @__PURE__ */ jsx(Button, { onClick: onClickSave, size: "small", children: "\uC800\uC7A5\uD558\uAE30" })
198
+ ] })
199
+ ] }) }),
200
+ readonly ? /* @__PURE__ */ jsx(Inset, { clip: "border-box", side: "bottom", children: /* @__PURE__ */ jsx(
201
+ Box,
202
+ {
203
+ mt: "5",
204
+ px: "5",
205
+ py: "4",
206
+ style: { backgroundColor: "var(--accent-a3)" },
207
+ width: "100%",
208
+ children: /* @__PURE__ */ jsxs(Flex, { align: "center", gap: "4", justify: "center", children: [
209
+ /* @__PURE__ */ jsxs(Typo, { children: [
210
+ sessionNumber || "-",
211
+ "\uD68C\uCC28 \uC138\uC158\uC744 \uC644\uB8CC\uD558\uC168\uB098\uC694?"
212
+ ] }),
213
+ /* @__PURE__ */ jsxs(Button, { onClick: onClickCompleteSession, size: "small", children: [
214
+ "\uC138\uC158 \uC885\uB8CC\uD558\uAE30",
215
+ /* @__PURE__ */ jsx(ArrowRightIcon, {})
216
+ ] })
217
+ ] })
218
+ }
219
+ ) }) : null
220
+ ]
221
+ }
222
+ );
223
+ }
224
+
225
+ export {
226
+ ReservationCard
227
+ };
228
+ //# sourceMappingURL=chunk-3ZWQBI3C.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/app/platform/reservation-card.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { format } from 'date-fns';\nimport { ko } from 'date-fns/locale';\nimport {\n Badge,\n Box,\n BulletText,\n Button,\n Card,\n Flex,\n Form,\n Grid,\n Heading,\n Inset,\n toast,\n Typo,\n} from '../../atoms';\nimport { ArrowRightIcon, Cross1Icon } from '../../icon';\nimport { DatePickerButton } from '../../molecules';\nimport { OnOfflineRadioCard } from './on-offline-radio-card';\n\ntype Type = 'onlineCoaching' | 'offlineCoaching';\n\ninterface Values {\n date?: Date;\n type?: Type;\n}\n\nexport interface ReservationCardProps {\n sessionNumber?: number;\n readonly?: boolean;\n defaultTime?: Date;\n defaultType?: Type;\n customerName?: string;\n error?: string;\n onClickCompleteSession?: () => void;\n onClickReserve?: () => void;\n onClickSave?: (values: Values) => void;\n onClickCancel?: () => void;\n minTime?: Date;\n maxTime?: Date;\n}\n\nexport function ReservationCard(props: ReservationCardProps): React.ReactNode {\n const {\n sessionNumber,\n customerName,\n readonly,\n defaultTime,\n defaultType,\n error,\n minTime,\n maxTime,\n onClickReserve,\n onClickCancel,\n onClickCompleteSession,\n } = props;\n\n const [editValues, setEditValues] = useState<Values>({\n date: props.defaultTime,\n type: props.defaultType,\n });\n\n const date = readonly ? defaultTime : editValues.date;\n const type = readonly ? defaultType : editValues.type;\n\n const onClickSave = useCallback(() => {\n props.onClickSave?.(editValues);\n }, [editValues, props]);\n\n const onClickReset = useCallback(() => {\n setEditValues({\n date: defaultTime,\n type: defaultType,\n });\n }, [defaultTime, defaultType]);\n\n const ActionButtons = useMemo(() => {\n if (readonly) {\n return (\n <Button onClick={onClickReserve} size=\"small\" variant=\"surface\">\n {defaultTime && defaultType ? '예약 수정하기' : '예약하기'}\n </Button>\n );\n }\n return (\n <Button color=\"gray\" onClick={onClickCancel} variant=\"transparent\">\n <Cross1Icon />\n </Button>\n );\n }, [defaultTime, defaultType, onClickCancel, onClickReserve, readonly]);\n\n const onChangeDate = useCallback((newDate: Date | null) => {\n if (!newDate) return;\n setEditValues((prev) => {\n return {\n ...prev,\n date: newDate,\n };\n });\n }, []);\n\n const onChangeType = useCallback((newType: string) => {\n setEditValues((prev) => {\n return {\n ...prev,\n type: newType as Type,\n };\n });\n }, []);\n\n const formatDate = useCallback((v: Date) => {\n return format(v, 'yyyy년 MM월 dd일(EEE) aa h:mm', { locale: ko });\n }, []);\n\n useEffect(() => {\n if (!minTime || !editValues.date || readonly) return;\n if (editValues.date < minTime) {\n toast.warn('선택 가능한 시간대로 변경되었습니다.');\n setEditValues((prev) => {\n return {\n ...prev,\n date: minTime,\n };\n });\n }\n }, [editValues, minTime, readonly]);\n\n useEffect(() => {\n if (!maxTime || !editValues.date || readonly) return;\n if (editValues.date > maxTime) {\n toast.warn('선택 가능한 시간대로 변경되었습니다.');\n setEditValues((prev) => {\n return {\n ...prev,\n date: maxTime,\n };\n });\n }\n }, [editValues, maxTime, readonly]);\n\n return (\n <Card\n error={Boolean(error)}\n size=\"3\"\n style={{ overflow: 'visible', contain: 'initial' }}\n >\n <Flex gap=\"3\" justify=\"between\" mb=\"5\">\n <Grid\n align=\"center\"\n columns={{ initial: '1', xs: 'auto 1fr' }}\n gapY=\"2\"\n >\n <Flex align=\"center\">\n <Heading variant=\"heading4\">\n {customerName || '-'}님 {sessionNumber || '-'}회차 세션\n </Heading>\n <Badge ml=\"2\">다음 세션</Badge>\n </Flex>\n {error ? (\n <BulletText color=\"red\" variant=\"caption\">\n {error}\n </BulletText>\n ) : null}\n </Grid>\n <Flex>{ActionButtons}</Flex>\n </Flex>\n\n <Box>\n <Flex direction=\"column\" gap=\"5\">\n <Heading mb=\"2\" variant=\"heading5\" weight=\"regular\">\n 세션 일자와 시각\n </Heading>\n <DatePickerButton\n disabled={readonly}\n format={formatDate}\n maxDate={maxTime}\n minDate={minTime}\n onChange={onChangeDate}\n placeholder=\"일자를 선택해주세요\"\n selected={date}\n showTimeSelect\n size=\"large\"\n />\n\n <Heading mb=\"2\" variant=\"heading5\" weight=\"regular\">\n 온/오프라인 진행 여부\n </Heading>\n <OnOfflineRadioCard\n disabled={readonly}\n onValueChange={onChangeType}\n size=\"1\"\n value={type}\n />\n\n {readonly ? null : (\n <Flex align=\"center\" gap=\"3\" justify=\"end\">\n <Button\n color=\"gray\"\n onClick={onClickReset}\n size=\"small\"\n variant=\"transparent\"\n >\n 초기화하기\n </Button>\n <Button onClick={onClickSave} size=\"small\">\n 저장하기\n </Button>\n </Flex>\n )}\n </Flex>\n </Box>\n\n {readonly ? (\n <Inset clip=\"border-box\" side=\"bottom\">\n <Box\n mt=\"5\"\n px=\"5\"\n py=\"4\"\n style={{ backgroundColor: 'var(--accent-a3)' }}\n width=\"100%\"\n >\n <Flex align=\"center\" gap=\"4\" justify=\"center\">\n <Typo>{sessionNumber || '-'}회차 세션을 완료하셨나요?</Typo>\n <Button onClick={onClickCompleteSession} size=\"small\">\n 세션 종료하기\n <ArrowRightIcon />\n </Button>\n </Flex>\n </Box>\n </Inset>\n ) : null}\n </Card>\n );\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,198 @@
1
+ import {
2
+ Row
3
+ } from "./chunk-JCG2AUFJ.js";
4
+ import {
5
+ Spinner
6
+ } from "./chunk-FR2GDOU2.js";
7
+ import {
8
+ Pagination
9
+ } from "./chunk-JAMNT4FG.js";
10
+ import {
11
+ Flex
12
+ } from "./chunk-25HMMI7R.js";
13
+ import {
14
+ TriangleArrowUpIcon
15
+ } from "./chunk-2O45FRFQ.js";
16
+ import {
17
+ TriangleArrowDownIcon
18
+ } from "./chunk-776WBOKL.js";
19
+ import {
20
+ Typo
21
+ } from "./chunk-PMJIFLDT.js";
22
+
23
+ // src/molecules/expand-table/index.tsx
24
+ import {
25
+ flexRender,
26
+ getCoreRowModel,
27
+ useReactTable,
28
+ getSortedRowModel,
29
+ createColumnHelper,
30
+ getPaginationRowModel
31
+ } from "@tanstack/react-table";
32
+ import { useCallback, useMemo, useState } from "react";
33
+ import { jsx, jsxs } from "react/jsx-runtime";
34
+ function ExpandTable(props) {
35
+ const {
36
+ data,
37
+ columns,
38
+ ExpandComp,
39
+ placeholder,
40
+ onRowClick,
41
+ tableStyle,
42
+ showPagination = true,
43
+ isLoading,
44
+ pageIndex = 0,
45
+ pageSize = 10,
46
+ siblingCount = 2,
47
+ getRowStyle,
48
+ getCellStyle
49
+ } = props;
50
+ const defaultAlign = "left";
51
+ const [pagination, setPagination] = useState({
52
+ pageIndex: pageIndex || 0,
53
+ pageSize: pageSize || 9999
54
+ });
55
+ const [sorting, setSorting] = useState([]);
56
+ const { getRowModel, getHeaderGroups, setPageIndex } = useReactTable({
57
+ data: data || [],
58
+ columns,
59
+ getCoreRowModel: getCoreRowModel(),
60
+ getSortedRowModel: getSortedRowModel(),
61
+ state: {
62
+ sorting,
63
+ pagination
64
+ },
65
+ onSortingChange: setSorting,
66
+ getPaginationRowModel: getPaginationRowModel(),
67
+ onPaginationChange: setPagination
68
+ });
69
+ const gridTemplateColumns = useMemo(() => {
70
+ return columns.map((col) => {
71
+ var _a;
72
+ if ((_a = col.meta) == null ? void 0 : _a.autoSize) return `minmax(${col.size || 50}px, 1fr)`;
73
+ return `${col.size || 150}px`;
74
+ }).join(" ");
75
+ }, [columns]);
76
+ const rowModels = getRowModel();
77
+ const onChangePagination = useCallback(
78
+ (page) => {
79
+ setPageIndex(page - 1);
80
+ },
81
+ [setPageIndex]
82
+ );
83
+ const helpCompRender = useCallback(
84
+ (rowLength) => {
85
+ if (isLoading) {
86
+ return /* @__PURE__ */ jsx(
87
+ Flex,
88
+ {
89
+ align: "center",
90
+ height: "100%",
91
+ justify: "center",
92
+ p: "5",
93
+ width: "100%",
94
+ children: /* @__PURE__ */ jsx(Spinner, {})
95
+ }
96
+ );
97
+ }
98
+ if (rowLength === 0) {
99
+ return /* @__PURE__ */ jsx("div", { className: "tr", children: /* @__PURE__ */ jsx(Flex, { align: "center", justify: "center", children: placeholder || /* @__PURE__ */ jsx(Typo, { color: "gray", mb: "6", mt: "6", variant: "body", children: "\uB370\uC774\uD130\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4" }) }) }, "expand_placeholder");
100
+ }
101
+ return null;
102
+ },
103
+ [isLoading, placeholder]
104
+ );
105
+ const pageCount = useMemo(() => {
106
+ if (!data) return 0;
107
+ return Math.ceil(data.length / pageSize);
108
+ }, [data, pageSize]);
109
+ return /* @__PURE__ */ jsxs("div", { className: "expand-table-wrapper", children: [
110
+ /* @__PURE__ */ jsxs("div", { className: "expand-table", style: tableStyle, children: [
111
+ /* @__PURE__ */ jsx("div", { className: "thead", children: getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx(
112
+ "div",
113
+ {
114
+ className: "tr",
115
+ style: { gridTemplateColumns },
116
+ children: headerGroup.headers.map((header) => {
117
+ var _a;
118
+ const sortable = header.column.getCanSort();
119
+ const sortedState = header.column.getIsSorted();
120
+ const justifyContent = ((_a = header.column.columnDef.meta) == null ? void 0 : _a.align) || defaultAlign;
121
+ if (sortable) {
122
+ return /* @__PURE__ */ jsx("div", { className: `${justifyContent} th`, children: /* @__PURE__ */ jsxs(
123
+ "button",
124
+ {
125
+ onClick: header.column.getToggleSortingHandler(),
126
+ style: { cursor: "pointer" },
127
+ type: "button",
128
+ children: [
129
+ /* @__PURE__ */ jsx(Typo, { as: "div", variant: "body", children: flexRender(
130
+ header.column.columnDef.header,
131
+ header.getContext()
132
+ ) }),
133
+ /* @__PURE__ */ jsxs(
134
+ Flex,
135
+ {
136
+ direction: "column",
137
+ style: { marginLeft: "var(--space-2)" },
138
+ children: [
139
+ /* @__PURE__ */ jsx(
140
+ TriangleArrowUpIcon,
141
+ {
142
+ color: sortedState === "asc" ? "var(--iris-10)" : "var(--iris-6)"
143
+ }
144
+ ),
145
+ /* @__PURE__ */ jsx(
146
+ TriangleArrowDownIcon,
147
+ {
148
+ color: sortedState === "desc" ? "var(--iris-10)" : "var(--iris-6)"
149
+ }
150
+ )
151
+ ]
152
+ }
153
+ )
154
+ ]
155
+ }
156
+ ) }, header.id);
157
+ }
158
+ return /* @__PURE__ */ jsx("div", { className: `${justifyContent} th`, children: /* @__PURE__ */ jsx("div", { style: { cursor: "default" }, children: /* @__PURE__ */ jsx(Typo, { as: "div", variant: "body", children: flexRender(
159
+ header.column.columnDef.header,
160
+ header.getContext()
161
+ ) }) }) }, header.id);
162
+ })
163
+ },
164
+ headerGroup.id
165
+ )) }),
166
+ /* @__PURE__ */ jsx("div", { className: "tbody", children: helpCompRender(rowModels.rows.length) || rowModels.rows.map((row) => {
167
+ return /* @__PURE__ */ jsx(
168
+ Row,
169
+ {
170
+ ExpandComp,
171
+ defaultAlign,
172
+ getCellStyle,
173
+ getRowStyle,
174
+ gridTemplateColumns,
175
+ onRowClick,
176
+ row
177
+ },
178
+ `row_${row.id}`
179
+ );
180
+ }) })
181
+ ] }),
182
+ showPagination ? /* @__PURE__ */ jsx(Flex, { justify: "end", pt: "3", width: "100%", children: /* @__PURE__ */ jsx(
183
+ Pagination,
184
+ {
185
+ count: pageCount,
186
+ onChange: onChangePagination,
187
+ page: pagination.pageIndex + 1,
188
+ siblingCount
189
+ }
190
+ ) }) : null
191
+ ] });
192
+ }
193
+
194
+ export {
195
+ createColumnHelper,
196
+ ExpandTable
197
+ };
198
+ //# sourceMappingURL=chunk-565LGGCZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/expand-table/index.tsx"],"sourcesContent":["import type {\n ColumnDef,\n SortingState,\n RowData,\n Row as RowType,\n PaginationState,\n} from '@tanstack/react-table';\nimport type { CSSProperties } from 'react';\nimport {\n flexRender,\n getCoreRowModel,\n useReactTable,\n getSortedRowModel,\n createColumnHelper,\n getPaginationRowModel,\n} from '@tanstack/react-table';\nimport React, { useCallback, useMemo, useState } from 'react';\nimport { Flex } from '@/atoms/flex';\nimport { Pagination } from '@/atoms/pagination';\nimport { Spinner } from '@/atoms/spinner';\nimport { Typo } from '@/atoms/typo';\nimport { TriangleArrowDownIcon } from '../../icons/down';\nimport { TriangleArrowUpIcon } from '../../icons/up';\nimport { Row, type ExpandComp, type OnRowClick } from './row';\n\nexport type { ExpandComp, OnRowClick, ColumnDef, RowType as Row };\nexport { createColumnHelper };\n\nexport interface ExpandTableProps<Datum extends RowData> {\n /** 렌더할 데이터 배열 */\n data?: Datum[];\n /** 테이블 컬럼의 메타 데이터 */\n columns: ColumnDef<Datum>[];\n /** Row의 open이 true인 경우 하단의 collapse에 렌더할 컴포넌트 */\n ExpandComp?: ExpandComp<Datum>;\n /** 데이테가 없을 시 화면에 표시할 컴포넌트 */\n placeholder?: React.ReactNode;\n /** 행 클릭 시 실행할 콜백 */\n onRowClick?: OnRowClick<Datum>;\n getRowStyle?: (data: Datum) => CSSProperties;\n getCellStyle?: (data: Datum) => CSSProperties;\n tableStyle?: CSSProperties;\n isLoading?: boolean;\n\n /** pagination - 표시 유무, 기본값 true */\n showPagination?: boolean;\n /** pagination - 현재 선택된 페이지, 0부터 시작 */\n pageIndex?: number;\n /** pagination - 한 페이지에 표시될 컬럼 개수, 기본값 10 */\n pageSize?: number;\n /** pagination - */\n siblingCount?: number;\n variant: 'card' | 'line';\n}\n\nexport function ExpandTable<Datum extends RowData>(\n props: ExpandTableProps<Datum>\n): React.ReactNode {\n const {\n data,\n columns,\n ExpandComp,\n placeholder,\n onRowClick,\n tableStyle,\n showPagination = true,\n isLoading,\n pageIndex = 0,\n pageSize = 10,\n siblingCount = 2,\n getRowStyle,\n getCellStyle,\n } = props;\n const defaultAlign = 'left';\n const [pagination, setPagination] = useState<PaginationState>({\n pageIndex: pageIndex || 0,\n pageSize: pageSize || 9999,\n });\n\n const [sorting, setSorting] = useState<SortingState>([]);\n const { getRowModel, getHeaderGroups, setPageIndex } = useReactTable({\n data: data || [],\n columns,\n getCoreRowModel: getCoreRowModel(),\n getSortedRowModel: getSortedRowModel(),\n state: {\n sorting,\n pagination,\n },\n onSortingChange: setSorting,\n getPaginationRowModel: getPaginationRowModel(),\n onPaginationChange: setPagination,\n });\n\n const gridTemplateColumns = useMemo<string>(() => {\n return columns\n .map((col) => {\n if (col.meta?.autoSize) return `minmax(${col.size || 50}px, 1fr)`;\n return `${col.size || 150}px`;\n })\n .join(' ');\n }, [columns]);\n\n const rowModels = getRowModel();\n\n const onChangePagination = useCallback(\n (page: number) => {\n setPageIndex(page - 1);\n },\n [setPageIndex]\n );\n\n const helpCompRender = useCallback(\n (rowLength: number) => {\n if (isLoading) {\n return (\n <Flex\n align=\"center\"\n height=\"100%\"\n justify=\"center\"\n p=\"5\"\n width=\"100%\"\n >\n <Spinner />\n </Flex>\n );\n }\n if (rowLength === 0) {\n return (\n <div className=\"tr\" key=\"expand_placeholder\">\n <Flex align=\"center\" justify=\"center\">\n {placeholder || (\n <Typo color=\"gray\" mb=\"6\" mt=\"6\" variant=\"body\">\n 데이터가 없습니다\n </Typo>\n )}\n </Flex>\n </div>\n );\n }\n return null;\n },\n [isLoading, placeholder]\n );\n\n const pageCount = useMemo(() => {\n if (!data) return 0;\n return Math.ceil(data.length / pageSize);\n }, [data, pageSize]);\n\n return (\n <div className=\"expand-table-wrapper\">\n <div className=\"expand-table\" style={tableStyle}>\n <div className=\"thead\">\n {getHeaderGroups().map((headerGroup) => (\n <div\n className=\"tr\"\n key={headerGroup.id}\n style={{ gridTemplateColumns }}\n >\n {headerGroup.headers.map((header) => {\n const sortable = header.column.getCanSort();\n const sortedState = header.column.getIsSorted();\n const justifyContent =\n header.column.columnDef.meta?.align || defaultAlign;\n\n if (sortable) {\n return (\n <div className={`${justifyContent} th`} key={header.id}>\n <button\n onClick={header.column.getToggleSortingHandler()}\n style={{ cursor: 'pointer' }}\n type=\"button\"\n >\n <Typo as=\"div\" variant=\"body\">\n {flexRender(\n header.column.columnDef.header,\n header.getContext()\n )}\n </Typo>\n <Flex\n direction=\"column\"\n style={{ marginLeft: 'var(--space-2)' }}\n >\n <TriangleArrowUpIcon\n color={\n sortedState === 'asc'\n ? 'var(--iris-10)'\n : 'var(--iris-6)'\n }\n />\n <TriangleArrowDownIcon\n color={\n sortedState === 'desc'\n ? 'var(--iris-10)'\n : 'var(--iris-6)'\n }\n />\n </Flex>\n </button>\n </div>\n );\n }\n\n return (\n <div className={`${justifyContent} th`} key={header.id}>\n <div style={{ cursor: 'default' }}>\n <Typo as=\"div\" variant=\"body\">\n {flexRender(\n header.column.columnDef.header,\n header.getContext()\n )}\n </Typo>\n </div>\n </div>\n );\n })}\n </div>\n ))}\n </div>\n <div className=\"tbody\">\n {/* 조건에 따라 placeholder 또는 loading 렌더*/}\n {helpCompRender(rowModels.rows.length) ||\n rowModels.rows.map((row) => {\n return (\n <Row\n ExpandComp={ExpandComp}\n defaultAlign={defaultAlign}\n getCellStyle={getCellStyle}\n getRowStyle={getRowStyle}\n gridTemplateColumns={gridTemplateColumns}\n key={`row_${row.id}`}\n onRowClick={onRowClick}\n row={row}\n />\n );\n })}\n </div>\n </div>\n {showPagination ? (\n <Flex justify=\"end\" pt=\"3\" width=\"100%\">\n <Pagination\n count={pageCount}\n onChange={onChangePagination}\n page={pagination.pageIndex + 1}\n siblingCount={siblingCount}\n />\n </Flex>\n ) : null}\n </div>\n );\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,51 @@
1
+ import {
2
+ section_title_default
3
+ } from "./chunk-4TST4UK5.js";
4
+ import {
5
+ curriculum_sidebar_item_wrapper_default
6
+ } from "./chunk-WS7IOHVK.js";
7
+ import {
8
+ section_item_default
9
+ } from "./chunk-XQUM7KZW.js";
10
+ import {
11
+ getCurriculumIconColor
12
+ } from "./chunk-RYK2ILB2.js";
13
+ import {
14
+ __spreadProps,
15
+ __spreadValues
16
+ } from "./chunk-CRTRMMJ7.js";
17
+
18
+ // src/molecules/curriculumV2/CurriculumSidebar/sidebar-item.tsx
19
+ import { jsx } from "react/jsx-runtime";
20
+ function SidebarItem({ item, selectedIndex, setSelectedIndex, index, done }) {
21
+ if (item.type === "sectionTitle") {
22
+ return /* @__PURE__ */ jsx(section_title_default, __spreadValues({}, item), item.uuid);
23
+ }
24
+ const isSelected = selectedIndex === index;
25
+ return /* @__PURE__ */ jsx(
26
+ curriculum_sidebar_item_wrapper_default,
27
+ {
28
+ index,
29
+ isSelected,
30
+ onClick: () => {
31
+ setSelectedIndex(index);
32
+ },
33
+ children: /* @__PURE__ */ jsx(
34
+ section_item_default,
35
+ __spreadProps(__spreadValues({}, item), {
36
+ color: getCurriculumIconColor({
37
+ done,
38
+ selected: isSelected
39
+ })
40
+ })
41
+ )
42
+ },
43
+ item.uuid
44
+ );
45
+ }
46
+ var sidebar_item_default = SidebarItem;
47
+
48
+ export {
49
+ sidebar_item_default
50
+ };
51
+ //# sourceMappingURL=chunk-5ALF4QOO.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/curriculumV2/CurriculumSidebar/sidebar-item.tsx"],"sourcesContent":["import type { CurriculumListContents } from '@/types/curriculum.type'; \nimport { getCurriculumIconColor } from '../../../utils/curriculum.utils';\nimport SectionTitle from './Items/section-title';\nimport CurriculumSidebarItemWrapper from './Items/curriculum-sidebar-item-wrapper';\nimport SectionCommonItem from './Items/section-item';\n\n\ninterface SidebarItemProps {\n item: CurriculumListContents;\n selectedIndex: number;\n setSelectedIndex: (index: number) => void;\n index: number;\n done: boolean;\n}\n\nfunction SidebarItem({item, selectedIndex, setSelectedIndex, index, done}: SidebarItemProps): React.ReactNode {\n \n \n if (item.type === 'sectionTitle') {\n return <SectionTitle key={item.uuid} {...item} />;\n }\n const isSelected = selectedIndex === index;\n\n return (\n <CurriculumSidebarItemWrapper\n index={index}\n isSelected={isSelected}\n key={item.uuid}\n onClick={() => {\n setSelectedIndex(index);\n }}\n >\n <SectionCommonItem\n {...item}\n color={getCurriculumIconColor({\n done,\n selected: isSelected,\n })}\n />\n </CurriculumSidebarItemWrapper>\n );\n }\n\nexport default SidebarItem;"],"mappings":";;;;;;;;;;;;;;;;;;AAmBe;AAJf,SAAS,YAAY,EAAC,MAAM,eAAe,kBAAkB,OAAO,KAAI,GAAsC;AAG5G,MAAI,KAAK,SAAS,gBAAgB;AAC5B,WAAO,oBAAC,0CAAiC,OAAf,KAAK,IAAgB;AAAA,EACjD;AACA,QAAM,aAAa,kBAAkB;AAErC,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MAEA,SAAS,MAAM;AACb,yBAAiB,KAAK;AAAA,MACxB;AAAA,MAEA;AAAA,QAAC;AAAA,yCACK,OADL;AAAA,UAEC,OAAO,uBAAuB;AAAA,YAC5B;AAAA,YACA,UAAU;AAAA,UACZ,CAAC;AAAA;AAAA,MACH;AAAA;AAAA,IAXK,KAAK;AAAA,EAYZ;AAEJ;AAEJ,IAAO,uBAAQ;","names":[]}