@tipp/ui 1.5.4 → 1.5.5

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 (345) hide show
  1. package/dist/app/index.cjs +119 -122
  2. package/dist/app/index.cjs.map +1 -1
  3. package/dist/app/index.js +28 -28
  4. package/dist/app/platform/coach-question-list.cjs +44 -45
  5. package/dist/app/platform/coach-question-list.cjs.map +1 -1
  6. package/dist/app/platform/coach-question-list.js +10 -10
  7. package/dist/app/platform/edit-coaching-time.cjs +66 -67
  8. package/dist/app/platform/edit-coaching-time.cjs.map +1 -1
  9. package/dist/app/platform/edit-coaching-time.js +18 -18
  10. package/dist/app/platform/edit-service-type.cjs +63 -64
  11. package/dist/app/platform/edit-service-type.cjs.map +1 -1
  12. package/dist/app/platform/edit-service-type.js +17 -17
  13. package/dist/app/platform/goal-manage-card-edit.cjs +62 -63
  14. package/dist/app/platform/goal-manage-card-edit.cjs.map +1 -1
  15. package/dist/app/platform/goal-manage-card-edit.js +18 -18
  16. package/dist/app/platform/goal-manage-card-read.cjs +56 -57
  17. package/dist/app/platform/goal-manage-card-read.cjs.map +1 -1
  18. package/dist/app/platform/goal-manage-card-read.js +11 -11
  19. package/dist/app/platform/on-offline-radio-card.cjs +60 -61
  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 +57 -58
  23. package/dist/app/platform/report-card.cjs.map +1 -1
  24. package/dist/app/platform/report-card.js +17 -17
  25. package/dist/app/platform/reservation-card.cjs +70 -71
  26. package/dist/app/platform/reservation-card.cjs.map +1 -1
  27. package/dist/app/platform/reservation-card.js +18 -18
  28. package/dist/app/platform/session-card.cjs +77 -83
  29. package/dist/app/platform/session-card.cjs.map +1 -1
  30. package/dist/app/platform/session-card.js +19 -19
  31. package/dist/app/platform/session-review-simple-read.cjs +46 -47
  32. package/dist/app/platform/session-review-simple-read.cjs.map +1 -1
  33. package/dist/app/platform/session-review-simple-read.js +10 -10
  34. package/dist/app/platform/userInfos/coaching-customer-info/index.cjs +58 -56
  35. package/dist/app/platform/userInfos/coaching-customer-info/index.cjs.map +1 -1
  36. package/dist/app/platform/userInfos/coaching-customer-info/index.js +15 -15
  37. package/dist/app/platform/userInfos/coaching-customer-info/large.cjs +52 -50
  38. package/dist/app/platform/userInfos/coaching-customer-info/large.cjs.map +1 -1
  39. package/dist/app/platform/userInfos/coaching-customer-info/large.js +12 -12
  40. package/dist/app/platform/userInfos/coaching-customer-info/medium.cjs +52 -50
  41. package/dist/app/platform/userInfos/coaching-customer-info/medium.cjs.map +1 -1
  42. package/dist/app/platform/userInfos/coaching-customer-info/medium.js +12 -12
  43. package/dist/app/platform/userInfos/coaching-customer-info/small.cjs +47 -48
  44. package/dist/app/platform/userInfos/coaching-customer-info/small.cjs.map +1 -1
  45. package/dist/app/platform/userInfos/coaching-customer-info/small.js +11 -11
  46. package/dist/app/platform/userInfos/session-user-info-detail.cjs +49 -47
  47. package/dist/app/platform/userInfos/session-user-info-detail.cjs.map +1 -1
  48. package/dist/app/platform/userInfos/session-user-info-detail.js +12 -12
  49. package/dist/app/platform/userInfos/utils.cjs +49 -47
  50. package/dist/app/platform/userInfos/utils.cjs.map +1 -1
  51. package/dist/app/platform/userInfos/utils.d.cts +13 -12
  52. package/dist/app/platform/userInfos/utils.d.ts +13 -12
  53. package/dist/app/platform/userInfos/utils.js +11 -11
  54. package/dist/atoms/dialog.cjs +1 -7
  55. package/dist/atoms/dialog.cjs.map +1 -1
  56. package/dist/atoms/dialog.js +1 -1
  57. package/dist/atoms/drawer.cjs.map +1 -1
  58. package/dist/atoms/drawer.d.cts +1 -1
  59. package/dist/atoms/drawer.d.ts +1 -1
  60. package/dist/atoms/drawer.js +1 -1
  61. package/dist/atoms/index.cjs +67 -73
  62. package/dist/atoms/index.cjs.map +1 -1
  63. package/dist/atoms/index.js +19 -19
  64. package/dist/atoms/pagination.cjs.map +1 -1
  65. package/dist/atoms/pagination.js +2 -2
  66. package/dist/chunk-22UB6WSY.js +145 -0
  67. package/dist/chunk-22UB6WSY.js.map +1 -0
  68. package/dist/chunk-2NTOPVA7.js +145 -0
  69. package/dist/chunk-2NTOPVA7.js.map +1 -0
  70. package/dist/chunk-2SAW4LXD.js +64 -0
  71. package/dist/chunk-2SAW4LXD.js.map +1 -0
  72. package/dist/chunk-2T46PYR4.js +52 -0
  73. package/dist/chunk-2T46PYR4.js.map +1 -0
  74. package/dist/chunk-36BELSBE.js +52 -0
  75. package/dist/chunk-36BELSBE.js.map +1 -0
  76. package/dist/chunk-3WEXXGSP.js +53 -0
  77. package/dist/chunk-3WEXXGSP.js.map +1 -0
  78. package/dist/chunk-3Z3JFOQI.js +169 -0
  79. package/dist/chunk-3Z3JFOQI.js.map +1 -0
  80. package/dist/chunk-46SJO7ZG.js +350 -0
  81. package/dist/chunk-46SJO7ZG.js.map +1 -0
  82. package/dist/chunk-4FQOLDMO.js +76 -0
  83. package/dist/chunk-4FQOLDMO.js.map +1 -0
  84. package/dist/chunk-4LFEZYPK.js +89 -0
  85. package/dist/chunk-4LFEZYPK.js.map +1 -0
  86. package/dist/chunk-4N3I4YS3.js +128 -0
  87. package/dist/chunk-4N3I4YS3.js.map +1 -0
  88. package/dist/chunk-4QTG7CEM.js +73 -0
  89. package/dist/chunk-4QTG7CEM.js.map +1 -0
  90. package/dist/chunk-4WZPTKWR.js +203 -0
  91. package/dist/chunk-4WZPTKWR.js.map +1 -0
  92. package/dist/chunk-54GKPG7B.js +101 -0
  93. package/dist/chunk-54GKPG7B.js.map +1 -0
  94. package/dist/chunk-5PS7RDU7.js +350 -0
  95. package/dist/chunk-5PS7RDU7.js.map +1 -0
  96. package/dist/chunk-72273TH3.js +79 -0
  97. package/dist/chunk-72273TH3.js.map +1 -0
  98. package/dist/chunk-7CTK6XVZ.js +169 -0
  99. package/dist/chunk-7CTK6XVZ.js.map +1 -0
  100. package/dist/chunk-AKTXS3XF.js +64 -0
  101. package/dist/chunk-AKTXS3XF.js.map +1 -0
  102. package/dist/chunk-AMFJ2GLM.js +169 -0
  103. package/dist/chunk-AMFJ2GLM.js.map +1 -0
  104. package/dist/chunk-AOCWQG3N.js +243 -0
  105. package/dist/chunk-AOCWQG3N.js.map +1 -0
  106. package/dist/chunk-AUNNPRJI.js +89 -0
  107. package/dist/chunk-AUNNPRJI.js.map +1 -0
  108. package/dist/chunk-AXQKYYJS.js +164 -0
  109. package/dist/chunk-AXQKYYJS.js.map +1 -0
  110. package/dist/chunk-B5SYGGHJ.js +192 -0
  111. package/dist/chunk-B5SYGGHJ.js.map +1 -0
  112. package/dist/chunk-BBF6FKOB.js +35 -0
  113. package/dist/chunk-BBF6FKOB.js.map +1 -0
  114. package/dist/chunk-BHB4RIYE.js +145 -0
  115. package/dist/chunk-BHB4RIYE.js.map +1 -0
  116. package/dist/chunk-BJIFRHFU.js +145 -0
  117. package/dist/chunk-BJIFRHFU.js.map +1 -0
  118. package/dist/chunk-BRNXYWBD.js +73 -0
  119. package/dist/chunk-BRNXYWBD.js.map +1 -0
  120. package/dist/chunk-CEMVFONQ.js +104 -0
  121. package/dist/chunk-CEMVFONQ.js.map +1 -0
  122. package/dist/chunk-CEPOV7P3.js +192 -0
  123. package/dist/chunk-CEPOV7P3.js.map +1 -0
  124. package/dist/chunk-CGWRXOYB.js +89 -0
  125. package/dist/chunk-CGWRXOYB.js.map +1 -0
  126. package/dist/chunk-CI7CUJTM.js +138 -0
  127. package/dist/chunk-CI7CUJTM.js.map +1 -0
  128. package/dist/chunk-CUHT2CEN.js +30 -0
  129. package/dist/chunk-CUHT2CEN.js.map +1 -0
  130. package/dist/chunk-D2RVLTMZ.js +52 -0
  131. package/dist/chunk-D2RVLTMZ.js.map +1 -0
  132. package/dist/chunk-DJN2IEY6.js +23 -0
  133. package/dist/chunk-DJN2IEY6.js.map +1 -0
  134. package/dist/chunk-DLLOQ3U6.js +30 -0
  135. package/dist/chunk-DLLOQ3U6.js.map +1 -0
  136. package/dist/chunk-EYCVRS2M.js +52 -0
  137. package/dist/chunk-EYCVRS2M.js.map +1 -0
  138. package/dist/chunk-EZ7GTTX4.js +138 -0
  139. package/dist/chunk-EZ7GTTX4.js.map +1 -0
  140. package/dist/chunk-F2H4ZJS3.js +243 -0
  141. package/dist/chunk-F2H4ZJS3.js.map +1 -0
  142. package/dist/chunk-FFASDLES.js +64 -0
  143. package/dist/chunk-FFASDLES.js.map +1 -0
  144. package/dist/chunk-FH4DNJWU.js +350 -0
  145. package/dist/chunk-FH4DNJWU.js.map +1 -0
  146. package/dist/chunk-FKQ5TEB2.js +169 -0
  147. package/dist/chunk-FKQ5TEB2.js.map +1 -0
  148. package/dist/chunk-FZKXTTBS.js +169 -0
  149. package/dist/chunk-FZKXTTBS.js.map +1 -0
  150. package/dist/chunk-GL6WSFZ5.js +89 -0
  151. package/dist/chunk-GL6WSFZ5.js.map +1 -0
  152. package/dist/chunk-HHMAK2SD.js +243 -0
  153. package/dist/chunk-HHMAK2SD.js.map +1 -0
  154. package/dist/chunk-HJWYFCQT.js +138 -0
  155. package/dist/chunk-HJWYFCQT.js.map +1 -0
  156. package/dist/chunk-HQSSAZHP.js +84 -0
  157. package/dist/chunk-HQSSAZHP.js.map +1 -0
  158. package/dist/chunk-HUDFEF2L.js +138 -0
  159. package/dist/chunk-HUDFEF2L.js.map +1 -0
  160. package/dist/chunk-HUXMVGOU.js +57 -0
  161. package/dist/chunk-HUXMVGOU.js.map +1 -0
  162. package/dist/chunk-I5CKCI5F.js +243 -0
  163. package/dist/chunk-I5CKCI5F.js.map +1 -0
  164. package/dist/chunk-IBNRCMIB.js +76 -0
  165. package/dist/chunk-IBNRCMIB.js.map +1 -0
  166. package/dist/chunk-IWW6ST7Q.js +30 -0
  167. package/dist/chunk-IWW6ST7Q.js.map +1 -0
  168. package/dist/chunk-IYBUKTHI.js +76 -0
  169. package/dist/chunk-IYBUKTHI.js.map +1 -0
  170. package/dist/chunk-IZBOGH4W.js +52 -0
  171. package/dist/chunk-IZBOGH4W.js.map +1 -0
  172. package/dist/chunk-IZXQPBJR.js +138 -0
  173. package/dist/chunk-IZXQPBJR.js.map +1 -0
  174. package/dist/chunk-JYLNC7NT.js +101 -0
  175. package/dist/chunk-JYLNC7NT.js.map +1 -0
  176. package/dist/chunk-K4SP3COU.js +203 -0
  177. package/dist/chunk-K4SP3COU.js.map +1 -0
  178. package/dist/chunk-KAMO3OQK.js +64 -0
  179. package/dist/chunk-KAMO3OQK.js.map +1 -0
  180. package/dist/chunk-KGSCGSDB.js +58 -0
  181. package/dist/chunk-KGSCGSDB.js.map +1 -0
  182. package/dist/chunk-KQZQEHAO.js +243 -0
  183. package/dist/chunk-KQZQEHAO.js.map +1 -0
  184. package/dist/chunk-LJNUHAEZ.js +76 -0
  185. package/dist/chunk-LJNUHAEZ.js.map +1 -0
  186. package/dist/chunk-LTSPMGMD.js +30 -0
  187. package/dist/chunk-LTSPMGMD.js.map +1 -0
  188. package/dist/chunk-LWRIWDWX.js +30 -0
  189. package/dist/chunk-LWRIWDWX.js.map +1 -0
  190. package/dist/chunk-MOZLM3CP.js +171 -0
  191. package/dist/chunk-MOZLM3CP.js.map +1 -0
  192. package/dist/chunk-N5OXNYUZ.js +57 -0
  193. package/dist/chunk-N5OXNYUZ.js.map +1 -0
  194. package/dist/chunk-NCPXYZEA.js +350 -0
  195. package/dist/chunk-NCPXYZEA.js.map +1 -0
  196. package/dist/chunk-NIBV5VZ5.js +350 -0
  197. package/dist/chunk-NIBV5VZ5.js.map +1 -0
  198. package/dist/chunk-NWEEOT3Z.js +79 -0
  199. package/dist/chunk-NWEEOT3Z.js.map +1 -0
  200. package/dist/chunk-O7Z2UIAR.js +203 -0
  201. package/dist/chunk-O7Z2UIAR.js.map +1 -0
  202. package/dist/chunk-ODNY3R6A.js +79 -0
  203. package/dist/chunk-ODNY3R6A.js.map +1 -0
  204. package/dist/chunk-OMHZDDO4.js +64 -0
  205. package/dist/chunk-OMHZDDO4.js.map +1 -0
  206. package/dist/chunk-P27CVRGR.js +74 -0
  207. package/dist/chunk-P27CVRGR.js.map +1 -0
  208. package/dist/chunk-P64RPVFZ.js +89 -0
  209. package/dist/chunk-P64RPVFZ.js.map +1 -0
  210. package/dist/chunk-PCNSA33Y.js +138 -0
  211. package/dist/chunk-PCNSA33Y.js.map +1 -0
  212. package/dist/chunk-PGIAKER2.js +89 -0
  213. package/dist/chunk-PGIAKER2.js.map +1 -0
  214. package/dist/chunk-PKILHKHX.js +52 -0
  215. package/dist/chunk-PKILHKHX.js.map +1 -0
  216. package/dist/chunk-QB7PZXMM.js +64 -0
  217. package/dist/chunk-QB7PZXMM.js.map +1 -0
  218. package/dist/chunk-QJ4FYN6G.js +76 -0
  219. package/dist/chunk-QJ4FYN6G.js.map +1 -0
  220. package/dist/chunk-QOABBRAS.js +171 -0
  221. package/dist/chunk-QOABBRAS.js.map +1 -0
  222. package/dist/chunk-QR66GBTG.js +169 -0
  223. package/dist/chunk-QR66GBTG.js.map +1 -0
  224. package/dist/chunk-QWSGRTKA.js +145 -0
  225. package/dist/chunk-QWSGRTKA.js.map +1 -0
  226. package/dist/chunk-RMW3CGV2.js +171 -0
  227. package/dist/chunk-RMW3CGV2.js.map +1 -0
  228. package/dist/chunk-RZCG3TLF.js +64 -0
  229. package/dist/chunk-RZCG3TLF.js.map +1 -0
  230. package/dist/chunk-S6NXMG2L.js +164 -0
  231. package/dist/chunk-S6NXMG2L.js.map +1 -0
  232. package/dist/chunk-SFCRNIUP.js +138 -0
  233. package/dist/chunk-SFCRNIUP.js.map +1 -0
  234. package/dist/chunk-SUETHF2K.js +30 -0
  235. package/dist/chunk-SUETHF2K.js.map +1 -0
  236. package/dist/chunk-TDUPNAYQ.js +30 -0
  237. package/dist/chunk-TDUPNAYQ.js.map +1 -0
  238. package/dist/chunk-TOBTSM5I.js +63 -0
  239. package/dist/chunk-TOBTSM5I.js.map +1 -0
  240. package/dist/chunk-TPXVOWXW.js +76 -0
  241. package/dist/chunk-TPXVOWXW.js.map +1 -0
  242. package/dist/chunk-TXQPIRH3.js +59 -0
  243. package/dist/chunk-TXQPIRH3.js.map +1 -0
  244. package/dist/chunk-U3IS6TVL.js +104 -0
  245. package/dist/chunk-U3IS6TVL.js.map +1 -0
  246. package/dist/chunk-U7WXGJ52.js +192 -0
  247. package/dist/chunk-U7WXGJ52.js.map +1 -0
  248. package/dist/chunk-UGQ3ECGA.js +30 -0
  249. package/dist/chunk-UGQ3ECGA.js.map +1 -0
  250. package/dist/chunk-UVJASJN4.js +64 -0
  251. package/dist/chunk-UVJASJN4.js.map +1 -0
  252. package/dist/chunk-V7NLUI44.js +192 -0
  253. package/dist/chunk-V7NLUI44.js.map +1 -0
  254. package/dist/chunk-VFX42N5Z.js +171 -0
  255. package/dist/chunk-VFX42N5Z.js.map +1 -0
  256. package/dist/chunk-WQKBKWTC.js +138 -0
  257. package/dist/chunk-WQKBKWTC.js.map +1 -0
  258. package/dist/chunk-WTY5FQH6.js +171 -0
  259. package/dist/chunk-WTY5FQH6.js.map +1 -0
  260. package/dist/chunk-X6PNCRPH.js +39 -0
  261. package/dist/chunk-X6PNCRPH.js.map +1 -0
  262. package/dist/chunk-XBLWJGNM.js +76 -0
  263. package/dist/chunk-XBLWJGNM.js.map +1 -0
  264. package/dist/chunk-XE6Q3UUE.js +104 -0
  265. package/dist/chunk-XE6Q3UUE.js.map +1 -0
  266. package/dist/chunk-XJOUZEPM.js +59 -0
  267. package/dist/chunk-XJOUZEPM.js.map +1 -0
  268. package/dist/chunk-Y5PBBGEF.js +52 -0
  269. package/dist/chunk-Y5PBBGEF.js.map +1 -0
  270. package/dist/chunk-Y7QUPKOR.js +39 -0
  271. package/dist/chunk-Y7QUPKOR.js.map +1 -0
  272. package/dist/chunk-YCBWW3Z7.js +138 -0
  273. package/dist/chunk-YCBWW3Z7.js.map +1 -0
  274. package/dist/chunk-YGIXMEJ5.js +89 -0
  275. package/dist/chunk-YGIXMEJ5.js.map +1 -0
  276. package/dist/chunk-YJYY6AGY.js +171 -0
  277. package/dist/chunk-YJYY6AGY.js.map +1 -0
  278. package/dist/chunk-YKUSL7DP.js +350 -0
  279. package/dist/chunk-YKUSL7DP.js.map +1 -0
  280. package/dist/chunk-YRZRBSOW.js +128 -0
  281. package/dist/chunk-YRZRBSOW.js.map +1 -0
  282. package/dist/chunk-Z77FAWTL.js +76 -0
  283. package/dist/chunk-Z77FAWTL.js.map +1 -0
  284. package/dist/chunk-ZAQQ6H6W.js +30 -0
  285. package/dist/chunk-ZAQQ6H6W.js.map +1 -0
  286. package/dist/chunk-ZC6UF5SE.js +89 -0
  287. package/dist/chunk-ZC6UF5SE.js.map +1 -0
  288. package/dist/chunk-ZD54B67F.js +243 -0
  289. package/dist/chunk-ZD54B67F.js.map +1 -0
  290. package/dist/chunk-ZPIMFRCZ.js +35 -0
  291. package/dist/chunk-ZPIMFRCZ.js.map +1 -0
  292. package/dist/icon.cjs +2 -0
  293. package/dist/icon.cjs.map +1 -1
  294. package/dist/icon.d.cts +1 -1
  295. package/dist/icon.d.ts +1 -1
  296. package/dist/icon.js +3 -1
  297. package/dist/index.cjs +180 -181
  298. package/dist/index.cjs.map +1 -1
  299. package/dist/index.css +2 -0
  300. package/dist/index.css.map +1 -1
  301. package/dist/index.d.cts +1 -1
  302. package/dist/index.d.ts +1 -1
  303. package/dist/index.js +39 -37
  304. package/dist/layouts/index.cjs +44 -45
  305. package/dist/layouts/index.cjs.map +1 -1
  306. package/dist/layouts/index.js +10 -10
  307. package/dist/layouts/response-display.cjs +44 -45
  308. package/dist/layouts/response-display.cjs.map +1 -1
  309. package/dist/layouts/response-display.js +10 -10
  310. package/dist/molecules/date-picker/date-picker-button.cjs +48 -49
  311. package/dist/molecules/date-picker/date-picker-button.cjs.map +1 -1
  312. package/dist/molecules/date-picker/date-picker-button.js +12 -12
  313. package/dist/molecules/date-picker/index.cjs.map +1 -1
  314. package/dist/molecules/date-picker/index.js +2 -2
  315. package/dist/molecules/expand-table/index.cjs +71 -72
  316. package/dist/molecules/expand-table/index.cjs.map +1 -1
  317. package/dist/molecules/expand-table/index.js +12 -12
  318. package/dist/molecules/expand-table/row.cjs +52 -53
  319. package/dist/molecules/expand-table/row.cjs.map +1 -1
  320. package/dist/molecules/expand-table/row.js +10 -10
  321. package/dist/molecules/form.d.cts +1 -1
  322. package/dist/molecules/form.d.ts +1 -1
  323. package/dist/molecules/index.cjs +121 -122
  324. package/dist/molecules/index.cjs.map +1 -1
  325. package/dist/molecules/index.js +17 -17
  326. package/dist/molecules/learning-post.js +2 -2
  327. package/dist/molecules/navigation.cjs +44 -45
  328. package/dist/molecules/navigation.cjs.map +1 -1
  329. package/dist/molecules/navigation.js +10 -10
  330. package/dist/molecules/radio-button-card.cjs +50 -51
  331. package/dist/molecules/radio-button-card.cjs.map +1 -1
  332. package/dist/molecules/radio-button-card.js +10 -10
  333. package/dist/molecules/stepper.cjs.map +1 -1
  334. package/dist/molecules/stepper.js +2 -2
  335. package/dist/molecules/tag-selector.cjs +68 -69
  336. package/dist/molecules/tag-selector.cjs.map +1 -1
  337. package/dist/molecules/tag-selector.js +11 -11
  338. package/dist/molecules/time-select.cjs +46 -47
  339. package/dist/molecules/time-select.cjs.map +1 -1
  340. package/dist/molecules/time-select.js +10 -10
  341. package/package.json +5 -5
  342. package/src/app/platform/userInfos/utils.tsx +24 -14
  343. package/src/atoms/dialog.tsx +1 -9
  344. package/src/atoms/drawer.tsx +1 -1
  345. package/src/icon.ts +1 -0
