pds-dev-kit-web-test 2.5.636 → 2.5.638

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 (370) hide show
  1. package/dist/index.d.ts +6 -6
  2. package/dist/index.js +12 -3
  3. package/dist/src/common/assets/icons/fill/Translate.d.ts +4 -0
  4. package/dist/src/common/assets/icons/fill/Translate.js +30 -0
  5. package/dist/src/common/assets/icons/fill/index.d.ts +1 -0
  6. package/dist/src/common/assets/icons/fill/index.js +2 -0
  7. package/dist/src/common/assets/icons/line/Translate.d.ts +4 -0
  8. package/dist/src/common/assets/icons/line/Translate.js +30 -0
  9. package/dist/src/common/assets/icons/line/index.d.ts +1 -0
  10. package/dist/src/common/assets/icons/line/index.js +2 -0
  11. package/dist/src/common/hooks/useParentResizeObserver.d.ts +2 -0
  12. package/dist/src/common/hooks/useParentResizeObserver.js +20 -0
  13. package/dist/src/common/hooks/useResizeObserver.d.ts +3 -0
  14. package/dist/src/common/hooks/useResizeObserver.js +27 -0
  15. package/dist/src/common/hooks/useTooltip.js +1 -1
  16. package/dist/src/common/hooks/useWindowSize.d.ts +4 -0
  17. package/dist/src/common/hooks/useWindowSize.js +22 -0
  18. package/dist/src/common/index.d.ts +1 -1
  19. package/dist/src/common/services/i18n/resources/en.json +61 -1
  20. package/dist/src/common/services/i18n/resources/es.json +61 -1
  21. package/dist/src/common/services/i18n/resources/fil.json +61 -1
  22. package/dist/src/common/services/i18n/resources/index.d.ts +421 -0
  23. package/dist/src/common/services/i18n/resources/ja.json +61 -1
  24. package/dist/src/common/services/i18n/resources/ko.json +62 -1
  25. package/dist/src/common/services/i18n/resources/zh-cn.json +61 -1
  26. package/dist/src/common/services/i18n/resources/zh-tw.json +61 -1
  27. package/dist/src/common/styles/colorSet/PaletteColor_Dark.json +4 -1
  28. package/dist/src/common/styles/colorSet/PaletteColor_light.json +4 -1
  29. package/dist/src/common/styles/colorSet/UIColor.json +5 -1
  30. package/dist/src/common/styles/colorSet/index.d.ts +10 -0
  31. package/dist/src/common/styles/colorSet/ui-type.d.ts +4 -0
  32. package/dist/src/common/styles/scroll/scrollbarStyle.d.ts +2 -0
  33. package/dist/src/common/styles/scroll/scrollbarStyle.js +4 -3
  34. package/dist/src/common/types/components.d.ts +9 -0
  35. package/dist/src/common/types/components.js +8 -0
  36. package/dist/src/common/types/index.d.ts +1 -1
  37. package/dist/src/common/types/index.js +1 -1
  38. package/dist/src/common/types/multilingual.d.ts +16 -0
  39. package/dist/src/common/types/text.d.ts +2 -0
  40. package/dist/src/common/utils/SystemUIPositionGenerator/hoverTypeSystemUICssGenerator.js +1 -1
  41. package/dist/src/common/utils/dateHelper.d.ts +3 -0
  42. package/dist/src/common/utils/dateHelper.js +37 -0
  43. package/dist/src/core/pricing/formatter.d.ts +4 -0
  44. package/dist/src/core/pricing/formatter.js +18 -0
  45. package/dist/src/core/pricing/index.d.ts +2 -0
  46. package/dist/src/core/pricing/index.js +18 -0
  47. package/dist/src/core/pricing/policy.d.ts +26 -0
  48. package/dist/src/core/pricing/policy.js +98 -0
  49. package/dist/src/core/pricing/service.d.ts +62 -0
  50. package/dist/src/core/pricing/service.js +157 -0
  51. package/dist/src/core/pricing/translator.d.ts +27 -0
  52. package/dist/src/core/pricing/translator.js +54 -0
  53. package/dist/src/core/pricing/types.d.ts +19 -0
  54. package/dist/src/core/pricing/types.js +31 -0
  55. package/dist/src/core/pricing/validator.d.ts +29 -0
  56. package/dist/src/core/pricing/validator.js +105 -0
  57. package/dist/src/desktop/common/components/TextFieldBase/TextFieldBase.d.ts +4 -1
  58. package/dist/src/desktop/common/components/TextFieldBase/TextFieldBase.js +32 -23
  59. package/dist/src/desktop/components/AdminList/AdminList.d.ts +10 -1
  60. package/dist/src/desktop/components/AdminList/AdminList.js +16 -18
  61. package/dist/src/desktop/components/AdminList/HeaderRow.d.ts +10 -1
  62. package/dist/src/desktop/components/AdminList/HeaderRow.js +2 -2
  63. package/dist/src/desktop/components/AdminListHeader/AdminListHeader.d.ts +2 -1
  64. package/dist/src/desktop/components/AdminListHeader/AdminListHeader.js +2 -2
  65. package/dist/src/desktop/components/AdminListHeader/HeaderBar.d.ts +2 -1
  66. package/dist/src/desktop/components/AdminListHeader/HeaderBar.js +2 -2
  67. package/dist/src/desktop/components/BasicButtonGroup/BasicButtonGroup.js +1 -1
  68. package/dist/src/desktop/components/BasicFormGroup/BasicFormGroup.d.ts +6 -2
  69. package/dist/src/desktop/components/BasicFormGroup/BasicFormGroup.js +67 -6
  70. package/dist/src/desktop/components/BodyTextGroup/BodyTextGroup.d.ts +6 -1
  71. package/dist/src/desktop/components/BodyTextGroup/BodyTextGroup.js +70 -2
  72. package/dist/src/desktop/components/BoxItem/BoxItem.d.ts +67 -0
  73. package/dist/src/desktop/components/BoxItem/BoxItem.js +107 -0
  74. package/dist/src/desktop/components/BoxItem/LeftBox/Checkbox.d.ts +7 -0
  75. package/dist/src/desktop/components/BoxItem/LeftBox/Checkbox.js +9 -0
  76. package/dist/src/desktop/components/BoxItem/LeftBox/Image.d.ts +11 -0
  77. package/dist/src/desktop/components/BoxItem/LeftBox/Image.js +9 -0
  78. package/dist/src/desktop/components/BoxItem/LeftBox/LeftBox.d.ts +11 -0
  79. package/dist/src/desktop/components/BoxItem/LeftBox/LeftBox.js +36 -0
  80. package/dist/src/desktop/components/BoxItem/LeftBox/index.d.ts +2 -0
  81. package/dist/src/{sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner → desktop/components/BoxItem/LeftBox}/index.js +3 -3
  82. package/dist/src/desktop/components/BoxItem/index.d.ts +1 -0
  83. package/dist/src/desktop/components/BoxItem/index.js +8 -0
  84. package/dist/src/desktop/components/Calendar/AllDaySchedulesSection.d.ts +12 -0
  85. package/dist/src/desktop/components/Calendar/AllDaySchedulesSection.js +134 -0
  86. package/dist/src/desktop/components/Calendar/Calendar.d.ts +4 -0
  87. package/dist/src/desktop/components/Calendar/Calendar.js +399 -0
  88. package/dist/src/desktop/components/Calendar/CalendarContext.d.ts +51 -0
  89. package/dist/src/desktop/components/Calendar/CalendarContext.js +76 -0
  90. package/dist/src/desktop/components/Calendar/CurrentTimeIndicator.d.ts +7 -0
  91. package/dist/src/desktop/components/Calendar/CurrentTimeIndicator.js +48 -0
  92. package/dist/src/desktop/components/Calendar/DailyView.d.ts +2 -0
  93. package/dist/src/desktop/components/Calendar/DailyView.js +91 -0
  94. package/dist/src/desktop/components/Calendar/MonthlyView.d.ts +28 -0
  95. package/dist/src/desktop/components/Calendar/MonthlyView.js +419 -0
  96. package/dist/src/desktop/components/Calendar/MultiWeekSchedulesLayer.d.ts +21 -0
  97. package/dist/src/desktop/components/Calendar/MultiWeekSchedulesLayer.js +186 -0
  98. package/dist/src/desktop/components/Calendar/ScheduleItem.d.ts +25 -0
  99. package/dist/src/desktop/components/Calendar/ScheduleItem.js +56 -0
  100. package/dist/src/desktop/components/Calendar/TimeBasedScheduleItem.d.ts +12 -0
  101. package/dist/src/desktop/components/Calendar/TimeBasedScheduleItem.js +184 -0
  102. package/dist/src/desktop/components/Calendar/WeeklyView.d.ts +6 -0
  103. package/dist/src/desktop/components/Calendar/WeeklyView.js +114 -0
  104. package/dist/src/desktop/components/Calendar/YearlyView.d.ts +13 -0
  105. package/dist/src/desktop/components/Calendar/YearlyView.js +76 -0
  106. package/dist/src/desktop/components/Calendar/calendarUtils.d.ts +24 -0
  107. package/dist/src/desktop/components/Calendar/calendarUtils.js +87 -0
  108. package/dist/src/desktop/components/Calendar/constants.d.ts +1 -0
  109. package/dist/src/desktop/components/Calendar/constants.js +31 -0
  110. package/dist/src/desktop/components/Calendar/index.d.ts +14 -0
  111. package/dist/src/desktop/components/Calendar/index.js +42 -0
  112. package/dist/src/desktop/components/Calendar/timeFormatUtils.d.ts +18 -0
  113. package/dist/src/desktop/components/Calendar/timeFormatUtils.js +59 -0
  114. package/dist/src/desktop/components/Calendar/types.d.ts +61 -0
  115. package/dist/src/desktop/components/ChatBubbleListItem/ChatBubbleListItem.d.ts +2 -3
  116. package/dist/src/desktop/components/ChatBubbleListItem/ChatBubbleListItem.js +3 -8
  117. package/dist/src/desktop/components/ChatList/Body.d.ts +1 -1
  118. package/dist/src/desktop/components/PriceTextField/PriceTextField.d.ts +43 -0
  119. package/dist/src/desktop/components/PriceTextField/PriceTextField.js +604 -0
  120. package/dist/src/desktop/components/PriceTextField/index.d.ts +1 -0
  121. package/dist/src/desktop/components/PriceTextField/index.js +8 -0
  122. package/dist/src/desktop/components/PriceTextLabel/PriceTextLabel.d.ts +14 -0
  123. package/dist/src/desktop/components/PriceTextLabel/PriceTextLabel.js +47 -0
  124. package/dist/src/desktop/components/PriceTextLabel/index.d.ts +1 -0
  125. package/dist/src/desktop/components/PriceTextLabel/index.js +8 -0
  126. package/dist/src/desktop/components/Snackbar/Snackbar.d.ts +17 -0
  127. package/dist/src/desktop/components/Snackbar/Snackbar.js +221 -0
  128. package/dist/src/desktop/components/Snackbar/index.d.ts +1 -0
  129. package/dist/src/desktop/components/Snackbar/index.js +8 -0
  130. package/dist/src/desktop/components/Snackbar/provider.d.ts +11 -0
  131. package/dist/src/desktop/components/Snackbar/provider.js +43 -0
  132. package/dist/src/desktop/components/TextButton/TextButton.d.ts +6 -3
  133. package/dist/src/desktop/components/TextButton/TextButton.js +67 -40
  134. package/dist/src/desktop/components/TextField/TextField.d.ts +2 -1
  135. package/dist/src/desktop/components/TextField/TextField.js +7 -7
  136. package/dist/src/desktop/components/TextLabel/TextLabel.d.ts +3 -3
  137. package/dist/src/desktop/components/UploadTextButton/UploadTextButton.d.ts +1 -1
  138. package/dist/src/desktop/components/UploadTextButton/UploadTextButton.js +56 -39
  139. package/dist/src/desktop/components/index.d.ts +6 -1
  140. package/dist/src/desktop/components/index.js +12 -1
  141. package/dist/src/desktop/index.d.ts +1 -1
  142. package/dist/src/desktop/index.js +7 -2
  143. package/dist/src/desktop/layout/LayoutWF/Containers/ContentsContainer/variation/WFA.js +1 -1
  144. package/dist/src/desktop/layout/LayoutWF/Containers/ContentsContainer/variation/WFB.js +1 -1
  145. package/dist/src/desktop/layout/LayoutWF/Containers/ContentsContainer/variation/WFE.js +1 -1
  146. package/dist/src/desktop/layout/LayoutWF/Containers/ContentsContainer/variation/WFL.js +8 -5
  147. package/dist/src/desktop/panels/DesktopBasicModal/DesktopBasicModal.d.ts +2 -1
  148. package/dist/src/desktop/panels/DesktopBasicModal/DesktopBasicModal.js +13 -15
  149. package/dist/src/desktop/panels/DesktopBasicModalWithTab/DesktopBasicModalWithTab.d.ts +3 -1
  150. package/dist/src/desktop/panels/DesktopBasicModalWithTab/DesktopBasicModalWithTab.js +16 -10
  151. package/dist/src/desktop/panels/DesktopHeadlessModal/DesktopHeadlessModal.d.ts +19 -3
  152. package/dist/src/desktop/panels/DesktopHeadlessModal/DesktopHeadlessModal.js +42 -31
  153. package/dist/src/desktop/panels/DesktopTutorialModal/DesktopTutorialModal.d.ts +3 -1
  154. package/dist/src/desktop/panels/DesktopTutorialModal/DesktopTutorialModal.js +11 -5
  155. package/dist/src/desktop/panels/MultilingualModal/MultilingualModal.d.ts +13 -0
  156. package/dist/src/desktop/panels/MultilingualModal/MultilingualModal.js +206 -0
  157. package/dist/src/desktop/panels/MultilingualModal/index.d.ts +1 -0
  158. package/dist/src/{sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList → desktop/panels/MultilingualModal}/index.js +3 -3
  159. package/dist/src/desktop/panels/index.d.ts +2 -1
  160. package/dist/src/desktop/panels/index.js +6 -1
  161. package/dist/src/hybrid/components/Divider/Divider.d.ts +3 -1
  162. package/dist/src/hybrid/components/Divider/Divider.js +9 -7
  163. package/dist/src/mobile/common/components/TextFieldBase/TextFieldBase.d.ts +3 -1
  164. package/dist/src/mobile/common/components/TextFieldBase/TextFieldBase.js +26 -22
  165. package/dist/src/mobile/components/BoxItem/BoxItem.d.ts +67 -0
  166. package/dist/src/mobile/components/BoxItem/BoxItem.js +106 -0
  167. package/dist/src/mobile/components/BoxItem/LeftBox/Checkbox.d.ts +7 -0
  168. package/dist/src/mobile/components/BoxItem/LeftBox/Checkbox.js +9 -0
  169. package/dist/src/mobile/components/BoxItem/LeftBox/Image.d.ts +11 -0
  170. package/dist/src/mobile/components/BoxItem/LeftBox/Image.js +9 -0
  171. package/dist/src/mobile/components/BoxItem/LeftBox/LeftBox.d.ts +11 -0
  172. package/dist/src/mobile/components/BoxItem/LeftBox/LeftBox.js +36 -0
  173. package/dist/src/mobile/components/BoxItem/LeftBox/index.d.ts +2 -0
  174. package/dist/src/mobile/components/BoxItem/LeftBox/index.js +8 -0
  175. package/dist/src/mobile/components/BoxItem/index.d.ts +1 -0
  176. package/dist/src/mobile/components/BoxItem/index.js +8 -0
  177. package/dist/src/mobile/components/ChatBubbleListItem/ChatBubbleListItem.d.ts +2 -3
  178. package/dist/src/mobile/components/ChatBubbleListItem/ChatBubbleListItem.js +3 -8
  179. package/dist/src/mobile/components/ChatList/Body.d.ts +1 -1
  180. package/dist/src/mobile/components/PriceTextField/PriceTextField.d.ts +42 -0
  181. package/dist/src/mobile/components/PriceTextField/PriceTextField.js +591 -0
  182. package/dist/src/mobile/components/PriceTextField/index.d.ts +1 -0
  183. package/dist/src/mobile/components/PriceTextField/index.js +8 -0
  184. package/dist/src/mobile/components/PriceTextLabel/PriceTextLabel.d.ts +14 -0
  185. package/dist/src/mobile/components/PriceTextLabel/PriceTextLabel.js +47 -0
  186. package/dist/src/mobile/components/PriceTextLabel/index.d.ts +1 -0
  187. package/dist/src/mobile/components/PriceTextLabel/index.js +8 -0
  188. package/dist/src/mobile/components/Snackbar/Snackbar.d.ts +17 -0
  189. package/dist/src/mobile/components/Snackbar/Snackbar.js +221 -0
  190. package/dist/src/mobile/components/Snackbar/index.d.ts +1 -0
  191. package/dist/src/mobile/components/Snackbar/index.js +8 -0
  192. package/dist/src/mobile/components/Snackbar/provider.d.ts +11 -0
  193. package/dist/src/mobile/components/Snackbar/provider.js +43 -0
  194. package/dist/src/mobile/components/TextButton/TextButton.d.ts +6 -3
  195. package/dist/src/mobile/components/TextButton/TextButton.js +55 -31
  196. package/dist/src/mobile/components/TextField/TextField.d.ts +2 -1
  197. package/dist/src/mobile/components/TextField/TextField.js +7 -7
  198. package/dist/src/mobile/components/TextLabel/TextLabel.d.ts +3 -3
  199. package/dist/src/mobile/components/UploadTextButton/UploadTextButton.d.ts +1 -1
  200. package/dist/src/mobile/components/UploadTextButton/UploadTextButton.js +44 -30
  201. package/dist/src/mobile/components/index.d.ts +5 -1
  202. package/dist/src/mobile/components/index.js +9 -1
  203. package/dist/src/mobile/index.d.ts +1 -1
  204. package/dist/src/mobile/index.js +6 -2
  205. package/dist/src/mobile/panels/MobileBasicModal/MobileBasicModal.d.ts +3 -1
  206. package/dist/src/mobile/panels/MobileBasicModal/MobileBasicModal.js +13 -6
  207. package/dist/src/sub/AdminList/AdminList/AdminList.d.ts +10 -1
  208. package/dist/src/sub/AdminList/AdminList/AdminList.js +19 -18
  209. package/dist/src/sub/AdminList/AdminList/HeaderRow.d.ts +10 -1
  210. package/dist/src/sub/AdminList/AdminList/HeaderRow.js +2 -2
  211. package/dist/src/sub/DynamicLayout/CompositionRenderer/ComponentBlockMatcher.js +1 -4
  212. package/dist/src/sub/DynamicLayout/CompositionRenderer/Composition.d.ts +3 -5
  213. package/dist/src/sub/DynamicLayout/CompositionRenderer/Composition.js +54 -54
  214. package/dist/src/sub/DynamicLayout/CompositionRenderer/CompositionRenderer.d.ts +6 -0
  215. package/dist/src/sub/DynamicLayout/CompositionRenderer/CompositionRenderer.js +27 -0
  216. package/dist/src/sub/DynamicLayout/DynamicLayout.d.ts +1 -1
  217. package/dist/src/sub/DynamicLayout/DynamicLayout.js +2 -4
  218. package/dist/src/sub/DynamicLayout/components/Section/components/CustomSectionBackgroundMedia.js +2 -24
  219. package/dist/src/sub/DynamicLayout/components/Section/sectionContext.d.ts +2 -2
  220. package/dist/src/sub/DynamicLayout/components/Section/util/parseSectionBackgroundMediaData.js +1 -3
  221. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/index.d.ts +0 -40
  222. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/index.js +177 -36
  223. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/styles/colorSet/PaletteColor_Dark.json +4 -152
  224. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/styles/colorSet/PaletteColor_light.json +2 -150
  225. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/styles/colorSet/SemanticColor.json +1 -45
  226. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/styles/colorSet/UIColor.json +9 -262
  227. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/styles/colorSet/index.d.ts +0 -593
  228. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/styles/colorSet/ui-type.d.ts +0 -253
  229. package/dist/src/sub/DynamicLayout/components/pdsOriginal/desktop/IconButton/IconButton.d.ts +1 -3
  230. package/dist/src/sub/DynamicLayout/components/pdsOriginal/desktop/IconButton/IconButton.js +3 -5
  231. package/dist/src/sub/DynamicLayout/components/pdsOriginal/hybrid/Icon/Icon.d.ts +1 -2
  232. package/dist/src/sub/DynamicLayout/components/pdsOriginal/hybrid/Icon/Icon.js +2 -9
  233. package/dist/src/sub/DynamicLayout/mock_video_cb.d.ts +1 -0
  234. package/dist/src/sub/DynamicLayout/mock_video_cb.js +5 -4
  235. package/dist/src/sub/DynamicLayout/mocks.d.ts +961 -8
  236. package/dist/src/sub/DynamicLayout/mocks.js +4239 -55
  237. package/dist/src/sub/DynamicLayout/sectionActionTypes.d.ts +4 -4
  238. package/dist/src/sub/DynamicLayout/sections/CustomSection/CustomSection.d.ts +1 -1
  239. package/dist/src/sub/DynamicLayout/sections/CustomSection/CustomSection.js +7 -7
  240. package/dist/src/sub/DynamicLayout/sections/CustomSection/FlexGridItem.d.ts +1 -1
  241. package/dist/src/sub/DynamicLayout/sections/CustomSection/FlexGridItem.js +5 -6
  242. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/ComponentBlockMatcher.js +3 -13
  243. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/Button/Button.js +2 -18
  244. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/ContentsCarousel.d.ts +4 -10
  245. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/ContentsCarousel.js +3 -140
  246. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/Image/Image.js +3 -39
  247. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/Text/Text.js +8 -49
  248. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/VideoPlayer/VideoPlayer.js +28 -3
  249. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/VideoPlayer/helper.d.ts +1 -0
  250. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/VideoPlayer/helper.js +15 -5
  251. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/types.d.ts +3 -55
  252. package/dist/src/sub/DynamicLayout/sections/CustomSection/newUtils/group.d.ts +1 -1
  253. package/dist/src/sub/DynamicLayout/sections/CustomSection/newUtils/replaceUndefinedValues.js +1 -1
  254. package/dist/src/sub/DynamicLayout/sections/CustomSection/types.d.ts +10 -27
  255. package/dist/src/sub/DynamicLayout/sections/CustomSection/types.js +1 -3
  256. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/effectPropParsers/parseEffectPropEntAnim.d.ts +4 -4
  257. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/layoutPropParsers/parseLayoutPropPadding.d.ts +2 -2
  258. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/parseJsonProperties.d.ts +2 -2
  259. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/parsePlacement.d.ts +2 -7
  260. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/parsePlacement.js +5 -16
  261. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/parseProperties.d.ts +2 -2
  262. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/stylePropParsers/parseStylePropTextSpec.js +0 -2
  263. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/types.d.ts +3 -53
  264. package/dist/src/sub/DynamicLayout/sections/FlexGridCustomSection.d.ts +1 -1
  265. package/dist/src/sub/DynamicLayout/sections/FlexGridCustomSection.js +0 -1
  266. package/dist/src/sub/DynamicLayout/types.d.ts +17 -64
  267. package/package.json +2 -3
  268. package/release-note.md +2 -2
  269. package/dist/src/common/types/form.d.ts +0 -9
  270. package/dist/src/common/types/form.js +0 -10
  271. package/dist/src/sub/DynamicLayout/CompositionEditor/CompositionEditor.d.ts +0 -22
  272. package/dist/src/sub/DynamicLayout/CompositionEditor/CompositionEditor.js +0 -1134
  273. package/dist/src/sub/DynamicLayout/CompositionRenderer/CompositionBackground.d.ts +0 -11
  274. package/dist/src/sub/DynamicLayout/CompositionRenderer/CompositionBackground.js +0 -45
  275. package/dist/src/sub/DynamicLayout/CompositionRenderer/createCompositions.d.ts +0 -10
  276. package/dist/src/sub/DynamicLayout/CompositionRenderer/createCompositions.js +0 -79
  277. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/downIcons.d.ts +0 -12
  278. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/downIcons.js +0 -76
  279. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/index.d.ts +0 -4
  280. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/index.js +0 -47
  281. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/leftIcons.d.ts +0 -12
  282. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/leftIcons.js +0 -76
  283. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/rightIcons.d.ts +0 -12
  284. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/rightIcons.js +0 -76
  285. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/upIcons.d.ts +0 -12
  286. package/dist/src/sub/DynamicLayout/components/pdsOriginal/common/assets/icons/line/editorNavigationIcons/upIcons.js +0 -76
  287. package/dist/src/sub/DynamicLayout/compositionActionTypes.d.ts +0 -139
  288. package/dist/src/sub/DynamicLayout/compositionQueryContext.d.ts +0 -8
  289. package/dist/src/sub/DynamicLayout/compositionQueryContext.js +0 -14
  290. package/dist/src/sub/DynamicLayout/mock_componentBlocks.d.ts +0 -911
  291. package/dist/src/sub/DynamicLayout/mock_componentBlocks.js +0 -4238
  292. package/dist/src/sub/DynamicLayout/mock_composition.d.ts +0 -3
  293. package/dist/src/sub/DynamicLayout/mock_composition.js +0 -1607
  294. package/dist/src/sub/DynamicLayout/mock_contentsCarousel.d.ts +0 -1
  295. package/dist/src/sub/DynamicLayout/mock_contentsCarousel.js +0 -1111
  296. package/dist/src/sub/DynamicLayout/mock_contentsList.d.ts +0 -1
  297. package/dist/src/sub/DynamicLayout/mock_contentsList.js +0 -1091
  298. package/dist/src/sub/DynamicLayout/mock_queryData.d.ts +0 -96
  299. package/dist/src/sub/DynamicLayout/mock_queryData.js +0 -2639
  300. package/dist/src/sub/DynamicLayout/mock_slideBanner.d.ts +0 -842
  301. package/dist/src/sub/DynamicLayout/mock_slideBanner.js +0 -854
  302. package/dist/src/sub/DynamicLayout/mock_video.d.ts +0 -368
  303. package/dist/src/sub/DynamicLayout/mock_video.js +0 -371
  304. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/ContentsCarouselCore.d.ts +0 -12
  305. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/ContentsCarouselCore.js +0 -61
  306. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/CustomNavigationNextBtn.d.ts +0 -15
  307. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/CustomNavigationNextBtn.js +0 -69
  308. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/CustomNavigationPrevBtn.d.ts +0 -15
  309. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/CustomNavigationPrevBtn.js +0 -69
  310. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/CustomProgressbar.d.ts +0 -9
  311. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/CustomProgressbar.js +0 -87
  312. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/navigationConfigs.d.ts +0 -4
  313. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/navigationConfigs.js +0 -849
  314. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/progressConfigs.d.ts +0 -43
  315. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/components/progressConfigs.js +0 -162
  316. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/contentsCarouselUtils.d.ts +0 -39
  317. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/contentsCarouselUtils.js +0 -182
  318. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/hooks/useFlexGridLayout.d.ts +0 -18
  319. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/hooks/useFlexGridLayout.js +0 -229
  320. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/hooks/useSwiper.d.ts +0 -14
  321. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/hooks/useSwiper.js +0 -46
  322. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/index.d.ts +0 -1
  323. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/index.js +0 -8
  324. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel/types.d.ts +0 -139
  325. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/ContentsList.d.ts +0 -14
  326. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/ContentsList.js +0 -221
  327. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/ContentsListCore.d.ts +0 -17
  328. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/ContentsListCore.js +0 -39
  329. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/components/CustomPagination.d.ts +0 -10
  330. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/components/CustomPagination.js +0 -85
  331. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/components/paginationConfigs.d.ts +0 -25
  332. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/components/paginationConfigs.js +0 -183
  333. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/contentsListUtils.d.ts +0 -29
  334. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/contentsListUtils.js +0 -130
  335. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/hooks/useFlexGridLayout.d.ts +0 -18
  336. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/hooks/useFlexGridLayout.js +0 -229
  337. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/index.d.ts +0 -1
  338. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/types.d.ts +0 -67
  339. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsList/types.js +0 -2
  340. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/SlideBanner.d.ts +0 -14
  341. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/SlideBanner.js +0 -151
  342. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/SlideBannerCore.d.ts +0 -12
  343. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/SlideBannerCore.js +0 -39
  344. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/CustomNavigationNextBtn.d.ts +0 -15
  345. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/CustomNavigationNextBtn.js +0 -69
  346. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/CustomNavigationPrevBtn.d.ts +0 -15
  347. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/CustomNavigationPrevBtn.js +0 -69
  348. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/CustomPagination.d.ts +0 -20
  349. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/CustomPagination.js +0 -173
  350. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/CustomProgressbar.d.ts +0 -9
  351. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/CustomProgressbar.js +0 -87
  352. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/navigationConfigs.d.ts +0 -4
  353. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/navigationConfigs.js +0 -849
  354. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/progressConfigs.d.ts +0 -43
  355. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/components/progressConfigs.js +0 -162
  356. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/hooks/useFlexGridLayout.d.ts +0 -18
  357. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/hooks/useFlexGridLayout.js +0 -229
  358. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/hooks/useSwiper.d.ts +0 -16
  359. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/hooks/useSwiper.js +0 -63
  360. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/index.d.ts +0 -1
  361. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/slideBannerUtils.d.ts +0 -46
  362. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/slideBannerUtils.js +0 -186
  363. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/types.d.ts +0 -163
  364. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/SlideBanner/types.js +0 -2
  365. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/Text/textSpecFormatOptions.d.ts +0 -7
  366. package/dist/src/sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/Text/textSpecFormatOptions.js +0 -211
  367. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/parseCompositionPlacement.d.ts +0 -14
  368. package/dist/src/sub/DynamicLayout/sections/CustomSection/util/parseCompositionPlacement.js +0 -26
  369. /package/dist/src/{sub/DynamicLayout/compositionActionTypes.js → common/types/multilingual.js} +0 -0
  370. /package/dist/src/{sub/DynamicLayout/sections/CustomSection/components/ComponentBlock/componentBlocks/ContentsCarousel → desktop/components/Calendar}/types.js +0 -0
