@pinnacle0/web-ui 0.3.22 → 0.3.23
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/build/LICENSE.md +21 -0
- package/build/README.md +26 -0
- package/{admin → build/admin}/AdminApp/Default/NavigatorSide/index.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/Default/NavigatorSide/index.js +0 -0
- package/{admin → build/admin}/AdminApp/Default/NavigatorSide/index.js.map +0 -0
- package/{admin → build/admin}/AdminApp/Default/NavigatorSide/index.less +0 -0
- package/{admin → build/admin}/AdminApp/Default/SoundSwitch.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/Default/SoundSwitch.js +0 -0
- package/{admin → build/admin}/AdminApp/Default/SoundSwitch.js.map +0 -0
- package/{admin → build/admin}/AdminApp/Default/SquareLogo/index.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/Default/SquareLogo/index.js +0 -0
- package/{admin → build/admin}/AdminApp/Default/SquareLogo/index.js.map +0 -0
- package/{admin → build/admin}/AdminApp/Default/SquareLogo/index.less +0 -0
- package/{admin → build/admin}/AdminApp/Menu.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/Menu.js +0 -0
- package/{admin → build/admin}/AdminApp/Menu.js.map +0 -0
- package/{admin → build/admin}/AdminApp/Navigator.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/Navigator.js +0 -0
- package/{admin → build/admin}/AdminApp/Navigator.js.map +0 -0
- package/{admin → build/admin}/AdminApp/NotFound.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/NotFound.js +0 -0
- package/{admin → build/admin}/AdminApp/NotFound.js.map +0 -0
- package/{admin → build/admin}/AdminApp/RouteSwitch.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/RouteSwitch.js +0 -0
- package/{admin → build/admin}/AdminApp/RouteSwitch.js.map +0 -0
- package/{admin → build/admin}/AdminApp/WithErrorBoundary.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/WithErrorBoundary.js +0 -0
- package/{admin → build/admin}/AdminApp/WithErrorBoundary.js.map +0 -0
- package/{admin → build/admin}/AdminApp/asset/alert.mp3 +0 -0
- package/{admin → build/admin}/AdminApp/context.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/context.js +0 -0
- package/{admin → build/admin}/AdminApp/context.js.map +0 -0
- package/{admin → build/admin}/AdminApp/index.d.ts +0 -0
- package/{admin → build/admin}/AdminApp/index.js +0 -0
- package/{admin → build/admin}/AdminApp/index.js.map +0 -0
- package/{admin → build/admin}/AdminApp/index.less +0 -0
- package/{admin → build/admin}/AdminPage/Filter.d.ts +0 -0
- package/{admin → build/admin}/AdminPage/Filter.js +0 -0
- package/{admin → build/admin}/AdminPage/Filter.js.map +0 -0
- package/{admin → build/admin}/AdminPage/Result.d.ts +0 -0
- package/{admin → build/admin}/AdminPage/Result.js +0 -0
- package/{admin → build/admin}/AdminPage/Result.js.map +0 -0
- package/{admin → build/admin}/AdminPage/SaveBar.d.ts +0 -0
- package/{admin → build/admin}/AdminPage/SaveBar.js +0 -0
- package/{admin → build/admin}/AdminPage/SaveBar.js.map +0 -0
- package/{admin → build/admin}/AdminPage/Summary.d.ts +0 -0
- package/{admin → build/admin}/AdminPage/Summary.js +0 -0
- package/{admin → build/admin}/AdminPage/Summary.js.map +0 -0
- package/{admin → build/admin}/AdminPage/TopBar.d.ts +0 -0
- package/{admin → build/admin}/AdminPage/TopBar.js +0 -0
- package/{admin → build/admin}/AdminPage/TopBar.js.map +0 -0
- package/{admin → build/admin}/AdminPage/index.d.ts +0 -0
- package/{admin → build/admin}/AdminPage/index.js +0 -0
- package/{admin → build/admin}/AdminPage/index.js.map +0 -0
- package/{admin → build/admin}/AdminPage/index.less +0 -0
- package/{admin → build/admin}/AdminPermissionSelector.d.ts +0 -0
- package/{admin → build/admin}/AdminPermissionSelector.js +0 -0
- package/{admin → build/admin}/AdminPermissionSelector.js.map +0 -0
- package/{admin → build/admin}/RichEditor/index.d.ts +0 -0
- package/{admin → build/admin}/RichEditor/index.js +0 -0
- package/{admin → build/admin}/RichEditor/index.js.map +0 -0
- package/{admin → build/admin}/RichEditor/index.less +0 -0
- package/{core → build/core}/Amount/AmountPercentage.d.ts +0 -0
- package/{core → build/core}/Amount/AmountPercentage.js +0 -0
- package/{core → build/core}/Amount/AmountPercentage.js.map +0 -0
- package/{core → build/core}/Amount/index.d.ts +0 -0
- package/{core → build/core}/Amount/index.js +0 -0
- package/{core → build/core}/Amount/index.js.map +0 -0
- package/{core → build/core}/Amount/index.less +0 -0
- package/{core → build/core}/AmountConditionInput.d.ts +0 -0
- package/{core → build/core}/AmountConditionInput.js +0 -0
- package/{core → build/core}/AmountConditionInput.js.map +0 -0
- package/{core → build/core}/AmountRangeInput.d.ts +0 -0
- package/{core → build/core}/AmountRangeInput.js +0 -0
- package/{core → build/core}/AmountRangeInput.js.map +0 -0
- package/{core → build/core}/AuthenticationCodeInput.d.ts +0 -0
- package/{core → build/core}/AuthenticationCodeInput.js +0 -0
- package/{core → build/core}/AuthenticationCodeInput.js.map +0 -0
- package/{core → build/core}/AutoCompleteInput.d.ts +0 -0
- package/{core → build/core}/AutoCompleteInput.js +0 -0
- package/{core → build/core}/AutoCompleteInput.js.map +0 -0
- package/{core → build/core}/Badge/index.d.ts +0 -0
- package/{core → build/core}/Badge/index.js +0 -0
- package/{core → build/core}/Badge/index.js.map +0 -0
- package/{core → build/core}/Badge/index.less +0 -0
- package/{core → build/core}/BoolRadio.d.ts +0 -0
- package/{core → build/core}/BoolRadio.js +0 -0
- package/{core → build/core}/BoolRadio.js.map +0 -0
- package/{core → build/core}/BoolSelect.d.ts +0 -0
- package/{core → build/core}/BoolSelect.js +0 -0
- package/{core → build/core}/BoolSelect.js.map +0 -0
- package/{core → build/core}/BoolSwitch.d.ts +0 -0
- package/{core → build/core}/BoolSwitch.js +0 -0
- package/{core → build/core}/BoolSwitch.js.map +0 -0
- package/{core → build/core}/Breadcrumb/index.d.ts +0 -0
- package/{core → build/core}/Breadcrumb/index.js +0 -0
- package/{core → build/core}/Breadcrumb/index.js.map +0 -0
- package/{core → build/core}/Breadcrumb/index.less +0 -0
- package/{core → build/core}/Button/index.d.ts +0 -0
- package/{core → build/core}/Button/index.js +0 -0
- package/{core → build/core}/Button/index.js.map +0 -0
- package/{core → build/core}/Button/index.less +0 -0
- package/{core → build/core}/Card.d.ts +0 -0
- package/{core → build/core}/Card.js +0 -0
- package/{core → build/core}/Card.js.map +0 -0
- package/{core → build/core}/Carousel.d.ts +0 -0
- package/{core → build/core}/Carousel.js +0 -0
- package/{core → build/core}/Carousel.js.map +0 -0
- package/{core → build/core}/Carousel3D/index.d.ts +0 -0
- package/{core → build/core}/Carousel3D/index.js +0 -0
- package/{core → build/core}/Carousel3D/index.js.map +0 -0
- package/{core → build/core}/Carousel3D/index.less +0 -0
- package/{core → build/core}/Cascader/InitialNullable.d.ts +0 -0
- package/{core → build/core}/Cascader/InitialNullable.js +0 -0
- package/{core → build/core}/Cascader/InitialNullable.js.map +0 -0
- package/{core → build/core}/Cascader/Nullable.d.ts +0 -0
- package/{core → build/core}/Cascader/Nullable.js +0 -0
- package/{core → build/core}/Cascader/Nullable.js.map +0 -0
- package/{core → build/core}/Cascader/index.d.ts +0 -0
- package/{core → build/core}/Cascader/index.js +0 -0
- package/{core → build/core}/Cascader/index.js.map +0 -0
- package/{core → build/core}/Cascader/index.less +0 -0
- package/{core → build/core}/Checkbox/index.d.ts +0 -0
- package/{core → build/core}/Checkbox/index.js +0 -0
- package/{core → build/core}/Checkbox/index.js.map +0 -0
- package/{core → build/core}/Checkbox/index.less +0 -0
- package/{core → build/core}/Collapse.d.ts +0 -0
- package/{core → build/core}/Collapse.js +0 -0
- package/{core → build/core}/Collapse.js.map +0 -0
- package/{core → build/core}/Countdown/SlidingDigit.d.ts +0 -0
- package/{core → build/core}/Countdown/SlidingDigit.js +0 -0
- package/{core → build/core}/Countdown/SlidingDigit.js.map +0 -0
- package/{core → build/core}/Countdown/index.d.ts +0 -0
- package/{core → build/core}/Countdown/index.js +0 -0
- package/{core → build/core}/Countdown/index.js.map +0 -0
- package/{core → build/core}/Countdown/index.less +0 -0
- package/{core → build/core}/DarkOverlay/index.d.ts +0 -0
- package/{core → build/core}/DarkOverlay/index.js +0 -0
- package/{core → build/core}/DarkOverlay/index.js.map +0 -0
- package/{core → build/core}/DarkOverlay/index.less +0 -0
- package/{core → build/core}/DateCalendar.d.ts +0 -0
- package/{core → build/core}/DateCalendar.js +0 -0
- package/{core → build/core}/DateCalendar.js.map +0 -0
- package/{core → build/core}/DatePicker/index.d.ts +0 -0
- package/{core → build/core}/DatePicker/index.js +0 -0
- package/{core → build/core}/DatePicker/index.js.map +0 -0
- package/{core → build/core}/DatePicker/index.less +0 -0
- package/{core → build/core}/DateRangePicker/index.d.ts +0 -0
- package/{core → build/core}/DateRangePicker/index.js +0 -0
- package/{core → build/core}/DateRangePicker/index.js.map +0 -0
- package/{core → build/core}/DateRangePicker/index.less +0 -0
- package/{core → build/core}/DateTimePicker/index.d.ts +0 -0
- package/{core → build/core}/DateTimePicker/index.js +0 -0
- package/{core → build/core}/DateTimePicker/index.js.map +0 -0
- package/{core → build/core}/DateTimePicker/index.less +0 -0
- package/{core → build/core}/DateTimeRangePicker/index.d.ts +0 -0
- package/{core → build/core}/DateTimeRangePicker/index.js +0 -0
- package/{core → build/core}/DateTimeRangePicker/index.js.map +0 -0
- package/{core → build/core}/DateTimeRangePicker/index.less +0 -0
- package/{core → build/core}/Descriptions/index.d.ts +0 -0
- package/{core → build/core}/Descriptions/index.js +0 -0
- package/{core → build/core}/Descriptions/index.js.map +0 -0
- package/{core → build/core}/Descriptions/index.less +0 -0
- package/{core → build/core}/DocumentTitle.d.ts +0 -0
- package/{core → build/core}/DocumentTitle.js +0 -0
- package/{core → build/core}/DocumentTitle.js.map +0 -0
- package/{core → build/core}/Drawer.d.ts +0 -0
- package/{core → build/core}/Drawer.js +0 -0
- package/{core → build/core}/Drawer.js.map +0 -0
- package/{core → build/core}/EnumCheckboxGroup/Map.d.ts +0 -0
- package/{core → build/core}/EnumCheckboxGroup/Map.js +0 -0
- package/{core → build/core}/EnumCheckboxGroup/Map.js.map +0 -0
- package/{core → build/core}/EnumCheckboxGroup/index.d.ts +0 -0
- package/{core → build/core}/EnumCheckboxGroup/index.js +0 -0
- package/{core → build/core}/EnumCheckboxGroup/index.js.map +0 -0
- package/{core → build/core}/EnumRadio/InitialNullable.d.ts +0 -0
- package/{core → build/core}/EnumRadio/InitialNullable.js +0 -0
- package/{core → build/core}/EnumRadio/InitialNullable.js.map +0 -0
- package/{core → build/core}/EnumRadio/Map.d.ts +0 -0
- package/{core → build/core}/EnumRadio/Map.js +0 -0
- package/{core → build/core}/EnumRadio/Map.js.map +0 -0
- package/{core → build/core}/EnumRadio/Nullable.d.ts +0 -0
- package/{core → build/core}/EnumRadio/Nullable.js +0 -0
- package/{core → build/core}/EnumRadio/Nullable.js.map +0 -0
- package/{core → build/core}/EnumRadio/index.d.ts +0 -0
- package/{core → build/core}/EnumRadio/index.js +0 -0
- package/{core → build/core}/EnumRadio/index.js.map +0 -0
- package/{core → build/core}/EnumSelect/InitialNullable.d.ts +0 -0
- package/{core → build/core}/EnumSelect/InitialNullable.js +0 -0
- package/{core → build/core}/EnumSelect/InitialNullable.js.map +0 -0
- package/{core → build/core}/EnumSelect/Map.d.ts +0 -0
- package/{core → build/core}/EnumSelect/Map.js +0 -0
- package/{core → build/core}/EnumSelect/Map.js.map +0 -0
- package/{core → build/core}/EnumSelect/Nullable.d.ts +0 -0
- package/{core → build/core}/EnumSelect/Nullable.js +0 -0
- package/{core → build/core}/EnumSelect/Nullable.js.map +0 -0
- package/build/core/EnumSelect/index.d.ts +29 -0
- package/build/core/EnumSelect/index.js +61 -0
- package/build/core/EnumSelect/index.js.map +1 -0
- package/{core → build/core}/EnumSelect/index.less +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/Item.d.ts +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/Item.js +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/Item.js.map +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/index.d.ts +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/index.js +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/index.js.map +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/index.less +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/type.d.ts +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/type.js +0 -0
- package/{core → build/core}/FlatList/VirtualFlatList/type.js.map +0 -0
- package/{core → build/core}/FlatList/index.d.ts +0 -0
- package/{core → build/core}/FlatList/index.js +0 -0
- package/{core → build/core}/FlatList/index.js.map +0 -0
- package/{core → build/core}/FlatList/shared/Footer/index.d.ts +0 -0
- package/{core → build/core}/FlatList/shared/Footer/index.js +0 -0
- package/{core → build/core}/FlatList/shared/Footer/index.js.map +0 -0
- package/{core → build/core}/FlatList/shared/Footer/index.less +0 -0
- package/{core → build/core}/FlatList/shared/Spinner/index.d.ts +0 -0
- package/{core → build/core}/FlatList/shared/Spinner/index.js +0 -0
- package/{core → build/core}/FlatList/shared/Spinner/index.js.map +0 -0
- package/{core → build/core}/FlatList/shared/Spinner/index.less +0 -0
- package/{core → build/core}/FlatList/shared/Wrapper/Loading.d.ts +0 -0
- package/{core → build/core}/FlatList/shared/Wrapper/Loading.js +0 -0
- package/{core → build/core}/FlatList/shared/Wrapper/Loading.js.map +0 -0
- package/{core → build/core}/FlatList/shared/Wrapper/index.d.ts +0 -0
- package/{core → build/core}/FlatList/shared/Wrapper/index.js +0 -0
- package/{core → build/core}/FlatList/shared/Wrapper/index.js.map +0 -0
- package/{core → build/core}/FlatList/shared/Wrapper/index.less +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useBounceSwipe.d.ts +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useBounceSwipe.js +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useBounceSwipe.js.map +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useElementScrollState.d.ts +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useElementScrollState.js +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useElementScrollState.js.map +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useLoadingWithDelay.d.ts +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useLoadingWithDelay.js +0 -0
- package/{core → build/core}/FlatList/shared/hooks/useLoadingWithDelay.js.map +0 -0
- package/{core → build/core}/FlatList/type.d.ts +0 -0
- package/{core → build/core}/FlatList/type.js +0 -0
- package/{core → build/core}/FlatList/type.js.map +0 -0
- package/{core → build/core}/Foldable/index.d.ts +0 -0
- package/{core → build/core}/Foldable/index.js +0 -0
- package/{core → build/core}/Foldable/index.js.map +0 -0
- package/{core → build/core}/Foldable/index.less +0 -0
- package/{core → build/core}/Form/Item.d.ts +0 -0
- package/{core → build/core}/Form/Item.js +0 -0
- package/{core → build/core}/Form/Item.js.map +0 -0
- package/{core → build/core}/Form/context.d.ts +0 -0
- package/{core → build/core}/Form/context.js +0 -0
- package/{core → build/core}/Form/context.js.map +0 -0
- package/{core → build/core}/Form/index.d.ts +0 -0
- package/{core → build/core}/Form/index.js +0 -0
- package/{core → build/core}/Form/index.js.map +0 -0
- package/{core → build/core}/Form/index.less +0 -0
- package/{core → build/core}/Grid.d.ts +0 -0
- package/{core → build/core}/Grid.js +0 -0
- package/{core → build/core}/Grid.js.map +0 -0
- package/{core → build/core}/HTMLContent/index.d.ts +0 -0
- package/{core → build/core}/HTMLContent/index.js +0 -0
- package/{core → build/core}/HTMLContent/index.js.map +0 -0
- package/{core → build/core}/HTMLContent/index.less +0 -0
- package/{core → build/core}/ImageUploader/index.d.ts +0 -0
- package/{core → build/core}/ImageUploader/index.js +0 -0
- package/{core → build/core}/ImageUploader/index.js.map +0 -0
- package/{core → build/core}/ImageUploader/index.less +0 -0
- package/{core → build/core}/Input/index.d.ts +0 -0
- package/{core → build/core}/Input/index.js +0 -0
- package/{core → build/core}/Input/index.js.map +0 -0
- package/{core → build/core}/Input/index.less +0 -0
- package/{core → build/core}/LabelledSelect.d.ts +0 -0
- package/{core → build/core}/LabelledSelect.js +0 -0
- package/{core → build/core}/LabelledSelect.js.map +0 -0
- package/{core → build/core}/Link.d.ts +0 -0
- package/{core → build/core}/Link.js +0 -0
- package/{core → build/core}/Link.js.map +0 -0
- package/{core → build/core}/LocalImporter.d.ts +0 -0
- package/{core → build/core}/LocalImporter.js +0 -0
- package/{core → build/core}/LocalImporter.js.map +0 -0
- package/{core → build/core}/LocaleProvider.d.ts +0 -0
- package/{core → build/core}/LocaleProvider.js +0 -0
- package/{core → build/core}/LocaleProvider.js.map +0 -0
- package/{core → build/core}/LocaleSelect.d.ts +0 -0
- package/{core → build/core}/LocaleSelect.js +0 -0
- package/{core → build/core}/LocaleSelect.js.map +0 -0
- package/{core → build/core}/Markdown/index.d.ts +0 -0
- package/{core → build/core}/Markdown/index.js +0 -0
- package/{core → build/core}/Markdown/index.js.map +0 -0
- package/{core → build/core}/Markdown/index.less +0 -0
- package/{core → build/core}/Modal/index.d.ts +0 -0
- package/{core → build/core}/Modal/index.js +0 -0
- package/{core → build/core}/Modal/index.js.map +0 -0
- package/{core → build/core}/Modal/index.less +0 -0
- package/{core → build/core}/MultipleCascader/index.d.ts +0 -0
- package/{core → build/core}/MultipleCascader/index.js +0 -0
- package/{core → build/core}/MultipleCascader/index.js.map +0 -0
- package/{core → build/core}/MultipleCascader/index.less +0 -0
- package/{core → build/core}/MultipleEnumSelect.d.ts +0 -0
- package/{core → build/core}/MultipleEnumSelect.js +0 -0
- package/{core → build/core}/MultipleEnumSelect.js.map +0 -0
- package/{core → build/core}/MultipleSelector/TablePopover.d.ts +0 -0
- package/{core → build/core}/MultipleSelector/TablePopover.js +0 -0
- package/{core → build/core}/MultipleSelector/TablePopover.js.map +0 -0
- package/{core → build/core}/MultipleSelector/index.d.ts +0 -0
- package/{core → build/core}/MultipleSelector/index.js +0 -0
- package/{core → build/core}/MultipleSelector/index.js.map +0 -0
- package/{core → build/core}/MutableTable/index.d.ts +0 -0
- package/{core → build/core}/MutableTable/index.js +0 -0
- package/{core → build/core}/MutableTable/index.js.map +0 -0
- package/{core → build/core}/MutableTable/index.less +0 -0
- package/{core → build/core}/NumberInput/NumberInputPercentage.d.ts +0 -0
- package/{core → build/core}/NumberInput/NumberInputPercentage.js +0 -0
- package/{core → build/core}/NumberInput/NumberInputPercentage.js.map +0 -0
- package/{core → build/core}/NumberInput/index.d.ts +0 -0
- package/{core → build/core}/NumberInput/index.js +0 -0
- package/{core → build/core}/NumberInput/index.js.map +0 -0
- package/{core → build/core}/NumberInput/index.less +0 -0
- package/{core → build/core}/NumberInput/util.d.ts +0 -0
- package/{core → build/core}/NumberInput/util.js +0 -0
- package/{core → build/core}/NumberInput/util.js.map +0 -0
- package/{core → build/core}/OverflowableText/index.d.ts +0 -0
- package/{core → build/core}/OverflowableText/index.js +0 -0
- package/{core → build/core}/OverflowableText/index.js.map +0 -0
- package/{core → build/core}/OverflowableText/index.less +0 -0
- package/{core → build/core}/PagedList/index.d.ts +0 -0
- package/{core → build/core}/PagedList/index.js +0 -0
- package/{core → build/core}/PagedList/index.js.map +0 -0
- package/{core → build/core}/PagedList/index.less +0 -0
- package/{core → build/core}/Pagination/index.d.ts +0 -0
- package/{core → build/core}/Pagination/index.js +0 -0
- package/{core → build/core}/Pagination/index.js.map +0 -0
- package/{core → build/core}/Pagination/index.less +0 -0
- package/{core → build/core}/Popover/index.d.ts +0 -0
- package/{core → build/core}/Popover/index.js +0 -0
- package/{core → build/core}/Popover/index.js.map +0 -0
- package/{core → build/core}/Popover/index.less +0 -0
- package/{core → build/core}/Progress.d.ts +0 -0
- package/{core → build/core}/Progress.js +0 -0
- package/{core → build/core}/Progress.js.map +0 -0
- package/{core → build/core}/Radio/index.d.ts +0 -0
- package/{core → build/core}/Radio/index.js +0 -0
- package/{core → build/core}/Radio/index.js.map +0 -0
- package/{core → build/core}/Radio/index.less +0 -0
- package/{core → build/core}/RelativeTime.d.ts +0 -0
- package/{core → build/core}/RelativeTime.js +0 -0
- package/{core → build/core}/RelativeTime.js.map +0 -0
- package/{core → build/core}/SearchableSelect.d.ts +0 -0
- package/{core → build/core}/SearchableSelect.js +0 -0
- package/{core → build/core}/SearchableSelect.js.map +0 -0
- package/{core → build/core}/Select/index.d.ts +0 -0
- package/{core → build/core}/Select/index.js +0 -0
- package/{core → build/core}/Select/index.js.map +0 -0
- package/{core → build/core}/Select/index.less +0 -0
- package/{core → build/core}/SignedAmountInput.d.ts +0 -0
- package/{core → build/core}/SignedAmountInput.js +0 -0
- package/{core → build/core}/SignedAmountInput.js.map +0 -0
- package/{core → build/core}/Skeleton.d.ts +0 -0
- package/{core → build/core}/Skeleton.js +0 -0
- package/{core → build/core}/Skeleton.js.map +0 -0
- package/{core → build/core}/Slider/RangeSlider.d.ts +0 -0
- package/{core → build/core}/Slider/RangeSlider.js +0 -0
- package/{core → build/core}/Slider/RangeSlider.js.map +0 -0
- package/{core → build/core}/Slider/index.d.ts +0 -0
- package/{core → build/core}/Slider/index.js +0 -0
- package/{core → build/core}/Slider/index.js.map +0 -0
- package/{core → build/core}/Slider/index.less +0 -0
- package/{core → build/core}/Space.d.ts +0 -0
- package/{core → build/core}/Space.js +0 -0
- package/{core → build/core}/Space.js.map +0 -0
- package/{core → build/core}/Spin.d.ts +0 -0
- package/{core → build/core}/Spin.js +0 -0
- package/{core → build/core}/Spin.js.map +0 -0
- package/{core → build/core}/StepFormContainer/index.d.ts +0 -0
- package/{core → build/core}/StepFormContainer/index.js +0 -0
- package/{core → build/core}/StepFormContainer/index.js.map +0 -0
- package/{core → build/core}/StepFormContainer/index.less +0 -0
- package/{core → build/core}/Steps/index.d.ts +0 -0
- package/{core → build/core}/Steps/index.js +0 -0
- package/{core → build/core}/Steps/index.js.map +0 -0
- package/{core → build/core}/Steps/index.less +0 -0
- package/{core → build/core}/Table/index.d.ts +0 -0
- package/{core → build/core}/Table/index.js +0 -0
- package/{core → build/core}/Table/index.js.map +0 -0
- package/{core → build/core}/Table/index.less +0 -0
- package/{core → build/core}/Tabs/Single.d.ts +0 -0
- package/{core → build/core}/Tabs/Single.js +0 -0
- package/{core → build/core}/Tabs/Single.js.map +0 -0
- package/{core → build/core}/Tabs/index.d.ts +0 -0
- package/{core → build/core}/Tabs/index.js +0 -0
- package/{core → build/core}/Tabs/index.js.map +0 -0
- package/{core → build/core}/Tabs/index.less +0 -0
- package/{core → build/core}/Tag.d.ts +0 -0
- package/{core → build/core}/Tag.js +0 -0
- package/{core → build/core}/Tag.js.map +0 -0
- package/{core → build/core}/TagInput/index.d.ts +0 -0
- package/{core → build/core}/TagInput/index.js +0 -0
- package/{core → build/core}/TagInput/index.js.map +0 -0
- package/{core → build/core}/TagInput/index.less +0 -0
- package/{core → build/core}/Tags.d.ts +0 -0
- package/{core → build/core}/Tags.js +0 -0
- package/{core → build/core}/Tags.js.map +0 -0
- package/{core → build/core}/TimePicker/index.d.ts +0 -0
- package/{core → build/core}/TimePicker/index.js +0 -0
- package/{core → build/core}/TimePicker/index.js.map +0 -0
- package/{core → build/core}/TimePicker/index.less +0 -0
- package/{core → build/core}/TimeRangePicker/index.d.ts +0 -0
- package/{core → build/core}/TimeRangePicker/index.js +0 -0
- package/{core → build/core}/TimeRangePicker/index.js.map +0 -0
- package/{core → build/core}/TimeRangePicker/index.less +0 -0
- package/{core → build/core}/Tooltip.d.ts +0 -0
- package/{core → build/core}/Tooltip.js +0 -0
- package/{core → build/core}/Tooltip.js.map +0 -0
- package/{core → build/core}/TypedTabs/index.d.ts +0 -0
- package/{core → build/core}/TypedTabs/index.js +0 -0
- package/{core → build/core}/TypedTabs/index.js.map +0 -0
- package/{core → build/core}/TypedTabs/index.less +0 -0
- package/{core → build/core}/Uploader.d.ts +0 -0
- package/{core → build/core}/Uploader.js +0 -0
- package/{core → build/core}/Uploader.js.map +0 -0
- package/{core → build/core}/VerticalMarquee/index.d.ts +0 -0
- package/{core → build/core}/VerticalMarquee/index.js +0 -0
- package/{core → build/core}/VerticalMarquee/index.js.map +0 -0
- package/{core → build/core}/VerticalMarquee/index.less +0 -0
- package/{core → build/core}/VirtualTable/TableHeader.d.ts +0 -0
- package/{core → build/core}/VirtualTable/TableHeader.js +0 -0
- package/{core → build/core}/VirtualTable/TableHeader.js.map +0 -0
- package/{core → build/core}/VirtualTable/TableRow.d.ts +0 -0
- package/{core → build/core}/VirtualTable/TableRow.js +0 -0
- package/{core → build/core}/VirtualTable/TableRow.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useColumnWidths.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useColumnWidths.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useColumnWidths.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useDebounce.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useDebounce.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useDebounce.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useLayout.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useLayout.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useLayout.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useRowExpand.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useRowExpand.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useRowExpand.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useRowSelection.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useRowSelection.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useRowSelection.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useScrollBarSize.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useScrollBarSize.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useScrollBarSize.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useScrollToEdge.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useScrollToEdge.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useScrollToEdge.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useStickyPosition.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useStickyPosition.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useStickyPosition.js.map +0 -0
- package/{core → build/core}/VirtualTable/hooks/useTransformColumn.d.ts +0 -0
- package/{core → build/core}/VirtualTable/hooks/useTransformColumn.js +0 -0
- package/{core → build/core}/VirtualTable/hooks/useTransformColumn.js.map +0 -0
- package/{core → build/core}/VirtualTable/index.d.ts +0 -0
- package/{core → build/core}/VirtualTable/index.js +0 -0
- package/{core → build/core}/VirtualTable/index.js.map +0 -0
- package/{core → build/core}/VirtualTable/index.less +0 -0
- package/{core → build/core}/VirtualTable/type.d.ts +0 -0
- package/{core → build/core}/VirtualTable/type.js +0 -0
- package/{core → build/core}/VirtualTable/type.js.map +0 -0
- package/{core → build/core}/WithExplanation/index.d.ts +0 -0
- package/{core → build/core}/WithExplanation/index.js +0 -0
- package/{core → build/core}/WithExplanation/index.js.map +0 -0
- package/{core → build/core}/WithExplanation/index.less +0 -0
- package/{core → build/core}/WithTooltipList.d.ts +0 -0
- package/{core → build/core}/WithTooltipList.js +0 -0
- package/{core → build/core}/WithTooltipList.js.map +0 -0
- package/{core → build/core}/YearMonthSelector.d.ts +0 -0
- package/{core → build/core}/YearMonthSelector.js +0 -0
- package/{core → build/core}/YearMonthSelector.js.map +0 -0
- package/{css → build/css}/global.less +0 -0
- package/{css → build/css}/variable.less +0 -0
- package/{hooks → build/hooks}/useSwipe/controller.d.ts +0 -0
- package/{hooks → build/hooks}/useSwipe/controller.js +0 -0
- package/{hooks → build/hooks}/useSwipe/controller.js.map +0 -0
- package/{hooks → build/hooks}/useSwipe/index.d.ts +0 -0
- package/{hooks → build/hooks}/useSwipe/index.js +0 -0
- package/{hooks → build/hooks}/useSwipe/index.js.map +0 -0
- package/{hooks → build/hooks}/useSwipe/type.d.ts +0 -0
- package/{hooks → build/hooks}/useSwipe/type.js +0 -0
- package/{hooks → build/hooks}/useSwipe/type.js.map +0 -0
- package/{hooks → build/hooks}/useTransform.d.ts +0 -0
- package/{hooks → build/hooks}/useTransform.js +0 -0
- package/{hooks → build/hooks}/useTransform.js.map +0 -0
- package/{internal → build/internal}/ArrayUtil.d.ts +0 -0
- package/{internal → build/internal}/ArrayUtil.js +0 -0
- package/{internal → build/internal}/ArrayUtil.js.map +0 -0
- package/{internal → build/internal}/ExpirableLocalStorage.d.ts +0 -0
- package/{internal → build/internal}/ExpirableLocalStorage.js +0 -0
- package/{internal → build/internal}/ExpirableLocalStorage.js.map +0 -0
- package/{internal → build/internal}/Memo.d.ts +0 -0
- package/{internal → build/internal}/Memo.js +0 -0
- package/{internal → build/internal}/Memo.js.map +0 -0
- package/{internal → build/internal}/NumberUtil.d.ts +0 -0
- package/{internal → build/internal}/NumberUtil.js +0 -0
- package/{internal → build/internal}/NumberUtil.js.map +0 -0
- package/{internal → build/internal}/StorageHelper.d.ts +0 -0
- package/{internal → build/internal}/StorageHelper.js +0 -0
- package/{internal → build/internal}/StorageHelper.js.map +0 -0
- package/{internal → build/internal}/TextUtil.d.ts +0 -0
- package/{internal → build/internal}/TextUtil.js +0 -0
- package/{internal → build/internal}/TextUtil.js.map +0 -0
- package/{internal → build/internal}/i18n/admin/en.d.ts +0 -0
- package/{internal → build/internal}/i18n/admin/en.js +0 -0
- package/{internal → build/internal}/i18n/admin/en.js.map +0 -0
- package/{internal → build/internal}/i18n/admin/index.d.ts +0 -0
- package/{internal → build/internal}/i18n/admin/index.js +0 -0
- package/{internal → build/internal}/i18n/admin/index.js.map +0 -0
- package/{internal → build/internal}/i18n/admin/zh.d.ts +0 -0
- package/{internal → build/internal}/i18n/admin/zh.js +0 -0
- package/{internal → build/internal}/i18n/admin/zh.js.map +0 -0
- package/{internal → build/internal}/i18n/core/en.d.ts +0 -0
- package/{internal → build/internal}/i18n/core/en.js +0 -0
- package/{internal → build/internal}/i18n/core/en.js.map +0 -0
- package/{internal → build/internal}/i18n/core/index.d.ts +0 -0
- package/{internal → build/internal}/i18n/core/index.js +0 -0
- package/{internal → build/internal}/i18n/core/index.js.map +0 -0
- package/{internal → build/internal}/i18n/core/zh.d.ts +0 -0
- package/{internal → build/internal}/i18n/core/zh.js +0 -0
- package/{internal → build/internal}/i18n/core/zh.js.map +0 -0
- package/{internal → build/internal}/i18n/util/en.d.ts +0 -0
- package/{internal → build/internal}/i18n/util/en.js +0 -0
- package/{internal → build/internal}/i18n/util/en.js.map +0 -0
- package/{internal → build/internal}/i18n/util/index.d.ts +0 -0
- package/{internal → build/internal}/i18n/util/index.js +0 -0
- package/{internal → build/internal}/i18n/util/index.js.map +0 -0
- package/{internal → build/internal}/i18n/util/zh.d.ts +0 -0
- package/{internal → build/internal}/i18n/util/zh.js +0 -0
- package/{internal → build/internal}/i18n/util/zh.js.map +0 -0
- package/{internal → build/internal}/type.d.ts +0 -0
- package/{internal → build/internal}/type.js +0 -0
- package/{internal → build/internal}/type.js.map +0 -0
- package/build/package.json +59 -0
- package/{util → build/util}/AdminNavigatorBase.d.ts +0 -0
- package/{util → build/util}/AdminNavigatorBase.js +0 -0
- package/{util → build/util}/AdminNavigatorBase.js.map +0 -0
- package/{util → build/util}/BrowserBookmarkUtil.d.ts +0 -0
- package/{util → build/util}/BrowserBookmarkUtil.js +0 -0
- package/{util → build/util}/BrowserBookmarkUtil.js.map +0 -0
- package/{util → build/util}/BrowserUtil.d.ts +0 -0
- package/{util → build/util}/BrowserUtil.js +0 -0
- package/{util → build/util}/BrowserUtil.js.map +0 -0
- package/{util → build/util}/CanvasUtil.d.ts +0 -0
- package/{util → build/util}/CanvasUtil.js +0 -0
- package/{util → build/util}/CanvasUtil.js.map +0 -0
- package/{util → build/util}/ClassNames.d.ts +0 -0
- package/{util → build/util}/ClassNames.js +0 -0
- package/{util → build/util}/ClassNames.js.map +0 -0
- package/{util → build/util}/Clipboard.d.ts +0 -0
- package/{util → build/util}/Clipboard.js +0 -0
- package/{util → build/util}/Clipboard.js.map +0 -0
- package/{util → build/util}/ExpirableLocalStorageUtil.d.ts +0 -0
- package/{util → build/util}/ExpirableLocalStorageUtil.js +0 -0
- package/{util → build/util}/ExpirableLocalStorageUtil.js.map +0 -0
- package/{util → build/util}/ExportUtil.d.ts +0 -0
- package/{util → build/util}/ExportUtil.js +0 -0
- package/{util → build/util}/ExportUtil.js.map +0 -0
- package/{util → build/util}/ImportUtil.d.ts +0 -0
- package/{util → build/util}/ImportUtil.js +0 -0
- package/{util → build/util}/ImportUtil.js.map +0 -0
- package/{util → build/util}/LocalStorageUtil.d.ts +0 -0
- package/{util → build/util}/LocalStorageUtil.js +0 -0
- package/{util → build/util}/LocalStorageUtil.js.map +0 -0
- package/{util → build/util}/LocaleUtil.d.ts +0 -0
- package/{util → build/util}/LocaleUtil.js +0 -0
- package/{util → build/util}/LocaleUtil.js.map +0 -0
- package/{util → build/util}/MediaUtil/index.d.ts +0 -0
- package/{util → build/util}/MediaUtil/index.js +0 -0
- package/{util → build/util}/MediaUtil/index.js.map +0 -0
- package/{util → build/util}/MediaUtil/index.less +0 -0
- package/{util → build/util}/MessageUtil/index.d.ts +0 -0
- package/{util → build/util}/MessageUtil/index.js +0 -0
- package/{util → build/util}/MessageUtil/index.js.map +0 -0
- package/{util → build/util}/MessageUtil/index.less +0 -0
- package/{util → build/util}/ModalUtil/index.d.ts +0 -0
- package/{util → build/util}/ModalUtil/index.js +0 -0
- package/{util → build/util}/ModalUtil/index.js.map +0 -0
- package/{util → build/util}/ModalUtil/index.less +0 -0
- package/{util → build/util}/NotificationUtil.d.ts +0 -0
- package/{util → build/util}/NotificationUtil.js +0 -0
- package/{util → build/util}/NotificationUtil.js.map +0 -0
- package/{util → build/util}/PromptUtil/PromptBody.d.ts +0 -0
- package/{util → build/util}/PromptUtil/PromptBody.js +0 -0
- package/{util → build/util}/PromptUtil/PromptBody.js.map +0 -0
- package/{util → build/util}/PromptUtil/index.d.ts +0 -0
- package/{util → build/util}/PromptUtil/index.js +0 -0
- package/{util → build/util}/PromptUtil/index.js.map +0 -0
- package/{util → build/util}/PromptUtil/index.less +0 -0
- package/{util → build/util}/RecentUsedStorageUtil.d.ts +0 -0
- package/{util → build/util}/RecentUsedStorageUtil.js +0 -0
- package/{util → build/util}/RecentUsedStorageUtil.js.map +0 -0
- package/{util → build/util}/SessionStorageUtil.d.ts +0 -0
- package/{util → build/util}/SessionStorageUtil.js +0 -0
- package/{util → build/util}/SessionStorageUtil.js.map +0 -0
- package/{util → build/util}/SwipeUtil.d.ts +0 -0
- package/{util → build/util}/SwipeUtil.js +0 -0
- package/{util → build/util}/SwipeUtil.js.map +0 -0
- package/{util → build/util}/UploadUtil/index.d.ts +0 -0
- package/{util → build/util}/UploadUtil/index.js +0 -0
- package/{util → build/util}/UploadUtil/index.js.map +0 -0
- package/{util → build/util}/UploadUtil/type.d.ts +0 -0
- package/{util → build/util}/UploadUtil/type.js +0 -0
- package/{util → build/util}/UploadUtil/type.js.map +0 -0
- package/config/jest-stubs/style-stub.js +13 -0
- package/config/jest.config.ts +57 -0
- package/config/tsconfig.script.json +13 -0
- package/config/tsconfig.src.json +15 -0
- package/config/tsconfig.test.json +20 -0
- package/package.json +1 -1
- package/script/build.ts +103 -0
- package/script/format.ts +7 -0
- package/script/start-mobile.ts +13 -0
- package/script/start.ts +31 -0
- package/src/admin/AdminApp/Default/NavigatorSide/index.less +57 -0
- package/src/admin/AdminApp/Default/NavigatorSide/index.tsx +68 -0
- package/src/admin/AdminApp/Default/SoundSwitch.tsx +32 -0
- package/src/admin/AdminApp/Default/SquareLogo/index.less +30 -0
- package/src/admin/AdminApp/Default/SquareLogo/index.tsx +32 -0
- package/src/admin/AdminApp/Menu.tsx +150 -0
- package/src/admin/AdminApp/Navigator.tsx +186 -0
- package/src/admin/AdminApp/NotFound.tsx +24 -0
- package/src/admin/AdminApp/RouteSwitch.tsx +61 -0
- package/src/admin/AdminApp/WithErrorBoundary.tsx +36 -0
- package/src/admin/AdminApp/asset/alert.mp3 +0 -0
- package/src/admin/AdminApp/context.ts +13 -0
- package/src/admin/AdminApp/index.less +148 -0
- package/src/admin/AdminApp/index.tsx +96 -0
- package/src/admin/AdminPage/Filter.tsx +76 -0
- package/src/admin/AdminPage/Result.tsx +41 -0
- package/src/admin/AdminPage/SaveBar.tsx +33 -0
- package/src/admin/AdminPage/Summary.tsx +15 -0
- package/src/admin/AdminPage/TopBar.tsx +15 -0
- package/src/admin/AdminPage/index.less +58 -0
- package/src/admin/AdminPage/index.tsx +29 -0
- package/src/admin/AdminPermissionSelector.tsx +299 -0
- package/src/admin/RichEditor/index.less +6 -0
- package/src/admin/RichEditor/index.tsx +123 -0
- package/src/core/Amount/AmountPercentage.tsx +27 -0
- package/src/core/Amount/index.less +52 -0
- package/src/core/Amount/index.tsx +71 -0
- package/src/core/AmountConditionInput.tsx +63 -0
- package/src/core/AmountRangeInput.tsx +66 -0
- package/src/core/AuthenticationCodeInput.tsx +85 -0
- package/src/core/AutoCompleteInput.tsx +16 -0
- package/src/core/Badge/index.less +3 -0
- package/src/core/Badge/index.tsx +15 -0
- package/src/core/BoolRadio.tsx +62 -0
- package/src/core/BoolSelect.tsx +50 -0
- package/src/core/BoolSwitch.tsx +37 -0
- package/src/core/Breadcrumb/index.less +54 -0
- package/src/core/Breadcrumb/index.tsx +46 -0
- package/src/core/Button/index.less +80 -0
- package/src/core/Button/index.tsx +59 -0
- package/src/core/Card.tsx +16 -0
- package/src/core/Carousel.tsx +19 -0
- package/src/core/Carousel3D/index.less +100 -0
- package/src/core/Carousel3D/index.tsx +150 -0
- package/src/core/Cascader/InitialNullable.tsx +20 -0
- package/src/core/Cascader/Nullable.tsx +28 -0
- package/src/core/Cascader/index.less +18 -0
- package/src/core/Cascader/index.tsx +93 -0
- package/src/core/Checkbox/index.less +4 -0
- package/src/core/Checkbox/index.tsx +24 -0
- package/src/core/Collapse.tsx +19 -0
- package/src/core/Countdown/SlidingDigit.tsx +39 -0
- package/src/core/Countdown/index.less +37 -0
- package/src/core/Countdown/index.tsx +125 -0
- package/src/core/DarkOverlay/index.less +20 -0
- package/src/core/DarkOverlay/index.tsx +24 -0
- package/src/core/DateCalendar.tsx +106 -0
- package/src/core/DatePicker/index.less +6 -0
- package/src/core/DatePicker/index.tsx +54 -0
- package/src/core/DateRangePicker/index.less +12 -0
- package/src/core/DateRangePicker/index.tsx +58 -0
- package/src/core/DateTimePicker/index.less +6 -0
- package/src/core/DateTimePicker/index.tsx +61 -0
- package/src/core/DateTimeRangePicker/index.less +5 -0
- package/src/core/DateTimeRangePicker/index.tsx +60 -0
- package/src/core/Descriptions/index.less +21 -0
- package/src/core/Descriptions/index.tsx +45 -0
- package/src/core/DocumentTitle.tsx +58 -0
- package/src/core/Drawer.tsx +14 -0
- package/src/core/EnumCheckboxGroup/Map.tsx +21 -0
- package/src/core/EnumCheckboxGroup/index.tsx +23 -0
- package/src/core/EnumRadio/InitialNullable.tsx +24 -0
- package/src/core/EnumRadio/Map.tsx +21 -0
- package/src/core/EnumRadio/Nullable.tsx +31 -0
- package/src/core/EnumRadio/index.tsx +45 -0
- package/src/core/EnumSelect/InitialNullable.tsx +20 -0
- package/src/core/EnumSelect/Map.tsx +21 -0
- package/src/core/EnumSelect/Nullable.tsx +31 -0
- package/src/core/EnumSelect/index.less +17 -0
- package/src/core/EnumSelect/index.tsx +74 -0
- package/src/core/FlatList/VirtualFlatList/Item.tsx +36 -0
- package/src/core/FlatList/VirtualFlatList/index.less +22 -0
- package/src/core/FlatList/VirtualFlatList/index.tsx +126 -0
- package/src/core/FlatList/VirtualFlatList/type.ts +27 -0
- package/src/core/FlatList/index.tsx +76 -0
- package/src/core/FlatList/shared/Footer/index.less +8 -0
- package/src/core/FlatList/shared/Footer/index.tsx +23 -0
- package/src/core/FlatList/shared/Spinner/index.less +13 -0
- package/src/core/FlatList/shared/Spinner/index.tsx +18 -0
- package/src/core/FlatList/shared/Wrapper/Loading.tsx +18 -0
- package/src/core/FlatList/shared/Wrapper/index.less +33 -0
- package/src/core/FlatList/shared/Wrapper/index.tsx +121 -0
- package/src/core/FlatList/shared/hooks/useBounceSwipe.ts +120 -0
- package/src/core/FlatList/shared/hooks/useElementScrollState.ts +43 -0
- package/src/core/FlatList/shared/hooks/useLoadingWithDelay.ts +40 -0
- package/src/core/FlatList/type.tsx +40 -0
- package/src/core/Foldable/index.less +77 -0
- package/src/core/Foldable/index.tsx +38 -0
- package/src/core/Form/Item.tsx +87 -0
- package/src/core/Form/context.ts +16 -0
- package/src/core/Form/index.less +199 -0
- package/src/core/Form/index.tsx +109 -0
- package/src/core/Grid.tsx +7 -0
- package/src/core/HTMLContent/index.less +15 -0
- package/src/core/HTMLContent/index.tsx +17 -0
- package/src/core/ImageUploader/index.less +53 -0
- package/src/core/ImageUploader/index.tsx +104 -0
- package/src/core/Input/index.less +4 -0
- package/src/core/Input/index.tsx +63 -0
- package/src/core/LabelledSelect.tsx +15 -0
- package/src/core/Link.tsx +57 -0
- package/src/core/LocalImporter.tsx +62 -0
- package/src/core/LocaleProvider.tsx +31 -0
- package/src/core/LocaleSelect.tsx +36 -0
- package/src/core/Markdown/index.less +5 -0
- package/src/core/Markdown/index.tsx +42 -0
- package/src/core/Modal/index.less +57 -0
- package/src/core/Modal/index.tsx +37 -0
- package/src/core/MultipleCascader/index.less +11 -0
- package/src/core/MultipleCascader/index.tsx +114 -0
- package/src/core/MultipleEnumSelect.tsx +28 -0
- package/src/core/MultipleSelector/TablePopover.tsx +62 -0
- package/src/core/MultipleSelector/index.tsx +106 -0
- package/src/core/MutableTable/index.less +31 -0
- package/src/core/MutableTable/index.tsx +151 -0
- package/src/core/NumberInput/NumberInputPercentage.tsx +103 -0
- package/src/core/NumberInput/index.less +105 -0
- package/src/core/NumberInput/index.tsx +192 -0
- package/src/core/NumberInput/util.ts +55 -0
- package/src/core/OverflowableText/index.less +29 -0
- package/src/core/OverflowableText/index.tsx +66 -0
- package/src/core/PagedList/index.less +91 -0
- package/src/core/PagedList/index.tsx +93 -0
- package/src/core/Pagination/index.less +14 -0
- package/src/core/Pagination/index.tsx +59 -0
- package/src/core/Popover/index.less +3 -0
- package/src/core/Popover/index.tsx +15 -0
- package/src/core/Progress.tsx +14 -0
- package/src/core/Radio/index.less +6 -0
- package/src/core/Radio/index.tsx +21 -0
- package/src/core/RelativeTime.tsx +59 -0
- package/src/core/SearchableSelect.tsx +17 -0
- package/src/core/Select/index.less +7 -0
- package/src/core/Select/index.tsx +25 -0
- package/src/core/SignedAmountInput.tsx +59 -0
- package/src/core/Skeleton.tsx +14 -0
- package/src/core/Slider/RangeSlider.tsx +17 -0
- package/src/core/Slider/index.less +33 -0
- package/src/core/Slider/index.tsx +50 -0
- package/src/core/Space.tsx +14 -0
- package/src/core/Spin.tsx +25 -0
- package/src/core/StepFormContainer/index.less +5 -0
- package/src/core/StepFormContainer/index.tsx +66 -0
- package/src/core/Steps/index.less +5 -0
- package/src/core/Steps/index.tsx +17 -0
- package/src/core/Table/index.less +39 -0
- package/src/core/Table/index.tsx +221 -0
- package/src/core/Tabs/Single.tsx +25 -0
- package/src/core/Tabs/index.less +14 -0
- package/src/core/Tabs/index.tsx +77 -0
- package/src/core/Tag.tsx +17 -0
- package/src/core/TagInput/index.less +59 -0
- package/src/core/TagInput/index.tsx +94 -0
- package/src/core/Tags.tsx +34 -0
- package/src/core/TimePicker/index.less +6 -0
- package/src/core/TimePicker/index.tsx +44 -0
- package/src/core/TimeRangePicker/index.less +12 -0
- package/src/core/TimeRangePicker/index.tsx +42 -0
- package/src/core/Tooltip.tsx +17 -0
- package/src/core/TypedTabs/index.less +17 -0
- package/src/core/TypedTabs/index.tsx +43 -0
- package/src/core/Uploader.tsx +118 -0
- package/src/core/VerticalMarquee/index.less +13 -0
- package/src/core/VerticalMarquee/index.tsx +51 -0
- package/src/core/VirtualTable/TableHeader.tsx +41 -0
- package/src/core/VirtualTable/TableRow.tsx +90 -0
- package/src/core/VirtualTable/hooks/useColumnWidths.ts +24 -0
- package/src/core/VirtualTable/hooks/useDebounce.ts +18 -0
- package/src/core/VirtualTable/hooks/useLayout.tsx +58 -0
- package/src/core/VirtualTable/hooks/useRowExpand.tsx +27 -0
- package/src/core/VirtualTable/hooks/useRowSelection.tsx +72 -0
- package/src/core/VirtualTable/hooks/useScrollBarSize.ts +23 -0
- package/src/core/VirtualTable/hooks/useScrollToEdge.ts +36 -0
- package/src/core/VirtualTable/hooks/useStickyPosition.ts +28 -0
- package/src/core/VirtualTable/hooks/useTransformColumn.ts +19 -0
- package/src/core/VirtualTable/index.less +162 -0
- package/src/core/VirtualTable/index.tsx +143 -0
- package/src/core/VirtualTable/type.ts +59 -0
- package/src/core/WithExplanation/index.less +30 -0
- package/src/core/WithExplanation/index.tsx +47 -0
- package/src/core/WithTooltipList.tsx +89 -0
- package/src/core/YearMonthSelector.tsx +53 -0
- package/src/css/global.less +93 -0
- package/src/css/variable.less +5 -0
- package/src/hooks/useSwipe/controller.ts +133 -0
- package/src/hooks/useSwipe/index.ts +11 -0
- package/src/hooks/useSwipe/type.ts +45 -0
- package/src/hooks/useTransform.ts +77 -0
- package/src/internal/ArrayUtil.ts +53 -0
- package/src/internal/ExpirableLocalStorage.ts +262 -0
- package/src/internal/Memo.ts +28 -0
- package/src/internal/NumberUtil.ts +38 -0
- package/src/internal/StorageHelper.ts +152 -0
- package/src/internal/TextUtil.ts +11 -0
- package/src/internal/i18n/admin/en.ts +18 -0
- package/src/internal/i18n/admin/index.ts +13 -0
- package/src/internal/i18n/admin/zh.ts +18 -0
- package/src/internal/i18n/core/en.ts +37 -0
- package/src/internal/i18n/core/index.ts +13 -0
- package/src/internal/i18n/core/zh.ts +37 -0
- package/src/internal/i18n/util/en.ts +9 -0
- package/src/internal/i18n/util/index.ts +13 -0
- package/src/internal/i18n/util/zh.ts +9 -0
- package/src/internal/type.ts +12 -0
- package/src/util/AdminNavigatorBase.ts +99 -0
- package/src/util/BrowserBookmarkUtil.ts +24 -0
- package/src/util/BrowserUtil.ts +122 -0
- package/src/util/CanvasUtil.ts +61 -0
- package/src/util/ClassNames.ts +2 -0
- package/src/util/Clipboard.ts +61 -0
- package/src/util/ExpirableLocalStorageUtil.ts +3 -0
- package/src/util/ExportUtil.ts +34 -0
- package/src/util/ImportUtil.ts +41 -0
- package/src/util/LocalStorageUtil.ts +3 -0
- package/src/util/LocaleUtil.ts +47 -0
- package/src/util/MediaUtil/index.less +27 -0
- package/src/util/MediaUtil/index.tsx +69 -0
- package/src/util/MessageUtil/index.less +3 -0
- package/src/util/MessageUtil/index.tsx +23 -0
- package/src/util/ModalUtil/index.less +83 -0
- package/src/util/ModalUtil/index.tsx +179 -0
- package/src/util/NotificationUtil.tsx +42 -0
- package/src/util/PromptUtil/PromptBody.tsx +62 -0
- package/src/util/PromptUtil/index.less +18 -0
- package/src/util/PromptUtil/index.tsx +50 -0
- package/src/util/RecentUsedStorageUtil.ts +46 -0
- package/src/util/SessionStorageUtil.ts +3 -0
- package/src/util/SwipeUtil.ts +25 -0
- package/src/util/UploadUtil/index.ts +73 -0
- package/src/util/UploadUtil/type.ts +46 -0
- package/test/mobile-ui-test/package.json +5 -0
- package/test/mobile-ui-test/src/component/FlatListDemo/fetch.ts +18 -0
- package/test/mobile-ui-test/src/component/FlatListDemo/index.less +22 -0
- package/test/mobile-ui-test/src/component/FlatListDemo/index.tsx +145 -0
- package/test/mobile-ui-test/src/component/Main.tsx +6 -0
- package/test/mobile-ui-test/src/index.html +12 -0
- package/test/mobile-ui-test/src/index.less +18 -0
- package/test/mobile-ui-test/src/index.tsx +6 -0
- package/test/mobile-ui-test/static/robots.txt +2 -0
- package/test/mobile-ui-test/tsconfig.json +4 -0
- package/test/ui-test/package.json +5 -0
- package/test/ui-test/src/asset/logo.png +0 -0
- package/test/ui-test/src/component/DemoHelper/index.less +33 -0
- package/test/ui-test/src/component/DemoHelper/index.tsx +55 -0
- package/test/ui-test/src/component/Main.tsx +33 -0
- package/test/ui-test/src/component/WebUILogo.tsx +7 -0
- package/test/ui-test/src/component/WebUINavigatorSide.tsx +20 -0
- package/test/ui-test/src/component/admin/ConfigPageDemo.tsx +39 -0
- package/test/ui-test/src/component/admin/NavigationHistoryDemo.tsx +30 -0
- package/test/ui-test/src/component/admin/PermissionSelectorDemo.tsx +65 -0
- package/test/ui-test/src/component/admin/RenderErrorDemo.tsx +5 -0
- package/test/ui-test/src/component/admin/ResultPageDemo.tsx +13 -0
- package/test/ui-test/src/component/admin/RichEditorDemo.tsx +20 -0
- package/test/ui-test/src/component/admin/SeparateTabDetailDemo.tsx +44 -0
- package/test/ui-test/src/component/admin/TablePageDemo.tsx +85 -0
- package/test/ui-test/src/component/core/AmountDemo.tsx +117 -0
- package/test/ui-test/src/component/core/ButtonDemo/__tests__/__snapshots__/dom-snapshot.test.tsx.snap +12 -0
- package/test/ui-test/src/component/core/ButtonDemo/__tests__/dom-snapshot.test.tsx +10 -0
- package/test/ui-test/src/component/core/ButtonDemo/__tests__/smoke.test.tsx +71 -0
- package/test/ui-test/src/component/core/ButtonDemo/index.tsx +39 -0
- package/test/ui-test/src/component/core/CalendarDemo.tsx +98 -0
- package/test/ui-test/src/component/core/CarouselDemo/index.tsx +51 -0
- package/test/ui-test/src/component/core/CascaderDemo/index.tsx +120 -0
- package/test/ui-test/src/component/core/FoldableDemo.tsx +31 -0
- package/test/ui-test/src/component/core/FormDemo.tsx +204 -0
- package/test/ui-test/src/component/core/InputDemo/index.tsx +123 -0
- package/test/ui-test/src/component/core/MiscellaneousDemo/TagInputDemo.tsx +8 -0
- package/test/ui-test/src/component/core/MiscellaneousDemo/index.tsx +157 -0
- package/test/ui-test/src/component/core/ModalDemo/index.tsx +75 -0
- package/test/ui-test/src/component/core/OverflowableTextDemo.tsx +78 -0
- package/test/ui-test/src/component/core/RelativeTimeDemo.tsx +35 -0
- package/test/ui-test/src/component/core/SelectDemo/index.tsx +141 -0
- package/test/ui-test/src/component/core/SliderDemo.tsx +44 -0
- package/test/ui-test/src/component/core/StepContainerDemo.tsx +53 -0
- package/test/ui-test/src/component/core/TableDemo.tsx +81 -0
- package/test/ui-test/src/component/core/TabsDemo.tsx +136 -0
- package/test/ui-test/src/component/core/UploaderImporterDemo.tsx +52 -0
- package/test/ui-test/src/component/core/VirtualTableDemo.tsx +232 -0
- package/test/ui-test/src/dummy/dummyCallback.ts +13 -0
- package/test/ui-test/src/dummy/dummyList.ts +63 -0
- package/test/ui-test/src/dummy/dummyTableData.tsx +60 -0
- package/test/ui-test/src/dummy/dummyUpload.tsx +43 -0
- package/test/ui-test/src/index.html +11 -0
- package/test/ui-test/src/index.tsx +5 -0
- package/test/ui-test/src/type.ts +8 -0
- package/test/ui-test/src/util/NavigationService.tsx +217 -0
- package/test/ui-test/src/util/withUncontrolledInitialValue.tsx +14 -0
- package/test/ui-test/static/robots.txt +2 -0
- package/test/ui-test/tsconfig.json +3 -0
- package/test/unit-test/ClassNames.test.ts +17 -0
- package/test/unit-test/ExpirableLocalStorageUtil.test.ts +42 -0
- package/test/unit-test/NumberInput.util.test.ts +344 -0
- package/test/unit-test/NumberUtil.test.ts +57 -0
- package/test/unit-test/TextUtil.test.ts +10 -0
- package/tsconfig.json +15 -0
- package/core/EnumSelect/index.d.ts +0 -27
- package/core/EnumSelect/index.js +0 -58
- package/core/EnumSelect/index.js.map +0 -1
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {Measure} from "../../VirtualFlatList/type";
|
|
3
|
+
import type {FooterData} from "../../type";
|
|
4
|
+
import {Spinner} from "../Spinner";
|
|
5
|
+
import "./index.less";
|
|
6
|
+
|
|
7
|
+
export interface Props extends FooterData {
|
|
8
|
+
measure?: Measure;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export const Footer = (props: Props) => {
|
|
12
|
+
const {loading, ended, loadingMessage, endMessage, measure} = props;
|
|
13
|
+
const measureRef = React.useRef(measure);
|
|
14
|
+
measureRef.current = measure;
|
|
15
|
+
|
|
16
|
+
return (
|
|
17
|
+
<div className="g-flat-list-footer" ref={measure}>
|
|
18
|
+
{loading && <Spinner loading message={loadingMessage ?? "loading..."} />}
|
|
19
|
+
{ended && !loading && (endMessage ?? "All data loaded")}
|
|
20
|
+
{!ended && !loading && "Pull up to loading more "}
|
|
21
|
+
</div>
|
|
22
|
+
);
|
|
23
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {Spin} from "../../../Spin";
|
|
3
|
+
import "./index.less";
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
loading: boolean;
|
|
7
|
+
message?: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export const Spinner = (props: Props) => {
|
|
11
|
+
const {loading, message} = props;
|
|
12
|
+
return (
|
|
13
|
+
<div className="g-flat-list-spinner">
|
|
14
|
+
<Spin spinning={loading} size="small" />
|
|
15
|
+
<div className="message">{message}</div>
|
|
16
|
+
</div>
|
|
17
|
+
);
|
|
18
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {Spin} from "../../../Spin";
|
|
3
|
+
import {Spinner} from "../Spinner";
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
loading: boolean;
|
|
7
|
+
message?: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export const Loading = (props: Props) => {
|
|
11
|
+
const {loading, message} = props;
|
|
12
|
+
|
|
13
|
+
return (
|
|
14
|
+
<div className="g-flat-list-loading">
|
|
15
|
+
<Spinner loading={loading} message={message ?? "Release to refresh"} />
|
|
16
|
+
</div>
|
|
17
|
+
);
|
|
18
|
+
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
.g-flat-list-wrapper {
|
|
2
|
+
flex: 1;
|
|
3
|
+
overflow: hidden;
|
|
4
|
+
position: relative;
|
|
5
|
+
display: flex;
|
|
6
|
+
flex-flow: column;
|
|
7
|
+
|
|
8
|
+
.inner-container {
|
|
9
|
+
flex: 1;
|
|
10
|
+
transition: all 300ms cubic-bezier(0, 0.61, 0.28, 1.22);
|
|
11
|
+
max-height: 100%;
|
|
12
|
+
will-change: transform;
|
|
13
|
+
|
|
14
|
+
.list-wrapper {
|
|
15
|
+
width: 100%;
|
|
16
|
+
height: 100%;
|
|
17
|
+
overflow: auto;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.g-flat-list-loading {
|
|
22
|
+
width: 100%;
|
|
23
|
+
padding: 8px;
|
|
24
|
+
display: flex;
|
|
25
|
+
justify-content: center;
|
|
26
|
+
align-items: center;
|
|
27
|
+
position: fixed;
|
|
28
|
+
left: 0;
|
|
29
|
+
min-height: 50px;
|
|
30
|
+
will-change: transform;
|
|
31
|
+
transform: translateY(-100%);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {classNames} from "../../../../util/ClassNames";
|
|
3
|
+
import {Direction} from "../../../../hooks/useSwipe";
|
|
4
|
+
import {useTransform} from "../../../../hooks/useTransform";
|
|
5
|
+
import {useBounceSwipe} from "../hooks/useBounceSwipe";
|
|
6
|
+
import {useElementScrollState} from "../hooks/useElementScrollState";
|
|
7
|
+
import type {FlatListProps, LoadingType} from "../../type";
|
|
8
|
+
import {PULL_DOWN_REFRESH_THRESHOLD} from "../../type";
|
|
9
|
+
import {Loading} from "./Loading";
|
|
10
|
+
import "./index.less";
|
|
11
|
+
|
|
12
|
+
interface Props<T> extends Pick<FlatListProps<T>, "loading" | "bounceEffect" | "onPullUpLoading" | "onPullDownRefresh" | "className" | "style" | "pullDownRefreshMessage"> {
|
|
13
|
+
children: React.ReactNode;
|
|
14
|
+
listWrapperRef: React.RefObject<HTMLDivElement>;
|
|
15
|
+
loadingType: LoadingType;
|
|
16
|
+
onLoadingTypeChange: (type: LoadingType) => void;
|
|
17
|
+
innerClassName?: string;
|
|
18
|
+
innerStyle?: React.CSSProperties;
|
|
19
|
+
onScroll?: (event: React.UIEvent) => void;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export const Wrapper = function <T>(props: Props<T>) {
|
|
23
|
+
const {
|
|
24
|
+
children,
|
|
25
|
+
bounceEffect,
|
|
26
|
+
listWrapperRef,
|
|
27
|
+
loadingType,
|
|
28
|
+
onLoadingTypeChange,
|
|
29
|
+
loading = false,
|
|
30
|
+
onPullDownRefresh,
|
|
31
|
+
onPullUpLoading,
|
|
32
|
+
className,
|
|
33
|
+
innerClassName,
|
|
34
|
+
style,
|
|
35
|
+
innerStyle,
|
|
36
|
+
pullDownRefreshMessage,
|
|
37
|
+
onScroll,
|
|
38
|
+
} = props;
|
|
39
|
+
const startOffsetRef = React.useRef(0);
|
|
40
|
+
|
|
41
|
+
const animatedRef = React.useRef<HTMLDivElement>(null);
|
|
42
|
+
|
|
43
|
+
const loadingTypeRef = React.useRef<LoadingType>(null);
|
|
44
|
+
loadingTypeRef.current = loadingType;
|
|
45
|
+
|
|
46
|
+
const onLoadingTypeChangeRef = React.useRef(onLoadingTypeChange);
|
|
47
|
+
onLoadingTypeChangeRef.current = onLoadingTypeChange;
|
|
48
|
+
|
|
49
|
+
const {isScrollable} = useElementScrollState(listWrapperRef);
|
|
50
|
+
const transform = useTransform(animatedRef);
|
|
51
|
+
const transformRef = React.useRef(transform);
|
|
52
|
+
transformRef.current = transform;
|
|
53
|
+
|
|
54
|
+
const reset = React.useCallback(() => {
|
|
55
|
+
startOffsetRef.current = 0;
|
|
56
|
+
}, []);
|
|
57
|
+
|
|
58
|
+
const handlers = useBounceSwipe({
|
|
59
|
+
axis: "vertical",
|
|
60
|
+
contentRef: listWrapperRef,
|
|
61
|
+
animatedRef,
|
|
62
|
+
onStart: ({delta: [, y]}) => {
|
|
63
|
+
startOffsetRef.current = y;
|
|
64
|
+
},
|
|
65
|
+
onEnd: ({delta, direction, boundary}) => {
|
|
66
|
+
if (loading) {
|
|
67
|
+
if (boundary !== "upper") {
|
|
68
|
+
transform.to({
|
|
69
|
+
y: PULL_DOWN_REFRESH_THRESHOLD,
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
} else {
|
|
73
|
+
if (Math.abs(startOffsetRef.current - delta[1]) >= PULL_DOWN_REFRESH_THRESHOLD) {
|
|
74
|
+
const scrollable = isScrollable("vertical");
|
|
75
|
+
if (boundary === "upper" || (!scrollable && direction === Direction.DOWN)) {
|
|
76
|
+
onLoadingTypeChange("refresh");
|
|
77
|
+
onPullDownRefresh?.();
|
|
78
|
+
} else {
|
|
79
|
+
onLoadingTypeChange("loading");
|
|
80
|
+
onPullUpLoading?.();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
reset();
|
|
85
|
+
},
|
|
86
|
+
onCancel: reset,
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
const handleScroll = React.useCallback(
|
|
90
|
+
(e: React.UIEvent) => {
|
|
91
|
+
transformRef.current.clear();
|
|
92
|
+
onScroll?.(e);
|
|
93
|
+
},
|
|
94
|
+
[onScroll]
|
|
95
|
+
);
|
|
96
|
+
|
|
97
|
+
React.useEffect(() => {
|
|
98
|
+
if (loading) {
|
|
99
|
+
if (loadingTypeRef.current === "refresh") {
|
|
100
|
+
transformRef.current.to({
|
|
101
|
+
y: PULL_DOWN_REFRESH_THRESHOLD,
|
|
102
|
+
immediate: false,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
} else {
|
|
106
|
+
transformRef.current.clear();
|
|
107
|
+
onLoadingTypeChangeRef.current(null);
|
|
108
|
+
}
|
|
109
|
+
}, [loading]);
|
|
110
|
+
|
|
111
|
+
return (
|
|
112
|
+
<div className={classNames("g-flat-list-wrapper", className)} style={style} {...(bounceEffect ? handlers : {})}>
|
|
113
|
+
<div className={classNames("inner-container", innerClassName)} style={innerStyle} ref={animatedRef}>
|
|
114
|
+
<Loading loading={loading && loadingType === "refresh"} message={pullDownRefreshMessage} />
|
|
115
|
+
<div className="list-wrapper" ref={listWrapperRef} onScroll={handleScroll}>
|
|
116
|
+
{children}
|
|
117
|
+
</div>
|
|
118
|
+
</div>
|
|
119
|
+
</div>
|
|
120
|
+
);
|
|
121
|
+
};
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {useElementScrollState} from "./useElementScrollState";
|
|
3
|
+
import type {SwipeHookResult, SwipeState} from "../../../../hooks/useSwipe";
|
|
4
|
+
import {Direction, useSwipe} from "../../../../hooks/useSwipe";
|
|
5
|
+
import {useTransform} from "../../../../hooks/useTransform";
|
|
6
|
+
|
|
7
|
+
export type Boundary = "upper" | "lower" | null;
|
|
8
|
+
|
|
9
|
+
interface BounceSwipeState extends SwipeState {
|
|
10
|
+
// always be null when inner content is not scrollable
|
|
11
|
+
boundary: Boundary;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export type BounceSwipeHandler = (state: BounceSwipeState) => void;
|
|
15
|
+
|
|
16
|
+
type BounceSwipeHookResult = SwipeHookResult;
|
|
17
|
+
|
|
18
|
+
interface BounceSwipeHandlers {
|
|
19
|
+
onMove?: BounceSwipeHandler;
|
|
20
|
+
onStart?: BounceSwipeHandler;
|
|
21
|
+
onEnd?: BounceSwipeHandler;
|
|
22
|
+
onCancel?: BounceSwipeHandler;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
interface BounceSwipeOption extends BounceSwipeHandlers {
|
|
26
|
+
axis: "vertical" | "horizontal";
|
|
27
|
+
// Use to determine content is scrollable or not
|
|
28
|
+
contentRef: React.RefObject<HTMLElement>;
|
|
29
|
+
// Element Ref which is going to be applied bounce transform and animation
|
|
30
|
+
animatedRef: React.RefObject<HTMLElement>;
|
|
31
|
+
baseOffset?: number;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export const useBounceSwipe = (options: BounceSwipeOption): BounceSwipeHookResult => {
|
|
35
|
+
const {contentRef, animatedRef, axis, baseOffset = 0, onStart, onMove, onEnd, onCancel} = options;
|
|
36
|
+
const [boundary, setBoundary] = React.useState<Boundary>(null);
|
|
37
|
+
const transform = useTransform(animatedRef, {duration: 300, timingFunction: "cubic-bezier(0, 0.61, 0.28, 1.22)", property: "transform"});
|
|
38
|
+
const startOffsetRef = React.useRef(0);
|
|
39
|
+
|
|
40
|
+
const isX = React.useMemo(() => axis === "horizontal", [axis]);
|
|
41
|
+
const isY = React.useMemo(() => axis === "vertical", [axis]);
|
|
42
|
+
const {isScrollable, isScrollTop, isScrollBottom, isScrollLeft, isScrollRight} = useElementScrollState(contentRef);
|
|
43
|
+
|
|
44
|
+
const threshold = ({direction}: SwipeState): boolean => {
|
|
45
|
+
if (isY) {
|
|
46
|
+
return (direction === Direction.DOWN && isScrollTop()) || (direction === Direction.UP && isScrollBottom());
|
|
47
|
+
} else {
|
|
48
|
+
return (direction === Direction.RIGHT && isScrollLeft()) || (direction === Direction.LEFT && isScrollRight());
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
const clearSwipe = () => {
|
|
53
|
+
startOffsetRef.current = 0;
|
|
54
|
+
setBoundary(null);
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
React.useEffect(() => {
|
|
58
|
+
// Changing overflow style to fixed laggy bounce swipe in chrome
|
|
59
|
+
if (contentRef.current) {
|
|
60
|
+
if (boundary) {
|
|
61
|
+
contentRef.current.style.overflow = "hidden";
|
|
62
|
+
} else {
|
|
63
|
+
contentRef.current.style.overflow = "auto";
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}, [boundary, contentRef]);
|
|
67
|
+
|
|
68
|
+
const getOffset = (delta: [number, number], boundary: Boundary): Readonly<[number, number]> | null => {
|
|
69
|
+
let resultOffset: Readonly<[number, number]> | null = [0, 0];
|
|
70
|
+
const limitedOffset = delta[isX ? 0 : 1] - startOffsetRef.current + baseOffset;
|
|
71
|
+
const computeResultOffset = (value: number) => [isX ? value : 0, isY ? value : 0] as const;
|
|
72
|
+
if (boundary === "upper") {
|
|
73
|
+
resultOffset = limitedOffset < 0 ? null : computeResultOffset(limitedOffset);
|
|
74
|
+
} else if (boundary === "lower") {
|
|
75
|
+
resultOffset = limitedOffset > 0 ? null : computeResultOffset(limitedOffset);
|
|
76
|
+
} else {
|
|
77
|
+
resultOffset = computeResultOffset(limitedOffset);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
return resultOffset;
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
const handlers = useSwipe(
|
|
84
|
+
{
|
|
85
|
+
onStart: state => {
|
|
86
|
+
const {
|
|
87
|
+
delta: [x, y],
|
|
88
|
+
direction,
|
|
89
|
+
} = state;
|
|
90
|
+
isScrollable(axis) && setBoundary(direction === Direction.DOWN ? "upper" : "lower");
|
|
91
|
+
startOffsetRef.current = isX ? x : y;
|
|
92
|
+
onStart?.({...state, boundary});
|
|
93
|
+
},
|
|
94
|
+
onMove: state => {
|
|
95
|
+
const {delta, cancel} = state;
|
|
96
|
+
const offset = getOffset(delta, boundary);
|
|
97
|
+
if (!offset) {
|
|
98
|
+
cancel();
|
|
99
|
+
} else {
|
|
100
|
+
const [x, y] = offset;
|
|
101
|
+
transform.to({x, y, immediate: true});
|
|
102
|
+
onMove?.({...state, boundary});
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
onEnd: state => {
|
|
106
|
+
onEnd?.({...state, boundary});
|
|
107
|
+
transform.clear();
|
|
108
|
+
clearSwipe();
|
|
109
|
+
},
|
|
110
|
+
onCancel: state => {
|
|
111
|
+
onCancel?.({...state, boundary});
|
|
112
|
+
transform.clear();
|
|
113
|
+
clearSwipe();
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
{threshold}
|
|
117
|
+
);
|
|
118
|
+
|
|
119
|
+
return handlers;
|
|
120
|
+
};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
|
|
3
|
+
// need to cache scrollable results
|
|
4
|
+
|
|
5
|
+
// only change when window resize, data change, and css change
|
|
6
|
+
|
|
7
|
+
export const useElementScrollState = (ref: React.RefObject<HTMLElement | null>) => {
|
|
8
|
+
const isScrollable = React.useCallback(
|
|
9
|
+
(direction: "vertical" | "horizontal") => {
|
|
10
|
+
if (ref.current) {
|
|
11
|
+
const element = ref.current;
|
|
12
|
+
return direction === "vertical" ? element.scrollHeight > element.clientHeight : element.scrollWidth > element.clientWidth;
|
|
13
|
+
} else {
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
},
|
|
17
|
+
[ref]
|
|
18
|
+
);
|
|
19
|
+
|
|
20
|
+
const isScrollTop = React.useCallback(() => ref.current?.scrollTop === 0, [ref]);
|
|
21
|
+
const isScrollBottom = React.useCallback(() => {
|
|
22
|
+
const element = ref.current;
|
|
23
|
+
if (element) {
|
|
24
|
+
const {scrollHeight, scrollTop, clientHeight} = element;
|
|
25
|
+
return Math.ceil(scrollTop) + clientHeight >= scrollHeight;
|
|
26
|
+
} else {
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
}, [ref]);
|
|
30
|
+
|
|
31
|
+
const isScrollLeft = React.useCallback(() => ref.current?.scrollLeft === 0, [ref]);
|
|
32
|
+
const isScrollRight = React.useCallback(() => {
|
|
33
|
+
const element = ref.current;
|
|
34
|
+
if (element) {
|
|
35
|
+
const {scrollWidth, scrollLeft, clientWidth} = element;
|
|
36
|
+
return Math.ceil(scrollLeft) + clientWidth >= scrollWidth;
|
|
37
|
+
} else {
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
}, [ref]);
|
|
41
|
+
|
|
42
|
+
return {isScrollTop, isScrollBottom, isScrollLeft, isScrollRight, isScrollable};
|
|
43
|
+
};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* This hook prevent loading state causing ui to flash
|
|
5
|
+
* For instance, in real life loading only last for 50ms, so it make loading ui appear in a blink of an eye, which is not good
|
|
6
|
+
* Hook will only delay the loading state change from true to false, it force loading ui at least appear for a period of time
|
|
7
|
+
* @param loading
|
|
8
|
+
* @param delay
|
|
9
|
+
* @returns
|
|
10
|
+
*/
|
|
11
|
+
export const useLoadingWithDelay = (loading: boolean, delay: number): Readonly<boolean> => {
|
|
12
|
+
const [loadingWithDelay, setLoadingWithDelay] = React.useState(loading);
|
|
13
|
+
const startTimeRef = React.useRef<number | null>(null);
|
|
14
|
+
const setLoadingRef = React.useRef<(value: boolean) => void>();
|
|
15
|
+
|
|
16
|
+
const setLoading = React.useCallback(
|
|
17
|
+
(value: boolean) => {
|
|
18
|
+
if (value) {
|
|
19
|
+
setLoadingWithDelay(true);
|
|
20
|
+
startTimeRef.current = Date.now();
|
|
21
|
+
setTimeout(() => (startTimeRef.current = null), delay);
|
|
22
|
+
} else {
|
|
23
|
+
if (startTimeRef.current) {
|
|
24
|
+
setTimeout(() => setLoadingWithDelay(false), Math.abs(delay - (Date.now() - startTimeRef.current)));
|
|
25
|
+
} else {
|
|
26
|
+
setLoadingWithDelay(value);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
[delay]
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
setLoadingRef.current = setLoading;
|
|
34
|
+
|
|
35
|
+
React.useEffect(() => {
|
|
36
|
+
setLoadingRef.current?.(loading);
|
|
37
|
+
}, [loading]);
|
|
38
|
+
|
|
39
|
+
return loadingWithDelay;
|
|
40
|
+
};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export const PULL_DOWN_REFRESH_THRESHOLD = 50;
|
|
2
|
+
|
|
3
|
+
export type LoadingType = "refresh" | "loading" | null;
|
|
4
|
+
|
|
5
|
+
export interface FlatListItemProps<T> {
|
|
6
|
+
data: T;
|
|
7
|
+
index: number;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export type ItemRenderer<T> = React.FunctionComponent<FlatListItemProps<T>>;
|
|
11
|
+
|
|
12
|
+
export interface FlatListProps<T> {
|
|
13
|
+
data: T[];
|
|
14
|
+
renderItem: ItemRenderer<T>;
|
|
15
|
+
loading?: boolean;
|
|
16
|
+
className?: string;
|
|
17
|
+
style?: React.CSSProperties;
|
|
18
|
+
/** When either onPullUpLoading or onPullDownRefresh is given, loading must be given too */
|
|
19
|
+
onPullUpLoading?: () => void;
|
|
20
|
+
onPullDownRefresh?: () => void;
|
|
21
|
+
emptyPlaceholder?: string | React.ReactElement;
|
|
22
|
+
contentStyle?: React.CSSProperties;
|
|
23
|
+
bounceEffect?: boolean;
|
|
24
|
+
hideFooter?: boolean;
|
|
25
|
+
pullUpLoadingMessage?: string;
|
|
26
|
+
endOfListMessage?: string;
|
|
27
|
+
pullDownRefreshMessage?: string;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export interface FlatListItemProps<T> {
|
|
31
|
+
data: T;
|
|
32
|
+
index: number;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
export interface FooterData {
|
|
36
|
+
loading: boolean;
|
|
37
|
+
ended: boolean;
|
|
38
|
+
loadingMessage?: string;
|
|
39
|
+
endMessage?: string;
|
|
40
|
+
}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
@import "../../css/variable.less";
|
|
2
|
+
|
|
3
|
+
.g-foldable-container {
|
|
4
|
+
font-size: 16px;
|
|
5
|
+
display: flex;
|
|
6
|
+
flex-flow: column;
|
|
7
|
+
min-height: 24px;
|
|
8
|
+
width: 100%;
|
|
9
|
+
|
|
10
|
+
> .header {
|
|
11
|
+
display: flex;
|
|
12
|
+
align-items: center;
|
|
13
|
+
width: 100%;
|
|
14
|
+
background: @lib-background-gray;
|
|
15
|
+
padding: 6px 10px;
|
|
16
|
+
|
|
17
|
+
> .right {
|
|
18
|
+
position: relative;
|
|
19
|
+
display: flex;
|
|
20
|
+
margin-left: auto;
|
|
21
|
+
align-items: center;
|
|
22
|
+
|
|
23
|
+
> .custom + a {
|
|
24
|
+
z-index: 1;
|
|
25
|
+
background: @lib-main-blue;
|
|
26
|
+
border-radius: 50%;
|
|
27
|
+
width: 20px;
|
|
28
|
+
height: 20px;
|
|
29
|
+
padding: 0;
|
|
30
|
+
margin-left: 10px;
|
|
31
|
+
|
|
32
|
+
// Arrow
|
|
33
|
+
&::before {
|
|
34
|
+
content: "";
|
|
35
|
+
position: absolute;
|
|
36
|
+
top: 50%;
|
|
37
|
+
border: solid rgba(0 0 0 / 65%);
|
|
38
|
+
border-width: 1px 0 0 1px;
|
|
39
|
+
transform: translateY(2px) translateY(-50%) rotate(45deg);
|
|
40
|
+
transition: transform 0.3s;
|
|
41
|
+
border-color: white;
|
|
42
|
+
right: 6px;
|
|
43
|
+
height: 8px;
|
|
44
|
+
width: 8px;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
&:hover {
|
|
48
|
+
opacity: 0.8;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
&:active {
|
|
52
|
+
opacity: 0.9;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
&.folded::before {
|
|
56
|
+
transform: translateY(-2px) translateY(-50%) rotate(45deg) rotate(180deg);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
> .content {
|
|
63
|
+
width: 100%;
|
|
64
|
+
max-height: 1000vh;
|
|
65
|
+
transition: max-height 0.3s cubic-bezier(1, 0, 1, 0);
|
|
66
|
+
overflow: hidden;
|
|
67
|
+
|
|
68
|
+
&.expanded {
|
|
69
|
+
border: 1px solid @lib-background-gray;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
&.folded {
|
|
73
|
+
max-height: 0;
|
|
74
|
+
transition: max-height 0.3s cubic-bezier(0, 1, 0, 1);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {classNames} from "../../util/ClassNames";
|
|
3
|
+
import type {SafeReactChild, SafeReactChildren} from "../../internal/type";
|
|
4
|
+
import "./index.less";
|
|
5
|
+
|
|
6
|
+
export interface Props {
|
|
7
|
+
title: SafeReactChild;
|
|
8
|
+
children: SafeReactChildren;
|
|
9
|
+
expanded: boolean;
|
|
10
|
+
onExpansionChange: (expanded: boolean) => void;
|
|
11
|
+
titleRight?: SafeReactChild;
|
|
12
|
+
className?: string;
|
|
13
|
+
style?: React.CSSProperties;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export class Foldable extends React.PureComponent<Props> {
|
|
17
|
+
static displayName = "Foldable";
|
|
18
|
+
|
|
19
|
+
expand = () => this.props.onExpansionChange(true);
|
|
20
|
+
|
|
21
|
+
fold = () => this.props.onExpansionChange(false);
|
|
22
|
+
|
|
23
|
+
render() {
|
|
24
|
+
const {title, children, titleRight, className, style, expanded} = this.props;
|
|
25
|
+
return (
|
|
26
|
+
<div className={classNames("g-foldable-container", className)} style={style}>
|
|
27
|
+
<div className={classNames("header", expanded ? "expanded" : "folded")}>
|
|
28
|
+
{title}
|
|
29
|
+
<div className="right">
|
|
30
|
+
<div className="custom">{titleRight}</div>
|
|
31
|
+
{expanded ? <a className="expanded" onClick={this.fold} /> : <a className="folded" onClick={this.expand} />}
|
|
32
|
+
</div>
|
|
33
|
+
</div>
|
|
34
|
+
<div className={classNames("content", expanded ? "expanded" : "folded")}>{children}</div>
|
|
35
|
+
</div>
|
|
36
|
+
);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {classNames} from "../../util/ClassNames";
|
|
3
|
+
import {Tooltip} from "../Tooltip";
|
|
4
|
+
import {FormValidationContext} from "./context";
|
|
5
|
+
import type {SafeReactChild} from "../../internal/type";
|
|
6
|
+
|
|
7
|
+
export type FormValidator = () => string | null | Promise<string | null>;
|
|
8
|
+
|
|
9
|
+
export interface Props {
|
|
10
|
+
children: SafeReactChild;
|
|
11
|
+
label?: SafeReactChild;
|
|
12
|
+
required?: boolean;
|
|
13
|
+
extra?: SafeReactChild;
|
|
14
|
+
validator?: FormValidator;
|
|
15
|
+
className?: string;
|
|
16
|
+
labelStyle?: React.CSSProperties;
|
|
17
|
+
widthMode?: "fill" | "auto" | "shrink"; // No affect for <Form layout="inline">
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
interface State {
|
|
21
|
+
errorMessage: string | null;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export class Item extends React.PureComponent<Props, State> {
|
|
25
|
+
static displayName = "Form.Item";
|
|
26
|
+
static contextType = FormValidationContext;
|
|
27
|
+
declare context: React.ContextType<typeof FormValidationContext>;
|
|
28
|
+
|
|
29
|
+
private readonly overlayStyle: React.CSSProperties = {color: "red"};
|
|
30
|
+
|
|
31
|
+
constructor(props: Props) {
|
|
32
|
+
super(props);
|
|
33
|
+
this.state = {errorMessage: null};
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
componentDidMount() {
|
|
37
|
+
this.context.registerValidator(this.validate);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
componentWillUnmount() {
|
|
41
|
+
this.context.unregisterValidator(this.validate);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
validate = async (): Promise<boolean> => {
|
|
45
|
+
const {validator} = this.props;
|
|
46
|
+
if (validator) {
|
|
47
|
+
const errorMessage = await validator();
|
|
48
|
+
this.setState({errorMessage});
|
|
49
|
+
return errorMessage === null;
|
|
50
|
+
} else {
|
|
51
|
+
return true;
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
render() {
|
|
56
|
+
const {label, children, className, required, extra, labelStyle, widthMode} = this.props;
|
|
57
|
+
const {errorMessage} = this.state;
|
|
58
|
+
const errorDisplayMode = this.context.errorDisplayMode();
|
|
59
|
+
|
|
60
|
+
const childrenNode = typeof children === "number" || typeof children === "string" ? <span className="pure-text">{children}</span> : children;
|
|
61
|
+
const extraMessageNode = extra && <div className="message">{extra}</div>;
|
|
62
|
+
|
|
63
|
+
return (
|
|
64
|
+
<div className={classNames("g-form-item", className)}>
|
|
65
|
+
<div className={classNames("g-form-item-label", {required})} style={labelStyle}>
|
|
66
|
+
{label && <label>{label}</label>}
|
|
67
|
+
</div>
|
|
68
|
+
<div className={classNames("g-form-item-children", {"has-error": errorMessage}, widthMode ? `width-${widthMode}` : "")}>
|
|
69
|
+
{errorDisplayMode.type === "extra" ? (
|
|
70
|
+
<React.Fragment>
|
|
71
|
+
{childrenNode}
|
|
72
|
+
{extraMessageNode}
|
|
73
|
+
{errorMessage && <div className="message error">{errorMessage}</div>}
|
|
74
|
+
</React.Fragment>
|
|
75
|
+
) : (
|
|
76
|
+
<React.Fragment>
|
|
77
|
+
<Tooltip title={errorMessage} visible={errorMessage !== null} placement={errorDisplayMode.placement || "right"} color="white" overlayInnerStyle={this.overlayStyle}>
|
|
78
|
+
{childrenNode}
|
|
79
|
+
</Tooltip>
|
|
80
|
+
{extraMessageNode}
|
|
81
|
+
</React.Fragment>
|
|
82
|
+
)}
|
|
83
|
+
</div>
|
|
84
|
+
</div>
|
|
85
|
+
);
|
|
86
|
+
}
|
|
87
|
+
}
|