@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,14 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import AntdDrawer from "antd/lib/drawer";
|
|
3
|
+
import type {DrawerProps, PushState} from "antd/lib/drawer";
|
|
4
|
+
import "antd/lib/drawer/style";
|
|
5
|
+
|
|
6
|
+
export interface Props extends DrawerProps {}
|
|
7
|
+
|
|
8
|
+
export class Drawer extends React.PureComponent<Props> {
|
|
9
|
+
render() {
|
|
10
|
+
return <AntdDrawer {...this.props} />;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export type {PushState};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {EnumCheckboxGroup} from "./index";
|
|
3
|
+
import type {ControlledFormValue} from "../../internal/type";
|
|
4
|
+
|
|
5
|
+
export interface Props<Enum extends string> extends ControlledFormValue<Enum[]> {
|
|
6
|
+
map: Record<Enum, React.ReactChild>;
|
|
7
|
+
disabledItems?: Enum[] | "all";
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export class Map<Enum extends string> extends React.PureComponent<Props<Enum>> {
|
|
11
|
+
static displayName = "EnumCheckboxGroup.Map";
|
|
12
|
+
|
|
13
|
+
render() {
|
|
14
|
+
const {map, ...restProps} = this.props;
|
|
15
|
+
|
|
16
|
+
const list: Enum[] = Object.keys(map) as Enum[];
|
|
17
|
+
const translator = (_: Enum) => map[_];
|
|
18
|
+
|
|
19
|
+
return <EnumCheckboxGroup list={list} translator={translator} {...restProps} />;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {Checkbox} from "../Checkbox";
|
|
3
|
+
import type {ControlledFormValue} from "../../internal/type";
|
|
4
|
+
|
|
5
|
+
interface Props<Enum extends string | boolean | number> extends ControlledFormValue<Enum[]> {
|
|
6
|
+
list: readonly Enum[];
|
|
7
|
+
translator?: (enumValue: Enum) => React.ReactChild;
|
|
8
|
+
disabledItems?: Enum[] | "all";
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export class EnumCheckboxGroup<Enum extends string | boolean | number> extends React.PureComponent<Props<Enum>> {
|
|
12
|
+
static displayName = "EnumCheckboxGroup";
|
|
13
|
+
|
|
14
|
+
render() {
|
|
15
|
+
const {list, translator, disabledItems, value, onChange} = this.props;
|
|
16
|
+
const options = list.map(_ => ({
|
|
17
|
+
label: translator ? translator(_) : _.toString(),
|
|
18
|
+
value: _,
|
|
19
|
+
disabled: disabledItems ? disabledItems === "all" || disabledItems.includes(_) : false,
|
|
20
|
+
}));
|
|
21
|
+
return <Checkbox.Group options={options} value={value} onChange={onChange as any} />;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {BaseProps} from "./index";
|
|
3
|
+
import {EnumRadio} from "./index";
|
|
4
|
+
|
|
5
|
+
type NullType = "@@NULL";
|
|
6
|
+
|
|
7
|
+
export interface Props<Enum extends string | boolean | number> extends BaseProps<Enum> {
|
|
8
|
+
value: Enum | null;
|
|
9
|
+
onChange: (newValue: Enum) => void;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export class InitialNullable<Enum extends string | boolean | number> extends React.PureComponent<Props<Enum>> {
|
|
13
|
+
static displayName = "EnumRadio.InitialNullable";
|
|
14
|
+
|
|
15
|
+
private readonly nullValue: NullType = "@@NULL";
|
|
16
|
+
|
|
17
|
+
render() {
|
|
18
|
+
const {value, ...restProps} = this.props;
|
|
19
|
+
|
|
20
|
+
const wrappedValue = (value === null ? this.nullValue : value) as Enum; // nullValue does not exist in list, so no Radio will be selected
|
|
21
|
+
|
|
22
|
+
return <EnumRadio value={wrappedValue} {...restProps} />;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {BaseProps} from "./index";
|
|
3
|
+
import {EnumRadio} from "./index";
|
|
4
|
+
import type {ControlledFormValue} from "../../internal/type";
|
|
5
|
+
|
|
6
|
+
export interface Props<Enum extends string> extends Omit<BaseProps<any>, "list" | "translator">, ControlledFormValue<Enum> {
|
|
7
|
+
map: Record<Enum, React.ReactChild>;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export class Map<Enum extends string> extends React.PureComponent<Props<Enum>> {
|
|
11
|
+
static displayName = "EnumRadio.Map";
|
|
12
|
+
|
|
13
|
+
render() {
|
|
14
|
+
const {map, ...restProps} = this.props;
|
|
15
|
+
|
|
16
|
+
const list: Enum[] = Object.keys(map) as Enum[];
|
|
17
|
+
const translator = (_: Enum) => map[_];
|
|
18
|
+
|
|
19
|
+
return <EnumRadio list={list} translator={translator} {...restProps} />;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {BaseProps} from "./index";
|
|
3
|
+
import {EnumRadio} from "./index";
|
|
4
|
+
import type {ControlledFormValue} from "../../internal/type";
|
|
5
|
+
import {i18n} from "../../internal/i18n/core";
|
|
6
|
+
|
|
7
|
+
type NullType = "@@NULL";
|
|
8
|
+
|
|
9
|
+
export interface Props<Enum extends string | boolean | number> extends BaseProps<Enum>, ControlledFormValue<Enum | null> {
|
|
10
|
+
nullText?: React.ReactChild;
|
|
11
|
+
nullPositionIndex?: number;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export class Nullable<Enum extends string | boolean | number> extends React.PureComponent<Props<Enum>> {
|
|
15
|
+
static displayName = "EnumRadio.Nullable";
|
|
16
|
+
|
|
17
|
+
private readonly nullValue: NullType = "@@NULL";
|
|
18
|
+
|
|
19
|
+
render() {
|
|
20
|
+
const {value, onChange, nullText, nullPositionIndex, list, translator, ...restProps} = this.props;
|
|
21
|
+
const t = i18n();
|
|
22
|
+
|
|
23
|
+
const wrappedValue = value === null ? this.nullValue : value;
|
|
24
|
+
const wrappedOnChange = (value: Enum | NullType) => onChange(value === this.nullValue ? null : value);
|
|
25
|
+
const wrappedList: Array<Enum | NullType> = [...list];
|
|
26
|
+
wrappedList.splice(nullPositionIndex || 0, 0, this.nullValue);
|
|
27
|
+
const wrappedTranslator = (value: Enum | NullType) => (value === this.nullValue ? nullText ?? t.all : translator ? translator(value) : value.toString());
|
|
28
|
+
|
|
29
|
+
return <EnumRadio value={wrappedValue} onChange={wrappedOnChange} list={wrappedList} translator={wrappedTranslator} {...restProps} />;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {RadioChangeEvent} from "../Radio";
|
|
3
|
+
import {Radio} from "../Radio";
|
|
4
|
+
import type {ControlledFormValue} from "../../internal/type";
|
|
5
|
+
import {Nullable} from "./Nullable";
|
|
6
|
+
import {InitialNullable} from "./InitialNullable";
|
|
7
|
+
import {Map} from "./Map";
|
|
8
|
+
|
|
9
|
+
export interface BaseProps<Enum extends string | boolean | number> {
|
|
10
|
+
list: readonly Enum[];
|
|
11
|
+
translator?: (enumValue: Enum) => React.ReactChild;
|
|
12
|
+
useButtonMode?: boolean;
|
|
13
|
+
disabled?: boolean;
|
|
14
|
+
className?: string;
|
|
15
|
+
style?: React.CSSProperties;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export interface Props<Enum extends string | boolean | number> extends BaseProps<Enum>, ControlledFormValue<Enum> {}
|
|
19
|
+
|
|
20
|
+
export class EnumRadio<Enum extends string | boolean | number> extends React.PureComponent<Props<Enum>> {
|
|
21
|
+
static displayName = "EnumRadio";
|
|
22
|
+
static Nullable = Nullable;
|
|
23
|
+
static InitialNullable = InitialNullable;
|
|
24
|
+
static Map = Map;
|
|
25
|
+
|
|
26
|
+
onChange = (event: RadioChangeEvent) => {
|
|
27
|
+
const enumValue: Enum = event.target.value;
|
|
28
|
+
this.props.onChange(enumValue);
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
render() {
|
|
32
|
+
const {list, translator, value, useButtonMode, disabled, className, style} = this.props;
|
|
33
|
+
const RadioItem = useButtonMode ? Radio.Button : Radio;
|
|
34
|
+
return (
|
|
35
|
+
<Radio.Group value={value} onChange={this.onChange} disabled={disabled} className={className} style={style} optionType={useButtonMode ? "button" : undefined}>
|
|
36
|
+
{list.map(_ => (
|
|
37
|
+
// RadioItem can accept any type as value, and emit the exact type while onChange
|
|
38
|
+
<RadioItem key={_.toString()} value={_}>
|
|
39
|
+
{translator ? translator(_) : _.toString()}
|
|
40
|
+
</RadioItem>
|
|
41
|
+
))}
|
|
42
|
+
</Radio.Group>
|
|
43
|
+
);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {BaseProps} from "./index";
|
|
3
|
+
import {EnumSelect} from "./index";
|
|
4
|
+
|
|
5
|
+
export interface Props<Enum extends string | boolean | number> extends BaseProps<Enum> {
|
|
6
|
+
value: Enum | null;
|
|
7
|
+
onChange: (newValue: Enum) => void;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export class InitialNullable<Enum extends string | boolean | number> extends React.PureComponent<Props<Enum>> {
|
|
11
|
+
static displayName = "EnumSelect.InitialNullable";
|
|
12
|
+
|
|
13
|
+
render() {
|
|
14
|
+
const {value, ...restProps} = this.props;
|
|
15
|
+
|
|
16
|
+
const wrappedValue = value as Enum;
|
|
17
|
+
|
|
18
|
+
return <EnumSelect value={wrappedValue} {...restProps} />;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {BaseProps} from "./index";
|
|
3
|
+
import {EnumSelect} from "./index";
|
|
4
|
+
import type {ControlledFormValue} from "../../internal/type";
|
|
5
|
+
|
|
6
|
+
export interface Props<T extends string> extends Omit<BaseProps<any>, "list" | "translator">, ControlledFormValue<T> {
|
|
7
|
+
map: Record<T, React.ReactChild>;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export class Map<T extends string> extends React.PureComponent<Props<T>> {
|
|
11
|
+
static displayName = "EnumSelect.Map";
|
|
12
|
+
|
|
13
|
+
render() {
|
|
14
|
+
const {map, ...restProps} = this.props;
|
|
15
|
+
|
|
16
|
+
const list: T[] = Object.keys(map) as T[];
|
|
17
|
+
const translator = (_: T) => map[_];
|
|
18
|
+
|
|
19
|
+
return <EnumSelect list={list} translator={translator} {...restProps} />;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {BaseProps} from "./index";
|
|
3
|
+
import {EnumSelect} from "./index";
|
|
4
|
+
import type {ControlledFormValue} from "../../internal/type";
|
|
5
|
+
import {i18n} from "../../internal/i18n/core";
|
|
6
|
+
|
|
7
|
+
type NullType = "@@NULL";
|
|
8
|
+
|
|
9
|
+
export interface Props<Enum extends string | boolean | number> extends BaseProps<Enum>, ControlledFormValue<Enum | null> {
|
|
10
|
+
nullText?: React.ReactChild;
|
|
11
|
+
nullPositionIndex?: number;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export class Nullable<Enum extends string | boolean | number> extends React.PureComponent<Props<Enum>> {
|
|
15
|
+
static displayName = "EnumSelect.Nullable";
|
|
16
|
+
|
|
17
|
+
private readonly nullValue: NullType = "@@NULL";
|
|
18
|
+
|
|
19
|
+
render() {
|
|
20
|
+
const {value, onChange, nullText, nullPositionIndex, list, translator, ...restProps} = this.props;
|
|
21
|
+
const t = i18n();
|
|
22
|
+
|
|
23
|
+
const wrappedValue = value === null ? this.nullValue : value;
|
|
24
|
+
const wrappedOnChange = (value: Enum | NullType) => onChange(value === this.nullValue ? null : value);
|
|
25
|
+
const wrappedList: Array<Enum | NullType> = [...list];
|
|
26
|
+
wrappedList.splice(nullPositionIndex || 0, 0, this.nullValue);
|
|
27
|
+
const wrappedTranslator = (value: Enum | NullType) => (value === this.nullValue ? nullText ?? t.all : translator ? translator(value) : value.toString());
|
|
28
|
+
|
|
29
|
+
return <EnumSelect value={wrappedValue} onChange={wrappedOnChange} list={wrappedList} translator={wrappedTranslator} {...restProps} />;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type {LabeledValue} from "antd/lib/select";
|
|
3
|
+
import type {ControlledFormValue} from "../../internal/type";
|
|
4
|
+
import {Select} from "../Select";
|
|
5
|
+
import {Nullable} from "./Nullable";
|
|
6
|
+
import {InitialNullable} from "./InitialNullable";
|
|
7
|
+
import {Map} from "./Map";
|
|
8
|
+
import "./index.less";
|
|
9
|
+
|
|
10
|
+
export interface BaseProps<Enum extends string | boolean | number> {
|
|
11
|
+
list: readonly Enum[];
|
|
12
|
+
translator?: (enumValue: Enum) => React.ReactChild;
|
|
13
|
+
disabled?: boolean;
|
|
14
|
+
className?: string;
|
|
15
|
+
style?: React.CSSProperties;
|
|
16
|
+
placeholder?: string;
|
|
17
|
+
suffixIcon?: React.ReactNode;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface Props<Enum extends string | boolean | number> extends BaseProps<Enum>, ControlledFormValue<Enum> {}
|
|
21
|
+
|
|
22
|
+
export class EnumSelect<Enum extends string | boolean | number> extends React.PureComponent<Props<Enum>> {
|
|
23
|
+
private readonly trueValue = "@@TRUE";
|
|
24
|
+
private readonly falseValue = "@@FALSE";
|
|
25
|
+
|
|
26
|
+
static displayName = "EnumSelect";
|
|
27
|
+
|
|
28
|
+
static Nullable = Nullable;
|
|
29
|
+
static InitialNullable = InitialNullable;
|
|
30
|
+
static Map = Map;
|
|
31
|
+
|
|
32
|
+
getAntSelectValue = (): LabeledValue | undefined => {
|
|
33
|
+
const value = this.props.value as Enum;
|
|
34
|
+
if (value === null) {
|
|
35
|
+
// Special case for InitialNullable, to show placeholder, no pre-selection
|
|
36
|
+
return undefined;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
const {translator} = this.props;
|
|
40
|
+
const antValue = value.toString();
|
|
41
|
+
const antLabel = translator ? translator(value) : antValue;
|
|
42
|
+
return {
|
|
43
|
+
value: antValue,
|
|
44
|
+
label: antLabel,
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
onChange = ({value: antValue}: LabeledValue) => {
|
|
49
|
+
const enumValue = antValue === this.trueValue ? true : antValue === this.falseValue ? false : antValue;
|
|
50
|
+
this.props.onChange(enumValue as Enum);
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
render() {
|
|
54
|
+
const {list, translator, disabled, className = "", style, placeholder, suffixIcon} = this.props;
|
|
55
|
+
return (
|
|
56
|
+
<Select<LabeledValue>
|
|
57
|
+
disabled={disabled}
|
|
58
|
+
labelInValue
|
|
59
|
+
value={this.getAntSelectValue()}
|
|
60
|
+
onChange={this.onChange}
|
|
61
|
+
className={`g-enum-select ${className}`}
|
|
62
|
+
style={style}
|
|
63
|
+
placeholder={placeholder}
|
|
64
|
+
suffixIcon={suffixIcon}
|
|
65
|
+
>
|
|
66
|
+
{list.map(_ => (
|
|
67
|
+
<Select.Option key={_.toString()} value={_ === true ? this.trueValue : _ === false ? this.falseValue : _}>
|
|
68
|
+
{translator ? translator(_) : _.toString()}
|
|
69
|
+
</Select.Option>
|
|
70
|
+
))}
|
|
71
|
+
</Select>
|
|
72
|
+
);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {Footer} from "../shared/Footer";
|
|
3
|
+
import type {FooterData} from "../type";
|
|
4
|
+
import type {ItemRenderer, Measure} from "./type";
|
|
5
|
+
|
|
6
|
+
export interface Gap {
|
|
7
|
+
top?: number;
|
|
8
|
+
bottom?: number;
|
|
9
|
+
left?: number;
|
|
10
|
+
right?: number;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export interface ListItemProps<T> {
|
|
14
|
+
measure: Measure;
|
|
15
|
+
data: (T | FooterData)[];
|
|
16
|
+
index: number;
|
|
17
|
+
itemRenderer: ItemRenderer<T>;
|
|
18
|
+
gap?: Gap;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export const Item = function <T>(props: ListItemProps<T>) {
|
|
22
|
+
const {data, index, itemRenderer: ItemRenderer, gap, measure} = props;
|
|
23
|
+
|
|
24
|
+
const padding = React.useMemo((): React.CSSProperties => (gap ? {paddingLeft: gap.left, paddingRight: gap.right, paddingBottom: gap.bottom, paddingTop: gap.top} : {}), [gap]);
|
|
25
|
+
|
|
26
|
+
if (index === data.length - 1) {
|
|
27
|
+
const {loading, loadingMessage, endMessage, ended} = data[index] as FooterData;
|
|
28
|
+
return <Footer loading={loading} ended={ended} loadingMessage={loadingMessage} endMessage={endMessage} measure={measure} />;
|
|
29
|
+
} else {
|
|
30
|
+
return (
|
|
31
|
+
<div className="g-virtual-flat-list-item" style={{...padding}}>
|
|
32
|
+
<ItemRenderer data={data[index] as T} index={index} measure={measure} />
|
|
33
|
+
</div>
|
|
34
|
+
);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
.g-virtual-flat-list {
|
|
2
|
+
.list-wrapper {
|
|
3
|
+
width: 100%;
|
|
4
|
+
height: 100%;
|
|
5
|
+
|
|
6
|
+
.list {
|
|
7
|
+
width: 100%;
|
|
8
|
+
position: relative;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.g-virtual-flat-list-item-wrapper {
|
|
13
|
+
width: 100%;
|
|
14
|
+
position: absolute;
|
|
15
|
+
top: 0;
|
|
16
|
+
left: 0;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.g-virtual-flat-list-item {
|
|
20
|
+
width: 100%;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {defaultRangeExtractor, useVirtual} from "react-virtual";
|
|
3
|
+
import {Wrapper} from "../shared/Wrapper";
|
|
4
|
+
import {Item} from "./Item";
|
|
5
|
+
import "./index.less";
|
|
6
|
+
import type {VirtualFlatListProps} from "./type";
|
|
7
|
+
import type {Range} from "react-virtual";
|
|
8
|
+
import type {FooterData, LoadingType} from "../type";
|
|
9
|
+
import {useLoadingWithDelay} from "../shared/hooks/useLoadingWithDelay";
|
|
10
|
+
import {classNames} from "../../../util/ClassNames";
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* VirtualizedFlatList currently only work with item without and size related animation and transition since it break the layout. This will be improve in the future
|
|
14
|
+
*/
|
|
15
|
+
export const VirtualFlatList = function <T>(props: VirtualFlatListProps<T>) {
|
|
16
|
+
const {
|
|
17
|
+
data,
|
|
18
|
+
renderItem,
|
|
19
|
+
loading,
|
|
20
|
+
bounceEffect = true,
|
|
21
|
+
className,
|
|
22
|
+
style,
|
|
23
|
+
onPullDownRefresh,
|
|
24
|
+
onPullUpLoading,
|
|
25
|
+
emptyPlaceholder,
|
|
26
|
+
contentStyle,
|
|
27
|
+
gap,
|
|
28
|
+
autoLoad = true,
|
|
29
|
+
overscan = 3,
|
|
30
|
+
hideFooter,
|
|
31
|
+
estimateSize,
|
|
32
|
+
listRef,
|
|
33
|
+
pullUpLoadingMessage,
|
|
34
|
+
endOfListMessage,
|
|
35
|
+
pullDownRefreshMessage,
|
|
36
|
+
} = props;
|
|
37
|
+
|
|
38
|
+
const listWrapperRef = React.useRef<HTMLDivElement>(null);
|
|
39
|
+
const [loadingType, setLoadingType] = React.useState<LoadingType>(null);
|
|
40
|
+
const currentRangeRef = React.useRef<Range>();
|
|
41
|
+
const previousRangeRef = React.useRef<Range>();
|
|
42
|
+
|
|
43
|
+
const loadingWithDelay = useLoadingWithDelay(loading ?? false, 300);
|
|
44
|
+
|
|
45
|
+
const listData: Array<T | FooterData> = React.useMemo(() => {
|
|
46
|
+
return hideFooter ? data : [...data, {loading: loadingWithDelay && loadingType === "loading", ended: !onPullUpLoading, endMessage: endOfListMessage, loadingMessage: pullUpLoadingMessage}];
|
|
47
|
+
}, [loadingWithDelay, loadingType, endOfListMessage, onPullUpLoading, pullUpLoadingMessage, data, hideFooter]);
|
|
48
|
+
|
|
49
|
+
const rangeExtractor = React.useCallback((range: Range) => {
|
|
50
|
+
previousRangeRef.current = currentRangeRef.current ?? range;
|
|
51
|
+
currentRangeRef.current = range;
|
|
52
|
+
return defaultRangeExtractor(range);
|
|
53
|
+
}, []);
|
|
54
|
+
|
|
55
|
+
const rowVirtualizer = useVirtual({
|
|
56
|
+
size: listData.length,
|
|
57
|
+
parentRef: listWrapperRef,
|
|
58
|
+
overscan,
|
|
59
|
+
estimateSize,
|
|
60
|
+
rangeExtractor,
|
|
61
|
+
});
|
|
62
|
+
const rowVirtualizerRef = React.useRef(rowVirtualizer);
|
|
63
|
+
rowVirtualizerRef.current = rowVirtualizer;
|
|
64
|
+
|
|
65
|
+
React.useImperativeHandle(listRef, () => ({
|
|
66
|
+
measure: rowVirtualizer.measure,
|
|
67
|
+
}));
|
|
68
|
+
|
|
69
|
+
React.useEffect(() => {
|
|
70
|
+
if ((loading === undefined || loading === null) && (onPullDownRefresh || onPullUpLoading)) {
|
|
71
|
+
throw new Error("Loading must be specify when given either onPullDownRefresh or onPullUpLoading");
|
|
72
|
+
}
|
|
73
|
+
}, [onPullDownRefresh, onPullUpLoading, loading]);
|
|
74
|
+
|
|
75
|
+
// the reason why onScroll event is used to simulate auto loading instead of rangeExtractor is rangeExtractor return a wrong range when on mount
|
|
76
|
+
const onAutoLoad = () => {
|
|
77
|
+
const previousRange = previousRangeRef.current;
|
|
78
|
+
const currentRange = currentRangeRef.current;
|
|
79
|
+
if (
|
|
80
|
+
previousRange &&
|
|
81
|
+
currentRange &&
|
|
82
|
+
autoLoad &&
|
|
83
|
+
onPullUpLoading &&
|
|
84
|
+
!loadingWithDelay &&
|
|
85
|
+
// check going downward
|
|
86
|
+
previousRange.end < currentRange.end &&
|
|
87
|
+
currentRange.end > data.length - 2 - (typeof autoLoad === "number" ? autoLoad : 3)
|
|
88
|
+
) {
|
|
89
|
+
setLoadingType("loading");
|
|
90
|
+
onPullUpLoading();
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
// TODO/Alvis loading more when item can not fill the whole viewport
|
|
95
|
+
|
|
96
|
+
return (
|
|
97
|
+
<Wrapper
|
|
98
|
+
className={classNames("g-virtual-flat-list", className)}
|
|
99
|
+
bounceEffect={bounceEffect}
|
|
100
|
+
listWrapperRef={listWrapperRef}
|
|
101
|
+
loadingType={loadingType}
|
|
102
|
+
onLoadingTypeChange={setLoadingType}
|
|
103
|
+
loading={loadingWithDelay}
|
|
104
|
+
onPullDownRefresh={onPullDownRefresh}
|
|
105
|
+
onPullUpLoading={onPullUpLoading}
|
|
106
|
+
innerStyle={contentStyle}
|
|
107
|
+
style={style}
|
|
108
|
+
pullDownRefreshMessage={pullDownRefreshMessage}
|
|
109
|
+
onScroll={onAutoLoad}
|
|
110
|
+
>
|
|
111
|
+
{data.length === 0 ? (
|
|
112
|
+
emptyPlaceholder
|
|
113
|
+
) : (
|
|
114
|
+
<div className="list" style={{height: rowVirtualizer.totalSize}}>
|
|
115
|
+
{rowVirtualizer.virtualItems.map(virtualItem => {
|
|
116
|
+
return (
|
|
117
|
+
<div key={virtualItem.index} className="g-virtual-flat-list-item-wrapper" style={{transform: `translateY(${virtualItem.start}px)`}} ref={virtualItem.measureRef}>
|
|
118
|
+
<Item data={listData} index={virtualItem.index} itemRenderer={renderItem} measure={virtualItem.measureRef} gap={gap} />
|
|
119
|
+
</div>
|
|
120
|
+
);
|
|
121
|
+
})}
|
|
122
|
+
</div>
|
|
123
|
+
)}
|
|
124
|
+
</Wrapper>
|
|
125
|
+
);
|
|
126
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type React from "react";
|
|
2
|
+
import type {FlatListItemProps, FlatListProps} from "../type";
|
|
3
|
+
|
|
4
|
+
// FlatList related type
|
|
5
|
+
export type Measure = (node: HTMLElement | null) => void;
|
|
6
|
+
|
|
7
|
+
export interface VirtualFlatListHandle {
|
|
8
|
+
measure: () => void;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export interface VirtualFlatListProps<T> extends Omit<FlatListProps<T>, "renderItem" | "autoLoad"> {
|
|
12
|
+
renderItem: ItemRenderer<T>;
|
|
13
|
+
/** Automatic load new data when scroll to bottom, a number {X} mean: when to scroll to last {X} items, auto load is going to be triggered */
|
|
14
|
+
autoLoad?: boolean | number;
|
|
15
|
+
/** Must wrap with React.useCallback */
|
|
16
|
+
estimateSize?: (index: number) => number;
|
|
17
|
+
/** The amount of items to load both behind and ahead of the current window range, default = 3 */
|
|
18
|
+
overscan?: number;
|
|
19
|
+
gap?: {top?: number; bottom?: number; left?: number; right?: number};
|
|
20
|
+
listRef?: React.RefObject<VirtualFlatListHandle>;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export interface VirtualFlatListItemProps<T> extends FlatListItemProps<T> {
|
|
24
|
+
measure: Measure;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export type ItemRenderer<T> = React.FunctionComponent<VirtualFlatListItemProps<T>>;
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import {Wrapper} from "./shared/Wrapper";
|
|
3
|
+
import type {FlatListProps, LoadingType} from "./type";
|
|
4
|
+
import {Footer} from "./shared/Footer";
|
|
5
|
+
import {useLoadingWithDelay} from "./shared/hooks/useLoadingWithDelay";
|
|
6
|
+
import {classNames} from "../../util/ClassNames";
|
|
7
|
+
|
|
8
|
+
export const FlatList = function <T>(props: FlatListProps<T>) {
|
|
9
|
+
const {
|
|
10
|
+
data,
|
|
11
|
+
renderItem: ItemRenderer,
|
|
12
|
+
loading,
|
|
13
|
+
bounceEffect = true,
|
|
14
|
+
className,
|
|
15
|
+
style,
|
|
16
|
+
onPullDownRefresh,
|
|
17
|
+
onPullUpLoading,
|
|
18
|
+
pullDownRefreshMessage,
|
|
19
|
+
pullUpLoadingMessage,
|
|
20
|
+
contentStyle,
|
|
21
|
+
emptyPlaceholder,
|
|
22
|
+
endOfListMessage,
|
|
23
|
+
hideFooter,
|
|
24
|
+
} = props;
|
|
25
|
+
|
|
26
|
+
const listWrapperRef = React.useRef<HTMLDivElement>(null);
|
|
27
|
+
const [loadingType, setLoadingType] = React.useState<LoadingType>(null);
|
|
28
|
+
const loadingWithDelay = useLoadingWithDelay(loading ?? false, 250);
|
|
29
|
+
|
|
30
|
+
React.useEffect(() => {
|
|
31
|
+
if ((loading === undefined || loading === null) && (onPullDownRefresh || onPullUpLoading)) {
|
|
32
|
+
throw new Error("Loading must be specify when given either onPullDownRefresh or onPullUpLoading");
|
|
33
|
+
}
|
|
34
|
+
}, [onPullDownRefresh, onPullUpLoading, loading]);
|
|
35
|
+
|
|
36
|
+
// Automatically loading new data when scroll near the bottom
|
|
37
|
+
const onScroll = (e: React.UIEvent) => {
|
|
38
|
+
if (!loadingWithDelay && onPullUpLoading) {
|
|
39
|
+
const {scrollHeight, scrollTop, clientHeight} = e.currentTarget;
|
|
40
|
+
if (scrollHeight * 0.8 < clientHeight + scrollTop) {
|
|
41
|
+
setLoadingType("loading");
|
|
42
|
+
onPullUpLoading?.();
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
return (
|
|
48
|
+
<Wrapper
|
|
49
|
+
className={classNames("g-flat-list", className)}
|
|
50
|
+
listWrapperRef={listWrapperRef}
|
|
51
|
+
bounceEffect={bounceEffect}
|
|
52
|
+
innerStyle={contentStyle}
|
|
53
|
+
loadingType={loadingType}
|
|
54
|
+
onLoadingTypeChange={setLoadingType}
|
|
55
|
+
loading={loadingWithDelay}
|
|
56
|
+
style={style}
|
|
57
|
+
onPullDownRefresh={onPullDownRefresh}
|
|
58
|
+
onPullUpLoading={onPullUpLoading}
|
|
59
|
+
pullDownRefreshMessage={pullDownRefreshMessage}
|
|
60
|
+
onScroll={onScroll}
|
|
61
|
+
>
|
|
62
|
+
{data.length === 0 ? (
|
|
63
|
+
emptyPlaceholder
|
|
64
|
+
) : (
|
|
65
|
+
<div className="list">
|
|
66
|
+
{data.map((d, i) => (
|
|
67
|
+
<div className="g-flat-list-item" key={i}>
|
|
68
|
+
<ItemRenderer data={d} index={i} />
|
|
69
|
+
</div>
|
|
70
|
+
))}
|
|
71
|
+
{!hideFooter && <Footer loading={loadingWithDelay && loadingType === "loading"} ended={!onPullUpLoading} endMessage={endOfListMessage} loadingMessage={pullUpLoadingMessage} />}
|
|
72
|
+
</div>
|
|
73
|
+
)}
|
|
74
|
+
</Wrapper>
|
|
75
|
+
);
|
|
76
|
+
};
|