@antscorp/antsomi-ui 2.0.101 → 2.0.102
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.
- package/README.md +78 -78
- package/es/__mocks__/1000_city.json +802 -802
- package/es/assets/css/main.scss +6 -6
- package/es/assets/images/components/Login/AuthenSuccess.png +0 -0
- package/es/assets/images/feedback.svg +3 -3
- package/es/assets/svg/mobile-frame.svg +3 -3
- package/es/assets/svg/warning-icon.svg +5 -5
- package/es/components/atoms/Alert/Alert.js +28 -28
- package/es/components/atoms/ContentEditable/styled.js +16 -16
- package/es/components/atoms/DividerPure/styled.js +35 -35
- package/es/components/atoms/Icon/index.js +19 -19
- package/es/components/atoms/Iframe/Iframe.js +18 -18
- package/es/components/atoms/Input/styled.js +104 -104
- package/es/components/atoms/InputDynamic/styled.js +284 -284
- package/es/components/atoms/MobileBrandingBar/styled.js +21 -21
- package/es/components/atoms/MobileFrame/styled.js +30 -30
- package/es/components/atoms/MobileFrameV2/styled.js +42 -42
- package/es/components/atoms/MobileFrameV3/styled.js +31 -31
- package/es/components/atoms/NotificationStatus/NotificationStatus.d.ts +12 -0
- package/es/components/atoms/NotificationStatus/NotificationStatus.js +27 -0
- package/es/components/atoms/NotificationStatus/constants/index.d.ts +15 -0
- package/es/components/atoms/NotificationStatus/constants/index.js +15 -0
- package/es/components/atoms/NotificationStatus/index.d.ts +1 -0
- package/es/components/atoms/NotificationStatus/index.js +1 -0
- package/es/components/atoms/NotificationStatus/styled.d.ts +3 -0
- package/es/components/atoms/NotificationStatus/styled.js +14 -0
- package/es/components/atoms/PreviewTabs/styled.js +69 -69
- package/es/components/atoms/Radio/index.js +16 -16
- package/es/components/atoms/ReactIframe/ReactIframe.js +5 -5
- package/es/components/atoms/ReactIframe/styled.js +9 -9
- package/es/components/atoms/RequiredLabel/styled.js +3 -3
- package/es/components/atoms/ScrollBox/index.js +5 -5
- package/es/components/atoms/Scrollbars/styled.js +21 -21
- package/es/components/atoms/SlideBar/styled.js +194 -194
- package/es/components/atoms/Slider/styled.js +31 -31
- package/es/components/atoms/Space/Space.js +4 -4
- package/es/components/atoms/Spin/styled.js +11 -11
- package/es/components/atoms/Steps/styled.js +244 -244
- package/es/components/atoms/Switch/styled.js +56 -56
- package/es/components/atoms/Tag/Tag.js +10 -10
- package/es/components/atoms/Text/styled.js +34 -34
- package/es/components/atoms/index.d.ts +1 -0
- package/es/components/atoms/index.js +1 -0
- package/es/components/icons/DomainManagementIcon.js +1 -1
- package/es/components/icons/KeyValueIcon.d.ts +3 -0
- package/es/components/icons/KeyValueIcon.js +7 -0
- package/es/components/icons/LazyIcon/LazyIcon.d.ts +11 -10
- package/es/components/icons/LazyIcon/LazyIcon.js +11 -10
- package/es/components/icons/LoadingIcon.js +33 -33
- package/es/components/icons/document/styled.js +43 -43
- package/es/components/icons/index.d.ts +11 -10
- package/es/components/icons/index.js +11 -10
- package/es/components/molecules/AccessDenied/styled.js +28 -28
- package/es/components/molecules/AccountSelection/styled.js +110 -110
- package/es/components/molecules/AddDynamicContent/styled.js +23 -23
- package/es/components/molecules/AlignSetting/styled.js +4 -4
- package/es/components/molecules/ApplyPopupContent/styled.js +32 -32
- package/es/components/molecules/CalendarSelection/components/AutoUpdateTo/styled.js +8 -8
- package/es/components/molecules/CalendarSelection/components/CustomPicker/styled.js +79 -79
- package/es/components/molecules/CalendarSelection/components/Footer/styled.js +4 -4
- package/es/components/molecules/CalendarSelection/components/RangePicker/styled.js +21 -21
- package/es/components/molecules/CalendarSelection/components/RangeSelectOptions/components/Option/Option.js +26 -26
- package/es/components/molecules/CalendarSelection/components/RangeSelectOptions/styled.js +30 -30
- package/es/components/molecules/CalendarSelection/components/TimeRangeDisplay/styled.js +26 -26
- package/es/components/molecules/CalendarSelection/styled.js +8 -8
- package/es/components/molecules/CaptureScreen/components/CommentBox/styled.js +119 -119
- package/es/components/molecules/CaptureScreen/components/Cursor/styled.js +67 -67
- package/es/components/molecules/CaptureScreen/styled.js +240 -240
- package/es/components/molecules/ChartTab/components/styled.js +24 -24
- package/es/components/molecules/ChartTab/styled.js +20 -20
- package/es/components/molecules/ChatBox/AntsomiAI.js +8 -8
- package/es/components/molecules/ChatBox/ChatBoxInsight/QuestionItem.js +9 -9
- package/es/components/molecules/ChatBox/ChatBoxInsight/styled.js +365 -365
- package/es/components/molecules/ChatBox/styled.js +324 -324
- package/es/components/molecules/CodeStructure/styled.js +5 -5
- package/es/components/molecules/ColorPicker/ChromePicker/styled.js +10 -10
- package/es/components/molecules/ColorPicker/CustomPicker/styled.js +89 -89
- package/es/components/molecules/ColorPicker/SketchPicker/styled.js +5 -5
- package/es/components/molecules/ColorPicker/styled.js +7 -7
- package/es/components/molecules/ColorSetting/styled.js +39 -39
- package/es/components/molecules/DatePicker/components/AdvancedPicker/styled.js +110 -110
- package/es/components/molecules/DatePickerV2/styled.js +6 -6
- package/es/components/molecules/DisplayFormat/styled.js +12 -12
- package/es/components/molecules/DrawerDetail/components/ToggleDrawerSizeButton.js +24 -24
- package/es/components/molecules/DrawerDetail/styled.js +109 -109
- package/es/components/molecules/Dropdown/style.scss +11 -11
- package/es/components/molecules/Dropdown/styled.js +28 -28
- package/es/components/molecules/EdgeSetting/styled.js +10 -10
- package/es/components/molecules/EditableName/styled.js +70 -70
- package/es/components/molecules/EditingList/styled.js +29 -29
- package/es/components/molecules/EditorTab/styled.js +156 -156
- package/es/components/molecules/EmojiCollections/styled.js +22 -22
- package/es/components/molecules/EmojiPopover/styled.js +4 -4
- package/es/components/molecules/EmptyData/styled.js +53 -53
- package/es/components/molecules/GradientSetting/styled.js +57 -57
- package/es/components/molecules/HeaderV2/styled.js +70 -70
- package/es/components/molecules/IconSelection/styled.js +69 -69
- package/es/components/molecules/ImageEditor/components/ModalShortcut.js +21 -21
- package/es/components/molecules/ImageEditor/styled.js +5 -5
- package/es/components/molecules/ImagePreview/styled.js +3 -3
- package/es/components/molecules/InputNumberWithUnit/styled.js +14 -14
- package/es/components/molecules/InputSearch/styled.js +41 -41
- package/es/components/molecules/ItemNotFound/styled.js +26 -26
- package/es/components/molecules/MatchAnySelect/components/ExtendValuePopup.js +8 -8
- package/es/components/molecules/MatchAnySelect/styled.js +247 -247
- package/es/components/molecules/Modal/styled.js +63 -63
- package/es/components/molecules/ModalSelect/styled.js +152 -152
- package/es/components/molecules/ModalV2/styled.js +27 -27
- package/es/components/molecules/PopupDraggable/styled.js +57 -57
- package/es/components/molecules/PreviewModal/styled.js +26 -26
- package/es/components/molecules/ProcessLoading/styled.js +2 -2
- package/es/components/molecules/QuillEditor/CustomToolbar.js +3165 -3165
- package/es/components/molecules/QuillEditor/EditorToolbar.js +7 -7
- package/es/components/molecules/QuillEditor/styled.js +25 -25
- package/es/components/molecules/RadioGroup/styled.js +9 -9
- package/es/components/molecules/RequestAccess/styled.js +38 -38
- package/es/components/molecules/ResizeGrid/components/Cell/styled.js +77 -77
- package/es/components/molecules/ResizeGrid/styled.js +50 -50
- package/es/components/molecules/RichMenu/RichMenuBlock/RichMenuCell/styled.js +118 -118
- package/es/components/molecules/RichMenu/RichMenuBlock/styled.js +13 -13
- package/es/components/molecules/RichMenu/RichMenuChatBar/TypingChat/styled.js +40 -40
- package/es/components/molecules/RichMenu/RichMenuChatBar/styled.js +27 -27
- package/es/components/molecules/RichMenu/RichMenuMobileView/RichMenuMobileView.js +2 -2
- package/es/components/molecules/RichMenu/RichMenuMobileView/styled.js +38 -38
- package/es/components/molecules/SearchPopover/components/PopoverSelect/styled.js +36 -36
- package/es/components/molecules/SearchPopover/components/PopoverSelect/styles.scss +7 -7
- package/es/components/molecules/SearchPopover/styled.js +32 -32
- package/es/components/molecules/Select/styled.js +32 -32
- package/es/components/molecules/SelectAccount/styled.js +147 -147
- package/es/components/molecules/SelectEventAttribute/styled.js +8 -8
- package/es/components/molecules/SelectMulti/styled.js +62 -62
- package/es/components/molecules/SelectV2/styled.js +124 -124
- package/es/components/molecules/SettingWrapper/styled.js +12 -12
- package/es/components/molecules/ShareAccess/components/GeneralAccess/styled.js +56 -56
- package/es/components/molecules/ShareAccess/components/LayoutContent/styled.js +5 -5
- package/es/components/molecules/ShareAccess/components/ModalTransferOwnerShip/styled.js +15 -15
- package/es/components/molecules/ShareAccess/components/PeopleAccess/styled.js +63 -63
- package/es/components/molecules/ShareAccess/components/SearchUser/styled.js +31 -31
- package/es/components/molecules/SliderWithInputNumber/styled.js +2 -2
- package/es/components/molecules/Tabs/Tabs.js +11 -11
- package/es/components/molecules/TagifyInput/TagifyInput.js +50 -50
- package/es/components/molecules/TagifyInput/styled.js +37 -37
- package/es/components/molecules/TagifyInput/utils.js +13 -13
- package/es/components/molecules/TagifyInput/utils.style.js +217 -217
- package/es/components/molecules/TemplateSaveAs/components/Category/Category.js +5 -5
- package/es/components/molecules/TemplateSaveAs/components/ImageSlider/styled.js +276 -276
- package/es/components/molecules/TemplateSaveAs/styled.js +134 -134
- package/es/components/molecules/ThumbnailCard/styled.js +92 -92
- package/es/components/molecules/Tree/styled.js +38 -38
- package/es/components/molecules/UploadImage/styled.js +114 -114
- package/es/components/molecules/VirtualizedMenu/styled.js +82 -82
- package/es/components/organism/AccountProfile/components/AccountSetting/components/EditableInput/styles.js +98 -98
- package/es/components/organism/AccountProfile/components/AccountSetting/components/LanguageSelector/styles.js +18 -18
- package/es/components/organism/AccountProfile/components/AccountSetting/styled.js +543 -543
- package/es/components/organism/AccountProfile/components/AccountSetting/styles.scss +39 -39
- package/es/components/organism/AccountSharing/styled.js +336 -336
- package/es/components/organism/ActivityTimeline/components/ActionHistory/styled.js +28 -28
- package/es/components/organism/ActivityTimeline/components/CardMember/styled.js +60 -60
- package/es/components/organism/ActivityTimeline/components/ItemGroupEvent/styled.js +4 -4
- package/es/components/organism/ActivityTimeline/components/List/styled.js +77 -77
- package/es/components/organism/ActivityTimeline/components/ListItem/styled.js +37 -37
- package/es/components/organism/ActivityTimeline/components/ProductCard/styled.js +92 -92
- package/es/components/organism/ActivityTimeline/components/Redeem/styled.js +7 -7
- package/es/components/organism/ActivityTimeline/components/Slide/styled.js +20 -20
- package/es/components/organism/ActivityTimeline/components/TimeLineTitle/styled.js +7 -7
- package/es/components/organism/ActivityTimeline/components/TimelineSection/styled.js +69 -69
- package/es/components/organism/ActivityTimeline/styled.js +39 -39
- package/es/components/organism/AlgorithmsSetting/styled.js +35 -35
- package/es/components/organism/BasicLogin/BasicLogin.d.ts +3 -0
- package/es/components/organism/BasicLogin/BasicLogin.js +156 -0
- package/es/components/organism/BasicLogin/__tests__/index.spec.d.ts +0 -0
- package/es/components/organism/BasicLogin/__tests__/index.spec.js +46 -0
- package/es/components/organism/BasicLogin/components/AuthenticateResult/AuthenticateResult.d.ts +8 -0
- package/es/components/organism/BasicLogin/components/AuthenticateResult/AuthenticateResult.js +23 -0
- package/es/components/organism/BasicLogin/components/AuthenticateResult/index.d.ts +1 -0
- package/es/components/organism/BasicLogin/components/AuthenticateResult/index.js +1 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/ChooseMethod.d.ts +9 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/ChooseMethod.js +54 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/Method.d.ts +10 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/Method.js +13 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/index.d.ts +2 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/index.js +2 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/styled.d.ts +10 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/styled.js +24 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/utils.d.ts +1 -0
- package/es/components/organism/BasicLogin/components/ChooseMethod/utils.js +1 -0
- package/es/components/organism/BasicLogin/components/LoginWithEmail/LoginWithEmail.d.ts +14 -0
- package/es/components/organism/BasicLogin/components/LoginWithEmail/LoginWithEmail.js +192 -0
- package/es/components/organism/BasicLogin/components/LoginWithEmail/index.d.ts +1 -0
- package/es/components/organism/BasicLogin/components/LoginWithEmail/index.js +1 -0
- package/es/components/organism/{Login/components/LoginStep2 → BasicLogin/components/LoginWithEmail}/styled.js +3 -3
- package/es/components/organism/BasicLogin/components/LoginWithGG/LoginWithGG.d.ts +12 -0
- package/es/components/organism/BasicLogin/components/LoginWithGG/LoginWithGG.js +107 -0
- package/es/components/organism/BasicLogin/components/LoginWithGG/index.d.ts +1 -0
- package/es/components/organism/BasicLogin/components/LoginWithGG/index.js +1 -0
- package/es/components/organism/BasicLogin/components/LoginWithGG/styled.d.ts +3 -0
- package/es/components/organism/BasicLogin/components/LoginWithGG/styled.js +5 -0
- package/es/components/organism/BasicLogin/components/SignIn/SignIn.d.ts +14 -0
- package/es/components/organism/BasicLogin/components/SignIn/SignIn.js +66 -0
- package/es/components/organism/BasicLogin/components/SignIn/index.d.ts +1 -0
- package/es/components/organism/BasicLogin/components/SignIn/index.js +1 -0
- package/es/components/organism/BasicLogin/components/SignIn/styled.d.ts +3 -0
- package/es/components/organism/BasicLogin/components/SignIn/styled.js +10 -0
- package/es/components/organism/BasicLogin/components/WidgetLayout/WidgetLayout.d.ts +13 -0
- package/es/components/organism/BasicLogin/components/WidgetLayout/WidgetLayout.js +18 -0
- package/es/components/organism/BasicLogin/components/WidgetLayout/index.d.ts +1 -0
- package/es/components/organism/BasicLogin/components/WidgetLayout/index.js +1 -0
- package/es/components/organism/BasicLogin/components/WidgetLayout/styled.d.ts +5 -0
- package/es/components/organism/BasicLogin/components/WidgetLayout/styled.js +22 -0
- package/es/components/organism/BasicLogin/components/index.d.ts +5 -0
- package/es/components/organism/BasicLogin/components/index.js +5 -0
- package/es/components/organism/BasicLogin/constants/index.d.ts +26 -0
- package/es/components/organism/BasicLogin/constants/index.js +26 -0
- package/es/components/organism/BasicLogin/index.d.ts +2 -0
- package/es/components/organism/BasicLogin/index.js +2 -0
- package/es/components/organism/BasicLogin/styled.d.ts +50 -0
- package/es/components/organism/BasicLogin/styled.js +120 -0
- package/es/components/organism/BasicLogin/types/index.d.ts +36 -0
- package/es/components/organism/BasicLogin/types/index.js +1 -0
- package/es/components/organism/BasicLogin/utils.d.ts +8 -0
- package/es/components/organism/BasicLogin/utils.js +18 -0
- package/es/components/organism/ContentSources/styled.js +50 -50
- package/es/components/organism/DataTable/components/AddButton/index.js +8 -8
- package/es/components/organism/DataTable/components/ModifyColumn/styled.js +18 -18
- package/es/components/organism/DataTable/components/Pagination/styled.js +26 -26
- package/es/components/organism/DataTable/components/Table/styled.js +135 -135
- package/es/components/organism/DataTable/components/Toolbar/SearchPopover.js +17 -17
- package/es/components/organism/DataTable/components/Toolbar/styled.js +70 -70
- package/es/components/organism/DataTable/styled/index.js +84 -84
- package/es/components/organism/Filter/components/FilterCondition/styled.js +34 -34
- package/es/components/organism/Filter/styled.js +109 -109
- package/es/components/organism/FilterSetting/components/common/InputArray/styled.js +5 -5
- package/es/components/organism/FilterSetting/components/common/InputOrSelect/index.js +63 -63
- package/es/components/organism/FilterSetting/components/common/InputSelectMulti/ColumnSuggestion/index.js +31 -31
- package/es/components/organism/FilterSetting/components/common/InputSelectMulti/Tree/index.js +22 -22
- package/es/components/organism/FilterSetting/components/common/InputSelectMulti/index.js +55 -55
- package/es/components/organism/FilterSetting/styled.js +19 -19
- package/es/components/organism/Help/styled.js +267 -267
- package/es/components/organism/LeftMenu/components/HomeMenu/styled.js +39 -39
- package/es/components/organism/LeftMenu/components/common/ChildMenu/components/MenuItemImage/styled.js +16 -16
- package/es/components/organism/LeftMenu/components/common/ChildMenu/styled.js +156 -156
- package/es/components/organism/LeftMenu/hooks/usePermission.js +1 -1
- package/es/components/organism/LeftMenu/styled.js +214 -214
- package/es/components/organism/Login/Login.js +71 -13
- package/es/components/organism/Login/components/ChooseMethod/ChooseMethod.d.ts +9 -0
- package/es/components/organism/Login/components/ChooseMethod/ChooseMethod.js +54 -0
- package/es/components/organism/Login/components/ChooseMethod/Method.d.ts +10 -0
- package/es/components/organism/Login/components/ChooseMethod/Method.js +13 -0
- package/es/components/organism/Login/components/ChooseMethod/index.d.ts +1 -0
- package/es/components/organism/Login/components/ChooseMethod/index.js +1 -0
- package/es/components/organism/Login/components/ChooseMethod/styled.d.ts +10 -0
- package/es/components/organism/Login/components/ChooseMethod/styled.js +24 -0
- package/es/components/organism/Login/components/ChooseMethod/utils.d.ts +1 -0
- package/es/components/organism/Login/components/ChooseMethod/utils.js +1 -0
- package/es/components/organism/Login/components/ForgotPassword/styled.js +8 -8
- package/es/components/organism/Login/components/LoginSelectPortal/Item/styled.js +31 -31
- package/es/components/organism/Login/components/LoginSelectPortal/styled.js +3 -3
- package/es/components/organism/Login/components/LoginWithEmail/LoginWithEmail.d.ts +15 -0
- package/es/components/organism/Login/components/LoginWithEmail/LoginWithEmail.js +211 -0
- package/es/components/organism/Login/components/LoginWithEmail/index.d.ts +1 -0
- package/es/components/organism/Login/components/LoginWithEmail/index.js +1 -0
- package/es/components/organism/Login/components/LoginWithEmail/styled.d.ts +3 -0
- package/es/components/organism/Login/components/LoginWithEmail/styled.js +5 -0
- package/es/components/organism/Login/components/{LoginStep2/LoginStep2.d.ts → LoginWithGG/LoginWithGG.d.ts} +1 -1
- package/es/components/organism/Login/components/{LoginStep2/LoginStep2.js → LoginWithGG/LoginWithGG.js} +6 -20
- package/es/components/organism/Login/components/LoginWithGG/index.d.ts +1 -0
- package/es/components/organism/Login/components/LoginWithGG/index.js +1 -0
- package/es/components/organism/Login/components/LoginWithGG/styled.d.ts +3 -0
- package/es/components/organism/Login/components/LoginWithGG/styled.js +5 -0
- package/es/components/organism/Login/components/SetupGGAuthenticator/SetupGGAuthenticator.js +1 -1
- package/es/components/organism/Login/components/SetupGGAuthenticator/styled.js +7 -7
- package/es/components/organism/Login/components/SignIn/styled.js +8 -8
- package/es/components/organism/Login/components/VerifyAccount/styled.js +13 -13
- package/es/components/organism/Login/components/WidgetLayout/WidgetLayout.js +3 -3
- package/es/components/organism/Login/components/WidgetLayout/styled.js +18 -18
- package/es/components/organism/Login/components/index.d.ts +3 -1
- package/es/components/organism/Login/components/index.js +3 -1
- package/es/components/organism/Login/constants/index.d.ts +25 -1
- package/es/components/organism/Login/constants/index.js +25 -1
- package/es/components/organism/Login/styled.d.ts +2 -1
- package/es/components/organism/Login/styled.js +115 -114
- package/es/components/organism/Login/types/index.d.ts +7 -0
- package/es/components/organism/Login/utils/index.d.ts +1 -0
- package/es/components/organism/Login/utils/index.js +8 -0
- package/es/components/organism/Menu/styled.js +6 -6
- package/es/components/organism/ModifyColumnModal/styled.js +132 -132
- package/es/components/organism/Notification/styled.js +155 -155
- package/es/components/organism/PreviewCollections/Messages/SkeletonMessage/styled.js +14 -14
- package/es/components/organism/PreviewCollections/WhatsappMessage/CarouselMessage/styled.js +63 -63
- package/es/components/organism/PreviewCollections/constants.js +50 -50
- package/es/components/organism/PreviewCollections/styled.js +16 -16
- package/es/components/organism/PreviewTemplateModal/components/Banner/styled.js +78 -78
- package/es/components/organism/PreviewTemplateModal/components/Information/styled.js +52 -52
- package/es/components/organism/PreviewTemplateModal/components/SimilarTemplate/styled.js +18 -18
- package/es/components/organism/PreviewTemplateModal/components/ThumbnailSlider/styled.js +75 -75
- package/es/components/organism/PreviewTemplateModal/styled.js +21 -21
- package/es/components/organism/Table/CrossTabTable/components/CustomCell/styled.js +11 -11
- package/es/components/organism/Table/CrossTabTable/styled.js +11 -11
- package/es/components/organism/Table/ExplorePivotTable/components/CustomCell/styled.js +17 -17
- package/es/components/organism/Table/ExplorePivotTable/styled.js +11 -11
- package/es/components/organism/TicketEditor/styled.js +850 -850
- package/es/components/organism/TicketEditorV2/styled.js +839 -839
- package/es/components/organism/index.d.ts +1 -0
- package/es/components/organism/index.js +1 -0
- package/es/components/template/Layout/Layout.js +10 -10
- package/es/components/template/Layout/components/RecommendationWorkspace/components/MenuMapping/components/OldLeftMenu/index.js +2 -2
- package/es/components/template/Layout/components/RecommendationWorkspace/components/MenuMapping/components/OldLeftMenu/styled.js +73 -73
- package/es/components/template/Layout/components/RecommendationWorkspace/components/MenuMapping/styled.js +39 -39
- package/es/components/template/Layout/components/RecommendationWorkspace/components/RecommendationImage/styled.js +61 -61
- package/es/components/template/Layout/components/RecommendationWorkspace/styled.js +16 -16
- package/es/components/template/Layout/styled.js +84 -84
- package/es/components/template/TemplateListing/components/BlankTemplate/styled.js +21 -21
- package/es/components/template/TemplateListing/components/CategoryListing/styled.js +123 -123
- package/es/components/template/TemplateListing/components/Empty/styled.js +20 -20
- package/es/components/template/TemplateListing/stories/demo/styled.js +4 -4
- package/es/components/template/TemplateListing/styled/index.js +40 -40
- package/es/hooks/index.d.ts +1 -0
- package/es/hooks/index.js +1 -0
- package/es/hooks/useCountdown.d.ts +49 -0
- package/es/hooks/useCountdown.js +122 -0
- package/es/providers/ConfigProvider/GlobalStyle.js +1142 -1119
- package/es/styled/common.js +51 -51
- package/es/tests/styled.js +4 -4
- package/es/utils/variables.js +7 -7
- package/package.json +261 -261
- package/CHANGELOG.md +0 -63
- package/es/components/organism/ActivityTimeline/__mocks__/event_tracking.json +0 -1290
- package/es/components/organism/ActivityTimeline/__mocks__/timeline.json +0 -3059
- package/es/components/organism/Login/components/LoginStep2/index.d.ts +0 -1
- package/es/components/organism/Login/components/LoginStep2/index.js +0 -1
- /package/es/components/organism/{Login/components/LoginStep2 → BasicLogin/components/LoginWithEmail}/styled.d.ts +0 -0
|
@@ -4,25 +4,25 @@ import styled from 'styled-components';
|
|
|
4
4
|
import { Flex } from '../../../../atoms';
|
|
5
5
|
// Constants
|
|
6
6
|
import { globalToken } from '@antscorp/antsomi-ui/es/constants';
|
|
7
|
-
export const BlankTemplateWrapper = styled(Flex) `
|
|
8
|
-
box-sizing: border-box;
|
|
9
|
-
border: 1px solid #b8cfe6;
|
|
10
|
-
border-radius: ${globalToken?.borderRadius}px;
|
|
11
|
-
cursor: pointer;
|
|
12
|
-
|
|
13
|
-
.add-blank-btn {
|
|
14
|
-
width: 50px !important;
|
|
15
|
-
height: 50px !important;
|
|
16
|
-
border-radius: 999px;
|
|
17
|
-
background-color: #005eb80d !important;
|
|
18
|
-
|
|
19
|
-
.antsomi-btn-icon {
|
|
20
|
-
margin-top: 3px;
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
.description {
|
|
25
|
-
font-weight: 700;
|
|
26
|
-
max-width: 90%;
|
|
27
|
-
}
|
|
7
|
+
export const BlankTemplateWrapper = styled(Flex) `
|
|
8
|
+
box-sizing: border-box;
|
|
9
|
+
border: 1px solid #b8cfe6;
|
|
10
|
+
border-radius: ${globalToken?.borderRadius}px;
|
|
11
|
+
cursor: pointer;
|
|
12
|
+
|
|
13
|
+
.add-blank-btn {
|
|
14
|
+
width: 50px !important;
|
|
15
|
+
height: 50px !important;
|
|
16
|
+
border-radius: 999px;
|
|
17
|
+
background-color: #005eb80d !important;
|
|
18
|
+
|
|
19
|
+
.antsomi-btn-icon {
|
|
20
|
+
margin-top: 3px;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.description {
|
|
25
|
+
font-weight: 700;
|
|
26
|
+
max-width: 90%;
|
|
27
|
+
}
|
|
28
28
|
`;
|
|
@@ -2,130 +2,130 @@ import styled from 'styled-components';
|
|
|
2
2
|
import { Typography } from '../../../../atoms';
|
|
3
3
|
import { THEME, globalToken } from '@antscorp/antsomi-ui/es/constants';
|
|
4
4
|
const { Text } = Typography;
|
|
5
|
-
export const MenuWrapper = styled.div `
|
|
6
|
-
position: relative;
|
|
7
|
-
flex-shrink: 0;
|
|
8
|
-
width: ${({ $width }) => ($width !== undefined ? `${$width}px` : 'auto')};
|
|
9
|
-
overflow: auto;
|
|
10
|
-
overflow-x: hidden;
|
|
11
|
-
border-right: 1px solid rgba(5, 5, 5, 0.06);
|
|
12
|
-
display: flex;
|
|
13
|
-
flex-direction: column;
|
|
14
|
-
overflow: hidden;
|
|
15
|
-
|
|
16
|
-
.category__listing {
|
|
17
|
-
position: relative;
|
|
18
|
-
height: 100%;
|
|
19
|
-
overflow-y: auto;
|
|
20
|
-
|
|
21
|
-
.antsomi-menu,
|
|
22
|
-
.ant-menu {
|
|
23
|
-
[role='menu'] {
|
|
24
|
-
background-color: white !important;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
[role='menuitem'] {
|
|
28
|
-
width: 100%;
|
|
29
|
-
border-radius: 0;
|
|
30
|
-
height: 30px;
|
|
31
|
-
padding: 0 10px !important;
|
|
32
|
-
margin-left: 0 !important;
|
|
33
|
-
margin-right: 0 !important;
|
|
34
|
-
|
|
35
|
-
.antsomi-menu-title-content,
|
|
36
|
-
.ant-menu-title-content {
|
|
37
|
-
height: 100%;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
.antsomi-menu-submenu-title,
|
|
42
|
-
.ant-menu-submenu-title {
|
|
43
|
-
height: 30px !important;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
.antsomi-menu-submenu-title {
|
|
47
|
-
margin-top: 10px;
|
|
48
|
-
margin-bottom: 10px;
|
|
49
|
-
transition: all 0.3s;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
.antsomi-menu-submenu-open {
|
|
53
|
-
.antsomi-menu-submenu-title {
|
|
54
|
-
margin-bottom: 0px;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
.antsomi-menu-sub {
|
|
59
|
-
> li.antsomi-menu-item:first-child {
|
|
60
|
-
margin-top: 0;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
.category-loading {
|
|
66
|
-
height: 100%;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
.empty-wrapper {
|
|
70
|
-
width: 100%;
|
|
71
|
-
height: 100%;
|
|
72
|
-
box-sizing: border-box;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
5
|
+
export const MenuWrapper = styled.div `
|
|
6
|
+
position: relative;
|
|
7
|
+
flex-shrink: 0;
|
|
8
|
+
width: ${({ $width }) => ($width !== undefined ? `${$width}px` : 'auto')};
|
|
9
|
+
overflow: auto;
|
|
10
|
+
overflow-x: hidden;
|
|
11
|
+
border-right: 1px solid rgba(5, 5, 5, 0.06);
|
|
12
|
+
display: flex;
|
|
13
|
+
flex-direction: column;
|
|
14
|
+
overflow: hidden;
|
|
15
|
+
|
|
16
|
+
.category__listing {
|
|
17
|
+
position: relative;
|
|
18
|
+
height: 100%;
|
|
19
|
+
overflow-y: auto;
|
|
20
|
+
|
|
21
|
+
.antsomi-menu,
|
|
22
|
+
.ant-menu {
|
|
23
|
+
[role='menu'] {
|
|
24
|
+
background-color: white !important;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
[role='menuitem'] {
|
|
28
|
+
width: 100%;
|
|
29
|
+
border-radius: 0;
|
|
30
|
+
height: 30px;
|
|
31
|
+
padding: 0 10px !important;
|
|
32
|
+
margin-left: 0 !important;
|
|
33
|
+
margin-right: 0 !important;
|
|
34
|
+
|
|
35
|
+
.antsomi-menu-title-content,
|
|
36
|
+
.ant-menu-title-content {
|
|
37
|
+
height: 100%;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.antsomi-menu-submenu-title,
|
|
42
|
+
.ant-menu-submenu-title {
|
|
43
|
+
height: 30px !important;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.antsomi-menu-submenu-title {
|
|
47
|
+
margin-top: 10px;
|
|
48
|
+
margin-bottom: 10px;
|
|
49
|
+
transition: all 0.3s;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.antsomi-menu-submenu-open {
|
|
53
|
+
.antsomi-menu-submenu-title {
|
|
54
|
+
margin-bottom: 0px;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.antsomi-menu-sub {
|
|
59
|
+
> li.antsomi-menu-item:first-child {
|
|
60
|
+
margin-top: 0;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.category-loading {
|
|
66
|
+
height: 100%;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.empty-wrapper {
|
|
70
|
+
width: 100%;
|
|
71
|
+
height: 100%;
|
|
72
|
+
box-sizing: border-box;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
75
|
`;
|
|
76
|
-
export const CustomLabelStyled = styled.div `
|
|
77
|
-
display: flex;
|
|
78
|
-
justify-content: space-between;
|
|
79
|
-
height: 100%;
|
|
80
|
-
align-items: center;
|
|
81
|
-
|
|
82
|
-
.label {
|
|
83
|
-
flex: 1 1 0%;
|
|
84
|
-
display: flex;
|
|
85
|
-
gap: 9px;
|
|
86
|
-
overflow: auto;
|
|
87
|
-
|
|
88
|
-
.antsomi-checkbox-wrapper {
|
|
89
|
-
width: 100%;
|
|
90
|
-
display: flex;
|
|
91
|
-
align-items: center;
|
|
92
|
-
|
|
93
|
-
.antsomi-checkbox-wrapper {
|
|
94
|
-
flex-shrink: 0;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
span:nth-child(2) {
|
|
98
|
-
flex: 1 1 0%;
|
|
99
|
-
overflow: auto;
|
|
100
|
-
& > span {
|
|
101
|
-
vertical-align: middle;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
.total {
|
|
108
|
-
flex-shrink: 0;
|
|
109
|
-
font-size: 13px;
|
|
110
|
-
font-weight: 400;
|
|
111
|
-
color: ${globalToken?.bw8};
|
|
112
|
-
line-height: 1 !important;
|
|
113
|
-
font-size: 11px;
|
|
114
|
-
height: fit-content;
|
|
115
|
-
}
|
|
76
|
+
export const CustomLabelStyled = styled.div `
|
|
77
|
+
display: flex;
|
|
78
|
+
justify-content: space-between;
|
|
79
|
+
height: 100%;
|
|
80
|
+
align-items: center;
|
|
81
|
+
|
|
82
|
+
.label {
|
|
83
|
+
flex: 1 1 0%;
|
|
84
|
+
display: flex;
|
|
85
|
+
gap: 9px;
|
|
86
|
+
overflow: auto;
|
|
87
|
+
|
|
88
|
+
.antsomi-checkbox-wrapper {
|
|
89
|
+
width: 100%;
|
|
90
|
+
display: flex;
|
|
91
|
+
align-items: center;
|
|
92
|
+
|
|
93
|
+
.antsomi-checkbox-wrapper {
|
|
94
|
+
flex-shrink: 0;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
span:nth-child(2) {
|
|
98
|
+
flex: 1 1 0%;
|
|
99
|
+
overflow: auto;
|
|
100
|
+
& > span {
|
|
101
|
+
vertical-align: middle;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
.total {
|
|
108
|
+
flex-shrink: 0;
|
|
109
|
+
font-size: 13px;
|
|
110
|
+
font-weight: 400;
|
|
111
|
+
color: ${globalToken?.bw8};
|
|
112
|
+
line-height: 1 !important;
|
|
113
|
+
font-size: 11px;
|
|
114
|
+
height: fit-content;
|
|
115
|
+
}
|
|
116
116
|
`;
|
|
117
|
-
export const CustomRootLabel = styled.div `
|
|
118
|
-
font-size: 13px !important;
|
|
119
|
-
font-weight: 400;
|
|
120
|
-
/* color: ${THEME?.token?.bw8}; */
|
|
121
|
-
height: 100%;
|
|
122
|
-
display: flex;
|
|
123
|
-
align-items: center;
|
|
124
|
-
padding-right: 20px;
|
|
117
|
+
export const CustomRootLabel = styled.div `
|
|
118
|
+
font-size: 13px !important;
|
|
119
|
+
font-weight: 400;
|
|
120
|
+
/* color: ${THEME?.token?.bw8}; */
|
|
121
|
+
height: 100%;
|
|
122
|
+
display: flex;
|
|
123
|
+
align-items: center;
|
|
124
|
+
padding-right: 20px;
|
|
125
125
|
`;
|
|
126
|
-
export const TextWrapper = styled(Text) `
|
|
127
|
-
max-width: 100%;
|
|
128
|
-
color: inherit !important;
|
|
129
|
-
height: fit-content;
|
|
130
|
-
font-size: inherit !important;
|
|
126
|
+
export const TextWrapper = styled(Text) `
|
|
127
|
+
max-width: 100%;
|
|
128
|
+
color: inherit !important;
|
|
129
|
+
height: fit-content;
|
|
130
|
+
font-size: inherit !important;
|
|
131
131
|
`;
|
|
@@ -4,13 +4,13 @@ import styled from 'styled-components';
|
|
|
4
4
|
import { Flex } from '@antscorp/antsomi-ui/es/components/atoms';
|
|
5
5
|
// Constants
|
|
6
6
|
import { THEME } from '@antscorp/antsomi-ui/es/constants';
|
|
7
|
-
export const EmptyWrapper = styled(Flex) `
|
|
8
|
-
width: 100%;
|
|
9
|
-
height: 100%;
|
|
10
|
-
|
|
11
|
-
.antsomi-typography {
|
|
12
|
-
color: ${THEME.token?.bw8};
|
|
13
|
-
}
|
|
7
|
+
export const EmptyWrapper = styled(Flex) `
|
|
8
|
+
width: 100%;
|
|
9
|
+
height: 100%;
|
|
10
|
+
|
|
11
|
+
.antsomi-typography {
|
|
12
|
+
color: ${THEME.token?.bw8};
|
|
13
|
+
}
|
|
14
14
|
`;
|
|
15
15
|
EmptyWrapper.defaultProps = {
|
|
16
16
|
vertical: true,
|
|
@@ -18,17 +18,17 @@ EmptyWrapper.defaultProps = {
|
|
|
18
18
|
justify: 'center',
|
|
19
19
|
gap: 15,
|
|
20
20
|
};
|
|
21
|
-
export const EmptyIcon = styled.div `
|
|
22
|
-
display: flex;
|
|
23
|
-
align-items: center;
|
|
24
|
-
justify-content: center;
|
|
25
|
-
width: 60px;
|
|
26
|
-
height: 60px;
|
|
27
|
-
border-radius: 100%;
|
|
28
|
-
background-color: ${THEME.token?.bw2};
|
|
29
|
-
|
|
30
|
-
i {
|
|
31
|
-
font-size: 24px;
|
|
32
|
-
color: ${THEME.token?.bw6};
|
|
33
|
-
}
|
|
21
|
+
export const EmptyIcon = styled.div `
|
|
22
|
+
display: flex;
|
|
23
|
+
align-items: center;
|
|
24
|
+
justify-content: center;
|
|
25
|
+
width: 60px;
|
|
26
|
+
height: 60px;
|
|
27
|
+
border-radius: 100%;
|
|
28
|
+
background-color: ${THEME.token?.bw2};
|
|
29
|
+
|
|
30
|
+
i {
|
|
31
|
+
font-size: 24px;
|
|
32
|
+
color: ${THEME.token?.bw6};
|
|
33
|
+
}
|
|
34
34
|
`;
|
|
@@ -2,46 +2,46 @@
|
|
|
2
2
|
import styled from 'styled-components';
|
|
3
3
|
// Components
|
|
4
4
|
import { Flex } from '../../../atoms';
|
|
5
|
-
export const TemplateListingWrapper = styled(Flex) `
|
|
6
|
-
position: relative;
|
|
7
|
-
height: 100%;
|
|
8
|
-
|
|
9
|
-
.template-listing {
|
|
10
|
-
width: 100%;
|
|
11
|
-
flex: 1 1 0%;
|
|
12
|
-
height: 100%;
|
|
13
|
-
max-height: 100%;
|
|
14
|
-
min-height: 200px;
|
|
15
|
-
overflow-y: auto;
|
|
16
|
-
box-sizing: border-box;
|
|
17
|
-
|
|
18
|
-
&__loading {
|
|
19
|
-
height: 100%;
|
|
20
|
-
|
|
21
|
-
.antsomi-spin-container {
|
|
22
|
-
height: 100%;
|
|
23
|
-
width: 100%;
|
|
24
|
-
|
|
25
|
-
> div {
|
|
26
|
-
max-height: 100%;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
&--full {
|
|
31
|
-
width: 100%;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
div.scrollbar-view {
|
|
36
|
-
box-sizing: border-box;
|
|
37
|
-
padding: 15px;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
5
|
+
export const TemplateListingWrapper = styled(Flex) `
|
|
6
|
+
position: relative;
|
|
7
|
+
height: 100%;
|
|
8
|
+
|
|
9
|
+
.template-listing {
|
|
10
|
+
width: 100%;
|
|
11
|
+
flex: 1 1 0%;
|
|
12
|
+
height: 100%;
|
|
13
|
+
max-height: 100%;
|
|
14
|
+
min-height: 200px;
|
|
15
|
+
overflow-y: auto;
|
|
16
|
+
box-sizing: border-box;
|
|
17
|
+
|
|
18
|
+
&__loading {
|
|
19
|
+
height: 100%;
|
|
20
|
+
|
|
21
|
+
.antsomi-spin-container {
|
|
22
|
+
height: 100%;
|
|
23
|
+
width: 100%;
|
|
24
|
+
|
|
25
|
+
> div {
|
|
26
|
+
max-height: 100%;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
&--full {
|
|
31
|
+
width: 100%;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
div.scrollbar-view {
|
|
36
|
+
box-sizing: border-box;
|
|
37
|
+
padding: 15px;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
40
|
`;
|
|
41
|
-
export const TemplateWrapper = styled.div `
|
|
42
|
-
width: 100%;
|
|
43
|
-
height: 100%;
|
|
44
|
-
display: flex;
|
|
45
|
-
flex-direction: column;
|
|
41
|
+
export const TemplateWrapper = styled.div `
|
|
42
|
+
width: 100%;
|
|
43
|
+
height: 100%;
|
|
44
|
+
display: flex;
|
|
45
|
+
flex-direction: column;
|
|
46
46
|
`;
|
|
47
47
|
export const LoadMoreBlock = styled.div ``;
|
package/es/hooks/index.d.ts
CHANGED
package/es/hooks/index.js
CHANGED
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Configuration options for useCountdown hook
|
|
3
|
+
*/
|
|
4
|
+
export interface CountdownOptions {
|
|
5
|
+
/** Automatically start countdown when hook initializes */
|
|
6
|
+
autoStart?: boolean;
|
|
7
|
+
/** Callback function called when countdown completes */
|
|
8
|
+
onComplete?: () => void;
|
|
9
|
+
/** Callback function called on each tick with current seconds */
|
|
10
|
+
onTick?: (seconds: number) => void;
|
|
11
|
+
/** Interval in milliseconds for countdown updates */
|
|
12
|
+
interval?: number;
|
|
13
|
+
/** Step size for countdown decrement */
|
|
14
|
+
step?: number;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Return type for useCountdown hook
|
|
18
|
+
*/
|
|
19
|
+
export interface CountdownReturn {
|
|
20
|
+
/** Current countdown seconds remaining */
|
|
21
|
+
seconds: number;
|
|
22
|
+
/** Whether countdown is currently active/running */
|
|
23
|
+
isActive: boolean;
|
|
24
|
+
/** Whether countdown has completed (reached 0) */
|
|
25
|
+
isComplete: boolean;
|
|
26
|
+
/** Whether countdown is paused */
|
|
27
|
+
isPaused: boolean;
|
|
28
|
+
/** Start the countdown */
|
|
29
|
+
start: () => void;
|
|
30
|
+
/** Pause the countdown */
|
|
31
|
+
pause: () => void;
|
|
32
|
+
/** Reset countdown to initial time */
|
|
33
|
+
reset: () => void;
|
|
34
|
+
/** Reset countdown with new time */
|
|
35
|
+
resetAndStartWithTime: (newTime: number) => void;
|
|
36
|
+
/** Toggle between start/pause */
|
|
37
|
+
toggle: () => void;
|
|
38
|
+
/** Format time as MM:SS */
|
|
39
|
+
formatTime: (customSeconds?: number) => string;
|
|
40
|
+
/** Format time as HH:MM:SS (or MM:SS if < 1 hour) */
|
|
41
|
+
formatTimeDetailed: (customSeconds?: number) => string;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Enhanced countdown hook with better performance and features
|
|
45
|
+
* @param initialTime - Initial time in seconds
|
|
46
|
+
* @param options - Configuration options
|
|
47
|
+
* @returns Countdown state and controls
|
|
48
|
+
*/
|
|
49
|
+
export declare const useCountdown: (initialTime: number, options?: CountdownOptions) => CountdownReturn;
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { useState, useEffect, useRef, useCallback } from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* Enhanced countdown hook with better performance and features
|
|
4
|
+
* @param initialTime - Initial time in seconds
|
|
5
|
+
* @param options - Configuration options
|
|
6
|
+
* @returns Countdown state and controls
|
|
7
|
+
*/
|
|
8
|
+
export const useCountdown = (initialTime, options = {}) => {
|
|
9
|
+
const { autoStart = false, onComplete = null, onTick = null, interval = 1000, step = 1, } = options;
|
|
10
|
+
const [seconds, setSeconds] = useState(initialTime);
|
|
11
|
+
const [isActive, setIsActive] = useState(autoStart);
|
|
12
|
+
const intervalRef = useRef(null);
|
|
13
|
+
const startTimeRef = useRef(null);
|
|
14
|
+
const pausedTimeRef = useRef(0);
|
|
15
|
+
// Memoized derived states
|
|
16
|
+
const isComplete = seconds === 0;
|
|
17
|
+
const isPaused = !isActive && seconds > 0 && seconds < initialTime;
|
|
18
|
+
// Clear interval helper
|
|
19
|
+
const clearTimer = useCallback(() => {
|
|
20
|
+
if (intervalRef.current) {
|
|
21
|
+
clearInterval(intervalRef.current);
|
|
22
|
+
intervalRef.current = null;
|
|
23
|
+
}
|
|
24
|
+
}, []);
|
|
25
|
+
// Main countdown effect
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
if (isActive && seconds > 0) {
|
|
28
|
+
intervalRef.current = setInterval(() => {
|
|
29
|
+
setSeconds(prev => {
|
|
30
|
+
const next = Math.max(0, prev - step);
|
|
31
|
+
if (onTick && next !== prev) {
|
|
32
|
+
onTick(next);
|
|
33
|
+
}
|
|
34
|
+
if (next === 0) {
|
|
35
|
+
setIsActive(false);
|
|
36
|
+
if (onComplete) {
|
|
37
|
+
setTimeout(onComplete, 0);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
return next;
|
|
41
|
+
});
|
|
42
|
+
}, interval);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
clearTimer();
|
|
46
|
+
}
|
|
47
|
+
return clearTimer;
|
|
48
|
+
}, [isActive, interval, step, onTick, onComplete, clearTimer]);
|
|
49
|
+
// Control functions
|
|
50
|
+
const start = useCallback(() => {
|
|
51
|
+
if (seconds > 0) {
|
|
52
|
+
if (isPaused) {
|
|
53
|
+
pausedTimeRef.current = (initialTime - seconds) * 1000;
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
pausedTimeRef.current = 0;
|
|
57
|
+
}
|
|
58
|
+
setIsActive(true);
|
|
59
|
+
}
|
|
60
|
+
}, [seconds, isPaused, initialTime]);
|
|
61
|
+
const pause = useCallback(() => {
|
|
62
|
+
setIsActive(false);
|
|
63
|
+
}, []);
|
|
64
|
+
const reset = useCallback(() => {
|
|
65
|
+
clearTimer();
|
|
66
|
+
setIsActive(false);
|
|
67
|
+
setSeconds(initialTime);
|
|
68
|
+
pausedTimeRef.current = 0;
|
|
69
|
+
startTimeRef.current = null;
|
|
70
|
+
}, [initialTime, clearTimer]);
|
|
71
|
+
const resetAndStartWithTime = useCallback((newTime) => {
|
|
72
|
+
if (newTime < 0)
|
|
73
|
+
throw new Error('Time cannot be negative');
|
|
74
|
+
clearTimer();
|
|
75
|
+
setSeconds(newTime);
|
|
76
|
+
pausedTimeRef.current = 0;
|
|
77
|
+
startTimeRef.current = null;
|
|
78
|
+
// Delay start to next tick, after seconds is updated
|
|
79
|
+
setTimeout(() => {
|
|
80
|
+
setIsActive(true);
|
|
81
|
+
}, 0);
|
|
82
|
+
}, [clearTimer]);
|
|
83
|
+
const toggle = useCallback(() => {
|
|
84
|
+
if (isActive) {
|
|
85
|
+
pause();
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
start();
|
|
89
|
+
}
|
|
90
|
+
}, [isActive, pause, start]);
|
|
91
|
+
// Time formatting utilities
|
|
92
|
+
const formatTime = useCallback((customSeconds = seconds) => {
|
|
93
|
+
const mins = Math.floor(customSeconds / 60);
|
|
94
|
+
const secs = customSeconds % 60;
|
|
95
|
+
return `${mins.toString().padStart(2, '0')}:${secs.toString().padStart(2, '0')}`;
|
|
96
|
+
}, [seconds]);
|
|
97
|
+
const formatTimeDetailed = useCallback((customSeconds = seconds) => {
|
|
98
|
+
const hours = Math.floor(customSeconds / 3600);
|
|
99
|
+
const mins = Math.floor((customSeconds % 3600) / 60);
|
|
100
|
+
const secs = customSeconds % 60;
|
|
101
|
+
if (hours > 0) {
|
|
102
|
+
return `${hours.toString().padStart(2, '0')}:${mins.toString().padStart(2, '0')}:${secs.toString().padStart(2, '0')}`;
|
|
103
|
+
}
|
|
104
|
+
return `${mins.toString().padStart(2, '0')}:${secs.toString().padStart(2, '0')}`;
|
|
105
|
+
}, [seconds]);
|
|
106
|
+
return {
|
|
107
|
+
// State
|
|
108
|
+
seconds,
|
|
109
|
+
isActive,
|
|
110
|
+
isComplete,
|
|
111
|
+
isPaused,
|
|
112
|
+
// Controls
|
|
113
|
+
start,
|
|
114
|
+
pause,
|
|
115
|
+
reset,
|
|
116
|
+
resetAndStartWithTime,
|
|
117
|
+
toggle,
|
|
118
|
+
// Utils
|
|
119
|
+
formatTime,
|
|
120
|
+
formatTimeDetailed,
|
|
121
|
+
};
|
|
122
|
+
};
|