@@ -0,0 +1,399 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __assign = (this && this.__assign) || function () {
7
+ __assign = Object.assign || function(t) {
8
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
9
+ s = arguments[i];
10
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
11
+ t[p] = s[p];
12
+ }
13
+ return t;
14
+ };
15
+ return __assign.apply(this, arguments);
16
+ };
17
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
18
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
19
+ if (ar || !(i in from)) {
20
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
21
+ ar[i] = from[i];
22
+ }
23
+ }
24
+ return to.concat(ar || Array.prototype.slice.call(from));
25
+ };
26
+ var __importDefault = (this && this.__importDefault) || function (mod) {
27
+ return (mod && mod.__esModule) ? mod : { "default": mod };
28
+ };
29
+ Object.defineProperty(exports, "__esModule", { value: true });
30
+ var jsx_runtime_1 = require("react/jsx-runtime");
31
+ var react_1 = require("react");
32
+ var react_i18next_1 = require("react-i18next");
33
+ var dateHelper_1 = require("../../../common/utils/dateHelper");
34
+ var styled_components_1 = __importDefault(require("styled-components"));
35
+ var Dropdown_1 = require("../Dropdown");
36
+ var IconButton_1 = require("../IconButton");
37
+ var TextButton_1 = require("../TextButton");
38
+ var TextLabel_1 = require("../TextLabel");
39
+ var CalendarContext_1 = require("./CalendarContext");
40
+ var calendarUtils_1 = require("./calendarUtils");
41
+ var DailyView_1 = require("./DailyView");
42
+ var MonthlyView_1 = require("./MonthlyView");
43
+ var WeeklyView_1 = require("./WeeklyView");
44
+ var YearlyView_1 = require("./YearlyView");
45
+ var Calendar = function (_a) {
46
+ var _b;
47
+ var _c = _a.defaultViewType, defaultViewType = _c === void 0 ? 'MONTHLY' : _c, _d = _a.viewTypes, viewTypes = _d === void 0 ? ['MONTHLY', 'WEEKLY', 'DAILY', 'YEARLY'] : _d, _e = _a.displayAllDayScheduleMode, displayAllDayScheduleMode = _e === void 0 ? 'none' : _e, _f = _a.startOfWeek, startOfWeek = _f === void 0 ? 'sunday' : _f, _g = _a.todayBtnMode, todayBtnMode = _g === void 0 ? 'use' : _g, _h = _a.schedules, schedules = _h === void 0 ? [] : _h, config = _a.config, onActionDispatch = _a.onActionDispatch;
48
+ // 다국어 키를 CalendarViewType으로 매핑하는 함수
49
+ var mapI18nKeyToViewType = function (key) {
50
+ switch (key) {
51
+ case 'str_fm_month':
52
+ return 'MONTHLY';
53
+ case 'str_fm_week':
54
+ return 'WEEKLY';
55
+ case 'str_fm_day':
56
+ return 'DAILY';
57
+ case 'str_fm_year':
58
+ return 'YEARLY';
59
+ default:
60
+ return key;
61
+ }
62
+ };
63
+ // 다국어 키를 받아서 내부적으로 매핑
64
+ var actualDefaultViewType = mapI18nKeyToViewType(defaultViewType);
65
+ var actualViewTypes = viewTypes.map(mapI18nKeyToViewType);
66
+ var t = (0, react_i18next_1.useTranslation)().t;
67
+ var _j = (0, react_1.useState)(actualDefaultViewType), currentViewType = _j[0], setCurrentViewType = _j[1];
68
+ var _k = (0, react_1.useState)(new Date()), selectedDate = _k[0], setSelectedDate = _k[1];
69
+ var _l = (0, react_1.useState)(null), dragStartDate = _l[0], setDragStartDate = _l[1];
70
+ var _m = (0, react_1.useState)(null), dragEndDate = _m[0], setDragEndDate = _m[1];
71
+ var _o = (0, react_1.useState)(false), isDragging = _o[0], setIsDragging = _o[1];
72
+ var _p = (0, react_1.useState)(null), draggedSchedule = _p[0], setDraggedSchedule = _p[1];
73
+ var _q = (0, react_1.useState)(null), isDragOverDate = _q[0], setIsDragOverDate = _q[1];
74
+ var _r = (0, react_1.useState)([]), selectedSchedules = _r[0], setSelectedSchedules = _r[1];
75
+ var _s = (0, react_1.useState)([]), selectedDates = _s[0], setSelectedDates = _s[1];
76
+ var _t = (0, react_1.useState)(null), lastSelectedDate = _t[0], setLastSelectedDate = _t[1];
77
+ // 오늘 날짜인지 확인
78
+ var today = new Date();
79
+ var isToday = function (date) { return dateHelper_1.DateHelper.isSameDay(date, today); };
80
+ var isDraggable = !!((_b = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _b === void 0 ? void 0 : _b.DRAG);
81
+ // 과거 날짜인지 확인
82
+ var isPastDate = (0, react_1.useCallback)(function (date) { return dateHelper_1.DateHelper.isBefore(date, today) && !dateHelper_1.DateHelper.isSameDay(date, today); }, [today]);
83
+ // 뷰 타입에 따른 시작일과 종료일 계산
84
+ var _u = (0, calendarUtils_1.calculateDateRange)(currentViewType, selectedDate), startDate = _u.startDate, endDate = _u.endDate;
85
+ // 뷰 타입 변경 처리
86
+ var handleViewTypeChange = (0, react_1.useCallback)(function (option) {
87
+ var newViewType = option.value;
88
+ setCurrentViewType(newViewType);
89
+ // 새로운 뷰 타입 기준으로 startDate와 endDate 계산
90
+ var _a = (0, calendarUtils_1.calculateDateRange)(newViewType, selectedDate), newStartDate = _a.startDate, newEndDate = _a.endDate;
91
+ onActionDispatch === null || onActionDispatch === void 0 ? void 0 : onActionDispatch({
92
+ type: 'CALENDAR_TYPE_CHANGE',
93
+ payload: {
94
+ type: newViewType,
95
+ startDate: (0, calendarUtils_1.toUTC)(newStartDate),
96
+ endDate: (0, calendarUtils_1.toUTC)(newEndDate)
97
+ }
98
+ });
99
+ }, [selectedDate, onActionDispatch, calendarUtils_1.calculateDateRange]);
100
+ // "오늘" 버튼 클릭 이벤트
101
+ var handleTodayClick = (0, react_1.useCallback)(function () {
102
+ setSelectedDate(today);
103
+ // 오늘 날짜 기준으로 startDate와 endDate 계산
104
+ var _a = (0, calendarUtils_1.calculateDateRange)(currentViewType, today), newStartDate = _a.startDate, newEndDate = _a.endDate;
105
+ onActionDispatch === null || onActionDispatch === void 0 ? void 0 : onActionDispatch({
106
+ type: 'TODAY_BUTTON_CLICK',
107
+ payload: {
108
+ startDate: (0, calendarUtils_1.toUTC)(newStartDate),
109
+ endDate: (0, calendarUtils_1.toUTC)(newEndDate)
110
+ }
111
+ });
112
+ }, [today, currentViewType, onActionDispatch, calendarUtils_1.calculateDateRange]);
113
+ // 이전/다음 이동 함수
114
+ var navigateDate = (0, react_1.useCallback)(function (direction) {
115
+ var increment = direction === 'next' ? 1 : -1;
116
+ var getNewDateByViewType = function (viewType) {
117
+ switch (viewType) {
118
+ case 'DAILY':
119
+ return dateHelper_1.DateHelper.addDays(selectedDate, increment);
120
+ case 'WEEKLY':
121
+ return dateHelper_1.DateHelper.addDays(selectedDate, increment * 7);
122
+ case 'MONTHLY':
123
+ return dateHelper_1.DateHelper.addMonths(selectedDate, increment);
124
+ case 'YEARLY':
125
+ return new Date(selectedDate.getFullYear() + increment, selectedDate.getMonth(), selectedDate.getDate());
126
+ default:
127
+ return selectedDate;
128
+ }
129
+ };
130
+ var newDate = getNewDateByViewType(currentViewType);
131
+ setSelectedDate(newDate);
132
+ // 새로운 날짜 기준으로 startDate와 endDate 계산
133
+ var _a = (0, calendarUtils_1.calculateDateRange)(currentViewType, newDate), newStartDate = _a.startDate, newEndDate = _a.endDate;
134
+ onActionDispatch === null || onActionDispatch === void 0 ? void 0 : onActionDispatch({
135
+ type: direction === 'prev' ? 'PREV_BUTTON_CLICK' : 'NEXT_BUTTON_CLICK',
136
+ payload: {
137
+ startDate: (0, calendarUtils_1.toUTC)(newStartDate),
138
+ endDate: (0, calendarUtils_1.toUTC)(newEndDate)
139
+ }
140
+ });
141
+ }, [selectedDate, currentViewType, onActionDispatch, calendarUtils_1.calculateDateRange]);
142
+ // 특정 날짜의 이벤트 가져오기
143
+ var getSchedulesForDate = (0, react_1.useCallback)(function (date) {
144
+ return schedules.filter(function (schedule) {
145
+ var scheduleStart = new Date(schedule.startDate);
146
+ var scheduleEnd = new Date(schedule.endDate);
147
+ var targetDate = new Date(date);
148
+ // 정확한 날짜 비교를 위해 시간을 일 시작으로 설정
149
+ scheduleStart.setHours(0, 0, 0, 0);
150
+ scheduleEnd.setHours(23, 59, 59, 999);
151
+ targetDate.setHours(0, 0, 0, 0);
152
+ // 대상 날짜가 이벤트 날짜 범위 내에 있는지 확인
153
+ return targetDate >= scheduleStart && targetDate <= scheduleEnd;
154
+ });
155
+ }, [schedules]);
156
+ // 날짜 클릭 이벤트 (일반 클릭, shift 클릭 둘다 포함)
157
+ var handleDateClick = (0, react_1.useCallback)(function (date, e) {
158
+ var _a, _b, _c, _d, _e, _f;
159
+ var isShiftClick = ((_a = config === null || config === void 0 ? void 0 : config.DATE) === null || _a === void 0 ? void 0 : _a.CLICK_WITH_SHIFT_KEY_DOWN) && (e === null || e === void 0 ? void 0 : e.shiftKey);
160
+ var isNormalClick = ((_b = config === null || config === void 0 ? void 0 : config.DATE) === null || _b === void 0 ? void 0 : _b.CLICK) && !(e === null || e === void 0 ? void 0 : e.shiftKey);
161
+ var getDateKey = function (d) { return "".concat(d.getFullYear(), "-").concat(d.getMonth(), "-").concat(d.getDate()); };
162
+ var clickedDateKey = getDateKey(date);
163
+ // shift 클릭 처리
164
+ if (isShiftClick) {
165
+ var newSelectedDates = selectedDates.some(function (d) { return getDateKey(d) === clickedDateKey; })
166
+ ? selectedDates.filter(function (d) { return getDateKey(d) !== clickedDateKey; })
167
+ : __spreadArray(__spreadArray([], selectedDates, true), [date], false);
168
+ setSelectedDates(newSelectedDates);
169
+ setLastSelectedDate(date);
170
+ (_d = (_c = config === null || config === void 0 ? void 0 : config.DATE) === null || _c === void 0 ? void 0 : _c.CLICK_WITH_SHIFT_KEY_DOWN) === null || _d === void 0 ? void 0 : _d.call(_c, {
171
+ action: 'CLICK_WITH_SHIFT_KEY_DOWN',
172
+ target: 'DATE',
173
+ dates: newSelectedDates,
174
+ startDate: (0, calendarUtils_1.toUTC)(startDate),
175
+ endDate: (0, calendarUtils_1.toUTC)(endDate)
176
+ });
177
+ }
178
+ setSelectedDate(date);
179
+ // 일반 클릭 처리
180
+ if (isNormalClick) {
181
+ (_f = (_e = config === null || config === void 0 ? void 0 : config.DATE) === null || _e === void 0 ? void 0 : _e.CLICK) === null || _f === void 0 ? void 0 : _f.call(_e, {
182
+ action: 'CLICK',
183
+ target: 'DATE',
184
+ date: date,
185
+ startDate: (0, calendarUtils_1.toUTC)(startDate),
186
+ endDate: (0, calendarUtils_1.toUTC)(endDate)
187
+ });
188
+ }
189
+ }, [isPastDate, config, lastSelectedDate, selectedDates, startDate, endDate]);
190
+ // 날짜 범위 선택을 위한 마우스 이벤트 처리
191
+ var handleMouseUp = (0, react_1.useCallback)(function () {
192
+ setIsDragging(false);
193
+ setDragStartDate(null);
194
+ setDragEndDate(null);
195
+ }, [isDragging, dragStartDate, dragEndDate]);
196
+ // 이벤트 드래그 핸들러
197
+ var handleScheduleDragStart = (0, react_1.useCallback)(function (schedule, e) {
198
+ setDraggedSchedule(schedule);
199
+ e.dataTransfer.effectAllowed = 'move';
200
+ e.dataTransfer.setData('text/plain', schedule.id.toString());
201
+ // 더 정확한 드롭 계산을 위한 오프셋 정보 저장
202
+ var scheduleStartDate = new Date(schedule.startDate);
203
+ scheduleStartDate.setHours(0, 0, 0, 0);
204
+ // 원본 이벤트 시작 시간을 dataTransfer에 저장
205
+ e.dataTransfer.setData('scheduleStartTime', scheduleStartDate.getTime().toString());
206
+ }, []);
207
+ // 이벤트 드래그 종료 이벤트
208
+ var handleScheduleDragEnd = (0, react_1.useCallback)(function () {
209
+ setDraggedSchedule(null);
210
+ setIsDragOverDate(null);
211
+ }, []);
212
+ // 날짜 드래그 오버 이벤트
213
+ var handleDateDragOver = (0, react_1.useCallback)(function (date, e) {
214
+ if (!draggedSchedule) {
215
+ return;
216
+ }
217
+ e.preventDefault();
218
+ e.dataTransfer.dropEffect = 'move';
219
+ setIsDragOverDate(date);
220
+ }, [draggedSchedule]);
221
+ // 날짜 드래그 떼기
222
+ var handleDateDragLeave = (0, react_1.useCallback)(function () {
223
+ setIsDragOverDate(null);
224
+ }, []);
225
+ // 삭제 키 이벤트 처리
226
+ var handleKeyDown = (0, react_1.useCallback)(function (e) {
227
+ var _a, _b, _c;
228
+ if (e.key === 'Backspace' &&
229
+ selectedSchedules.length > 0 &&
230
+ ((_a = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _a === void 0 ? void 0 : _a.DELETE_KEY_DOWN)) {
231
+ (_c = (_b = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _b === void 0 ? void 0 : _b.DELETE_KEY_DOWN) === null || _c === void 0 ? void 0 : _c.call(_b, {
232
+ action: 'DELETE_KEY_DOWN',
233
+ target: 'SCHEDULE',
234
+ schedules: selectedSchedules,
235
+ startDate: (0, calendarUtils_1.toUTC)(startDate),
236
+ endDate: (0, calendarUtils_1.toUTC)(endDate)
237
+ });
238
+ setSelectedSchedules([]);
239
+ }
240
+ }, [config, selectedSchedules]);
241
+ // 날짜 드래그 놓기
242
+ var handleDateDrop = (0, react_1.useCallback)(function (date, e) {
243
+ var _a, _b, _c;
244
+ e.preventDefault();
245
+ if (!draggedSchedule) {
246
+ return;
247
+ }
248
+ if (!((_a = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _a === void 0 ? void 0 : _a.DRAG)) {
249
+ return;
250
+ }
251
+ var originalStartDate = new Date(draggedSchedule.startDate);
252
+ var originalEndDate = new Date(draggedSchedule.endDate);
253
+ var duration = originalEndDate.getTime() - originalStartDate.getTime();
254
+ var getAdjustedStartDate = function () {
255
+ var baseDate = new Date(date);
256
+ if (currentViewType === 'MONTHLY') {
257
+ var target = e.target;
258
+ var gridContainer = target.closest('[data-calendar-grid]');
259
+ if (gridContainer) {
260
+ var gridRect = gridContainer.getBoundingClientRect();
261
+ var cellWidth = gridRect.width / 7;
262
+ var clickedColumn = Math.floor((e.clientX - gridRect.left) / cellWidth);
263
+ var dropDayOfWeek = baseDate.getDay();
264
+ var columnOffset = clickedColumn - dropDayOfWeek;
265
+ var actualDropDate = new Date(baseDate);
266
+ actualDropDate.setDate(baseDate.getDate() + columnOffset);
267
+ actualDropDate.setHours(originalStartDate.getHours(), originalStartDate.getMinutes(), 0, 0);
268
+ return actualDropDate;
269
+ }
270
+ }
271
+ // 공통 처리 (WEEKLY, DAILY, fallback)
272
+ baseDate.setHours(originalStartDate.getHours(), originalStartDate.getMinutes(), 0, 0);
273
+ return baseDate;
274
+ };
275
+ var newStartDate = getAdjustedStartDate();
276
+ var newEndDate = new Date(newStartDate.getTime() + duration);
277
+ var updatedSchedule = __assign(__assign({}, draggedSchedule), { startDate: newStartDate, endDate: newEndDate });
278
+ (_c = (_b = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _b === void 0 ? void 0 : _b.DRAG) === null || _c === void 0 ? void 0 : _c.call(_b, {
279
+ action: 'DRAG',
280
+ target: 'SCHEDULE',
281
+ schedule: updatedSchedule,
282
+ startDate: (0, calendarUtils_1.toUTC)(startDate),
283
+ endDate: (0, calendarUtils_1.toUTC)(endDate)
284
+ });
285
+ setIsDragOverDate(null);
286
+ }, [draggedSchedule, config, currentViewType]);
287
+ var defaultDayTexts = (0, react_1.useMemo)(function () { return [
288
+ t('str_3893'),
289
+ t('str_3887'),
290
+ t('str_3888'),
291
+ t('str_3889'),
292
+ t('str_3890'),
293
+ t('str_3891'),
294
+ t('str_3892') // 토 - 6
295
+ ]; }, [t]);
296
+ // 날짜의 실제 요일에 따른 요일 텍스트 가져오기
297
+ var getDayTextByDate = function (date) {
298
+ return defaultDayTexts[date.getDay()];
299
+ };
300
+ // 뷰 타입을 위한 드롭다운 옵션 생성
301
+ var viewTypeOptions = (0, react_1.useMemo)(function () {
302
+ var viewTypeTextMap = {
303
+ MONTHLY: t('str_fm_month'),
304
+ WEEKLY: t('str_fm_week'),
305
+ DAILY: t('str_fm_day'),
306
+ YEARLY: t('str_fm_year')
307
+ };
308
+ return actualViewTypes.map(function (viewType) { return ({
309
+ text: viewTypeTextMap[viewType] || viewType,
310
+ value: viewType
311
+ }); });
312
+ }, [actualViewTypes, t]);
313
+ // 특정 월의 캘린더 날짜 생성 (연간 보기용)
314
+ var getMonthDates = (0, react_1.useCallback)(function (year, month) {
315
+ var monthDate = new Date(year, month, 1);
316
+ return dateHelper_1.DateHelper.getCalendarDates(monthDate, startOfWeek);
317
+ }, [startOfWeek]);
318
+ // 스케줄 클릭 (일반 클릭, shift 클릭 둘다 포함)
319
+ var handleScheduleClick = function (schedule, e) {
320
+ var _a, _b, _c, _d, _e, _f;
321
+ var isShiftClick = ((_a = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _a === void 0 ? void 0 : _a.CLICK_WITH_SHIFT_KEY_DOWN) && (e === null || e === void 0 ? void 0 : e.shiftKey);
322
+ var isNormalClick = ((_b = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _b === void 0 ? void 0 : _b.CLICK) && !(e === null || e === void 0 ? void 0 : e.shiftKey);
323
+ var isSelected = selectedSchedules.some(function (s) { return s.id === (schedule === null || schedule === void 0 ? void 0 : schedule.id); });
324
+ if (isShiftClick) {
325
+ var newSelectedSchedules = isSelected
326
+ ? selectedSchedules.filter(function (s) { return s.id !== (schedule === null || schedule === void 0 ? void 0 : schedule.id); })
327
+ : __spreadArray(__spreadArray([], selectedSchedules, true), [schedule], false).filter(function (s) { return s !== undefined; });
328
+ setSelectedSchedules(newSelectedSchedules);
329
+ (_d = (_c = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _c === void 0 ? void 0 : _c.CLICK_WITH_SHIFT_KEY_DOWN) === null || _d === void 0 ? void 0 : _d.call(_c, {
330
+ action: 'CLICK_WITH_SHIFT_KEY_DOWN',
331
+ target: 'SCHEDULE',
332
+ schedules: newSelectedSchedules,
333
+ startDate: (0, calendarUtils_1.toUTC)(startDate),
334
+ endDate: (0, calendarUtils_1.toUTC)(endDate)
335
+ });
336
+ return;
337
+ }
338
+ if (isNormalClick) {
339
+ // 일반 클릭 시 해당 스케줄만 선택
340
+ setSelectedSchedules([schedule]);
341
+ (_f = (_e = config === null || config === void 0 ? void 0 : config.SCHEDULE) === null || _e === void 0 ? void 0 : _e.CLICK) === null || _f === void 0 ? void 0 : _f.call(_e, {
342
+ action: 'CLICK',
343
+ target: 'SCHEDULE',
344
+ schedule: schedule,
345
+ startDate: (0, calendarUtils_1.toUTC)(startDate),
346
+ endDate: (0, calendarUtils_1.toUTC)(endDate)
347
+ });
348
+ return;
349
+ }
350
+ };
351
+ // 주간 뷰로 전환하는 핸들러
352
+ var handleSwitchToWeeklyView = (0, react_1.useCallback)(function (date) {
353
+ setCurrentViewType('WEEKLY');
354
+ setSelectedDate(date);
355
+ // 주간 뷰로 전환할 때의 startDate와 endDate 계산
356
+ var _a = (0, calendarUtils_1.calculateDateRange)('WEEKLY', date), newStartDate = _a.startDate, newEndDate = _a.endDate;
357
+ onActionDispatch === null || onActionDispatch === void 0 ? void 0 : onActionDispatch({
358
+ type: 'CALENDAR_TYPE_CHANGE',
359
+ payload: {
360
+ type: 'WEEKLY',
361
+ startDate: (0, calendarUtils_1.toUTC)(newStartDate),
362
+ endDate: (0, calendarUtils_1.toUTC)(newEndDate)
363
+ }
364
+ });
365
+ }, [onActionDispatch, calendarUtils_1.calculateDateRange]);
366
+ // 뷰 타입에 따른 캘린더 콘텐츠 렌더링
367
+ var renderCalendarContent = function () {
368
+ switch (currentViewType) {
369
+ case 'MONTHLY':
370
+ return ((0, jsx_runtime_1.jsx)(MonthlyView_1.MonthlyView, { getDayTextByDate: getDayTextByDate, startOfWeek: startOfWeek, selectedDate: selectedDate, selectedDates: selectedDates, dragStartDate: dragStartDate, selectedSchedules: selectedSchedules, dragEndDate: dragEndDate, isDragOverDate: isDragOverDate, schedules: schedules, getSchedulesForDate: getSchedulesForDate, isToday: isToday, isPastDate: isPastDate, handleDateClick: handleDateClick, handleScheduleClick: handleScheduleClick, handleMouseUp: handleMouseUp, handleDateDragOver: handleDateDragOver, handleDateDragLeave: handleDateDragLeave, handleDateDrop: handleDateDrop, handleScheduleDragStart: handleScheduleDragStart, handleScheduleDragEnd: handleScheduleDragEnd, isDraggable: isDraggable, onSwitchToWeeklyView: handleSwitchToWeeklyView }));
371
+ case 'WEEKLY':
372
+ return (0, jsx_runtime_1.jsx)(WeeklyView_1.WeeklyView, { startOfWeek: startOfWeek });
373
+ case 'DAILY':
374
+ return (0, jsx_runtime_1.jsx)(DailyView_1.DailyView, {});
375
+ case 'YEARLY':
376
+ return ((0, jsx_runtime_1.jsx)(YearlyView_1.YearlyView, { selectedDate: selectedDate, getMonthDates: getMonthDates, getDayTextByDate: getDayTextByDate, startOfWeek: startOfWeek, isToday: isToday, handleDateClick: handleDateClick, getSchedulesForDate: getSchedulesForDate }));
377
+ default:
378
+ return null;
379
+ }
380
+ };
381
+ return ((0, jsx_runtime_1.jsx)(CalendarContext_1.CalendarProvider
382
+ // 스케줄 관련
383
+ , __assign({
384
+ // 스케줄 관련
385
+ selectedSchedules: selectedSchedules, isDraggable: isDraggable, handleScheduleClick: handleScheduleClick, handleScheduleDragStart: handleScheduleDragStart, handleScheduleDragEnd: handleScheduleDragEnd,
386
+ // 날짜 관련
387
+ handleDateClick: handleDateClick, handleDateDragOver: handleDateDragOver, handleDateDragLeave: handleDateDragLeave, handleDateDrop: handleDateDrop,
388
+ // 유틸리티 함수
389
+ getSchedulesForDate: getSchedulesForDate, isToday: isToday, isPastDate: isPastDate, getDayTextByDate: getDayTextByDate,
390
+ // 상태값
391
+ isDragOverDate: isDragOverDate, selectedDate: selectedDate, displayAllDayScheduleMode: displayAllDayScheduleMode }, { children: (0, jsx_runtime_1.jsxs)(S_CalendarContainer, __assign({ "x-pds-name": "Calendar", "x-pds-element-type": "component", "x-pds-device-type": "desktop", onKeyDown: handleKeyDown, tabIndex: 0 }, { children: [(0, jsx_runtime_1.jsxs)(S_CalendarHeader, { children: [(0, jsx_runtime_1.jsx)(TextLabel_1.TextLabel, { styleTheme: "headingBold", textAlign: "center", text: (0, calendarUtils_1.getHeaderText)(currentViewType, selectedDate, t) }), (0, jsx_runtime_1.jsxs)(S_LeftContainer, { children: [(0, jsx_runtime_1.jsx)(S_NavigationButtonContainer, __assign({ onClick: function () { return navigateDate('prev'); } }, { children: (0, jsx_runtime_1.jsx)(IconButton_1.IconButton, { iconName: "ic_arrow_left", baseSize: "small", iconSize: 16, baseColorKey: "ui_cpnt_button_fill_base_transparent", iconColorKey: "ui_cpnt_icon_sys_grey_01" }) })), todayBtnMode === 'use' && ((0, jsx_runtime_1.jsx)(TextButton_1.TextButton, { text: t('str_calendar_today'), size: "small", colorTheme: "grey_01", onClick: handleTodayClick })), (0, jsx_runtime_1.jsx)(S_NavigationButtonContainer, __assign({ onClick: function () { return navigateDate('next'); } }, { children: (0, jsx_runtime_1.jsx)(IconButton_1.IconButton, { iconName: "ic_arrow_right", baseSize: "small", iconSize: 16, baseColorKey: "ui_cpnt_button_fill_base_transparent", iconColorKey: "ui_cpnt_icon_sys_grey_01" }) })), (0, jsx_runtime_1.jsx)(Dropdown_1.Dropdown, { size: "small", valueArray: viewTypeOptions, value: viewTypeOptions.find(function (option) { return option.value === currentViewType; }), onChange: handleViewTypeChange, customWidth: "120px" })] })] }), (0, jsx_runtime_1.jsx)(S_CalendarContent, { children: renderCalendarContent() })] })) })));
392
+ };
393
+ var S_CalendarContainer = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n display: flex;\n flex-direction: column;\n height: 100%;\n min-height: 400px;\n outline: 0px;\n overflow: hidden;\n width: 100%;\n"], ["\n display: flex;\n flex-direction: column;\n height: 100%;\n min-height: 400px;\n outline: 0px;\n overflow: hidden;\n width: 100%;\n"])));
394
+ var S_CalendarHeader = styled_components_1.default.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n align-items: center;\n display: flex;\n gap: 16px;\n padding: 0px 0px 8px 0px;\n"], ["\n align-items: center;\n display: flex;\n gap: 16px;\n padding: 0px 0px 8px 0px;\n"])));
395
+ var S_NavigationButtonContainer = styled_components_1.default.div(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n align-items: center;\n background: none;\n border: none;\n cursor: pointer;\n display: flex;\n height: 32px;\n justify-content: center;\n width: 32px;\n"], ["\n align-items: center;\n background: none;\n border: none;\n cursor: pointer;\n display: flex;\n height: 32px;\n justify-content: center;\n width: 32px;\n"])));
396
+ var S_LeftContainer = styled_components_1.default.div(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n align-items: center;\n display: flex;\n gap: 8px;\n margin-left: auto;\n"], ["\n align-items: center;\n display: flex;\n gap: 8px;\n margin-left: auto;\n"])));
397
+ var S_CalendarContent = styled_components_1.default.div(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n flex: 1;\n overflow: auto;\n"], ["\n flex: 1;\n overflow: auto;\n"])));
398
+ exports.default = Calendar;
399
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5;
@@ -0,0 +1,51 @@
1
+ import React from 'react';
2
+ import type { Schedule, displayAllDayScheduleMode } from './types';
3
+ export interface ScheduleItemExtraProps {
4
+ onDragStart?: (e: React.DragEvent) => void;
5
+ onDragEnd?: () => void;
6
+ onClick?: (e: React.MouseEvent) => void;
7
+ style?: React.CSSProperties;
8
+ className?: string;
9
+ [key: string]: unknown;
10
+ }
11
+ interface CalendarContextValue {
12
+ renderScheduleItem: (schedule: Schedule, extraProps?: ScheduleItemExtraProps) => React.ReactNode;
13
+ handleScheduleClick: (schedule: Schedule, e?: React.MouseEvent) => void;
14
+ handleScheduleDragStart: (schedule: Schedule, e: React.DragEvent) => void;
15
+ handleScheduleDragEnd: () => void;
16
+ handleDateClick: (date: Date, e: React.MouseEvent) => void;
17
+ handleDateDragOver: (date: Date, e: React.DragEvent) => void;
18
+ handleDateDragLeave: () => void;
19
+ handleDateDrop: (date: Date, e: React.DragEvent) => void;
20
+ getSchedulesForDate: (date: Date) => Schedule[];
21
+ isToday: (date: Date) => boolean;
22
+ isPastDate: (date: Date) => boolean;
23
+ getDayTextByDate: (date: Date) => string;
24
+ selectedSchedules: Schedule[];
25
+ isDragOverDate: Date | null;
26
+ selectedDate: Date;
27
+ displayAllDayScheduleMode: displayAllDayScheduleMode;
28
+ isDraggable: boolean;
29
+ }
30
+ export declare const useCalendarContext: () => CalendarContextValue;
31
+ interface CalendarProviderProps {
32
+ children: React.ReactNode;
33
+ selectedSchedules: Schedule[];
34
+ isDraggable: boolean;
35
+ handleScheduleClick: (schedule: Schedule, e?: React.MouseEvent) => void;
36
+ handleScheduleDragStart: (schedule: Schedule, e: React.DragEvent) => void;
37
+ handleScheduleDragEnd: () => void;
38
+ handleDateClick: (date: Date, e: React.MouseEvent) => void;
39
+ handleDateDragOver: (date: Date, e: React.DragEvent) => void;
40
+ handleDateDragLeave: () => void;
41
+ handleDateDrop: (date: Date, e: React.DragEvent) => void;
42
+ getSchedulesForDate: (date: Date) => Schedule[];
43
+ isToday: (date: Date) => boolean;
44
+ isPastDate: (date: Date) => boolean;
45
+ getDayTextByDate: (date: Date) => string;
46
+ isDragOverDate: Date | null;
47
+ selectedDate: Date;
48
+ displayAllDayScheduleMode: displayAllDayScheduleMode;
49
+ }
50
+ export declare const CalendarProvider: React.FC<CalendarProviderProps>;
51
+ export {};
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.CalendarProvider = exports.useCalendarContext = void 0;
15
+ var jsx_runtime_1 = require("react/jsx-runtime");
16
+ var react_1 = require("react");
17
+ var calendarUtils_1 = require("./calendarUtils");
18
+ var ScheduleItem_1 = require("./ScheduleItem");
19
+ var CalendarContext = (0, react_1.createContext)(null);
20
+ var useCalendarContext = function () {
21
+ var context = (0, react_1.useContext)(CalendarContext);
22
+ if (!context) {
23
+ throw new Error('useCalendarContext must be used within a CalendarProvider');
24
+ }
25
+ return context;
26
+ };
27
+ exports.useCalendarContext = useCalendarContext;
28
+ var CalendarProvider = function (_a) {
29
+ var children = _a.children,
30
+ // 스케줄 관련
31
+ selectedSchedules = _a.selectedSchedules, isDraggable = _a.isDraggable, handleScheduleClick = _a.handleScheduleClick, handleScheduleDragStart = _a.handleScheduleDragStart, handleScheduleDragEnd = _a.handleScheduleDragEnd,
32
+ // 날짜 관련
33
+ handleDateClick = _a.handleDateClick, handleDateDragOver = _a.handleDateDragOver, handleDateDragLeave = _a.handleDateDragLeave, handleDateDrop = _a.handleDateDrop,
34
+ // 유틸리티 함수
35
+ getSchedulesForDate = _a.getSchedulesForDate, isToday = _a.isToday, isPastDate = _a.isPastDate, getDayTextByDate = _a.getDayTextByDate,
36
+ // 상태값
37
+ isDragOverDate = _a.isDragOverDate, selectedDate = _a.selectedDate, displayAllDayScheduleMode = _a.displayAllDayScheduleMode;
38
+ var renderScheduleItem = (0, react_1.useCallback)(function (schedule, extraProps) {
39
+ if (extraProps === void 0) { extraProps = {}; }
40
+ var isAllDay = (0, calendarUtils_1.calculateIsAllDay)(new Date(schedule.startDate), new Date(schedule.endDate));
41
+ var isSelected = selectedSchedules.some(function (s) { return s.id === schedule.id; });
42
+ return ((0, jsx_runtime_1.jsx)(ScheduleItem_1.ScheduleItem, { schedule: schedule, extraProps: extraProps, onDragStart: handleScheduleDragStart, onDragEnd: handleScheduleDragEnd, onClick: handleScheduleClick, isSelected: isSelected, isAllDay: isAllDay, isDraggable: isDraggable }));
43
+ }, [
44
+ selectedSchedules,
45
+ isDraggable,
46
+ handleScheduleClick,
47
+ handleScheduleDragStart,
48
+ handleScheduleDragEnd
49
+ ]);
50
+ var value = {
51
+ // 스케줄 렌더링 관련
52
+ renderScheduleItem: renderScheduleItem,
53
+ // 스케줄 이벤트 핸들러
54
+ handleScheduleClick: handleScheduleClick,
55
+ handleScheduleDragStart: handleScheduleDragStart,
56
+ handleScheduleDragEnd: handleScheduleDragEnd,
57
+ // 날짜 이벤트 핸들러
58
+ handleDateClick: handleDateClick,
59
+ handleDateDragOver: handleDateDragOver,
60
+ handleDateDragLeave: handleDateDragLeave,
61
+ handleDateDrop: handleDateDrop,
62
+ // 유틸리티 함수
63
+ getSchedulesForDate: getSchedulesForDate,
64
+ isToday: isToday,
65
+ isPastDate: isPastDate,
66
+ getDayTextByDate: getDayTextByDate,
67
+ // 상태값
68
+ selectedSchedules: selectedSchedules,
69
+ isDragOverDate: isDragOverDate,
70
+ selectedDate: selectedDate,
71
+ displayAllDayScheduleMode: displayAllDayScheduleMode,
72
+ isDraggable: isDraggable
73
+ };
74
+ return (0, jsx_runtime_1.jsx)(CalendarContext.Provider, __assign({ value: value }, { children: children }));
75
+ };
76
+ exports.CalendarProvider = CalendarProvider;
@@ -0,0 +1,7 @@
1
+ import type React from 'react';
2
+ interface CurrentTimeIndicatorProps {
3
+ show: boolean;
4
+ leftOffset?: string;
5
+ }
6
+ export declare const CurrentTimeIndicator: React.FC<CurrentTimeIndicatorProps>;
7
+ export {};
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.CurrentTimeIndicator = void 0;
11
+ var jsx_runtime_1 = require("react/jsx-runtime");
12
+ var react_1 = require("react");
13
+ var react_i18next_1 = require("react-i18next");
14
+ var styled_components_1 = __importDefault(require("styled-components"));
15
+ var constants_1 = require("./constants");
16
+ var CurrentTimeIndicator = function (_a) {
17
+ var show = _a.show, _b = _a.leftOffset, leftOffset = _b === void 0 ? '80px' : _b;
18
+ var i18n = (0, react_i18next_1.useTranslation)().i18n;
19
+ var getCurrentTime = (0, react_1.useCallback)(function () {
20
+ var now = new Date();
21
+ var locale = (0, constants_1.getLocaleFromLang)(i18n.language);
22
+ var timeInTimezone = new Date(now.toLocaleString(locale));
23
+ return {
24
+ hour: timeInTimezone.getHours(),
25
+ minute: timeInTimezone.getMinutes(),
26
+ percentage: ((timeInTimezone.getHours() * 60 + timeInTimezone.getMinutes()) / (24 * 60)) * 100
27
+ };
28
+ }, [i18n.language]);
29
+ var _c = (0, react_1.useState)(getCurrentTime()), currentTime = _c[0], setCurrentTime = _c[1];
30
+ (0, react_1.useEffect)(function () {
31
+ var updateTime = function () {
32
+ setCurrentTime(getCurrentTime());
33
+ };
34
+ updateTime();
35
+ var interval = setInterval(updateTime, 60000);
36
+ return function () { return clearInterval(interval); };
37
+ }, [getCurrentTime]);
38
+ return ((0, jsx_runtime_1.jsx)(S_CurrentTimeIndicator, { "$show": show, "$top": "".concat(currentTime.percentage, "%"), "$leftOffset": leftOffset }));
39
+ };
40
+ exports.CurrentTimeIndicator = CurrentTimeIndicator;
41
+ var S_CurrentTimeIndicator = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n background: ", ";\n display: ", ";\n height: 2px;\n left: ", ";\n position: absolute;\n right: 0;\n top: ", ";\n z-index: 10;\n\n &::before {\n background: ", ";\n border-radius: 50%;\n content: '';\n height: 8px;\n left: -4px;\n position: absolute;\n top: -3px;\n width: 8px;\n }\n"], ["\n background: ", ";\n display: ", ";\n height: 2px;\n left: ", ";\n position: absolute;\n right: 0;\n top: ", ";\n z-index: 10;\n\n &::before {\n background: ", ";\n border-radius: 50%;\n content: '';\n height: 8px;\n left: -4px;\n position: absolute;\n top: -3px;\n width: 8px;\n }\n"])), function (_a) {
42
+ var theme = _a.theme;
43
+ return theme.ui_cpnt_sheet_border_07;
44
+ }, function (props) { return (props.$show ? 'block' : 'none'); }, function (props) { return props.$leftOffset; }, function (props) { return props.$top; }, function (_a) {
45
+ var theme = _a.theme;
46
+ return theme.ui_cpnt_sheet_border_07;
47
+ });
48
+ var templateObject_1;
@@ -0,0 +1,2 @@
1
+ /// <reference types="react" />
2
+ export declare const DailyView: () => JSX.Element;