@pinnacle0/web-ui 0.3.35 → 0.3.36

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (878) hide show
  1. package/config/jest-stubs/style-stub.js +13 -0
  2. package/config/jest.config.ts +57 -0
  3. package/config/tsconfig.script.json +12 -0
  4. package/config/tsconfig.src.json +15 -0
  5. package/config/tsconfig.test.json +20 -0
  6. package/package.json +1 -1
  7. package/script/build.ts +103 -0
  8. package/script/format.ts +7 -0
  9. package/script/start-mobile.ts +13 -0
  10. package/script/start.ts +31 -0
  11. package/{admin → src/admin}/AdminApp/Default/NavigatorSide/index.less +0 -0
  12. package/src/admin/AdminApp/Default/NavigatorSide/index.tsx +68 -0
  13. package/src/admin/AdminApp/Default/SoundSwitch.tsx +32 -0
  14. package/{admin → src/admin}/AdminApp/Default/SquareLogo/index.less +0 -0
  15. package/src/admin/AdminApp/Default/SquareLogo/index.tsx +32 -0
  16. package/src/admin/AdminApp/Menu.tsx +154 -0
  17. package/src/admin/AdminApp/Navigator.tsx +186 -0
  18. package/src/admin/AdminApp/NotFound.tsx +24 -0
  19. package/src/admin/AdminApp/RouteSwitch.tsx +61 -0
  20. package/src/admin/AdminApp/WithErrorBoundary.tsx +36 -0
  21. package/{admin → src/admin}/AdminApp/asset/alert.mp3 +0 -0
  22. package/src/admin/AdminApp/context.ts +13 -0
  23. package/{admin → src/admin}/AdminApp/index.less +0 -0
  24. package/src/admin/AdminApp/index.tsx +96 -0
  25. package/src/admin/AdminPage/Filter.tsx +76 -0
  26. package/src/admin/AdminPage/Result.tsx +41 -0
  27. package/src/admin/AdminPage/SaveBar.tsx +33 -0
  28. package/src/admin/AdminPage/Summary.tsx +15 -0
  29. package/src/admin/AdminPage/TopBar.tsx +15 -0
  30. package/{admin → src/admin}/AdminPage/index.less +0 -0
  31. package/src/admin/AdminPage/index.tsx +29 -0
  32. package/src/admin/AdminPermissionSelector.tsx +299 -0
  33. package/{admin → src/admin}/RichEditor/index.less +0 -0
  34. package/src/admin/RichEditor/index.tsx +123 -0
  35. package/src/core/Amount/AmountPercentage.tsx +27 -0
  36. package/{core → src/core}/Amount/index.less +0 -0
  37. package/src/core/Amount/index.tsx +71 -0
  38. package/src/core/AmountConditionInput.tsx +63 -0
  39. package/src/core/AmountRangeInput.tsx +66 -0
  40. package/src/core/AuthenticationCodeInput.tsx +85 -0
  41. package/src/core/AutoCompleteInput.tsx +16 -0
  42. package/{core → src/core}/Badge/index.less +0 -0
  43. package/src/core/Badge/index.tsx +15 -0
  44. package/src/core/BoolRadio.tsx +62 -0
  45. package/src/core/BoolSelect.tsx +50 -0
  46. package/src/core/BoolSwitch.tsx +37 -0
  47. package/{core → src/core}/Breadcrumb/index.less +0 -0
  48. package/src/core/Breadcrumb/index.tsx +46 -0
  49. package/{core → src/core}/Button/index.less +0 -0
  50. package/src/core/Button/index.tsx +59 -0
  51. package/src/core/Card.tsx +16 -0
  52. package/src/core/Carousel.tsx +19 -0
  53. package/{core → src/core}/Carousel3D/index.less +0 -0
  54. package/src/core/Carousel3D/index.tsx +150 -0
  55. package/src/core/Cascader/InitialNullable.tsx +20 -0
  56. package/src/core/Cascader/Nullable.tsx +28 -0
  57. package/{core → src/core}/Cascader/index.less +0 -0
  58. package/src/core/Cascader/index.tsx +93 -0
  59. package/{core → src/core}/Checkbox/index.less +0 -0
  60. package/src/core/Checkbox/index.tsx +24 -0
  61. package/src/core/Collapse.tsx +19 -0
  62. package/src/core/Countdown/SlidingDigit.tsx +39 -0
  63. package/{core → src/core}/Countdown/index.less +0 -0
  64. package/src/core/Countdown/index.tsx +125 -0
  65. package/{core → src/core}/DarkOverlay/index.less +0 -0
  66. package/src/core/DarkOverlay/index.tsx +24 -0
  67. package/src/core/DateCalendar.tsx +106 -0
  68. package/{core → src/core}/DatePicker/index.less +0 -0
  69. package/src/core/DatePicker/index.tsx +54 -0
  70. package/{core → src/core}/DateRangePicker/index.less +0 -0
  71. package/src/core/DateRangePicker/index.tsx +58 -0
  72. package/{core → src/core}/DateTimePicker/index.less +0 -0
  73. package/src/core/DateTimePicker/index.tsx +61 -0
  74. package/{core → src/core}/DateTimeRangePicker/index.less +0 -0
  75. package/src/core/DateTimeRangePicker/index.tsx +60 -0
  76. package/{core → src/core}/Descriptions/index.less +0 -0
  77. package/src/core/Descriptions/index.tsx +45 -0
  78. package/src/core/DocumentTitle.tsx +58 -0
  79. package/src/core/Drawer.tsx +14 -0
  80. package/src/core/Dropdown.tsx +10 -0
  81. package/src/core/EnumCheckboxGroup/Map.tsx +21 -0
  82. package/src/core/EnumCheckboxGroup/index.tsx +23 -0
  83. package/src/core/EnumRadio/InitialNullable.tsx +24 -0
  84. package/src/core/EnumRadio/Map.tsx +21 -0
  85. package/src/core/EnumRadio/Nullable.tsx +31 -0
  86. package/src/core/EnumRadio/index.tsx +45 -0
  87. package/src/core/EnumSelect/InitialNullable.tsx +20 -0
  88. package/src/core/EnumSelect/Map.tsx +21 -0
  89. package/src/core/EnumSelect/Nullable.tsx +31 -0
  90. package/{core → src/core}/EnumSelect/index.less +0 -0
  91. package/src/core/EnumSelect/index.tsx +74 -0
  92. package/src/core/FlatList/VirtualFlatList/Item.tsx +28 -0
  93. package/{core → src/core}/FlatList/VirtualFlatList/index.less +0 -0
  94. package/src/core/FlatList/VirtualFlatList/index.tsx +142 -0
  95. package/src/core/FlatList/VirtualFlatList/type.ts +26 -0
  96. package/src/core/FlatList/index.tsx +95 -0
  97. package/{core → src/core}/FlatList/shared/Footer/index.less +0 -0
  98. package/src/core/FlatList/shared/Footer/index.tsx +23 -0
  99. package/src/core/FlatList/shared/GetRowKey.ts +11 -0
  100. package/{core → src/core}/FlatList/shared/Spinner/index.less +0 -0
  101. package/src/core/FlatList/shared/Spinner/index.tsx +18 -0
  102. package/src/core/FlatList/shared/Wrapper/Loading.tsx +17 -0
  103. package/{core → src/core}/FlatList/shared/Wrapper/index.less +0 -0
  104. package/src/core/FlatList/shared/Wrapper/index.tsx +123 -0
  105. package/src/core/FlatList/shared/hooks/useBounceSwipe.ts +120 -0
  106. package/src/core/FlatList/shared/hooks/useElementScrollState.ts +43 -0
  107. package/src/core/FlatList/shared/hooks/useLoadingWithDelay.ts +40 -0
  108. package/src/core/FlatList/type.tsx +56 -0
  109. package/{core → src/core}/Foldable/index.less +0 -0
  110. package/src/core/Foldable/index.tsx +38 -0
  111. package/src/core/Form/Item.tsx +87 -0
  112. package/src/core/Form/context.ts +16 -0
  113. package/{core → src/core}/Form/index.less +0 -0
  114. package/src/core/Form/index.tsx +109 -0
  115. package/src/core/Grid.tsx +7 -0
  116. package/{core → src/core}/HTMLContent/index.less +0 -0
  117. package/src/core/HTMLContent/index.tsx +17 -0
  118. package/{core → src/core}/ImageUploader/index.less +0 -0
  119. package/src/core/ImageUploader/index.tsx +104 -0
  120. package/{core → src/core}/Input/index.less +0 -0
  121. package/src/core/Input/index.tsx +63 -0
  122. package/src/core/LabelledSelect.tsx +15 -0
  123. package/src/core/Link.tsx +57 -0
  124. package/src/core/LocalImporter.tsx +62 -0
  125. package/src/core/LocaleProvider.tsx +31 -0
  126. package/src/core/LocaleSelect.tsx +36 -0
  127. package/{core → src/core}/Markdown/index.less +0 -0
  128. package/src/core/Markdown/index.tsx +42 -0
  129. package/{core → src/core}/Modal/index.less +0 -0
  130. package/src/core/Modal/index.tsx +37 -0
  131. package/{core → src/core}/MultipleCascader/index.less +0 -0
  132. package/src/core/MultipleCascader/index.tsx +114 -0
  133. package/src/core/MultipleEnumSelect.tsx +28 -0
  134. package/src/core/MultipleSelector/TablePopover.tsx +62 -0
  135. package/src/core/MultipleSelector/index.tsx +106 -0
  136. package/{core → src/core}/MutableTable/index.less +0 -0
  137. package/src/core/MutableTable/index.tsx +151 -0
  138. package/src/core/NumberInput/NumberInputPercentage.tsx +103 -0
  139. package/{core → src/core}/NumberInput/index.less +0 -0
  140. package/src/core/NumberInput/index.tsx +192 -0
  141. package/src/core/NumberInput/util.ts +55 -0
  142. package/{core → src/core}/OverflowableText/index.less +0 -0
  143. package/src/core/OverflowableText/index.tsx +66 -0
  144. package/{core → src/core}/PagedList/index.less +0 -0
  145. package/src/core/PagedList/index.tsx +93 -0
  146. package/{core → src/core}/Pagination/index.less +0 -0
  147. package/src/core/Pagination/index.tsx +59 -0
  148. package/{core → src/core}/Popover/index.less +0 -0
  149. package/src/core/Popover/index.tsx +15 -0
  150. package/src/core/Progress.tsx +14 -0
  151. package/{core → src/core}/Radio/index.less +0 -0
  152. package/src/core/Radio/index.tsx +21 -0
  153. package/src/core/RelativeTime.tsx +59 -0
  154. package/src/core/ResizeObserver.tsx +2 -0
  155. package/src/core/SearchableSelect.tsx +17 -0
  156. package/{core → src/core}/Select/index.less +0 -0
  157. package/src/core/Select/index.tsx +25 -0
  158. package/src/core/SignedAmountInput.tsx +59 -0
  159. package/src/core/Skeleton.tsx +14 -0
  160. package/src/core/Slider/RangeSlider.tsx +17 -0
  161. package/{core → src/core}/Slider/index.less +0 -0
  162. package/src/core/Slider/index.tsx +50 -0
  163. package/src/core/Space.tsx +14 -0
  164. package/src/core/Spin.tsx +25 -0
  165. package/{core → src/core}/StepFormContainer/index.less +0 -0
  166. package/src/core/StepFormContainer/index.tsx +66 -0
  167. package/{core → src/core}/Steps/index.less +0 -0
  168. package/src/core/Steps/index.tsx +17 -0
  169. package/{core → src/core}/Table/index.less +0 -0
  170. package/src/core/Table/index.tsx +221 -0
  171. package/src/core/Tabs/Single.tsx +25 -0
  172. package/{core → src/core}/Tabs/index.less +0 -0
  173. package/src/core/Tabs/index.tsx +82 -0
  174. package/src/core/Tag.tsx +17 -0
  175. package/{core → src/core}/TagInput/index.less +0 -0
  176. package/src/core/TagInput/index.tsx +94 -0
  177. package/src/core/Tags.tsx +34 -0
  178. package/{core → src/core}/TimePicker/index.less +0 -0
  179. package/src/core/TimePicker/index.tsx +44 -0
  180. package/{core → src/core}/TimeRangePicker/index.less +0 -0
  181. package/src/core/TimeRangePicker/index.tsx +42 -0
  182. package/src/core/Tooltip.tsx +17 -0
  183. package/{core → src/core}/TypedTabs/index.less +0 -0
  184. package/src/core/TypedTabs/index.tsx +43 -0
  185. package/src/core/Uploader.tsx +118 -0
  186. package/{core → src/core}/VerticalMarquee/index.less +0 -0
  187. package/src/core/VerticalMarquee/index.tsx +51 -0
  188. package/src/core/VirtualTable/TableHeader.tsx +41 -0
  189. package/src/core/VirtualTable/TableRow.tsx +90 -0
  190. package/src/core/VirtualTable/hooks/useColumnWidths.ts +24 -0
  191. package/src/core/VirtualTable/hooks/useDebounce.ts +18 -0
  192. package/src/core/VirtualTable/hooks/useLayout.tsx +58 -0
  193. package/src/core/VirtualTable/hooks/useRowExpand.tsx +27 -0
  194. package/src/core/VirtualTable/hooks/useRowSelection.tsx +72 -0
  195. package/src/core/VirtualTable/hooks/useScrollBarSize.ts +23 -0
  196. package/src/core/VirtualTable/hooks/useScrollToEdge.ts +36 -0
  197. package/src/core/VirtualTable/hooks/useStickyPosition.ts +28 -0
  198. package/src/core/VirtualTable/hooks/useTransformColumn.ts +19 -0
  199. package/{core → src/core}/VirtualTable/index.less +0 -0
  200. package/src/core/VirtualTable/index.tsx +143 -0
  201. package/src/core/VirtualTable/type.ts +59 -0
  202. package/{core → src/core}/WithExplanation/index.less +0 -0
  203. package/src/core/WithExplanation/index.tsx +47 -0
  204. package/src/core/WithTooltipList.tsx +89 -0
  205. package/src/core/YearMonthSelector.tsx +53 -0
  206. package/{css → src/css}/global.less +0 -0
  207. package/{css → src/css}/variable.less +0 -0
  208. package/src/hooks/useOrientationMode.ts +18 -0
  209. package/src/hooks/useSwipe/controller.ts +133 -0
  210. package/src/hooks/useSwipe/index.ts +11 -0
  211. package/src/hooks/useSwipe/type.ts +45 -0
  212. package/src/hooks/useTransform.ts +78 -0
  213. package/src/internal/ArrayUtil.ts +53 -0
  214. package/src/internal/ExpirableLocalStorage.ts +262 -0
  215. package/src/internal/Memo.ts +28 -0
  216. package/src/internal/NumberUtil.ts +38 -0
  217. package/src/internal/StorageHelper.ts +152 -0
  218. package/src/internal/TextUtil.ts +11 -0
  219. package/src/internal/i18n/admin/en.ts +18 -0
  220. package/src/internal/i18n/admin/index.ts +13 -0
  221. package/src/internal/i18n/admin/zh.ts +18 -0
  222. package/src/internal/i18n/core/en.ts +37 -0
  223. package/src/internal/i18n/core/index.ts +13 -0
  224. package/src/internal/i18n/core/zh.ts +37 -0
  225. package/src/internal/i18n/util/en.ts +9 -0
  226. package/src/internal/i18n/util/index.ts +13 -0
  227. package/src/internal/i18n/util/zh.ts +9 -0
  228. package/src/internal/type.ts +12 -0
  229. package/src/util/AdminNavigatorBase.ts +99 -0
  230. package/src/util/BrowserBookmarkUtil.ts +24 -0
  231. package/src/util/BrowserUtil.ts +122 -0
  232. package/src/util/CanvasUtil.ts +61 -0
  233. package/src/util/ClassNames.ts +2 -0
  234. package/src/util/Clipboard.ts +61 -0
  235. package/src/util/ExpirableLocalStorageUtil.ts +3 -0
  236. package/src/util/ExportUtil.ts +34 -0
  237. package/src/util/ImportUtil.ts +41 -0
  238. package/src/util/LocalStorageUtil.ts +3 -0
  239. package/src/util/LocaleUtil.ts +47 -0
  240. package/{util → src/util}/MediaUtil/index.less +0 -0
  241. package/src/util/MediaUtil/index.tsx +69 -0
  242. package/{util → src/util}/MessageUtil/index.less +0 -0
  243. package/src/util/MessageUtil/index.tsx +23 -0
  244. package/{util → src/util}/ModalUtil/index.less +0 -0
  245. package/src/util/ModalUtil/index.tsx +179 -0
  246. package/src/util/NotificationUtil.tsx +42 -0
  247. package/src/util/OrientationUtil.ts +51 -0
  248. package/src/util/PromptUtil/PromptBody.tsx +62 -0
  249. package/{util → src/util}/PromptUtil/index.less +0 -0
  250. package/src/util/PromptUtil/index.tsx +50 -0
  251. package/src/util/RecentUsedStorageUtil.ts +46 -0
  252. package/src/util/SessionStorageUtil.ts +3 -0
  253. package/src/util/SwipeUtil.ts +25 -0
  254. package/src/util/UploadUtil/index.ts +73 -0
  255. package/src/util/UploadUtil/type.ts +46 -0
  256. package/test/mobile-ui-test/package.json +5 -0
  257. package/test/mobile-ui-test/src/component/FlatListDemo/fetch.ts +18 -0
  258. package/test/mobile-ui-test/src/component/FlatListDemo/index.less +22 -0
  259. package/test/mobile-ui-test/src/component/FlatListDemo/index.tsx +149 -0
  260. package/test/mobile-ui-test/src/component/Main.tsx +6 -0
  261. package/test/mobile-ui-test/src/index.html +12 -0
  262. package/test/mobile-ui-test/src/index.less +18 -0
  263. package/test/mobile-ui-test/src/index.tsx +6 -0
  264. package/test/mobile-ui-test/static/robots.txt +2 -0
  265. package/test/mobile-ui-test/tsconfig.json +4 -0
  266. package/test/ui-test/package.json +5 -0
  267. package/test/ui-test/src/asset/logo.png +0 -0
  268. package/test/ui-test/src/component/DemoHelper/index.less +33 -0
  269. package/test/ui-test/src/component/DemoHelper/index.tsx +55 -0
  270. package/test/ui-test/src/component/Main.tsx +33 -0
  271. package/test/ui-test/src/component/WebUILogo.tsx +7 -0
  272. package/test/ui-test/src/component/WebUINavigatorSide.tsx +20 -0
  273. package/test/ui-test/src/component/admin/ConfigPageDemo.tsx +39 -0
  274. package/test/ui-test/src/component/admin/NavigationHistoryDemo.tsx +30 -0
  275. package/test/ui-test/src/component/admin/PermissionSelectorDemo.tsx +65 -0
  276. package/test/ui-test/src/component/admin/RenderErrorDemo.tsx +5 -0
  277. package/test/ui-test/src/component/admin/ResultPageDemo.tsx +13 -0
  278. package/test/ui-test/src/component/admin/RichEditorDemo.tsx +20 -0
  279. package/test/ui-test/src/component/admin/SeparateTabDetailDemo.tsx +44 -0
  280. package/test/ui-test/src/component/admin/TablePageDemo.tsx +85 -0
  281. package/test/ui-test/src/component/core/AmountDemo.tsx +117 -0
  282. package/test/ui-test/src/component/core/ButtonDemo/__tests__/__snapshots__/dom-snapshot.test.tsx.snap +12 -0
  283. package/test/ui-test/src/component/core/ButtonDemo/__tests__/dom-snapshot.test.tsx +10 -0
  284. package/test/ui-test/src/component/core/ButtonDemo/__tests__/smoke.test.tsx +71 -0
  285. package/test/ui-test/src/component/core/ButtonDemo/index.tsx +39 -0
  286. package/test/ui-test/src/component/core/CalendarDemo.tsx +98 -0
  287. package/test/ui-test/src/component/core/CarouselDemo/index.tsx +51 -0
  288. package/test/ui-test/src/component/core/CascaderDemo/index.tsx +120 -0
  289. package/test/ui-test/src/component/core/FoldableDemo.tsx +31 -0
  290. package/test/ui-test/src/component/core/FormDemo.tsx +204 -0
  291. package/test/ui-test/src/component/core/InputDemo/index.tsx +123 -0
  292. package/test/ui-test/src/component/core/MiscellaneousDemo/TagInputDemo.tsx +8 -0
  293. package/test/ui-test/src/component/core/MiscellaneousDemo/index.tsx +157 -0
  294. package/test/ui-test/src/component/core/ModalDemo/index.tsx +75 -0
  295. package/test/ui-test/src/component/core/OverflowableTextDemo.tsx +78 -0
  296. package/test/ui-test/src/component/core/RelativeTimeDemo.tsx +35 -0
  297. package/test/ui-test/src/component/core/SelectDemo/index.tsx +141 -0
  298. package/test/ui-test/src/component/core/SliderDemo.tsx +44 -0
  299. package/test/ui-test/src/component/core/StepContainerDemo.tsx +53 -0
  300. package/test/ui-test/src/component/core/TableDemo.tsx +81 -0
  301. package/test/ui-test/src/component/core/TabsDemo.tsx +136 -0
  302. package/test/ui-test/src/component/core/UploaderImporterDemo.tsx +52 -0
  303. package/test/ui-test/src/component/core/VirtualTableDemo.tsx +232 -0
  304. package/test/ui-test/src/dummy/dummyCallback.ts +13 -0
  305. package/test/ui-test/src/dummy/dummyList.ts +63 -0
  306. package/test/ui-test/src/dummy/dummyTableData.tsx +60 -0
  307. package/test/ui-test/src/dummy/dummyUpload.tsx +43 -0
  308. package/test/ui-test/src/index.html +11 -0
  309. package/test/ui-test/src/index.tsx +5 -0
  310. package/test/ui-test/src/type.ts +8 -0
  311. package/test/ui-test/src/util/NavigationService.tsx +217 -0
  312. package/test/ui-test/src/util/withUncontrolledInitialValue.tsx +14 -0
  313. package/test/ui-test/static/robots.txt +2 -0
  314. package/test/ui-test/tsconfig.json +3 -0
  315. package/test/unit-test/ClassNames.test.ts +17 -0
  316. package/test/unit-test/ExpirableLocalStorageUtil.test.ts +42 -0
  317. package/test/unit-test/NumberInput.util.test.ts +344 -0
  318. package/test/unit-test/NumberUtil.test.ts +57 -0
  319. package/test/unit-test/TextUtil.test.ts +10 -0
  320. package/tsconfig.json +15 -0
  321. package/admin/AdminApp/Default/NavigatorSide/index.d.ts +0 -20
  322. package/admin/AdminApp/Default/NavigatorSide/index.js +0 -74
  323. package/admin/AdminApp/Default/NavigatorSide/index.js.map +0 -1
  324. package/admin/AdminApp/Default/SoundSwitch.d.ts +0 -14
  325. package/admin/AdminApp/Default/SoundSwitch.js +0 -41
  326. package/admin/AdminApp/Default/SoundSwitch.js.map +0 -1
  327. package/admin/AdminApp/Default/SquareLogo/index.d.ts +0 -15
  328. package/admin/AdminApp/Default/SquareLogo/index.js +0 -39
  329. package/admin/AdminApp/Default/SquareLogo/index.js.map +0 -1
  330. package/admin/AdminApp/Menu.d.ts +0 -52
  331. package/admin/AdminApp/Menu.js +0 -174
  332. package/admin/AdminApp/Menu.js.map +0 -1
  333. package/admin/AdminApp/Navigator.d.ts +0 -30
  334. package/admin/AdminApp/Navigator.js +0 -200
  335. package/admin/AdminApp/Navigator.js.map +0 -1
  336. package/admin/AdminApp/NotFound.d.ts +0 -10
  337. package/admin/AdminApp/NotFound.js +0 -37
  338. package/admin/AdminApp/NotFound.js.map +0 -1
  339. package/admin/AdminApp/RouteSwitch.d.ts +0 -19
  340. package/admin/AdminApp/RouteSwitch.js +0 -64
  341. package/admin/AdminApp/RouteSwitch.js.map +0 -1
  342. package/admin/AdminApp/WithErrorBoundary.d.ts +0 -15
  343. package/admin/AdminApp/WithErrorBoundary.js +0 -39
  344. package/admin/AdminApp/WithErrorBoundary.js.map +0 -1
  345. package/admin/AdminApp/context.d.ts +0 -7
  346. package/admin/AdminApp/context.js +0 -7
  347. package/admin/AdminApp/context.js.map +0 -1
  348. package/admin/AdminApp/index.d.ts +0 -39
  349. package/admin/AdminApp/index.js +0 -76
  350. package/admin/AdminApp/index.js.map +0 -1
  351. package/admin/AdminPage/Filter.d.ts +0 -23
  352. package/admin/AdminPage/Filter.js +0 -60
  353. package/admin/AdminPage/Filter.js.map +0 -1
  354. package/admin/AdminPage/Result.d.ts +0 -19
  355. package/admin/AdminPage/Result.js +0 -43
  356. package/admin/AdminPage/Result.js.map +0 -1
  357. package/admin/AdminPage/SaveBar.d.ts +0 -10
  358. package/admin/AdminPage/SaveBar.js +0 -37
  359. package/admin/AdminPage/SaveBar.js.map +0 -1
  360. package/admin/AdminPage/Summary.d.ts +0 -9
  361. package/admin/AdminPage/Summary.js +0 -30
  362. package/admin/AdminPage/Summary.js.map +0 -1
  363. package/admin/AdminPage/TopBar.d.ts +0 -9
  364. package/admin/AdminPage/TopBar.js +0 -30
  365. package/admin/AdminPage/TopBar.js.map +0 -1
  366. package/admin/AdminPage/index.d.ts +0 -21
  367. package/admin/AdminPage/index.js +0 -42
  368. package/admin/AdminPage/index.js.map +0 -1
  369. package/admin/AdminPermissionSelector.d.ts +0 -45
  370. package/admin/AdminPermissionSelector.js +0 -213
  371. package/admin/AdminPermissionSelector.js.map +0 -1
  372. package/admin/RichEditor/index.d.ts +0 -34
  373. package/admin/RichEditor/index.js +0 -104
  374. package/admin/RichEditor/index.js.map +0 -1
  375. package/core/Amount/AmountPercentage.d.ts +0 -19
  376. package/core/Amount/AmountPercentage.js +0 -54
  377. package/core/Amount/AmountPercentage.js.map +0 -1
  378. package/core/Amount/index.d.ts +0 -26
  379. package/core/Amount/index.js +0 -65
  380. package/core/Amount/index.js.map +0 -1
  381. package/core/AmountConditionInput.d.ts +0 -28
  382. package/core/AmountConditionInput.js +0 -66
  383. package/core/AmountConditionInput.js.map +0 -1
  384. package/core/AmountRangeInput.d.ts +0 -23
  385. package/core/AmountRangeInput.js +0 -59
  386. package/core/AmountRangeInput.js.map +0 -1
  387. package/core/AuthenticationCodeInput.d.ts +0 -25
  388. package/core/AuthenticationCodeInput.js +0 -149
  389. package/core/AuthenticationCodeInput.js.map +0 -1
  390. package/core/AutoCompleteInput.d.ts +0 -10
  391. package/core/AutoCompleteInput.js +0 -43
  392. package/core/AutoCompleteInput.js.map +0 -1
  393. package/core/Badge/index.d.ts +0 -10
  394. package/core/Badge/index.js +0 -43
  395. package/core/Badge/index.js.map +0 -1
  396. package/core/BoolRadio.d.ts +0 -20
  397. package/core/BoolRadio.js +0 -49
  398. package/core/BoolRadio.js.map +0 -1
  399. package/core/BoolSelect.d.ts +0 -19
  400. package/core/BoolSelect.js +0 -48
  401. package/core/BoolSelect.js.map +0 -1
  402. package/core/BoolSwitch.d.ts +0 -17
  403. package/core/BoolSwitch.js +0 -56
  404. package/core/BoolSwitch.js.map +0 -1
  405. package/core/Breadcrumb/index.d.ts +0 -17
  406. package/core/Breadcrumb/index.js +0 -45
  407. package/core/Breadcrumb/index.js.map +0 -1
  408. package/core/Button/index.d.ts +0 -37
  409. package/core/Button/index.js +0 -60
  410. package/core/Button/index.js.map +0 -1
  411. package/core/Card.d.ts +0 -10
  412. package/core/Card.js +0 -43
  413. package/core/Card.js.map +0 -1
  414. package/core/Carousel.d.ts +0 -11
  415. package/core/Carousel.js +0 -54
  416. package/core/Carousel.js.map +0 -1
  417. package/core/Carousel3D/index.d.ts +0 -27
  418. package/core/Carousel3D/index.js +0 -116
  419. package/core/Carousel3D/index.js.map +0 -1
  420. package/core/Cascader/InitialNullable.d.ts +0 -10
  421. package/core/Cascader/InitialNullable.js +0 -54
  422. package/core/Cascader/InitialNullable.js.map +0 -1
  423. package/core/Cascader/Nullable.d.ts +0 -12
  424. package/core/Cascader/Nullable.js +0 -86
  425. package/core/Cascader/Nullable.js.map +0 -1
  426. package/core/Cascader/index.d.ts +0 -37
  427. package/core/Cascader/index.js +0 -117
  428. package/core/Cascader/index.js.map +0 -1
  429. package/core/Checkbox/index.d.ts +0 -15
  430. package/core/Checkbox/index.js +0 -47
  431. package/core/Checkbox/index.js.map +0 -1
  432. package/core/Collapse.d.ts +0 -12
  433. package/core/Collapse.js +0 -43
  434. package/core/Collapse.js.map +0 -1
  435. package/core/Countdown/SlidingDigit.d.ts +0 -15
  436. package/core/Countdown/SlidingDigit.js +0 -43
  437. package/core/Countdown/SlidingDigit.js.map +0 -1
  438. package/core/Countdown/index.d.ts +0 -39
  439. package/core/Countdown/index.js +0 -106
  440. package/core/Countdown/index.js.map +0 -1
  441. package/core/DarkOverlay/index.d.ts +0 -12
  442. package/core/DarkOverlay/index.js +0 -32
  443. package/core/DarkOverlay/index.js.map +0 -1
  444. package/core/DateCalendar.d.ts +0 -18
  445. package/core/DateCalendar.js +0 -85
  446. package/core/DateCalendar.js.map +0 -1
  447. package/core/DatePicker/index.d.ts +0 -18
  448. package/core/DatePicker/index.js +0 -53
  449. package/core/DatePicker/index.js.map +0 -1
  450. package/core/DateRangePicker/index.d.ts +0 -18
  451. package/core/DateRangePicker/index.js +0 -59
  452. package/core/DateRangePicker/index.js.map +0 -1
  453. package/core/DateTimePicker/index.d.ts +0 -19
  454. package/core/DateTimePicker/index.js +0 -59
  455. package/core/DateTimePicker/index.js.map +0 -1
  456. package/core/DateTimeRangePicker/index.d.ts +0 -20
  457. package/core/DateTimeRangePicker/index.js +0 -59
  458. package/core/DateTimeRangePicker/index.js.map +0 -1
  459. package/core/Descriptions/index.d.ts +0 -27
  460. package/core/Descriptions/index.js +0 -51
  461. package/core/Descriptions/index.js.map +0 -1
  462. package/core/DocumentTitle.d.ts +0 -28
  463. package/core/DocumentTitle.js +0 -53
  464. package/core/DocumentTitle.js.map +0 -1
  465. package/core/Drawer.d.ts +0 -9
  466. package/core/Drawer.js +0 -41
  467. package/core/Drawer.js.map +0 -1
  468. package/core/Dropdown.d.ts +0 -9
  469. package/core/Dropdown.js +0 -10
  470. package/core/Dropdown.js.map +0 -1
  471. package/core/EnumCheckboxGroup/Map.d.ts +0 -10
  472. package/core/EnumCheckboxGroup/Map.js +0 -55
  473. package/core/EnumCheckboxGroup/Map.js.map +0 -1
  474. package/core/EnumCheckboxGroup/index.d.ts +0 -12
  475. package/core/EnumCheckboxGroup/index.js +0 -36
  476. package/core/EnumCheckboxGroup/index.js.map +0 -1
  477. package/core/EnumRadio/InitialNullable.d.ts +0 -11
  478. package/core/EnumRadio/InitialNullable.js +0 -56
  479. package/core/EnumRadio/InitialNullable.js.map +0 -1
  480. package/core/EnumRadio/Map.d.ts +0 -10
  481. package/core/EnumRadio/Map.js +0 -55
  482. package/core/EnumRadio/Map.js.map +0 -1
  483. package/core/EnumRadio/Nullable.d.ts +0 -12
  484. package/core/EnumRadio/Nullable.js +0 -88
  485. package/core/EnumRadio/Nullable.js.map +0 -1
  486. package/core/EnumRadio/index.d.ts +0 -24
  487. package/core/EnumRadio/index.js +0 -45
  488. package/core/EnumRadio/index.js.map +0 -1
  489. package/core/EnumSelect/InitialNullable.d.ts +0 -10
  490. package/core/EnumSelect/InitialNullable.js +0 -54
  491. package/core/EnumSelect/InitialNullable.js.map +0 -1
  492. package/core/EnumSelect/Map.d.ts +0 -10
  493. package/core/EnumSelect/Map.js +0 -55
  494. package/core/EnumSelect/Map.js.map +0 -1
  495. package/core/EnumSelect/Nullable.d.ts +0 -12
  496. package/core/EnumSelect/Nullable.js +0 -88
  497. package/core/EnumSelect/Nullable.js.map +0 -1
  498. package/core/EnumSelect/index.d.ts +0 -29
  499. package/core/EnumSelect/index.js +0 -61
  500. package/core/EnumSelect/index.js.map +0 -1
  501. package/core/FlatList/VirtualFlatList/Item.d.ts +0 -11
  502. package/core/FlatList/VirtualFlatList/Item.js +0 -20
  503. package/core/FlatList/VirtualFlatList/Item.js.map +0 -1
  504. package/core/FlatList/VirtualFlatList/index.d.ts +0 -7
  505. package/core/FlatList/VirtualFlatList/index.js +0 -110
  506. package/core/FlatList/VirtualFlatList/index.js.map +0 -1
  507. package/core/FlatList/VirtualFlatList/type.d.ts +0 -20
  508. package/core/FlatList/VirtualFlatList/type.js +0 -2
  509. package/core/FlatList/VirtualFlatList/type.js.map +0 -1
  510. package/core/FlatList/index.d.ts +0 -3
  511. package/core/FlatList/index.js +0 -60
  512. package/core/FlatList/index.js.map +0 -1
  513. package/core/FlatList/shared/Footer/index.d.ts +0 -8
  514. package/core/FlatList/shared/Footer/index.js +0 -13
  515. package/core/FlatList/shared/Footer/index.js.map +0 -1
  516. package/core/FlatList/shared/GetRowKey.d.ts +0 -2
  517. package/core/FlatList/shared/GetRowKey.js +0 -12
  518. package/core/FlatList/shared/GetRowKey.js.map +0 -1
  519. package/core/FlatList/shared/Spinner/index.d.ts +0 -8
  520. package/core/FlatList/shared/Spinner/index.js +0 -10
  521. package/core/FlatList/shared/Spinner/index.js.map +0 -1
  522. package/core/FlatList/shared/Wrapper/Loading.d.ts +0 -8
  523. package/core/FlatList/shared/Wrapper/Loading.js +0 -7
  524. package/core/FlatList/shared/Wrapper/Loading.js.map +0 -1
  525. package/core/FlatList/shared/Wrapper/index.d.ts +0 -14
  526. package/core/FlatList/shared/Wrapper/index.js +0 -109
  527. package/core/FlatList/shared/Wrapper/index.js.map +0 -1
  528. package/core/FlatList/shared/hooks/useBounceSwipe.d.ts +0 -22
  529. package/core/FlatList/shared/hooks/useBounceSwipe.js +0 -111
  530. package/core/FlatList/shared/hooks/useBounceSwipe.js.map +0 -1
  531. package/core/FlatList/shared/hooks/useElementScrollState.d.ts +0 -8
  532. package/core/FlatList/shared/hooks/useElementScrollState.js +0 -38
  533. package/core/FlatList/shared/hooks/useElementScrollState.js.map +0 -1
  534. package/core/FlatList/shared/hooks/useLoadingWithDelay.d.ts +0 -9
  535. package/core/FlatList/shared/hooks/useLoadingWithDelay.js +0 -52
  536. package/core/FlatList/shared/hooks/useLoadingWithDelay.js.map +0 -1
  537. package/core/FlatList/type.d.ts +0 -48
  538. package/core/FlatList/type.js +0 -2
  539. package/core/FlatList/type.js.map +0 -1
  540. package/core/Foldable/index.d.ts +0 -18
  541. package/core/Foldable/index.js +0 -41
  542. package/core/Foldable/index.js.map +0 -1
  543. package/core/Form/Item.d.ts +0 -29
  544. package/core/Form/Item.js +0 -106
  545. package/core/Form/Item.js.map +0 -1
  546. package/core/Form/context.d.ts +0 -14
  547. package/core/Form/context.js +0 -7
  548. package/core/Form/context.js.map +0 -1
  549. package/core/Form/index.d.ts +0 -36
  550. package/core/Form/index.js +0 -143
  551. package/core/Form/index.js.map +0 -1
  552. package/core/Grid.d.ts +0 -6
  553. package/core/Grid.js +0 -7
  554. package/core/Grid.js.map +0 -1
  555. package/core/HTMLContent/index.d.ts +0 -11
  556. package/core/HTMLContent/index.js +0 -32
  557. package/core/HTMLContent/index.js.map +0 -1
  558. package/core/ImageUploader/index.d.ts +0 -24
  559. package/core/ImageUploader/index.js +0 -148
  560. package/core/ImageUploader/index.js.map +0 -1
  561. package/core/Input/index.d.ts +0 -39
  562. package/core/Input/index.js +0 -88
  563. package/core/Input/index.js.map +0 -1
  564. package/core/LabelledSelect.d.ts +0 -11
  565. package/core/LabelledSelect.js +0 -42
  566. package/core/LabelledSelect.js.map +0 -1
  567. package/core/Link.d.ts +0 -15
  568. package/core/Link.js +0 -48
  569. package/core/Link.js.map +0 -1
  570. package/core/LocalImporter.d.ts +0 -21
  571. package/core/LocalImporter.js +0 -93
  572. package/core/LocalImporter.js.map +0 -1
  573. package/core/LocaleProvider.d.ts +0 -12
  574. package/core/LocaleProvider.js +0 -38
  575. package/core/LocaleProvider.js.map +0 -1
  576. package/core/LocaleSelect.d.ts +0 -11
  577. package/core/LocaleSelect.js +0 -45
  578. package/core/LocaleSelect.js.map +0 -1
  579. package/core/Markdown/index.d.ts +0 -20
  580. package/core/Markdown/index.js +0 -40
  581. package/core/Markdown/index.js.map +0 -1
  582. package/core/Modal/index.d.ts +0 -16
  583. package/core/Modal/index.js +0 -67
  584. package/core/Modal/index.js.map +0 -1
  585. package/core/MultipleCascader/index.d.ts +0 -31
  586. package/core/MultipleCascader/index.js +0 -151
  587. package/core/MultipleCascader/index.js.map +0 -1
  588. package/core/MultipleEnumSelect.d.ts +0 -17
  589. package/core/MultipleEnumSelect.js +0 -40
  590. package/core/MultipleEnumSelect.js.map +0 -1
  591. package/core/MultipleSelector/TablePopover.d.ts +0 -20
  592. package/core/MultipleSelector/TablePopover.js +0 -95
  593. package/core/MultipleSelector/TablePopover.js.map +0 -1
  594. package/core/MultipleSelector/index.d.ts +0 -33
  595. package/core/MultipleSelector/index.js +0 -103
  596. package/core/MultipleSelector/index.js.map +0 -1
  597. package/core/MutableTable/index.d.ts +0 -44
  598. package/core/MutableTable/index.js +0 -139
  599. package/core/MutableTable/index.js.map +0 -1
  600. package/core/NumberInput/NumberInputPercentage.d.ts +0 -58
  601. package/core/NumberInput/NumberInputPercentage.js +0 -75
  602. package/core/NumberInput/NumberInputPercentage.js.map +0 -1
  603. package/core/NumberInput/index.d.ts +0 -70
  604. package/core/NumberInput/index.js +0 -130
  605. package/core/NumberInput/index.js.map +0 -1
  606. package/core/NumberInput/util.d.ts +0 -34
  607. package/core/NumberInput/util.js +0 -57
  608. package/core/NumberInput/util.js.map +0 -1
  609. package/core/OverflowableText/index.d.ts +0 -22
  610. package/core/OverflowableText/index.js +0 -64
  611. package/core/OverflowableText/index.js.map +0 -1
  612. package/core/PagedList/index.d.ts +0 -27
  613. package/core/PagedList/index.js +0 -81
  614. package/core/PagedList/index.js.map +0 -1
  615. package/core/Pagination/index.d.ts +0 -21
  616. package/core/Pagination/index.js +0 -51
  617. package/core/Pagination/index.js.map +0 -1
  618. package/core/Popover/index.d.ts +0 -11
  619. package/core/Popover/index.js +0 -43
  620. package/core/Popover/index.js.map +0 -1
  621. package/core/Progress.d.ts +0 -10
  622. package/core/Progress.js +0 -42
  623. package/core/Progress.js.map +0 -1
  624. package/core/Radio/index.d.ts +0 -13
  625. package/core/Radio/index.js +0 -45
  626. package/core/Radio/index.js.map +0 -1
  627. package/core/RelativeTime.d.ts +0 -18
  628. package/core/RelativeTime.js +0 -60
  629. package/core/RelativeTime.js.map +0 -1
  630. package/core/ResizeObserver.d.ts +0 -2
  631. package/core/ResizeObserver.js +0 -2
  632. package/core/ResizeObserver.js.map +0 -1
  633. package/core/SearchableSelect.d.ts +0 -15
  634. package/core/SearchableSelect.js +0 -42
  635. package/core/SearchableSelect.js.map +0 -1
  636. package/core/Select/index.d.ts +0 -16
  637. package/core/Select/index.js +0 -45
  638. package/core/Select/index.js.map +0 -1
  639. package/core/SignedAmountInput.d.ts +0 -20
  640. package/core/SignedAmountInput.js +0 -56
  641. package/core/SignedAmountInput.js.map +0 -1
  642. package/core/Skeleton.d.ts +0 -9
  643. package/core/Skeleton.js +0 -42
  644. package/core/Skeleton.js.map +0 -1
  645. package/core/Slider/RangeSlider.d.ts +0 -11
  646. package/core/Slider/RangeSlider.js +0 -53
  647. package/core/Slider/RangeSlider.js.map +0 -1
  648. package/core/Slider/index.d.ts +0 -16
  649. package/core/Slider/index.js +0 -79
  650. package/core/Slider/index.js.map +0 -1
  651. package/core/Space.d.ts +0 -10
  652. package/core/Space.js +0 -42
  653. package/core/Space.js.map +0 -1
  654. package/core/Spin.d.ts +0 -12
  655. package/core/Spin.js +0 -55
  656. package/core/Spin.js.map +0 -1
  657. package/core/StepFormContainer/index.d.ts +0 -27
  658. package/core/StepFormContainer/index.js +0 -50
  659. package/core/StepFormContainer/index.js.map +0 -1
  660. package/core/Steps/index.d.ts +0 -11
  661. package/core/Steps/index.js +0 -44
  662. package/core/Steps/index.js.map +0 -1
  663. package/core/Table/index.d.ts +0 -89
  664. package/core/Table/index.js +0 -152
  665. package/core/Table/index.js.map +0 -1
  666. package/core/Tabs/Single.d.ts +0 -11
  667. package/core/Tabs/Single.js +0 -54
  668. package/core/Tabs/Single.js.map +0 -1
  669. package/core/Tabs/index.d.ts +0 -30
  670. package/core/Tabs/index.js +0 -96
  671. package/core/Tabs/index.js.map +0 -1
  672. package/core/Tag.d.ts +0 -11
  673. package/core/Tag.js +0 -42
  674. package/core/Tag.js.map +0 -1
  675. package/core/TagInput/index.d.ts +0 -27
  676. package/core/TagInput/index.js +0 -107
  677. package/core/TagInput/index.js.map +0 -1
  678. package/core/Tags.d.ts +0 -17
  679. package/core/Tags.js +0 -38
  680. package/core/Tags.js.map +0 -1
  681. package/core/TimePicker/index.d.ts +0 -17
  682. package/core/TimePicker/index.js +0 -46
  683. package/core/TimePicker/index.js.map +0 -1
  684. package/core/TimeRangePicker/index.d.ts +0 -17
  685. package/core/TimeRangePicker/index.js +0 -45
  686. package/core/TimeRangePicker/index.js.map +0 -1
  687. package/core/Tooltip.d.ts +0 -9
  688. package/core/Tooltip.js +0 -42
  689. package/core/Tooltip.js.map +0 -1
  690. package/core/TypedTabs/index.d.ts +0 -23
  691. package/core/TypedTabs/index.js +0 -76
  692. package/core/TypedTabs/index.js.map +0 -1
  693. package/core/Uploader.d.ts +0 -34
  694. package/core/Uploader.js +0 -97
  695. package/core/Uploader.js.map +0 -1
  696. package/core/VerticalMarquee/index.d.ts +0 -19
  697. package/core/VerticalMarquee/index.js +0 -51
  698. package/core/VerticalMarquee/index.js.map +0 -1
  699. package/core/VirtualTable/TableHeader.d.ts +0 -13
  700. package/core/VirtualTable/TableHeader.js +0 -45
  701. package/core/VirtualTable/TableHeader.js.map +0 -1
  702. package/core/VirtualTable/TableRow.d.ts +0 -21
  703. package/core/VirtualTable/TableRow.js +0 -59
  704. package/core/VirtualTable/TableRow.js.map +0 -1
  705. package/core/VirtualTable/hooks/useColumnWidths.d.ts +0 -11
  706. package/core/VirtualTable/hooks/useColumnWidths.js +0 -38
  707. package/core/VirtualTable/hooks/useColumnWidths.js.map +0 -1
  708. package/core/VirtualTable/hooks/useDebounce.d.ts +0 -1
  709. package/core/VirtualTable/hooks/useDebounce.js +0 -45
  710. package/core/VirtualTable/hooks/useDebounce.js.map +0 -1
  711. package/core/VirtualTable/hooks/useLayout.d.ts +0 -17
  712. package/core/VirtualTable/hooks/useLayout.js +0 -44
  713. package/core/VirtualTable/hooks/useLayout.js.map +0 -1
  714. package/core/VirtualTable/hooks/useRowExpand.d.ts +0 -7
  715. package/core/VirtualTable/hooks/useRowExpand.js +0 -20
  716. package/core/VirtualTable/hooks/useRowExpand.js.map +0 -1
  717. package/core/VirtualTable/hooks/useRowSelection.d.ts +0 -10
  718. package/core/VirtualTable/hooks/useRowSelection.js +0 -83
  719. package/core/VirtualTable/hooks/useRowSelection.js.map +0 -1
  720. package/core/VirtualTable/hooks/useScrollBarSize.d.ts +0 -5
  721. package/core/VirtualTable/hooks/useScrollBarSize.js +0 -36
  722. package/core/VirtualTable/hooks/useScrollBarSize.js.map +0 -1
  723. package/core/VirtualTable/hooks/useScrollToEdge.d.ts +0 -8
  724. package/core/VirtualTable/hooks/useScrollToEdge.js +0 -48
  725. package/core/VirtualTable/hooks/useScrollToEdge.js.map +0 -1
  726. package/core/VirtualTable/hooks/useStickyPosition.d.ts +0 -2
  727. package/core/VirtualTable/hooks/useStickyPosition.js +0 -24
  728. package/core/VirtualTable/hooks/useStickyPosition.js.map +0 -1
  729. package/core/VirtualTable/hooks/useTransformColumn.d.ts +0 -11
  730. package/core/VirtualTable/hooks/useTransformColumn.js +0 -9
  731. package/core/VirtualTable/hooks/useTransformColumn.js.map +0 -1
  732. package/core/VirtualTable/index.d.ts +0 -30
  733. package/core/VirtualTable/index.js +0 -85
  734. package/core/VirtualTable/index.js.map +0 -1
  735. package/core/VirtualTable/type.d.ts +0 -57
  736. package/core/VirtualTable/type.js +0 -2
  737. package/core/VirtualTable/type.js.map +0 -1
  738. package/core/WithExplanation/index.d.ts +0 -21
  739. package/core/WithExplanation/index.js +0 -46
  740. package/core/WithExplanation/index.js.map +0 -1
  741. package/core/WithTooltipList.d.ts +0 -23
  742. package/core/WithTooltipList.js +0 -64
  743. package/core/WithTooltipList.js.map +0 -1
  744. package/core/YearMonthSelector.d.ts +0 -16
  745. package/core/YearMonthSelector.js +0 -53
  746. package/core/YearMonthSelector.js.map +0 -1
  747. package/hooks/useOrientationMode.d.ts +0 -2
  748. package/hooks/useOrientationMode.js +0 -30
  749. package/hooks/useOrientationMode.js.map +0 -1
  750. package/hooks/useSwipe/controller.d.ts +0 -20
  751. package/hooks/useSwipe/controller.js +0 -126
  752. package/hooks/useSwipe/controller.js.map +0 -1
  753. package/hooks/useSwipe/index.d.ts +0 -3
  754. package/hooks/useSwipe/index.js +0 -9
  755. package/hooks/useSwipe/index.js.map +0 -1
  756. package/hooks/useSwipe/type.d.ts +0 -38
  757. package/hooks/useSwipe/type.js +0 -8
  758. package/hooks/useSwipe/type.js.map +0 -1
  759. package/hooks/useTransform.d.ts +0 -18
  760. package/hooks/useTransform.js +0 -50
  761. package/hooks/useTransform.js.map +0 -1
  762. package/internal/ArrayUtil.d.ts +0 -29
  763. package/internal/ArrayUtil.js +0 -76
  764. package/internal/ArrayUtil.js.map +0 -1
  765. package/internal/ExpirableLocalStorage.d.ts +0 -123
  766. package/internal/ExpirableLocalStorage.js +0 -245
  767. package/internal/ExpirableLocalStorage.js.map +0 -1
  768. package/internal/Memo.d.ts +0 -9
  769. package/internal/Memo.js +0 -31
  770. package/internal/Memo.js.map +0 -1
  771. package/internal/NumberUtil.d.ts +0 -7
  772. package/internal/NumberUtil.js +0 -38
  773. package/internal/NumberUtil.js.map +0 -1
  774. package/internal/StorageHelper.d.ts +0 -31
  775. package/internal/StorageHelper.js +0 -152
  776. package/internal/StorageHelper.js.map +0 -1
  777. package/internal/TextUtil.d.ts +0 -5
  778. package/internal/TextUtil.js +0 -15
  779. package/internal/TextUtil.js.map +0 -1
  780. package/internal/i18n/admin/en.d.ts +0 -18
  781. package/internal/i18n/admin/en.js +0 -19
  782. package/internal/i18n/admin/en.js.map +0 -1
  783. package/internal/i18n/admin/index.d.ts +0 -18
  784. package/internal/i18n/admin/index.js +0 -11
  785. package/internal/i18n/admin/index.js.map +0 -1
  786. package/internal/i18n/admin/zh.d.ts +0 -18
  787. package/internal/i18n/admin/zh.js +0 -19
  788. package/internal/i18n/admin/zh.js.map +0 -1
  789. package/internal/i18n/core/en.d.ts +0 -37
  790. package/internal/i18n/core/en.js +0 -38
  791. package/internal/i18n/core/en.js.map +0 -1
  792. package/internal/i18n/core/index.d.ts +0 -37
  793. package/internal/i18n/core/index.js +0 -11
  794. package/internal/i18n/core/index.js.map +0 -1
  795. package/internal/i18n/core/zh.d.ts +0 -37
  796. package/internal/i18n/core/zh.js +0 -38
  797. package/internal/i18n/core/zh.js.map +0 -1
  798. package/internal/i18n/util/en.d.ts +0 -9
  799. package/internal/i18n/util/en.js +0 -10
  800. package/internal/i18n/util/en.js.map +0 -1
  801. package/internal/i18n/util/index.d.ts +0 -9
  802. package/internal/i18n/util/index.js +0 -11
  803. package/internal/i18n/util/index.js.map +0 -1
  804. package/internal/i18n/util/zh.d.ts +0 -9
  805. package/internal/i18n/util/zh.js +0 -10
  806. package/internal/i18n/util/zh.js.map +0 -1
  807. package/internal/type.d.ts +0 -15
  808. package/internal/type.js +0 -2
  809. package/internal/type.js.map +0 -1
  810. package/util/AdminNavigatorBase.d.ts +0 -64
  811. package/util/AdminNavigatorBase.js +0 -101
  812. package/util/AdminNavigatorBase.js.map +0 -1
  813. package/util/BrowserBookmarkUtil.d.ts +0 -5
  814. package/util/BrowserBookmarkUtil.js +0 -25
  815. package/util/BrowserBookmarkUtil.js.map +0 -1
  816. package/util/BrowserUtil.d.ts +0 -31
  817. package/util/BrowserUtil.js +0 -154
  818. package/util/BrowserUtil.js.map +0 -1
  819. package/util/CanvasUtil.d.ts +0 -17
  820. package/util/CanvasUtil.js +0 -94
  821. package/util/CanvasUtil.js.map +0 -1
  822. package/util/ClassNames.d.ts +0 -2
  823. package/util/ClassNames.js +0 -3
  824. package/util/ClassNames.js.map +0 -1
  825. package/util/Clipboard.d.ts +0 -22
  826. package/util/Clipboard.js +0 -118
  827. package/util/Clipboard.js.map +0 -1
  828. package/util/ExpirableLocalStorageUtil.d.ts +0 -2
  829. package/util/ExpirableLocalStorageUtil.js +0 -3
  830. package/util/ExpirableLocalStorageUtil.js.map +0 -1
  831. package/util/ExportUtil.d.ts +0 -11
  832. package/util/ExportUtil.js +0 -28
  833. package/util/ExportUtil.js.map +0 -1
  834. package/util/ImportUtil.d.ts +0 -10
  835. package/util/ImportUtil.js +0 -94
  836. package/util/ImportUtil.js.map +0 -1
  837. package/util/LocalStorageUtil.d.ts +0 -2
  838. package/util/LocalStorageUtil.js +0 -3
  839. package/util/LocalStorageUtil.js.map +0 -1
  840. package/util/LocaleUtil.d.ts +0 -22
  841. package/util/LocaleUtil.js +0 -34
  842. package/util/LocaleUtil.js.map +0 -1
  843. package/util/MediaUtil/index.d.ts +0 -10
  844. package/util/MediaUtil/index.js +0 -60
  845. package/util/MediaUtil/index.js.map +0 -1
  846. package/util/MessageUtil/index.d.ts +0 -15
  847. package/util/MessageUtil/index.js +0 -29
  848. package/util/MessageUtil/index.js.map +0 -1
  849. package/util/ModalUtil/index.d.ts +0 -41
  850. package/util/ModalUtil/index.js +0 -145
  851. package/util/ModalUtil/index.js.map +0 -1
  852. package/util/NotificationUtil.d.ts +0 -12
  853. package/util/NotificationUtil.js +0 -52
  854. package/util/NotificationUtil.js.map +0 -1
  855. package/util/OrientationUtil.d.ts +0 -20
  856. package/util/OrientationUtil.js +0 -50
  857. package/util/OrientationUtil.js.map +0 -1
  858. package/util/PromptUtil/PromptBody.d.ts +0 -18
  859. package/util/PromptUtil/PromptBody.js +0 -100
  860. package/util/PromptUtil/PromptBody.js.map +0 -1
  861. package/util/PromptUtil/index.d.ts +0 -19
  862. package/util/PromptUtil/index.js +0 -48
  863. package/util/PromptUtil/index.js.map +0 -1
  864. package/util/RecentUsedStorageUtil.d.ts +0 -12
  865. package/util/RecentUsedStorageUtil.js +0 -45
  866. package/util/RecentUsedStorageUtil.js.map +0 -1
  867. package/util/SessionStorageUtil.d.ts +0 -2
  868. package/util/SessionStorageUtil.js +0 -3
  869. package/util/SessionStorageUtil.js.map +0 -1
  870. package/util/SwipeUtil.d.ts +0 -8
  871. package/util/SwipeUtil.js +0 -26
  872. package/util/SwipeUtil.js.map +0 -1
  873. package/util/UploadUtil/index.d.ts +0 -6
  874. package/util/UploadUtil/index.js +0 -61
  875. package/util/UploadUtil/index.js.map +0 -1
  876. package/util/UploadUtil/type.d.ts +0 -41
  877. package/util/UploadUtil/type.js +0 -2
  878. package/util/UploadUtil/type.js.map +0 -1