@@ -0,0 +1,89 @@
1
+ import {
2
+ DataList
3
+ } from "./chunk-VTJZMOSP.js";
4
+ import {
5
+ toast
6
+ } from "./chunk-CYYWMYE7.js";
7
+ import {
8
+ Button
9
+ } from "./chunk-U7JPP7WJ.js";
10
+
11
+ // src/app/platform/userInfos/utils.tsx
12
+ import { format } from "date-fns";
13
+ import { CopyIcon } from "@radix-ui/react-icons";
14
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
15
+ var infoList = [
16
+ { label: "\uC774\uB984", getValue: (customer) => customer == null ? void 0 : customer.username },
17
+ { label: "\uC131\uBCC4", getValue: (customer) => customer == null ? void 0 : customer.gender },
18
+ {
19
+ label: "\uC0DD\uB144\uC6D4\uC77C",
20
+ getValue: (customer) => (customer == null ? void 0 : customer.birthdate) && format(customer.birthdate, "yyyy.MM.dd")
21
+ },
22
+ { label: "\uBD80\uC11C", getValue: (customer) => customer == null ? void 0 : customer.team },
23
+ { label: "\uC9C1\uCC45", getValue: (customer) => customer == null ? void 0 : customer.position },
24
+ { label: "\uC9C1\uAE09", getValue: (customer) => customer == null ? void 0 : customer.level },
25
+ { label: "\uC774\uBA54\uC77C", getValue: (customer) => customer == null ? void 0 : customer.email, copyable: true },
26
+ {
27
+ label: "\uC804\uD654\uBC88\uD638",
28
+ getValue: (customer) => customer == null ? void 0 : customer.phone,
29
+ render: (value) => {
30
+ return value == null ? void 0 : value.replace(/[^0-9]/g, "").replace(/^(\d{2,3})(\d{3,4})(\d{4})$/, `$1-$2-$3`);
31
+ },
32
+ copyable: true
33
+ }
34
+ ];
35
+ var sessionList = [
36
+ {
37
+ label: "\uC9C4\uD589\uC911\uC778 \uC138\uC158",
38
+ getValue: (session) => `${(session == null ? void 0 : session.restSession) || "-"}\uD68C\uCC28/${(session == null ? void 0 : session.totalSession) || "-"}\uD68C\uCC28`
39
+ },
40
+ {
41
+ label: "\uB2E4\uC74C \uC138\uC158 \uC77C\uC2DC",
42
+ getValue: (session) => (session == null ? void 0 : session.nextSessionDate) ? format(session.nextSessionDate, "yyyy\uB144 MM\uC6D4 dd\uC77C HH\uC2DC mm\uBD84") : "-"
43
+ },
44
+ {
45
+ label: "\uB2E4\uC74C \uC138\uC158 \uCC38\uC5EC \uBC29\uC2DD",
46
+ getValue: (session) => (session == null ? void 0 : session.nextSessionType) || "-"
47
+ },
48
+ {
49
+ label: "\uCF54\uCE6D \uB9CC\uB8CC \uAE30\uD55C",
50
+ getValue: (session) => (session == null ? void 0 : session.expiredAt) ? format(session.expiredAt, "yyyy\uB144 MM\uC6D4 dd\uC77C") : "-"
51
+ }
52
+ ];
53
+ var renderItem = (info, data) => {
54
+ const value = info.getValue(data);
55
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
56
+ info.render ? info.render(value) : value || "-",
57
+ info.copyable && value ? /* @__PURE__ */ jsx(CopyButton, { value }) : null
58
+ ] });
59
+ };
60
+ var renderDataListItem = (info, data) => {
61
+ return /* @__PURE__ */ jsxs(DataList.Item, { children: [
62
+ /* @__PURE__ */ jsx(DataList.Label, { children: info.label }),
63
+ /* @__PURE__ */ jsx(DataList.Value, { children: renderItem(info, data) })
64
+ ] }, info.label);
65
+ };
66
+ function CopyButton(props) {
67
+ return /* @__PURE__ */ jsx(
68
+ Button,
69
+ {
70
+ color: "gray",
71
+ onClick: () => {
72
+ void navigator.clipboard.writeText(props.value);
73
+ toast.success("\uBCF5\uC0AC\uB418\uC5C8\uC2B5\uB2C8\uB2E4.");
74
+ },
75
+ style: { marginLeft: "0", marginTop: "0" },
76
+ variant: "transparent",
77
+ children: /* @__PURE__ */ jsx(CopyIcon, {})
78
+ }
79
+ );
80
+ }
81
+
82
+ export {
83
+ infoList,
84
+ sessionList,
85
+ renderItem,
86
+ renderDataListItem,
87
+ CopyButton
88
+ };
89
+ //# sourceMappingURL=chunk-4LFEZYPK.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/app/platform/userInfos/utils.tsx"],"sourcesContent":["import type { ProjectStatus } from '@tipp/biz-utils';\nimport { format } from 'date-fns';\nimport { CopyIcon } from '@radix-ui/react-icons';\nimport { Button, DataList, toast } from '../../../atoms';\n\nexport interface CoachingCustomerInfoProps {\n customer?: Customer;\n session?: Session;\n children?: React.ReactElement;\n}\n\nexport interface Customer {\n username: string;\n email: string;\n gender: string;\n birthdate: Date;\n phone: string;\n company: string;\n team: string;\n position: string;\n level: string;\n}\n\nexport interface Session {\n state: ProjectStatus;\n totalSession: number;\n restSession: number;\n nextSessionDate?: Date;\n nextSessionType?: string;\n expiredAt: Date;\n}\n\nexport interface DataListItems<T> {\n label: string;\n getValue: (original?: T) => string | undefined;\n copyable?: boolean;\n render?: (value?: string) => React.ReactNode;\n}\n\nexport const infoList: DataListItems<Customer>[] = [\n { label: '이름', getValue: (customer) => customer?.username },\n { label: '성별', getValue: (customer) => customer?.gender },\n {\n label: '생년월일',\n getValue: (customer) =>\n customer?.birthdate && format(customer.birthdate, 'yyyy.MM.dd'),\n },\n { label: '부서', getValue: (customer) => customer?.team },\n { label: '직책', getValue: (customer) => customer?.position },\n { label: '직급', getValue: (customer) => customer?.level },\n { label: '이메일', getValue: (customer) => customer?.email, copyable: true },\n {\n label: '전화번호',\n getValue: (customer) => customer?.phone,\n render: (value) => {\n // 핸드폰 전화번호 형식으로 변환\n return value\n ?.replace(/[^0-9]/g, '')\n .replace(/^(\\d{2,3})(\\d{3,4})(\\d{4})$/, `$1-$2-$3`);\n },\n copyable: true,\n },\n];\n\nexport const sessionList: DataListItems<Session>[] = [\n {\n label: '진행중인 세션',\n getValue: (session) =>\n `${session?.restSession || '-'}회차/${session?.totalSession || '-'}회차`,\n },\n {\n label: '다음 세션 일시',\n getValue: (session) =>\n session?.nextSessionDate\n ? format(session.nextSessionDate, 'yyyy년 MM월 dd일 HH시 mm분')\n : '-',\n },\n {\n label: '다음 세션 참여 방식',\n getValue: (session) => session?.nextSessionType || '-',\n },\n {\n label: '코칭 만료 기한',\n getValue: (session) =>\n session?.expiredAt ? format(session.expiredAt, 'yyyy년 MM월 dd일') : '-',\n },\n];\n\nexport const renderItem = <T extends object>(\n info: DataListItems<T>,\n data?: T\n): JSX.Element => {\n const value = info.getValue(data);\n return (\n <>\n {info.render ? info.render(value) : value || '-'}\n {info.copyable && value ? <CopyButton value={value} /> : null}\n </>\n );\n};\n\nexport const renderDataListItem = <T extends object>(\n info: DataListItems<T>,\n data?: T\n): React.ReactElement => {\n return (\n <DataList.Item key={info.label}>\n <DataList.Label>{info.label}</DataList.Label>\n <DataList.Value>{renderItem(info, data)}</DataList.Value>\n </DataList.Item>\n );\n};\n\nexport function CopyButton(props: { value: string }): JSX.Element {\n return (\n <Button\n color=\"gray\"\n onClick={() => {\n void navigator.clipboard.writeText(props.value);\n toast.success('복사되었습니다.');\n }}\n style={{ marginLeft: '0', marginTop: '0' }}\n variant=\"transparent\"\n >\n <CopyIcon />\n </Button>\n );\n}\n"],"mappings":";;;;;;;;;;;AACA,SAAS,cAAc;AACvB,SAAS,gBAAgB;AA4FrB,mBAE4B,KAF5B;AAvDG,IAAM,WAAsC;AAAA,EACjD,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,SAAS;AAAA,EAC1D,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,OAAO;AAAA,EACxD;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,cACT,qCAAU,cAAa,OAAO,SAAS,WAAW,YAAY;AAAA,EAClE;AAAA,EACA,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,KAAK;AAAA,EACtD,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,SAAS;AAAA,EAC1D,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,MAAM;AAAA,EACvD,EAAE,OAAO,sBAAO,UAAU,CAAC,aAAa,qCAAU,OAAO,UAAU,KAAK;AAAA,EACxE;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,aAAa,qCAAU;AAAA,IAClC,QAAQ,CAAC,UAAU;AAEjB,aAAO,+BACH,QAAQ,WAAW,IACpB,QAAQ,+BAA+B;AAAA,IAC5C;AAAA,IACA,UAAU;AAAA,EACZ;AACF;AAEO,IAAM,cAAwC;AAAA,EACnD;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,YACT,IAAG,mCAAS,gBAAe,GAAG,iBAAM,mCAAS,iBAAgB,GAAG;AAAA,EACpE;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,aACT,mCAAS,mBACL,OAAO,QAAQ,iBAAiB,gDAAuB,IACvD;AAAA,EACR;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,aAAY,mCAAS,oBAAmB;AAAA,EACrD;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,aACT,mCAAS,aAAY,OAAO,QAAQ,WAAW,8BAAe,IAAI;AAAA,EACtE;AACF;AAEO,IAAM,aAAa,CACxB,MACA,SACgB;AAChB,QAAM,QAAQ,KAAK,SAAS,IAAI;AAChC,SACE,iCACG;AAAA,SAAK,SAAS,KAAK,OAAO,KAAK,IAAI,SAAS;AAAA,IAC5C,KAAK,YAAY,QAAQ,oBAAC,cAAW,OAAc,IAAK;AAAA,KAC3D;AAEJ;AAEO,IAAM,qBAAqB,CAChC,MACA,SACuB;AACvB,SACE,qBAAC,SAAS,MAAT,EACC;AAAA,wBAAC,SAAS,OAAT,EAAgB,eAAK,OAAM;AAAA,IAC5B,oBAAC,SAAS,OAAT,EAAgB,qBAAW,MAAM,IAAI,GAAE;AAAA,OAFtB,KAAK,KAGzB;AAEJ;AAEO,SAAS,WAAW,OAAuC;AAChE,SACE;AAAA,IAAC;AAAA;AAAA,MACC,OAAM;AAAA,MACN,SAAS,MAAM;AACb,aAAK,UAAU,UAAU,UAAU,MAAM,KAAK;AAC9C,cAAM,QAAQ,6CAAU;AAAA,MAC1B;AAAA,MACA,OAAO,EAAE,YAAY,KAAK,WAAW,IAAI;AAAA,MACzC,SAAQ;AAAA,MAER,8BAAC,YAAS;AAAA;AAAA,EACZ;AAEJ;","names":[]}
@@ -0,0 +1,128 @@
1
+ import {
2
+ IconButton
3
+ } from "./chunk-O3DNDMV3.js";
4
+ import {
5
+ Typo
6
+ } from "./chunk-52MVZ6AN.js";
7
+ import {
8
+ Flex
9
+ } from "./chunk-25HMMI7R.js";
10
+ import {
11
+ ChevronLeftIcon,
12
+ ChevronRightIcon,
13
+ DoubleArrowLeftIcon,
14
+ DoubleArrowRightIcon
15
+ } from "./chunk-PGIAKER2.js";
16
+ import {
17
+ __spreadProps,
18
+ __spreadValues
19
+ } from "./chunk-N552FDTV.js";
20
+
21
+ // src/atoms/pagination.tsx
22
+ import { useCallback, useEffect, useMemo, useState } from "react";
23
+ import { jsx, jsxs } from "react/jsx-runtime";
24
+ function Pagination(props) {
25
+ const { onChange, count = 0, siblingCount = 2 } = props;
26
+ const [page, setPage] = useState(() => props.page || props.defaultPage || 1);
27
+ const visibleItems = useMemo(() => {
28
+ let start = Math.max(1, page - siblingCount);
29
+ let end = Math.min(count, page + siblingCount);
30
+ if (page - siblingCount <= 0 && end < count) {
31
+ end = Math.min(count, end + Math.abs(page - siblingCount) + 1);
32
+ } else if (page + siblingCount > count && start > 1) {
33
+ start = Math.max(1, start - (page + siblingCount - count));
34
+ }
35
+ return Array.from({ length: end - start + 1 }, (_, i) => i + start);
36
+ }, [count, page, siblingCount]);
37
+ useEffect(() => {
38
+ onChange == null ? void 0 : onChange(page);
39
+ }, [onChange, page]);
40
+ useEffect(() => {
41
+ if (props.page) {
42
+ setPage(props.page);
43
+ }
44
+ }, [props.page]);
45
+ const prev = useMemo(() => {
46
+ const p = page - 1;
47
+ return p < 1 ? void 0 : p;
48
+ }, [page]);
49
+ const next = useMemo(() => {
50
+ const n = page + 1;
51
+ return n > count ? void 0 : n;
52
+ }, [count, page]);
53
+ const onClickPrev = useCallback(() => {
54
+ prev && setPage(prev);
55
+ }, [prev]);
56
+ const onClickNext = useCallback(() => {
57
+ next && setPage(next);
58
+ }, [next]);
59
+ const doublePrev = useMemo(() => {
60
+ if (!visibleItems.length)
61
+ return;
62
+ return Math.max(0, visibleItems[0] - 1);
63
+ }, [visibleItems]);
64
+ const onClickDoublePrev = useCallback(() => {
65
+ doublePrev && setPage(doublePrev);
66
+ }, [doublePrev]);
67
+ const doubleNext = useMemo(() => {
68
+ if (!visibleItems.length)
69
+ return;
70
+ const n = visibleItems[visibleItems.length - 1] + 1;
71
+ if (n > count)
72
+ return;
73
+ return Math.min(count, n);
74
+ }, [count, visibleItems]);
75
+ const onClickDoubleNext = useCallback(() => {
76
+ doubleNext && setPage(doubleNext);
77
+ }, [doubleNext]);
78
+ const iconSize = {
79
+ height: 24,
80
+ width: 24
81
+ };
82
+ const moveButtonProps = {
83
+ variant: "ghost",
84
+ size: "3",
85
+ style: { borderRadius: "50%" }
86
+ };
87
+ return /* @__PURE__ */ jsxs(Flex, { align: "center", className: "tipp-pagination", gap: "4", children: [
88
+ /* @__PURE__ */ jsx(
89
+ IconButton,
90
+ __spreadProps(__spreadValues({
91
+ disabled: !doublePrev,
92
+ onClick: onClickDoublePrev
93
+ }, moveButtonProps), {
94
+ children: /* @__PURE__ */ jsx(DoubleArrowLeftIcon, __spreadValues({}, iconSize))
95
+ })
96
+ ),
97
+ /* @__PURE__ */ jsx(IconButton, __spreadProps(__spreadValues({ disabled: !prev, onClick: onClickPrev }, moveButtonProps), { children: /* @__PURE__ */ jsx(ChevronLeftIcon, __spreadValues({}, iconSize)) })),
98
+ /* @__PURE__ */ jsx(Flex, { gap: "1", children: visibleItems.map((item) => {
99
+ return /* @__PURE__ */ jsx(
100
+ "button",
101
+ {
102
+ className: `page-button ${item === page ? "active" : ""}`,
103
+ onClick: () => {
104
+ setPage(item);
105
+ },
106
+ type: "button",
107
+ children: /* @__PURE__ */ jsx(Typo, { variant: "body", children: item })
108
+ },
109
+ item
110
+ );
111
+ }) }),
112
+ /* @__PURE__ */ jsx(IconButton, __spreadProps(__spreadValues({ disabled: !next, onClick: onClickNext }, moveButtonProps), { children: /* @__PURE__ */ jsx(ChevronRightIcon, __spreadValues({}, iconSize)) })),
113
+ /* @__PURE__ */ jsx(
114
+ IconButton,
115
+ __spreadProps(__spreadValues({
116
+ disabled: !doubleNext,
117
+ onClick: onClickDoubleNext
118
+ }, moveButtonProps), {
119
+ children: /* @__PURE__ */ jsx(DoubleArrowRightIcon, __spreadValues({}, iconSize))
120
+ })
121
+ )
122
+ ] });
123
+ }
124
+
125
+ export {
126
+ Pagination
127
+ };
128
+ //# sourceMappingURL=chunk-4N3I4YS3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/atoms/pagination.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport {\n ChevronLeftIcon,\n ChevronRightIcon,\n DoubleArrowLeftIcon,\n DoubleArrowRightIcon,\n} from '../icon';\nimport type { IconButtonProps } from './icon-button';\nimport { IconButton } from './icon-button';\nimport { Flex } from './flex';\nimport { Typo } from './typo';\n\nexport interface PaginationProps {\n /** 현재 선택된 페이지, 1부터 시작 */\n page?: number;\n /** 기본 선택 페이지, page보다 낮은 우선 순위를 갖는다 */\n defaultPage?: number;\n /** 선택한 페이지 변경 이벤트 cb */\n onChange?: (page: number) => void;\n /** 전체 페이지의 수 */\n count?: number;\n /** 표시할 페이지 버튼의 개수 */\n siblingCount?: number;\n}\n\nexport function Pagination(props: PaginationProps): React.ReactNode {\n const { onChange, count = 0, siblingCount = 2 } = props;\n\n const [page, setPage] = useState(() => props.page || props.defaultPage || 1);\n\n const visibleItems = useMemo(() => {\n let start = Math.max(1, page - siblingCount);\n let end = Math.min(count, page + siblingCount);\n if (page - siblingCount <= 0 && end < count) {\n end = Math.min(count, end + Math.abs(page - siblingCount) + 1);\n } else if (page + siblingCount > count && start > 1) {\n start = Math.max(1, start - (page + siblingCount - count));\n }\n\n return Array.from({ length: end - start + 1 }, (_, i) => i + start);\n }, [count, page, siblingCount]);\n\n useEffect(() => {\n onChange?.(page);\n }, [onChange, page]);\n\n useEffect(() => {\n if (props.page) {\n setPage(props.page);\n }\n }, [props.page]);\n\n const prev = useMemo<number | undefined>(() => {\n const p = page - 1;\n return p < 1 ? undefined : p;\n }, [page]);\n\n const next = useMemo<number | undefined>(() => {\n const n = page + 1;\n return n > count ? undefined : n;\n }, [count, page]);\n\n const onClickPrev = useCallback(() => {\n prev && setPage(prev);\n }, [prev]);\n\n const onClickNext = useCallback(() => {\n next && setPage(next);\n }, [next]);\n\n const doublePrev = useMemo<number | undefined>(() => {\n if (!visibleItems.length) return;\n return Math.max(0, visibleItems[0] - 1);\n }, [visibleItems]);\n\n const onClickDoublePrev = useCallback(() => {\n doublePrev && setPage(doublePrev);\n }, [doublePrev]);\n\n const doubleNext = useMemo<number | undefined>(() => {\n if (!visibleItems.length) return;\n const n = visibleItems[visibleItems.length - 1] + 1;\n if (n > count) return;\n return Math.min(count, n);\n }, [count, visibleItems]);\n\n const onClickDoubleNext = useCallback(() => {\n doubleNext && setPage(doubleNext);\n }, [doubleNext]);\n\n const iconSize = {\n height: 24,\n width: 24,\n };\n\n const moveButtonProps: IconButtonProps = {\n variant: 'ghost',\n size: '3',\n style: { borderRadius: '50%' },\n };\n\n return (\n <Flex align=\"center\" className=\"tipp-pagination\" gap=\"4\">\n <IconButton\n disabled={!doublePrev}\n onClick={onClickDoublePrev}\n {...moveButtonProps}\n >\n <DoubleArrowLeftIcon {...iconSize} />\n </IconButton>\n <IconButton disabled={!prev} onClick={onClickPrev} {...moveButtonProps}>\n <ChevronLeftIcon {...iconSize} />\n </IconButton>\n <Flex gap=\"1\">\n {visibleItems.map((item) => {\n return (\n <button\n className={`page-button ${item === page ? 'active' : ''}`}\n key={item}\n onClick={() => {\n setPage(item);\n }}\n type=\"button\"\n >\n <Typo variant=\"body\">{item}</Typo>\n </button>\n );\n })}\n </Flex>\n <IconButton disabled={!next} onClick={onClickNext} {...moveButtonProps}>\n <ChevronRightIcon {...iconSize} />\n </IconButton>\n <IconButton\n disabled={!doubleNext}\n onClick={onClickDoubleNext}\n {...moveButtonProps}\n >\n <DoubleArrowRightIcon {...iconSize} />\n </IconButton>\n </Flex>\n );\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,73 @@
1
+ import {
2
+ Card
3
+ } from "./chunk-2ZQK7NTN.js";
4
+ import {
5
+ Badge
6
+ } from "./chunk-EWD4AO5N.js";
7
+ import {
8
+ Box
9
+ } from "./chunk-4Y5BEXVN.js";
10
+ import {
11
+ Flex
12
+ } from "./chunk-25HMMI7R.js";
13
+ import {
14
+ Heading
15
+ } from "./chunk-HK224ADT.js";
16
+ import {
17
+ Typo
18
+ } from "./chunk-52MVZ6AN.js";
19
+
20
+ // src/app/platform/session-review-simple-read.tsx
21
+ import { useMemo } from "react";
22
+ import { jsx, jsxs } from "react/jsx-runtime";
23
+ function SubTitleWrapper({
24
+ children,
25
+ title
26
+ }) {
27
+ return /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "2", children: [
28
+ /* @__PURE__ */ jsx(Heading, { mb: "2", variant: "heading5", weight: "regular", children: title }),
29
+ /* @__PURE__ */ jsx(Box, { children })
30
+ ] });
31
+ }
32
+ function SessionReviewSimpleRead({
33
+ helpfulness,
34
+ review,
35
+ sessionNumber,
36
+ customerName
37
+ }) {
38
+ const helpfulnessMeta = useMemo(() => {
39
+ if (helpfulness) {
40
+ return {
41
+ text: "\uB124",
42
+ color: "success"
43
+ };
44
+ }
45
+ if (typeof helpfulness === "undefined") {
46
+ return {
47
+ text: "-",
48
+ color: "neutral"
49
+ };
50
+ }
51
+ return {
52
+ text: "\uC544\uB2C8\uC694",
53
+ color: "error"
54
+ };
55
+ }, [helpfulness]);
56
+ return /* @__PURE__ */ jsxs(Box, { children: [
57
+ /* @__PURE__ */ jsxs(Heading, { mb: "5", variant: "heading5", children: [
58
+ customerName || "-",
59
+ "\uB2D8\uC758 ",
60
+ sessionNumber || "-",
61
+ "\uD68C\uCC28 \uC138\uC158 \uD6C4\uAE30"
62
+ ] }),
63
+ /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "5", children: [
64
+ /* @__PURE__ */ jsx(SubTitleWrapper, { title: "\uC774\uBC88 \uCF54\uCE6D\uC774 \uBAA9\uD45C \uB2EC\uC131\uC5D0 \uB3C4\uC6C0\uC774 \uB418\uC5C8\uB098\uC694?", children: /* @__PURE__ */ jsx(Badge, { color: helpfulnessMeta.color, children: helpfulnessMeta.text }) }),
65
+ /* @__PURE__ */ jsx(SubTitleWrapper, { title: "\uC138\uC158 \uD6C4\uAE30", children: /* @__PURE__ */ jsx(Card, { children: review ? /* @__PURE__ */ jsx(Typo, { as: "p", children: review }) : /* @__PURE__ */ jsx(Typo, { color: "gray", children: "\uC785\uB825\uB41C \uD6C4\uAE30\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4." }) }) })
66
+ ] })
67
+ ] });
68
+ }
69
+
70
+ export {
71
+ SessionReviewSimpleRead
72
+ };
73
+ //# sourceMappingURL=chunk-4QTG7CEM.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/app/platform/session-review-simple-read.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport type { BadgeProps } from '../../atoms';\nimport { Badge, Box, Card, Flex, Heading, Typo } from '../../atoms';\n\nexport interface SessionReviewSimpleReadProps {\n helpfulness?: boolean;\n review?: string;\n sessionNumber?: number;\n customerName?: string;\n}\n\nfunction SubTitleWrapper({\n children,\n title,\n}: {\n children: React.ReactNode;\n title: string;\n}): JSX.Element {\n return (\n <Flex direction=\"column\" gap=\"2\">\n <Heading mb=\"2\" variant=\"heading5\" weight=\"regular\">\n {title}\n </Heading>\n\n <Box>{children}</Box>\n </Flex>\n );\n}\n\nexport function SessionReviewSimpleRead({\n helpfulness,\n review,\n sessionNumber,\n customerName,\n}: SessionReviewSimpleReadProps): React.ReactElement {\n const helpfulnessMeta = useMemo<{\n text: string;\n color: BadgeProps['color'];\n }>(() => {\n if (helpfulness) {\n return {\n text: '네',\n color: 'success',\n };\n }\n if (typeof helpfulness === 'undefined') {\n return {\n text: '-',\n color: 'neutral',\n };\n }\n return {\n text: '아니요',\n color: 'error',\n };\n }, [helpfulness]);\n\n return (\n <Box>\n <Heading mb=\"5\" variant=\"heading5\">\n {customerName || '-'}님의 {sessionNumber || '-'}회차 세션 후기\n </Heading>\n <Flex direction=\"column\" gap=\"5\">\n <SubTitleWrapper title=\"이번 코칭이 목표 달성에 도움이 되었나요?\">\n <Badge color={helpfulnessMeta.color}>{helpfulnessMeta.text}</Badge>\n </SubTitleWrapper>\n <SubTitleWrapper title=\"세션 후기\">\n <Card>\n {review ? (\n <Typo as=\"p\">{review}</Typo>\n ) : (\n <Typo color=\"gray\">입력된 후기가 없습니다.</Typo>\n )}\n </Card>\n </SubTitleWrapper>\n </Flex>\n </Box>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAmB3B,SACE,KADF;AARJ,SAAS,gBAAgB;AAAA,EACvB;AAAA,EACA;AACF,GAGgB;AACd,SACE,qBAAC,QAAK,WAAU,UAAS,KAAI,KAC3B;AAAA,wBAAC,WAAQ,IAAG,KAAI,SAAQ,YAAW,QAAO,WACvC,iBACH;AAAA,IAEA,oBAAC,OAAK,UAAS;AAAA,KACjB;AAEJ;AAEO,SAAS,wBAAwB;AAAA,EACtC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAqD;AACnD,QAAM,kBAAkB,QAGrB,MAAM;AACP,QAAI,aAAa;AACf,aAAO;AAAA,QACL,MAAM;AAAA,QACN,OAAO;AAAA,MACT;AAAA,IACF;AACA,QAAI,OAAO,gBAAgB,aAAa;AACtC,aAAO;AAAA,QACL,MAAM;AAAA,QACN,OAAO;AAAA,MACT;AAAA,IACF;AACA,WAAO;AAAA,MACL,MAAM;AAAA,MACN,OAAO;AAAA,IACT;AAAA,EACF,GAAG,CAAC,WAAW,CAAC;AAEhB,SACE,qBAAC,OACC;AAAA,yBAAC,WAAQ,IAAG,KAAI,SAAQ,YACrB;AAAA,sBAAgB;AAAA,MAAI;AAAA,MAAI,iBAAiB;AAAA,MAAI;AAAA,OAChD;AAAA,IACA,qBAAC,QAAK,WAAU,UAAS,KAAI,KAC3B;AAAA,0BAAC,mBAAgB,OAAM,gHACrB,8BAAC,SAAM,OAAO,gBAAgB,OAAQ,0BAAgB,MAAK,GAC7D;AAAA,MACA,oBAAC,mBAAgB,OAAM,6BACrB,8BAAC,QACE,mBACC,oBAAC,QAAK,IAAG,KAAK,kBAAO,IAErB,oBAAC,QAAK,OAAM,QAAO,6EAAa,GAEpC,GACF;AAAA,OACF;AAAA,KACF;AAEJ;","names":[]}
@@ -0,0 +1,203 @@
1
+ import {
2
+ DatePickerButton
3
+ } from "./chunk-N5OXNYUZ.js";
4
+ import {
5
+ TimeSelect
6
+ } from "./chunk-K55LGP5B.js";
7
+ import {
8
+ getTimeOption,
9
+ parseTimeOption
10
+ } from "./chunk-VAXB7NV2.js";
11
+ import {
12
+ ResponseDisplay
13
+ } from "./chunk-O4ZX5Z2J.js";
14
+ import {
15
+ Form
16
+ } from "./chunk-SRZ6X74X.js";
17
+ import {
18
+ Grid
19
+ } from "./chunk-EGEQY3KT.js";
20
+ import {
21
+ toast
22
+ } from "./chunk-CYYWMYE7.js";
23
+ import {
24
+ Heading
25
+ } from "./chunk-HK224ADT.js";
26
+ import {
27
+ Separator
28
+ } from "./chunk-HYITAA4J.js";
29
+ import {
30
+ Box
31
+ } from "./chunk-4Y5BEXVN.js";
32
+ import {
33
+ Flex
34
+ } from "./chunk-25HMMI7R.js";
35
+ import {
36
+ Button
37
+ } from "./chunk-U7JPP7WJ.js";
38
+ import {
39
+ __spreadProps,
40
+ __spreadValues
41
+ } from "./chunk-N552FDTV.js";
42
+
43
+ // src/app/platform/edit-coaching-time.tsx
44
+ import { useCallback, useState } from "react";
45
+ import { jsx, jsxs } from "react/jsx-runtime";
46
+ var getValueFromDefaultValue = (args) => {
47
+ return {
48
+ startTime: args.startAt ? getTimeOption(args.startAt) : "00:00",
49
+ endTime: args.endAt ? getTimeOption(args.endAt) : "00:00",
50
+ date: args.startAt || /* @__PURE__ */ new Date()
51
+ };
52
+ };
53
+ var getDateFromValue = (date, time) => {
54
+ const { hour, minute } = parseTimeOption(time);
55
+ return new Date(
56
+ date.getFullYear(),
57
+ date.getMonth(),
58
+ date.getDate(),
59
+ hour,
60
+ minute
61
+ );
62
+ };
63
+ function EditCoachingTime(props) {
64
+ const { defaultEndAt, defaultStartAt, onClickCancel, sessionNumber } = props;
65
+ const [values, setValues] = useState(() => {
66
+ return getValueFromDefaultValue({
67
+ startAt: defaultStartAt,
68
+ endAt: defaultEndAt
69
+ });
70
+ });
71
+ const [timeError, setTimeError] = useState("");
72
+ const checkTimeError = useCallback(
73
+ (startTime, endTime) => {
74
+ const error = startTime >= endTime ? "\uC2DC\uC791\uC2DC\uAC04\uC744 \uC885\uB8CC\uC2DC\uAC04\uBCF4\uB2E4 \uBE60\uB974\uAC8C \uC120\uD0DD\uD574\uC8FC\uC138\uC694." : "";
75
+ if (error) {
76
+ setTimeError(error);
77
+ return false;
78
+ }
79
+ return true;
80
+ },
81
+ []
82
+ );
83
+ const onChangeStartTime = useCallback(
84
+ (v) => {
85
+ checkTimeError(v, values.endTime);
86
+ setValues((prev) => __spreadProps(__spreadValues({}, prev), {
87
+ startTime: v
88
+ }));
89
+ },
90
+ [checkTimeError, values.endTime]
91
+ );
92
+ const onChangeEndTime = useCallback(
93
+ (v) => {
94
+ checkTimeError(values.startTime, v);
95
+ setValues((prev) => __spreadProps(__spreadValues({}, prev), {
96
+ endTime: v
97
+ }));
98
+ },
99
+ [checkTimeError, values.startTime]
100
+ );
101
+ const onChangeDate = useCallback((date) => {
102
+ date && setValues((prev) => __spreadProps(__spreadValues({}, prev), {
103
+ date
104
+ }));
105
+ }, []);
106
+ const onClickSave = useCallback(() => {
107
+ if (checkTimeError(values.startTime, values.endTime)) {
108
+ const startAt = getDateFromValue(values.date, values.startTime);
109
+ const endAt = getDateFromValue(values.date, values.endTime);
110
+ props.onClickSave && props.onClickSave(startAt, endAt);
111
+ } else {
112
+ toast.error("\uC785\uB825 \uAC12\uC774 \uC720\uD6A8\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.");
113
+ }
114
+ }, [checkTimeError, props, values.date, values.endTime, values.startTime]);
115
+ const title = `${sessionNumber || "-"}\uD68C\uCC28 \uC138\uC158 \uC77C\uC2DC \uBCC0\uACBD\uD558\uAE30`;
116
+ return /* @__PURE__ */ jsxs(Box, { width: { initial: "100%" }, children: [
117
+ /* @__PURE__ */ jsx(
118
+ ResponseDisplay,
119
+ {
120
+ initial: /* @__PURE__ */ jsx(Heading, { align: "center", mb: "2", variant: "heading3", children: title }),
121
+ xs: /* @__PURE__ */ jsx(Heading, { mb: "2", variant: "heading5", weight: "regular", children: title })
122
+ }
123
+ ),
124
+ /* @__PURE__ */ jsxs(Form.Root, { children: [
125
+ /* @__PURE__ */ jsxs(Form.Field, { name: "date", children: [
126
+ /* @__PURE__ */ jsx(Form.Label, { variant: "caption", children: "\uB0A0\uC9DC" }),
127
+ /* @__PURE__ */ jsx(
128
+ DatePickerButton,
129
+ {
130
+ onChange: onChangeDate,
131
+ selected: values.date,
132
+ size: { initial: "large", xs: "medium" }
133
+ }
134
+ )
135
+ ] }),
136
+ /* @__PURE__ */ jsxs(
137
+ Grid,
138
+ {
139
+ align: "center",
140
+ columns: {
141
+ initial: "1fr 0 1fr",
142
+ xs: "1fr auto 1fr"
143
+ },
144
+ gapX: "3",
145
+ gapY: "2",
146
+ justify: "center",
147
+ mb: { initial: "5", xs: "4" },
148
+ mt: "5",
149
+ width: "100%",
150
+ children: [
151
+ /* @__PURE__ */ jsx(Form.Field, { name: "startTime", children: /* @__PURE__ */ jsx(Form.Label, { variant: "caption", children: "\uC2DC\uC791 \uC2DC\uAC04" }) }),
152
+ /* @__PURE__ */ jsx("div", {}),
153
+ /* @__PURE__ */ jsx(Form.Field, { name: "endTime", children: /* @__PURE__ */ jsx(Form.Label, { variant: "caption", children: "\uC885\uB8CC \uC2DC\uAC04" }) }),
154
+ /* @__PURE__ */ jsx(
155
+ TimeSelect,
156
+ {
157
+ onValueChange: onChangeStartTime,
158
+ size: { initial: "3", xs: "2" },
159
+ value: values.startTime
160
+ }
161
+ ),
162
+ /* @__PURE__ */ jsx(ResponseDisplay, { initial: /* @__PURE__ */ jsx("div", {}), xs: /* @__PURE__ */ jsx(Separator, {}) }),
163
+ /* @__PURE__ */ jsx(
164
+ TimeSelect,
165
+ {
166
+ onValueChange: onChangeEndTime,
167
+ size: { initial: "3", xs: "2" },
168
+ value: values.endTime
169
+ }
170
+ ),
171
+ /* @__PURE__ */ jsx(Form.Field, { name: "startEndTime", style: { gridColumn: "1/span 3" }, children: /* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(timeError), children: timeError }) })
172
+ ]
173
+ }
174
+ ),
175
+ /* @__PURE__ */ jsxs(Flex, { gap: "3", justify: "end", children: [
176
+ /* @__PURE__ */ jsx(
177
+ Button,
178
+ {
179
+ onClick: onClickCancel,
180
+ size: { initial: "large", xs: "small" },
181
+ type: "button",
182
+ variant: "outline",
183
+ children: "\uCDE8\uC18C\uD558\uAE30"
184
+ }
185
+ ),
186
+ /* @__PURE__ */ jsx(
187
+ Button,
188
+ {
189
+ onClick: onClickSave,
190
+ size: { initial: "large", xs: "small" },
191
+ type: "button",
192
+ children: "\uC800\uC7A5\uD558\uAE30"
193
+ }
194
+ )
195
+ ] })
196
+ ] })
197
+ ] });
198
+ }
199
+
200
+ export {
201
+ EditCoachingTime
202
+ };
203
+ //# sourceMappingURL=chunk-4WZPTKWR.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/app/platform/edit-coaching-time.tsx"],"sourcesContent":["import React, { useCallback, useState } from 'react';\nimport {\n Button,\n Flex,\n Form,\n Grid,\n Heading,\n Separator,\n Box,\n toast,\n} from '../../atoms';\nimport { DatePickerButton, TimeSelect } from '../../molecules';\nimport { getTimeOption, parseTimeOption } from '../../utils';\nimport { ResponseDisplay } from '../../layouts';\n\nexport interface EditCoachingTimeProps {\n defaultStartAt?: Date;\n defaultEndAt?: Date;\n onClickSave?: (startAt: Date, endAt: Date) => void;\n onClickCancel?: () => void;\n sessionNumber?: number;\n}\n\ninterface Values {\n startTime: string;\n endTime: string;\n date: Date;\n}\n\nconst getValueFromDefaultValue = (args: {\n startAt?: Date;\n endAt?: Date;\n}): Values => {\n return {\n startTime: args.startAt ? getTimeOption(args.startAt) : '00:00',\n endTime: args.endAt ? getTimeOption(args.endAt) : '00:00',\n date: args.startAt || new Date(),\n };\n};\n\nconst getDateFromValue = (date: Date, time: string): Date => {\n const { hour, minute } = parseTimeOption(time);\n return new Date(\n date.getFullYear(),\n date.getMonth(),\n date.getDate(),\n hour,\n minute\n );\n};\n\nexport function EditCoachingTime(\n props: EditCoachingTimeProps\n): React.ReactElement {\n const { defaultEndAt, defaultStartAt, onClickCancel, sessionNumber } = props;\n\n const [values, setValues] = useState<Values>(() => {\n return getValueFromDefaultValue({\n startAt: defaultStartAt,\n endAt: defaultEndAt,\n });\n });\n\n const [timeError, setTimeError] = useState('');\n\n const checkTimeError = useCallback(\n (startTime: string, endTime: string): boolean => {\n const error =\n startTime >= endTime\n ? '시작시간을 종료시간보다 빠르게 선택해주세요.'\n : '';\n if (error) {\n setTimeError(error);\n return false;\n }\n return true;\n },\n []\n );\n\n const onChangeStartTime = useCallback(\n (v: string) => {\n checkTimeError(v, values.endTime);\n setValues((prev) => ({\n ...prev,\n startTime: v,\n }));\n },\n [checkTimeError, values.endTime]\n );\n\n const onChangeEndTime = useCallback(\n (v: string) => {\n checkTimeError(values.startTime, v);\n setValues((prev) => ({\n ...prev,\n endTime: v,\n }));\n },\n [checkTimeError, values.startTime]\n );\n\n const onChangeDate = useCallback((date: Date | null) => {\n date &&\n setValues((prev) => ({\n ...prev,\n date,\n }));\n }, []);\n\n const onClickSave = useCallback(() => {\n if (checkTimeError(values.startTime, values.endTime)) {\n const startAt = getDateFromValue(values.date, values.startTime);\n const endAt = getDateFromValue(values.date, values.endTime);\n props.onClickSave && props.onClickSave(startAt, endAt);\n } else {\n toast.error('입력 값이 유효하지 않습니다.');\n }\n }, [checkTimeError, props, values.date, values.endTime, values.startTime]);\n const title = `${sessionNumber || '-'}회차 세션 일시 변경하기`;\n\n return (\n <Box width={{ initial: '100%' }}>\n <ResponseDisplay\n initial={\n <Heading align=\"center\" mb=\"2\" variant=\"heading3\">\n {title}\n </Heading>\n }\n xs={\n <Heading mb=\"2\" variant=\"heading5\" weight=\"regular\">\n {title}\n </Heading>\n }\n />\n\n <Form.Root>\n <Form.Field name=\"date\">\n <Form.Label variant=\"caption\">날짜</Form.Label>\n <DatePickerButton\n onChange={onChangeDate}\n selected={values.date}\n size={{ initial: 'large', xs: 'medium' }}\n />\n </Form.Field>\n <Grid\n align=\"center\"\n columns={{\n initial: '1fr 0 1fr',\n xs: '1fr auto 1fr',\n }}\n gapX=\"3\"\n gapY=\"2\"\n justify=\"center\"\n mb={{ initial: '5', xs: '4' }}\n mt=\"5\"\n width=\"100%\"\n >\n <Form.Field name=\"startTime\">\n <Form.Label variant=\"caption\">시작 시간</Form.Label>\n </Form.Field>\n <div />\n <Form.Field name=\"endTime\">\n <Form.Label variant=\"caption\">종료 시간</Form.Label>\n </Form.Field>\n <TimeSelect\n onValueChange={onChangeStartTime}\n size={{ initial: '3', xs: '2' }}\n value={values.startTime}\n />\n <ResponseDisplay initial={<div />} xs={<Separator />} />\n\n <TimeSelect\n onValueChange={onChangeEndTime}\n size={{ initial: '3', xs: '2' }}\n value={values.endTime}\n />\n <Form.Field name=\"startEndTime\" style={{ gridColumn: '1/span 3' }}>\n <Form.Message forceMatch={Boolean(timeError)}>\n {timeError}\n </Form.Message>\n </Form.Field>\n </Grid>\n <Flex gap=\"3\" justify=\"end\">\n <Button\n onClick={onClickCancel}\n size={{ initial: 'large', xs: 'small' }}\n type=\"button\"\n variant=\"outline\"\n >\n 취소하기\n </Button>\n <Button\n onClick={onClickSave}\n size={{ initial: 'large', xs: 'small' }}\n type=\"button\"\n >\n 저장하기\n </Button>\n </Flex>\n </Form.Root>\n </Box>\n );\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,101 @@
1
+ import {
2
+ IconButton
3
+ } from "./chunk-O3DNDMV3.js";
4
+ import {
5
+ Flex
6
+ } from "./chunk-25HMMI7R.js";
7
+ import {
8
+ Heading
9
+ } from "./chunk-HK224ADT.js";
10
+ import {
11
+ ChevronLeftIcon,
12
+ ChevronRightIcon
13
+ } from "./chunk-PGIAKER2.js";
14
+ import {
15
+ __objRest,
16
+ __spreadProps,
17
+ __spreadValues
18
+ } from "./chunk-N552FDTV.js";
19
+
20
+ // src/molecules/date-picker/index.tsx
21
+ import { forwardRef } from "react";
22
+ import * as RDP from "react-datepicker";
23
+ import { registerLocale, setDefaultLocale } from "react-datepicker";
24
+ import { ko as fnKo } from "date-fns/locale";
25
+ import { jsx, jsxs } from "react/jsx-runtime";
26
+ registerLocale("ko", fnKo);
27
+ setDefaultLocale("ko");
28
+ var ReactDatePicker = RDP.default.default || RDP.default || RDP;
29
+ var DatePicker = forwardRef(
30
+ (props, ref) => {
31
+ const _a = props, { fullWidth } = _a, rest = __objRest(_a, ["fullWidth"]);
32
+ const fullWidthClassName = fullWidth ? "full-width" : "";
33
+ return /* @__PURE__ */ jsx(Flex, { p: "0", width: "100%", children: /* @__PURE__ */ jsx(
34
+ ReactDatePicker,
35
+ __spreadProps(__spreadValues({
36
+ dateFormat: "YYYY/MM/dd",
37
+ nextMonthButtonLabel: "\uB2E4\uC74C \uB2EC",
38
+ placeholderText: "YYYY/mm/dd",
39
+ popperProps: { strategy: "fixed" },
40
+ previousMonthButtonLabel: "\uC774\uC804 \uB2EC",
41
+ ref,
42
+ renderCustomHeader,
43
+ showPopperArrow: false,
44
+ timeIntervals: 10
45
+ }, rest), {
46
+ calendarClassName: `tipp_datePicker_calendar ${rest.calendarClassName || ""}`,
47
+ timeCaption: "\uC2DC\uAC04",
48
+ wrapperClassName: `tipp_datePicker ${fullWidthClassName} ${rest.wrapperClassName || ""}`
49
+ })
50
+ ) });
51
+ }
52
+ );
53
+ DatePicker.displayName = "DatePicker";
54
+ var renderCustomHeader = (props) => {
55
+ const {
56
+ date,
57
+ decreaseMonth,
58
+ increaseMonth,
59
+ prevMonthButtonDisabled,
60
+ nextMonthButtonDisabled
61
+ } = props;
62
+ const year = date ? date.getFullYear() : "-";
63
+ const month = date ? date.getMonth() + 1 : "-";
64
+ return /* @__PURE__ */ jsxs(Flex, { align: "center", justify: "between", pb: "2", pl: "2", pr: "2", children: [
65
+ /* @__PURE__ */ jsx(
66
+ IconButton,
67
+ {
68
+ disabled: prevMonthButtonDisabled,
69
+ onClick: decreaseMonth,
70
+ type: "button",
71
+ variant: "ghost",
72
+ children: /* @__PURE__ */ jsx(ChevronLeftIcon, {})
73
+ }
74
+ ),
75
+ /* @__PURE__ */ jsxs(Flex, { gap: "3", children: [
76
+ /* @__PURE__ */ jsxs(Heading, { variant: "heading4", weight: "regular", children: [
77
+ year,
78
+ "\uB144"
79
+ ] }),
80
+ /* @__PURE__ */ jsxs(Heading, { variant: "heading4", weight: "regular", children: [
81
+ month,
82
+ "\uC6D4"
83
+ ] })
84
+ ] }),
85
+ /* @__PURE__ */ jsx(
86
+ IconButton,
87
+ {
88
+ disabled: nextMonthButtonDisabled,
89
+ onClick: increaseMonth,
90
+ type: "button",
91
+ variant: "ghost",
92
+ children: /* @__PURE__ */ jsx(ChevronRightIcon, {})
93
+ }
94
+ )
95
+ ] });
96
+ };
97
+
98
+ export {
99
+ DatePicker
100
+ };
101
+ //# sourceMappingURL=chunk-54GKPG7B.js.map