@@ -0,0 +1,142 @@
1
+ import React from "react";
2
+ import {defaultRangeExtractor, useVirtual} from "react-virtual";
3
+ import {classNames} from "../../../util/ClassNames";
4
+ import {useLoadingWithDelay} from "../shared/hooks/useLoadingWithDelay";
5
+ import {Wrapper} from "../shared/Wrapper";
6
+ import {Footer} from "../shared/Footer";
7
+ import {GetRowKey} from "../shared/GetRowKey";
8
+ import {Item} from "./Item";
9
+ import type {VirtualFlatListProps} from "./type";
10
+ import type {Range} from "react-virtual";
11
+ import type {FooterData, LoadingType} from "../type";
12
+ import "./index.less";
13
+
14
+ /**
15
+ * 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
16
+ */
17
+ export const VirtualFlatList = function <T>(props: VirtualFlatListProps<T>) {
18
+ const {
19
+ data,
20
+ renderItem,
21
+ rowKey,
22
+ loading,
23
+ bounceEffect = true,
24
+ className,
25
+ style,
26
+ onPullDownRefresh,
27
+ onPullUpLoading,
28
+ emptyPlaceholder,
29
+ contentStyle,
30
+ gap,
31
+ autoLoad = true,
32
+ overscan = 3,
33
+ hideFooter,
34
+ estimateSize,
35
+ listRef,
36
+ pullUpLoadingMessage,
37
+ endOfListMessage,
38
+ pullDownRefreshMessage,
39
+ } = props;
40
+
41
+ const listWrapperRef = React.useRef<HTMLDivElement>(null);
42
+ const [loadingType, setLoadingType] = React.useState<LoadingType>(null);
43
+ const currentRangeRef = React.useRef<Range>();
44
+ const previousRangeRef = React.useRef<Range>();
45
+
46
+ const loadingWithDelay = useLoadingWithDelay(loading ?? false, 300);
47
+
48
+ const listData: Array<T | FooterData> = React.useMemo(() => {
49
+ return hideFooter
50
+ ? data
51
+ : [
52
+ ...data,
53
+ {
54
+ loading: loadingWithDelay && loadingType === "loading",
55
+ ended: !onPullUpLoading,
56
+ endMessage: endOfListMessage,
57
+ loadingMessage: pullUpLoadingMessage,
58
+ __markedAsFooterData: true,
59
+ } as FooterData,
60
+ ];
61
+ }, [loadingWithDelay, loadingType, endOfListMessage, onPullUpLoading, pullUpLoadingMessage, data, hideFooter]);
62
+
63
+ const rangeExtractor = React.useCallback((range: Range) => {
64
+ previousRangeRef.current = currentRangeRef.current ?? range;
65
+ currentRangeRef.current = range;
66
+ return defaultRangeExtractor(range);
67
+ }, []);
68
+
69
+ const rowVirtualizer = useVirtual({
70
+ size: listData.length,
71
+ parentRef: listWrapperRef,
72
+ overscan,
73
+ estimateSize,
74
+ rangeExtractor,
75
+ });
76
+ const rowVirtualizerRef = React.useRef(rowVirtualizer);
77
+ rowVirtualizerRef.current = rowVirtualizer;
78
+
79
+ React.useImperativeHandle(listRef, () => ({
80
+ measure: rowVirtualizer.measure,
81
+ }));
82
+
83
+ React.useEffect(() => {
84
+ if ((loading === undefined || loading === null) && (onPullDownRefresh || onPullUpLoading)) {
85
+ throw new Error("Loading must be specify when given either onPullDownRefresh or onPullUpLoading");
86
+ }
87
+ }, [onPullDownRefresh, onPullUpLoading, loading]);
88
+
89
+ // the reason why onScroll event is used to simulate auto loading instead of rangeExtractor is rangeExtractor return a wrong range when on mount
90
+ const onAutoLoad = () => {
91
+ const previousRange = previousRangeRef.current;
92
+ const currentRange = currentRangeRef.current;
93
+ if (
94
+ previousRange &&
95
+ currentRange &&
96
+ autoLoad &&
97
+ onPullUpLoading &&
98
+ !loadingWithDelay &&
99
+ // check going downward
100
+ previousRange.end < currentRange.end &&
101
+ currentRange.end > data.length - 2 - (typeof autoLoad === "number" ? autoLoad : 3)
102
+ ) {
103
+ setLoadingType("loading");
104
+ onPullUpLoading();
105
+ }
106
+ };
107
+
108
+ // TODO/Alvis loading more when item can not fill the whole viewport
109
+
110
+ return (
111
+ <Wrapper
112
+ className={classNames("g-virtual-flat-list", className)}
113
+ bounceEffect={bounceEffect}
114
+ listWrapperRef={listWrapperRef}
115
+ loadingType={loadingType}
116
+ onLoadingTypeChange={setLoadingType}
117
+ loading={loadingWithDelay}
118
+ onPullDownRefresh={onPullDownRefresh}
119
+ onPullUpLoading={onPullUpLoading}
120
+ innerStyle={contentStyle}
121
+ style={style}
122
+ pullDownRefreshMessage={pullDownRefreshMessage}
123
+ onScroll={onAutoLoad}
124
+ >
125
+ {data.length === 0 && !loadingWithDelay ? (
126
+ emptyPlaceholder
127
+ ) : (
128
+ <div className="list" style={{height: rowVirtualizer.totalSize}}>
129
+ {rowVirtualizer.virtualItems.map(virtualItem => {
130
+ const data = listData[virtualItem.index];
131
+ if (listData[virtualItem.index]?.["__markedAsFooterData"] === true) {
132
+ const {loading, loadingMessage, endMessage, ended} = data as FooterData;
133
+ return <Footer key={virtualItem.index} loading={loading} ended={ended} loadingMessage={loadingMessage} endMessage={endMessage} measure={virtualItem.measureRef} />;
134
+ } else {
135
+ return <Item key={GetRowKey(rowKey, data as T, virtualItem.index)} virtualItem={virtualItem} data={data as T} gap={gap} renderItem={renderItem} />;
136
+ }
137
+ })}
138
+ </div>
139
+ )}
140
+ </Wrapper>
141
+ );
142
+ };
@@ -0,0 +1,26 @@
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
+ listRef?: React.RefObject<VirtualFlatListHandle>;
20
+ }
21
+
22
+ export interface VirtualFlatListItemProps<T> extends FlatListItemProps<T> {
23
+ measure: Measure;
24
+ }
25
+
26
+ export type ItemRenderer<T> = React.FunctionComponent<VirtualFlatListItemProps<T>>;
@@ -0,0 +1,95 @@
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
+ import {GetRowKey} from "./shared/GetRowKey";
8
+
9
+ export const FlatList = function <T>(props: FlatListProps<T>) {
10
+ const {
11
+ data,
12
+ renderItem: ItemRenderer,
13
+ rowKey,
14
+ loading,
15
+ bounceEffect = true,
16
+ className,
17
+ style,
18
+ gap,
19
+ onPullDownRefresh,
20
+ onPullUpLoading,
21
+ contentStyle,
22
+ emptyPlaceholder,
23
+ pullDownRefreshingMessage,
24
+ pullUpLoadMoreMessage,
25
+ pullDownRefreshMessage,
26
+ pullUpLoadingMessage,
27
+ endOfListMessage,
28
+ hideFooter,
29
+ } = props;
30
+
31
+ const listWrapperRef = React.useRef<HTMLDivElement>(null);
32
+ const [loadingType, setLoadingType] = React.useState<LoadingType>(null);
33
+ const loadingWithDelay = useLoadingWithDelay(loading ?? false, 250);
34
+
35
+ React.useEffect(() => {
36
+ if ((loading === undefined || loading === null) && (onPullDownRefresh || onPullUpLoading)) {
37
+ throw new Error("Loading must be specify when given either onPullDownRefresh or onPullUpLoading");
38
+ }
39
+ }, [onPullDownRefresh, onPullUpLoading, loading]);
40
+
41
+ // Automatically loading new data when scroll near the bottom
42
+ const onScroll = (e: React.UIEvent) => {
43
+ if (!loadingWithDelay && onPullUpLoading) {
44
+ const {scrollHeight, scrollTop, clientHeight} = e.currentTarget;
45
+ if (scrollHeight * 0.8 < clientHeight + scrollTop) {
46
+ setLoadingType("loading");
47
+ onPullUpLoading?.();
48
+ }
49
+ }
50
+ };
51
+
52
+ const margin = React.useMemo(
53
+ (): React.CSSProperties => (gap ? (typeof gap === "number" ? {margin: gap} : {marginLeft: gap.left, marginRight: gap.right, marginBottom: gap.bottom, marginTop: gap.top}) : {}),
54
+ [gap]
55
+ );
56
+
57
+ return (
58
+ <Wrapper
59
+ className={classNames("g-flat-list", className)}
60
+ listWrapperRef={listWrapperRef}
61
+ bounceEffect={bounceEffect}
62
+ innerStyle={contentStyle}
63
+ loadingType={loadingType}
64
+ onLoadingTypeChange={setLoadingType}
65
+ loading={loadingWithDelay}
66
+ style={style}
67
+ onPullDownRefresh={onPullDownRefresh}
68
+ onPullUpLoading={onPullUpLoading}
69
+ pullDownRefreshMessage={pullDownRefreshMessage}
70
+ pullDownRefreshingMessage={pullDownRefreshingMessage}
71
+ onScroll={onScroll}
72
+ >
73
+ {data.length === 0 ? (
74
+ emptyPlaceholder
75
+ ) : (
76
+ <div className="list">
77
+ {data.map((d, i) => (
78
+ <div className="g-flat-list-item" key={GetRowKey(rowKey, d, i)} style={{...margin}}>
79
+ <ItemRenderer data={d} index={i} />
80
+ </div>
81
+ ))}
82
+ {!hideFooter && (
83
+ <Footer
84
+ loading={loadingWithDelay && loadingType === "loading"}
85
+ ended={!onPullUpLoading}
86
+ loadMoreMessage={pullUpLoadMoreMessage}
87
+ loadingMessage={pullUpLoadingMessage}
88
+ endMessage={endOfListMessage}
89
+ />
90
+ )}
91
+ </div>
92
+ )}
93
+ </Wrapper>
94
+ );
95
+ };
@@ -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 Omit<FooterData, "__markedAsFooterData"> {
8
+ measure?: Measure;
9
+ }
10
+
11
+ export const Footer = (props: Props) => {
12
+ const {loading, ended, loadMoreMessage, 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 && (typeof loadingMessage !== "object" ? <Spinner loading message={loadingMessage ?? "loading..."} /> : loadingMessage)}
19
+ {ended && !loading && (endMessage ?? "All data loaded")}
20
+ {!ended && !loading && (loadMoreMessage ?? "Pull up to loading more")}
21
+ </div>
22
+ );
23
+ };
@@ -0,0 +1,11 @@
1
+ import type {RowKey} from "../type";
2
+
3
+ export function GetRowKey<T>(rowKey: RowKey<T>, data: T, index: number): string | number {
4
+ if (rowKey === "index") {
5
+ return index;
6
+ } else if (typeof rowKey === "function") {
7
+ return rowKey(data, index);
8
+ } else {
9
+ return data[rowKey] as any;
10
+ }
11
+ }
@@ -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,17 @@
1
+ import React from "react";
2
+ import {Spinner} from "../Spinner";
3
+
4
+ interface Props {
5
+ loading: boolean;
6
+ message?: React.ReactElement | string;
7
+ loadingMessage?: React.ReactElement | string;
8
+ }
9
+
10
+ export const Loading = (props: Props) => {
11
+ const {loading, message, loadingMessage} = props;
12
+ return (
13
+ <div className="g-flat-list-loading">
14
+ {loading ? typeof loadingMessage !== "object" ? <Spinner loading={loading} message={loadingMessage ?? "loading..."} /> : loadingMessage : message ?? "Release to refresh"}
15
+ </div>
16
+ );
17
+ };
@@ -0,0 +1,123 @@
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>
13
+ extends Pick<FlatListProps<T>, "loading" | "bounceEffect" | "onPullUpLoading" | "onPullDownRefresh" | "className" | "style" | "pullDownRefreshMessage" | "pullDownRefreshingMessage"> {
14
+ children: React.ReactNode;
15
+ listWrapperRef: React.RefObject<HTMLDivElement>;
16
+ loadingType: LoadingType;
17
+ onLoadingTypeChange: (type: LoadingType) => void;
18
+ innerClassName?: string;
19
+ innerStyle?: React.CSSProperties;
20
+ onScroll?: (event: React.UIEvent) => void;
21
+ }
22
+
23
+ export const Wrapper = function <T>(props: Props<T>) {
24
+ const {
25
+ children,
26
+ bounceEffect,
27
+ listWrapperRef,
28
+ loadingType,
29
+ onLoadingTypeChange,
30
+ loading = false,
31
+ onPullDownRefresh,
32
+ onPullUpLoading,
33
+ className,
34
+ innerClassName,
35
+ style,
36
+ innerStyle,
37
+ pullDownRefreshMessage,
38
+ pullDownRefreshingMessage,
39
+ onScroll,
40
+ } = props;
41
+ const startOffsetRef = React.useRef(0);
42
+
43
+ const animatedRef = React.useRef<HTMLDivElement>(null);
44
+
45
+ const loadingTypeRef = React.useRef<LoadingType>(null);
46
+ loadingTypeRef.current = loadingType;
47
+
48
+ const onLoadingTypeChangeRef = React.useRef(onLoadingTypeChange);
49
+ onLoadingTypeChangeRef.current = onLoadingTypeChange;
50
+
51
+ const {isScrollable} = useElementScrollState(listWrapperRef);
52
+ const transform = useTransform(animatedRef);
53
+ const transformRef = React.useRef(transform);
54
+ transformRef.current = transform;
55
+
56
+ const reset = React.useCallback(() => {
57
+ startOffsetRef.current = 0;
58
+ }, []);
59
+
60
+ const handlers = useBounceSwipe({
61
+ axis: "vertical",
62
+ contentRef: listWrapperRef,
63
+ animatedRef,
64
+ onStart: ({delta: [, y]}) => {
65
+ startOffsetRef.current = y;
66
+ },
67
+ onEnd: ({delta, direction, boundary}) => {
68
+ if (loading) {
69
+ if (boundary !== "upper") {
70
+ transform.to({
71
+ y: PULL_DOWN_REFRESH_THRESHOLD,
72
+ });
73
+ }
74
+ } else {
75
+ if (Math.abs(startOffsetRef.current - delta[1]) >= PULL_DOWN_REFRESH_THRESHOLD) {
76
+ const scrollable = isScrollable("vertical");
77
+ if (boundary === "upper" || (!scrollable && direction === Direction.DOWN)) {
78
+ onLoadingTypeChange("refresh");
79
+ onPullDownRefresh?.();
80
+ } else {
81
+ onLoadingTypeChange("loading");
82
+ onPullUpLoading?.();
83
+ }
84
+ }
85
+ }
86
+ reset();
87
+ },
88
+ onCancel: reset,
89
+ });
90
+
91
+ const handleScroll = React.useCallback(
92
+ (e: React.UIEvent) => {
93
+ transformRef.current.clear();
94
+ onScroll?.(e);
95
+ },
96
+ [onScroll]
97
+ );
98
+
99
+ React.useEffect(() => {
100
+ if (loading) {
101
+ if (loadingTypeRef.current === "refresh") {
102
+ transformRef.current.to({
103
+ y: PULL_DOWN_REFRESH_THRESHOLD,
104
+ immediate: false,
105
+ });
106
+ }
107
+ } else {
108
+ transformRef.current.clear();
109
+ onLoadingTypeChangeRef.current(null);
110
+ }
111
+ }, [loading]);
112
+
113
+ return (
114
+ <div className={classNames(className, "g-flat-list-wrapper")} style={style} {...(bounceEffect ? handlers : {})}>
115
+ <div className={classNames("inner-container", innerClassName)} style={innerStyle} ref={animatedRef}>
116
+ <Loading loading={loading && loadingType === "refresh"} message={pullDownRefreshMessage} loadingMessage={pullDownRefreshingMessage} />
117
+ <div className="list-wrapper" ref={listWrapperRef} onScroll={handleScroll}>
118
+ {children}
119
+ </div>
120
+ </div>
121
+ </div>
122
+ );
123
+ };
@@ -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
+ };