@ioca/react 1.4.80 → 1.4.81
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/lib/cjs/components/affix/affix.js +68 -63
- package/lib/cjs/components/affix/affix.js.map +1 -1
- package/lib/cjs/components/affix/index.js +9 -5
- package/lib/cjs/components/affix/index.js.map +1 -1
- package/lib/cjs/components/affix/totop.js +18 -22
- package/lib/cjs/components/affix/totop.js.map +1 -1
- package/lib/cjs/components/badge/badge.js +18 -21
- package/lib/cjs/components/badge/badge.js.map +1 -1
- package/lib/cjs/components/badge/index.js +9 -5
- package/lib/cjs/components/badge/index.js.map +1 -1
- package/lib/cjs/components/button/button.js +68 -60
- package/lib/cjs/components/button/button.js.map +1 -1
- package/lib/cjs/components/button/confirm.js +51 -53
- package/lib/cjs/components/button/confirm.js.map +1 -1
- package/lib/cjs/components/button/group.js +26 -23
- package/lib/cjs/components/button/group.js.map +1 -1
- package/lib/cjs/components/button/index.js +9 -5
- package/lib/cjs/components/button/index.js.map +1 -1
- package/lib/cjs/components/button/toggle.js +44 -43
- package/lib/cjs/components/button/toggle.js.map +1 -1
- package/lib/cjs/components/card/card.js +18 -30
- package/lib/cjs/components/card/card.js.map +1 -1
- package/lib/cjs/components/card/index.js +9 -5
- package/lib/cjs/components/card/index.js.map +1 -1
- package/lib/cjs/components/checkbox/checkbox.js +44 -63
- package/lib/cjs/components/checkbox/checkbox.js.map +1 -1
- package/lib/cjs/components/checkbox/index.js +9 -5
- package/lib/cjs/components/checkbox/index.js.map +1 -1
- package/lib/cjs/components/checkbox/item.js +40 -56
- package/lib/cjs/components/checkbox/item.js.map +1 -1
- package/lib/cjs/components/collapse/collapse.js +77 -81
- package/lib/cjs/components/collapse/collapse.js.map +1 -1
- package/lib/cjs/components/collapse/index.js +9 -5
- package/lib/cjs/components/collapse/index.js.map +1 -1
- package/lib/cjs/components/collapse/item.js +9 -7
- package/lib/cjs/components/collapse/item.js.map +1 -1
- package/lib/cjs/components/datagrid/cell.js +26 -34
- package/lib/cjs/components/datagrid/cell.js.map +1 -1
- package/lib/cjs/components/datagrid/datagrid.js +118 -137
- package/lib/cjs/components/datagrid/datagrid.js.map +1 -1
- package/lib/cjs/components/datagrid/index.js +9 -5
- package/lib/cjs/components/datagrid/index.js.map +1 -1
- package/lib/cjs/components/datagrid/resize.js +41 -39
- package/lib/cjs/components/datagrid/resize.js.map +1 -1
- package/lib/cjs/components/datagrid/row.js +35 -62
- package/lib/cjs/components/datagrid/row.js.map +1 -1
- package/lib/cjs/components/datagrid/sorter.js +18 -25
- package/lib/cjs/components/datagrid/sorter.js.map +1 -1
- package/lib/cjs/components/description/description.js +33 -40
- package/lib/cjs/components/description/description.js.map +1 -1
- package/lib/cjs/components/description/index.js +9 -5
- package/lib/cjs/components/description/index.js.map +1 -1
- package/lib/cjs/components/drawer/drawer.js +71 -81
- package/lib/cjs/components/drawer/drawer.js.map +1 -1
- package/lib/cjs/components/drawer/index.js +9 -5
- package/lib/cjs/components/drawer/index.js.map +1 -1
- package/lib/cjs/components/dropdown/dropdown.js +30 -35
- package/lib/cjs/components/dropdown/dropdown.js.map +1 -1
- package/lib/cjs/components/dropdown/index.js +9 -5
- package/lib/cjs/components/dropdown/index.js.map +1 -1
- package/lib/cjs/components/dropdown/item.js +19 -33
- package/lib/cjs/components/dropdown/item.js.map +1 -1
- package/lib/cjs/components/editor/controls.js +84 -78
- package/lib/cjs/components/editor/controls.js.map +1 -1
- package/lib/cjs/components/editor/editor.js +86 -88
- package/lib/cjs/components/editor/editor.js.map +1 -1
- package/lib/cjs/components/editor/index.js +9 -5
- package/lib/cjs/components/editor/index.js.map +1 -1
- package/lib/cjs/components/flex/flex.js +33 -28
- package/lib/cjs/components/flex/flex.js.map +1 -1
- package/lib/cjs/components/flex/index.js +9 -5
- package/lib/cjs/components/flex/index.js.map +1 -1
- package/lib/cjs/components/form/context.js +9 -6
- package/lib/cjs/components/form/context.js.map +1 -1
- package/lib/cjs/components/form/field.js +74 -68
- package/lib/cjs/components/form/field.js.map +1 -1
- package/lib/cjs/components/form/form.js +65 -61
- package/lib/cjs/components/form/form.js.map +1 -1
- package/lib/cjs/components/form/index.js +9 -5
- package/lib/cjs/components/form/index.js.map +1 -1
- package/lib/cjs/components/form/useConfig.js +35 -42
- package/lib/cjs/components/form/useConfig.js.map +1 -1
- package/lib/cjs/components/form/useForm.js +139 -120
- package/lib/cjs/components/form/useForm.js.map +1 -1
- package/lib/cjs/components/icon/icon.js +28 -21
- package/lib/cjs/components/icon/icon.js.map +1 -1
- package/lib/cjs/components/icon/index.js +9 -5
- package/lib/cjs/components/icon/index.js.map +1 -1
- package/lib/cjs/components/image/image.js +84 -83
- package/lib/cjs/components/image/image.js.map +1 -1
- package/lib/cjs/components/image/index.js +9 -5
- package/lib/cjs/components/image/index.js.map +1 -1
- package/lib/cjs/components/image/list.js +44 -46
- package/lib/cjs/components/image/list.js.map +1 -1
- package/lib/cjs/components/input/container.js +19 -27
- package/lib/cjs/components/input/container.js.map +1 -1
- package/lib/cjs/components/input/index.js +9 -5
- package/lib/cjs/components/input/index.js.map +1 -1
- package/lib/cjs/components/input/input.js +80 -110
- package/lib/cjs/components/input/input.js.map +1 -1
- package/lib/cjs/components/input/number.js +114 -135
- package/lib/cjs/components/input/number.js.map +1 -1
- package/lib/cjs/components/input/range.js +78 -131
- package/lib/cjs/components/input/range.js.map +1 -1
- package/lib/cjs/components/input/textarea.js +54 -58
- package/lib/cjs/components/input/textarea.js.map +1 -1
- package/lib/cjs/components/list/index.js +9 -5
- package/lib/cjs/components/list/index.js.map +1 -1
- package/lib/cjs/components/list/item.js +20 -27
- package/lib/cjs/components/list/item.js.map +1 -1
- package/lib/cjs/components/list/list.js +30 -27
- package/lib/cjs/components/list/list.js.map +1 -1
- package/lib/cjs/components/loading/index.js +9 -5
- package/lib/cjs/components/loading/index.js.map +1 -1
- package/lib/cjs/components/loading/loading.js +22 -36
- package/lib/cjs/components/loading/loading.js.map +1 -1
- package/lib/cjs/components/message/index.js +9 -5
- package/lib/cjs/components/message/index.js.map +1 -1
- package/lib/cjs/components/message/message.js +162 -163
- package/lib/cjs/components/message/message.js.map +1 -1
- package/lib/cjs/components/modal/content.js +34 -54
- package/lib/cjs/components/modal/content.js.map +1 -1
- package/lib/cjs/components/modal/context.js +9 -6
- package/lib/cjs/components/modal/context.js.map +1 -1
- package/lib/cjs/components/modal/hookModal.js +28 -25
- package/lib/cjs/components/modal/hookModal.js.map +1 -1
- package/lib/cjs/components/modal/index.js +9 -5
- package/lib/cjs/components/modal/index.js.map +1 -1
- package/lib/cjs/components/modal/modal.js +96 -114
- package/lib/cjs/components/modal/modal.js.map +1 -1
- package/lib/cjs/components/modal/useModal.js +35 -36
- package/lib/cjs/components/modal/useModal.js.map +1 -1
- package/lib/cjs/components/pagination/index.js +9 -5
- package/lib/cjs/components/pagination/index.js.map +1 -1
- package/lib/cjs/components/pagination/page.js +29 -28
- package/lib/cjs/components/pagination/page.js.map +1 -1
- package/lib/cjs/components/pagination/pagination.js +49 -83
- package/lib/cjs/components/pagination/pagination.js.map +1 -1
- package/lib/cjs/components/picker/colors/footer.js +33 -58
- package/lib/cjs/components/picker/colors/footer.js.map +1 -1
- package/lib/cjs/components/picker/colors/handle.js +15 -22
- package/lib/cjs/components/picker/colors/handle.js.map +1 -1
- package/lib/cjs/components/picker/colors/index.js +64 -78
- package/lib/cjs/components/picker/colors/index.js.map +1 -1
- package/lib/cjs/components/picker/dates/dates.js +52 -65
- package/lib/cjs/components/picker/dates/dates.js.map +1 -1
- package/lib/cjs/components/picker/dates/index.js +65 -93
- package/lib/cjs/components/picker/dates/index.js.map +1 -1
- package/lib/cjs/components/picker/dates/panel.js +75 -146
- package/lib/cjs/components/picker/dates/panel.js.map +1 -1
- package/lib/cjs/components/picker/time/index.js +46 -69
- package/lib/cjs/components/picker/time/index.js.map +1 -1
- package/lib/cjs/components/picker/time/item.js +20 -17
- package/lib/cjs/components/picker/time/item.js.map +1 -1
- package/lib/cjs/components/picker/time/panel.js +99 -139
- package/lib/cjs/components/picker/time/panel.js.map +1 -1
- package/lib/cjs/components/popconfirm/index.js +9 -5
- package/lib/cjs/components/popconfirm/index.js.map +1 -1
- package/lib/cjs/components/popconfirm/popconfirm.js +52 -81
- package/lib/cjs/components/popconfirm/popconfirm.js.map +1 -1
- package/lib/cjs/components/popup/content.js +49 -54
- package/lib/cjs/components/popup/content.js.map +1 -1
- package/lib/cjs/components/popup/index.js +9 -5
- package/lib/cjs/components/popup/index.js.map +1 -1
- package/lib/cjs/components/popup/popup.js +462 -422
- package/lib/cjs/components/popup/popup.js.map +1 -1
- package/lib/cjs/components/progress/circle.js +13 -42
- package/lib/cjs/components/progress/circle.js.map +1 -1
- package/lib/cjs/components/progress/index.js +9 -5
- package/lib/cjs/components/progress/index.js.map +1 -1
- package/lib/cjs/components/progress/line.js +19 -24
- package/lib/cjs/components/progress/line.js.map +1 -1
- package/lib/cjs/components/progress/progress.js +87 -97
- package/lib/cjs/components/progress/progress.js.map +1 -1
- package/lib/cjs/components/radio/index.js +9 -5
- package/lib/cjs/components/radio/index.js.map +1 -1
- package/lib/cjs/components/radio/item.js +22 -31
- package/lib/cjs/components/radio/item.js.map +1 -1
- package/lib/cjs/components/radio/radio.js +37 -59
- package/lib/cjs/components/radio/radio.js.map +1 -1
- package/lib/cjs/components/resizable/index.js +9 -5
- package/lib/cjs/components/resizable/index.js.map +1 -1
- package/lib/cjs/components/resizable/resizable.js +65 -78
- package/lib/cjs/components/resizable/resizable.js.map +1 -1
- package/lib/cjs/components/river/index.js +9 -5
- package/lib/cjs/components/river/index.js.map +1 -1
- package/lib/cjs/components/river/river.js +111 -113
- package/lib/cjs/components/river/river.js.map +1 -1
- package/lib/cjs/components/select/index.js +9 -5
- package/lib/cjs/components/select/index.js.map +1 -1
- package/lib/cjs/components/select/options.js +47 -68
- package/lib/cjs/components/select/options.js.map +1 -1
- package/lib/cjs/components/select/select.js +100 -152
- package/lib/cjs/components/select/select.js.map +1 -1
- package/lib/cjs/components/step/divider.js +9 -7
- package/lib/cjs/components/step/divider.js.map +1 -1
- package/lib/cjs/components/step/index.js +9 -5
- package/lib/cjs/components/step/index.js.map +1 -1
- package/lib/cjs/components/step/item.js +25 -55
- package/lib/cjs/components/step/item.js.map +1 -1
- package/lib/cjs/components/step/step.js +41 -39
- package/lib/cjs/components/step/step.js.map +1 -1
- package/lib/cjs/components/swiper/index.js +9 -5
- package/lib/cjs/components/swiper/index.js.map +1 -1
- package/lib/cjs/components/swiper/item.js +30 -36
- package/lib/cjs/components/swiper/item.js.map +1 -1
- package/lib/cjs/components/swiper/swiper.js +238 -259
- package/lib/cjs/components/swiper/swiper.js.map +1 -1
- package/lib/cjs/components/tabs/index.js +9 -5
- package/lib/cjs/components/tabs/index.js.map +1 -1
- package/lib/cjs/components/tabs/item.js +9 -7
- package/lib/cjs/components/tabs/item.js.map +1 -1
- package/lib/cjs/components/tabs/tabs.js +225 -269
- package/lib/cjs/components/tabs/tabs.js.map +1 -1
- package/lib/cjs/components/tag/index.js +9 -5
- package/lib/cjs/components/tag/index.js.map +1 -1
- package/lib/cjs/components/tag/tag.js +23 -29
- package/lib/cjs/components/tag/tag.js.map +1 -1
- package/lib/cjs/components/text/highlight.js +29 -32
- package/lib/cjs/components/text/highlight.js.map +1 -1
- package/lib/cjs/components/text/index.js +9 -5
- package/lib/cjs/components/text/index.js.map +1 -1
- package/lib/cjs/components/text/number.js +28 -29
- package/lib/cjs/components/text/number.js.map +1 -1
- package/lib/cjs/components/text/text.js +39 -36
- package/lib/cjs/components/text/text.js.map +1 -1
- package/lib/cjs/components/text/time.js +21 -21
- package/lib/cjs/components/text/time.js.map +1 -1
- package/lib/cjs/components/tree/index.js +9 -5
- package/lib/cjs/components/tree/index.js.map +1 -1
- package/lib/cjs/components/tree/item.js +73 -129
- package/lib/cjs/components/tree/item.js.map +1 -1
- package/lib/cjs/components/tree/tree.js +129 -122
- package/lib/cjs/components/tree/tree.js.map +1 -1
- package/lib/cjs/components/upload/index.js +9 -5
- package/lib/cjs/components/upload/index.js.map +1 -1
- package/lib/cjs/components/upload/renderFile.js +63 -93
- package/lib/cjs/components/upload/renderFile.js.map +1 -1
- package/lib/cjs/components/upload/upload.js +123 -162
- package/lib/cjs/components/upload/upload.js.map +1 -1
- package/lib/cjs/components/utils/empty/index.js +16 -14
- package/lib/cjs/components/utils/empty/index.js.map +1 -1
- package/lib/cjs/components/utils/helpericon/helpericon.js +29 -21
- package/lib/cjs/components/utils/helpericon/helpericon.js.map +1 -1
- package/lib/cjs/components/utils/helpericon/index.js +9 -5
- package/lib/cjs/components/utils/helpericon/index.js.map +1 -1
- package/lib/cjs/components/video/index.js +9 -5
- package/lib/cjs/components/video/index.js.map +1 -1
- package/lib/cjs/components/video/video.js +178 -234
- package/lib/cjs/components/video/video.js.map +1 -1
- package/lib/cjs/index.js +88 -83
- package/lib/cjs/index.js.map +1 -0
- package/lib/cjs/js/hooks.js +273 -228
- package/lib/cjs/js/hooks.js.map +1 -1
- package/lib/cjs/js/usePreview/content.js +161 -194
- package/lib/cjs/js/usePreview/content.js.map +1 -1
- package/lib/cjs/js/usePreview/index.js +24 -36
- package/lib/cjs/js/usePreview/index.js.map +1 -1
- package/lib/cjs/js/usePreview/renderFile.js +21 -25
- package/lib/cjs/js/usePreview/renderFile.js.map +1 -1
- package/lib/cjs/js/usePreview/type.js +12 -14
- package/lib/cjs/js/usePreview/type.js.map +1 -1
- package/lib/cjs/js/useRipple/index.js +36 -30
- package/lib/cjs/js/useRipple/index.js.map +1 -1
- package/lib/cjs/js/useTheme/index.js +34 -27
- package/lib/cjs/js/useTheme/index.js.map +1 -1
- package/lib/cjs/js/utils.js +257 -239
- package/lib/cjs/js/utils.js.map +1 -1
- package/lib/css/index.css +3 -0
- package/lib/css/index.css.map +1 -0
- package/lib/es/components/affix/affix.js +59 -60
- package/lib/es/components/affix/affix.js.map +1 -1
- package/lib/es/components/affix/index.js +5 -6
- package/lib/es/components/affix/index.js.map +1 -1
- package/lib/es/components/affix/totop.js +10 -20
- package/lib/es/components/affix/totop.js.map +1 -1
- package/lib/es/components/badge/badge.js +10 -19
- package/lib/es/components/badge/badge.js.map +1 -1
- package/lib/es/components/badge/index.js +5 -6
- package/lib/es/components/badge/index.js.map +1 -1
- package/lib/es/components/button/button.js +57 -55
- package/lib/es/components/button/button.js.map +1 -1
- package/lib/es/components/button/confirm.js +47 -52
- package/lib/es/components/button/confirm.js.map +1 -1
- package/lib/es/components/button/group.js +18 -21
- package/lib/es/components/button/group.js.map +1 -1
- package/lib/es/components/button/index.js +5 -6
- package/lib/es/components/button/index.js.map +1 -1
- package/lib/es/components/button/toggle.js +36 -41
- package/lib/es/components/button/toggle.js.map +1 -1
- package/lib/es/components/card/card.js +10 -28
- package/lib/es/components/card/card.js.map +1 -1
- package/lib/es/components/card/index.js +5 -6
- package/lib/es/components/card/index.js.map +1 -1
- package/lib/es/components/checkbox/checkbox.js +35 -60
- package/lib/es/components/checkbox/checkbox.js.map +1 -1
- package/lib/es/components/checkbox/index.js +5 -6
- package/lib/es/components/checkbox/index.js.map +1 -1
- package/lib/es/components/checkbox/item.js +32 -54
- package/lib/es/components/checkbox/item.js.map +1 -1
- package/lib/es/components/collapse/collapse.js +68 -78
- package/lib/es/components/collapse/collapse.js.map +1 -1
- package/lib/es/components/collapse/index.js +5 -6
- package/lib/es/components/collapse/index.js.map +1 -1
- package/lib/es/components/collapse/item.js +5 -6
- package/lib/es/components/collapse/item.js.map +1 -1
- package/lib/es/components/datagrid/cell.js +20 -32
- package/lib/es/components/datagrid/cell.js.map +1 -1
- package/lib/es/components/datagrid/datagrid.js +110 -135
- package/lib/es/components/datagrid/datagrid.js.map +1 -1
- package/lib/es/components/datagrid/index.js +5 -6
- package/lib/es/components/datagrid/index.js.map +1 -1
- package/lib/es/components/datagrid/resize.js +37 -38
- package/lib/es/components/datagrid/resize.js.map +1 -1
- package/lib/es/components/datagrid/row.js +27 -60
- package/lib/es/components/datagrid/row.js.map +1 -1
- package/lib/es/components/datagrid/sorter.js +10 -23
- package/lib/es/components/datagrid/sorter.js.map +1 -1
- package/lib/es/components/description/description.js +25 -38
- package/lib/es/components/description/description.js.map +1 -1
- package/lib/es/components/description/index.js +5 -6
- package/lib/es/components/description/index.js.map +1 -1
- package/lib/es/components/drawer/drawer.js +63 -79
- package/lib/es/components/drawer/drawer.js.map +1 -1
- package/lib/es/components/drawer/index.js +5 -6
- package/lib/es/components/drawer/index.js.map +1 -1
- package/lib/es/components/dropdown/dropdown.js +25 -33
- package/lib/es/components/dropdown/dropdown.js.map +1 -1
- package/lib/es/components/dropdown/index.js +5 -6
- package/lib/es/components/dropdown/index.js.map +1 -1
- package/lib/es/components/dropdown/item.js +15 -32
- package/lib/es/components/dropdown/item.js.map +1 -1
- package/lib/es/components/editor/controls.js +75 -75
- package/lib/es/components/editor/controls.js.map +1 -1
- package/lib/es/components/editor/editor.js +77 -85
- package/lib/es/components/editor/editor.js.map +1 -1
- package/lib/es/components/editor/index.js +5 -6
- package/lib/es/components/editor/index.js.map +1 -1
- package/lib/es/components/flex/flex.js +25 -26
- package/lib/es/components/flex/flex.js.map +1 -1
- package/lib/es/components/flex/index.js +5 -6
- package/lib/es/components/flex/index.js.map +1 -1
- package/lib/es/components/form/context.js +4 -5
- package/lib/es/components/form/context.js.map +1 -1
- package/lib/es/components/form/field.js +66 -66
- package/lib/es/components/form/field.js.map +1 -1
- package/lib/es/components/form/form.js +53 -55
- package/lib/es/components/form/form.js.map +1 -1
- package/lib/es/components/form/index.js +5 -6
- package/lib/es/components/form/index.js.map +1 -1
- package/lib/es/components/form/useConfig.js +31 -41
- package/lib/es/components/form/useConfig.js.map +1 -1
- package/lib/es/components/form/useForm.js +130 -118
- package/lib/es/components/form/useForm.js.map +1 -1
- package/lib/es/components/icon/icon.js +20 -19
- package/lib/es/components/icon/icon.js.map +1 -1
- package/lib/es/components/icon/index.js +5 -6
- package/lib/es/components/icon/index.js.map +1 -1
- package/lib/es/components/image/image.js +75 -80
- package/lib/es/components/image/image.js.map +1 -1
- package/lib/es/components/image/index.js +5 -6
- package/lib/es/components/image/index.js.map +1 -1
- package/lib/es/components/image/list.js +40 -45
- package/lib/es/components/image/list.js.map +1 -1
- package/lib/es/components/input/container.js +11 -25
- package/lib/es/components/input/container.js.map +1 -1
- package/lib/es/components/input/index.js +5 -6
- package/lib/es/components/input/index.js.map +1 -1
- package/lib/es/components/input/input.js +69 -105
- package/lib/es/components/input/input.js.map +1 -1
- package/lib/es/components/input/number.js +106 -133
- package/lib/es/components/input/number.js.map +1 -1
- package/lib/es/components/input/range.js +70 -129
- package/lib/es/components/input/range.js.map +1 -1
- package/lib/es/components/input/textarea.js +46 -56
- package/lib/es/components/input/textarea.js.map +1 -1
- package/lib/es/components/list/index.js +5 -6
- package/lib/es/components/list/index.js.map +1 -1
- package/lib/es/components/list/item.js +12 -25
- package/lib/es/components/list/item.js.map +1 -1
- package/lib/es/components/list/list.js +21 -24
- package/lib/es/components/list/list.js.map +1 -1
- package/lib/es/components/loading/index.js +5 -6
- package/lib/es/components/loading/index.js.map +1 -1
- package/lib/es/components/loading/loading.js +14 -34
- package/lib/es/components/loading/loading.js.map +1 -1
- package/lib/es/components/message/index.js +5 -6
- package/lib/es/components/message/index.js.map +1 -1
- package/lib/es/components/message/message.js +154 -161
- package/lib/es/components/message/message.js.map +1 -1
- package/lib/es/components/modal/content.js +30 -53
- package/lib/es/components/modal/content.js.map +1 -1
- package/lib/es/components/modal/context.js +4 -5
- package/lib/es/components/modal/context.js.map +1 -1
- package/lib/es/components/modal/hookModal.js +24 -24
- package/lib/es/components/modal/hookModal.js.map +1 -1
- package/lib/es/components/modal/index.js +5 -6
- package/lib/es/components/modal/index.js.map +1 -1
- package/lib/es/components/modal/modal.js +87 -111
- package/lib/es/components/modal/modal.js.map +1 -1
- package/lib/es/components/modal/useModal.js +31 -35
- package/lib/es/components/modal/useModal.js.map +1 -1
- package/lib/es/components/pagination/index.js +5 -6
- package/lib/es/components/pagination/index.js.map +1 -1
- package/lib/es/components/pagination/page.js +21 -26
- package/lib/es/components/pagination/page.js.map +1 -1
- package/lib/es/components/pagination/pagination.js +41 -81
- package/lib/es/components/pagination/pagination.js.map +1 -1
- package/lib/es/components/picker/colors/footer.js +29 -57
- package/lib/es/components/picker/colors/footer.js.map +1 -1
- package/lib/es/components/picker/colors/handle.js +7 -20
- package/lib/es/components/picker/colors/handle.js.map +1 -1
- package/lib/es/components/picker/colors/index.js +56 -76
- package/lib/es/components/picker/colors/index.js.map +1 -1
- package/lib/es/components/picker/dates/dates.js +43 -62
- package/lib/es/components/picker/dates/dates.js.map +1 -1
- package/lib/es/components/picker/dates/index.js +54 -88
- package/lib/es/components/picker/dates/index.js.map +1 -1
- package/lib/es/components/picker/dates/panel.js +66 -143
- package/lib/es/components/picker/dates/panel.js.map +1 -1
- package/lib/es/components/picker/time/index.js +38 -67
- package/lib/es/components/picker/time/index.js.map +1 -1
- package/lib/es/components/picker/time/item.js +12 -15
- package/lib/es/components/picker/time/item.js.map +1 -1
- package/lib/es/components/picker/time/panel.js +95 -138
- package/lib/es/components/picker/time/panel.js.map +1 -1
- package/lib/es/components/popconfirm/index.js +5 -6
- package/lib/es/components/popconfirm/index.js.map +1 -1
- package/lib/es/components/popconfirm/popconfirm.js +48 -80
- package/lib/es/components/popconfirm/popconfirm.js.map +1 -1
- package/lib/es/components/popup/content.js +40 -51
- package/lib/es/components/popup/content.js.map +1 -1
- package/lib/es/components/popup/index.js +5 -6
- package/lib/es/components/popup/index.js.map +1 -1
- package/lib/es/components/popup/popup.js +458 -421
- package/lib/es/components/popup/popup.js.map +1 -1
- package/lib/es/components/progress/circle.js +9 -41
- package/lib/es/components/progress/circle.js.map +1 -1
- package/lib/es/components/progress/index.js +5 -6
- package/lib/es/components/progress/index.js.map +1 -1
- package/lib/es/components/progress/line.js +11 -22
- package/lib/es/components/progress/line.js.map +1 -1
- package/lib/es/components/progress/progress.js +79 -95
- package/lib/es/components/progress/progress.js.map +1 -1
- package/lib/es/components/radio/index.js +5 -6
- package/lib/es/components/radio/index.js.map +1 -1
- package/lib/es/components/radio/item.js +14 -29
- package/lib/es/components/radio/item.js.map +1 -1
- package/lib/es/components/radio/radio.js +28 -56
- package/lib/es/components/radio/radio.js.map +1 -1
- package/lib/es/components/resizable/index.js +5 -6
- package/lib/es/components/resizable/index.js.map +1 -1
- package/lib/es/components/resizable/resizable.js +57 -76
- package/lib/es/components/resizable/resizable.js.map +1 -1
- package/lib/es/components/river/index.js +5 -6
- package/lib/es/components/river/index.js.map +1 -1
- package/lib/es/components/river/river.js +103 -111
- package/lib/es/components/river/river.js.map +1 -1
- package/lib/es/components/select/index.js +5 -6
- package/lib/es/components/select/index.js.map +1 -1
- package/lib/es/components/select/options.js +40 -66
- package/lib/es/components/select/options.js.map +1 -1
- package/lib/es/components/select/select.js +92 -150
- package/lib/es/components/select/select.js.map +1 -1
- package/lib/es/components/step/divider.js +5 -6
- package/lib/es/components/step/divider.js.map +1 -1
- package/lib/es/components/step/index.js +5 -6
- package/lib/es/components/step/index.js.map +1 -1
- package/lib/es/components/step/item.js +17 -53
- package/lib/es/components/step/item.js.map +1 -1
- package/lib/es/components/step/step.js +32 -36
- package/lib/es/components/step/step.js.map +1 -1
- package/lib/es/components/swiper/index.js +5 -6
- package/lib/es/components/swiper/index.js.map +1 -1
- package/lib/es/components/swiper/item.js +22 -34
- package/lib/es/components/swiper/item.js.map +1 -1
- package/lib/es/components/swiper/swiper.js +229 -256
- package/lib/es/components/swiper/swiper.js.map +1 -1
- package/lib/es/components/tabs/index.js +5 -6
- package/lib/es/components/tabs/index.js.map +1 -1
- package/lib/es/components/tabs/item.js +5 -6
- package/lib/es/components/tabs/item.js.map +1 -1
- package/lib/es/components/tabs/tabs.js +216 -266
- package/lib/es/components/tabs/tabs.js.map +1 -1
- package/lib/es/components/tag/index.js +5 -6
- package/lib/es/components/tag/index.js.map +1 -1
- package/lib/es/components/tag/tag.js +15 -27
- package/lib/es/components/tag/tag.js.map +1 -1
- package/lib/es/components/text/highlight.js +25 -31
- package/lib/es/components/text/highlight.js.map +1 -1
- package/lib/es/components/text/index.js +5 -6
- package/lib/es/components/text/index.js.map +1 -1
- package/lib/es/components/text/number.js +24 -28
- package/lib/es/components/text/number.js.map +1 -1
- package/lib/es/components/text/text.js +28 -31
- package/lib/es/components/text/text.js.map +1 -1
- package/lib/es/components/text/time.js +17 -20
- package/lib/es/components/text/time.js.map +1 -1
- package/lib/es/components/tree/index.js +5 -6
- package/lib/es/components/tree/index.js.map +1 -1
- package/lib/es/components/tree/item.js +66 -127
- package/lib/es/components/tree/item.js.map +1 -1
- package/lib/es/components/tree/tree.js +125 -121
- package/lib/es/components/tree/tree.js.map +1 -1
- package/lib/es/components/upload/index.js +5 -6
- package/lib/es/components/upload/index.js.map +1 -1
- package/lib/es/components/upload/renderFile.js +55 -91
- package/lib/es/components/upload/renderFile.js.map +1 -1
- package/lib/es/components/upload/upload.js +115 -160
- package/lib/es/components/upload/upload.js.map +1 -1
- package/lib/es/components/utils/empty/index.js +8 -12
- package/lib/es/components/utils/empty/index.js.map +1 -1
- package/lib/es/components/utils/helpericon/helpericon.js +21 -19
- package/lib/es/components/utils/helpericon/helpericon.js.map +1 -1
- package/lib/es/components/utils/helpericon/index.js +5 -6
- package/lib/es/components/utils/helpericon/index.js.map +1 -1
- package/lib/es/components/video/index.js +5 -6
- package/lib/es/components/video/index.js.map +1 -1
- package/lib/es/components/video/video.js +170 -232
- package/lib/es/components/video/video.js.map +1 -1
- package/lib/es/index.js +42 -42
- package/lib/es/index.js.map +1 -0
- package/lib/es/js/hooks.js +271 -227
- package/lib/es/js/hooks.js.map +1 -1
- package/lib/es/js/usePreview/content.js +153 -192
- package/lib/es/js/usePreview/content.js.map +1 -1
- package/lib/es/js/usePreview/index.js +20 -35
- package/lib/es/js/usePreview/index.js.map +1 -1
- package/lib/es/js/usePreview/renderFile.js +17 -24
- package/lib/es/js/usePreview/renderFile.js.map +1 -1
- package/lib/es/js/usePreview/type.js +12 -14
- package/lib/es/js/usePreview/type.js.map +1 -1
- package/lib/es/js/useRipple/index.js +32 -30
- package/lib/es/js/useRipple/index.js.map +1 -1
- package/lib/es/js/useTheme/index.js +30 -26
- package/lib/es/js/useTheme/index.js.map +1 -1
- package/lib/es/js/utils.js +255 -238
- package/lib/es/js/utils.js.map +1 -1
- package/lib/index.js +5146 -0
- package/lib/types/components/affix/affix.d.ts +10 -0
- package/lib/types/components/affix/index.d.ts +5 -0
- package/lib/types/components/affix/totop.d.ts +6 -0
- package/lib/types/components/affix/type.d.ts +13 -0
- package/lib/types/components/badge/badge.d.ts +6 -0
- package/lib/types/components/badge/index.d.ts +5 -0
- package/lib/types/components/badge/type.d.ts +15 -0
- package/lib/types/components/button/button.d.ts +5 -0
- package/lib/types/components/button/confirm.d.ts +6 -0
- package/lib/types/components/button/group.d.ts +6 -0
- package/lib/types/components/button/index.d.ts +5 -0
- package/lib/types/components/button/toggle.d.ts +6 -0
- package/lib/types/components/button/type.d.ts +53 -0
- package/lib/types/components/card/card.d.ts +6 -0
- package/lib/types/components/card/index.d.ts +5 -0
- package/lib/types/components/card/type.d.ts +13 -0
- package/lib/types/components/checkbox/checkbox.d.ts +10 -0
- package/lib/types/components/checkbox/index.d.ts +5 -0
- package/lib/types/components/checkbox/item.d.ts +6 -0
- package/lib/types/components/checkbox/type.d.ts +24 -0
- package/lib/types/components/collapse/collapse.d.ts +10 -0
- package/lib/types/components/collapse/index.d.ts +5 -0
- package/lib/types/components/collapse/item.d.ts +6 -0
- package/lib/types/components/collapse/type.d.ts +23 -0
- package/lib/types/components/datagrid/datagrid.d.ts +6 -0
- package/lib/types/components/datagrid/index.d.ts +5 -0
- package/lib/types/components/datagrid/type.d.ts +40 -0
- package/lib/types/components/description/description.d.ts +6 -0
- package/lib/types/components/description/index.d.ts +5 -0
- package/lib/types/components/description/type.d.ts +25 -0
- package/lib/types/components/drawer/drawer.d.ts +5 -0
- package/lib/types/components/drawer/index.d.ts +5 -0
- package/lib/types/components/drawer/type.d.ts +16 -0
- package/lib/types/components/dropdown/dropdown.d.ts +10 -0
- package/lib/types/components/dropdown/index.d.ts +5 -0
- package/lib/types/components/dropdown/type.d.ts +14 -0
- package/lib/types/components/editor/editor.d.ts +6 -0
- package/lib/types/components/editor/index.d.ts +5 -0
- package/lib/types/components/editor/type.d.ts +20 -0
- package/lib/types/components/flex/flex.d.ts +5 -0
- package/lib/types/components/flex/index.d.ts +5 -0
- package/lib/types/components/flex/type.d.ts +13 -0
- package/lib/types/components/form/field.d.ts +6 -0
- package/lib/types/components/form/form.d.ts +14 -0
- package/lib/types/components/form/index.d.ts +5 -0
- package/lib/types/components/form/type.d.ts +43 -0
- package/lib/types/components/form/useConfig.d.ts +10 -0
- package/lib/types/components/form/useForm.d.ts +17 -0
- package/lib/types/components/icon/icon.d.ts +6 -0
- package/lib/types/components/icon/index.d.ts +5 -0
- package/lib/types/components/icon/type.d.ts +12 -0
- package/lib/types/components/image/image.d.ts +5 -0
- package/lib/types/components/image/index.d.ts +5 -0
- package/lib/types/components/image/list.d.ts +6 -0
- package/lib/types/components/image/type.d.ts +33 -0
- package/lib/types/components/input/index.d.ts +5 -0
- package/lib/types/components/input/input.d.ts +5 -0
- package/lib/types/components/input/number.d.ts +6 -0
- package/lib/types/components/input/range.d.ts +6 -0
- package/lib/types/components/input/textarea.d.ts +6 -0
- package/lib/types/components/input/type.d.ts +53 -0
- package/lib/types/components/list/index.d.ts +5 -0
- package/lib/types/components/list/list.d.ts +9 -0
- package/lib/types/components/list/type.d.ts +16 -0
- package/lib/types/components/loading/index.d.ts +5 -0
- package/lib/types/components/loading/loading.d.ts +6 -0
- package/lib/types/components/loading/type.d.ts +10 -0
- package/lib/types/components/message/index.d.ts +5 -0
- package/lib/types/components/message/message.d.ts +28 -0
- package/lib/types/components/message/type.d.ts +21 -0
- package/lib/types/components/modal/index.d.ts +5 -0
- package/lib/types/components/modal/modal.d.ts +5 -0
- package/lib/types/components/modal/type.d.ts +31 -0
- package/lib/types/components/modal/useModal.d.ts +9 -0
- package/lib/types/components/pagination/index.d.ts +5 -0
- package/lib/types/components/pagination/pagination.d.ts +6 -0
- package/lib/types/components/pagination/type.d.ts +18 -0
- package/lib/types/components/picker/colors/index.d.ts +6 -0
- package/lib/types/components/picker/dates/index.d.ts +6 -0
- package/lib/types/components/picker/time/index.d.ts +6 -0
- package/lib/types/components/picker/type.d.ts +41 -0
- package/lib/types/components/popconfirm/index.d.ts +5 -0
- package/lib/types/components/popconfirm/popconfirm.d.ts +6 -0
- package/lib/types/components/popconfirm/type.d.ts +14 -0
- package/lib/types/components/popup/index.d.ts +5 -0
- package/lib/types/components/popup/popup.d.ts +6 -0
- package/lib/types/components/popup/type.d.ts +24 -0
- package/lib/types/components/progress/index.d.ts +5 -0
- package/lib/types/components/progress/progress.d.ts +6 -0
- package/lib/types/components/progress/type.d.ts +23 -0
- package/lib/types/components/radio/index.d.ts +5 -0
- package/lib/types/components/radio/item.d.ts +6 -0
- package/lib/types/components/radio/radio.d.ts +10 -0
- package/lib/types/components/radio/type.d.ts +20 -0
- package/lib/types/components/resizable/index.d.ts +5 -0
- package/lib/types/components/resizable/resizable.d.ts +6 -0
- package/lib/types/components/resizable/type.d.ts +19 -0
- package/lib/types/components/river/index.d.ts +5 -0
- package/lib/types/components/river/river.d.ts +6 -0
- package/lib/types/components/river/type.d.ts +8 -0
- package/lib/types/components/select/index.d.ts +5 -0
- package/lib/types/components/select/select.d.ts +6 -0
- package/lib/types/components/select/type.d.ts +22 -0
- package/lib/types/components/step/index.d.ts +5 -0
- package/lib/types/components/step/item.d.ts +6 -0
- package/lib/types/components/step/step.d.ts +10 -0
- package/lib/types/components/step/type.d.ts +19 -0
- package/lib/types/components/swiper/index.d.ts +5 -0
- package/lib/types/components/swiper/item.d.ts +6 -0
- package/lib/types/components/swiper/swiper.d.ts +5 -0
- package/lib/types/components/swiper/type.d.ts +52 -0
- package/lib/types/components/tabs/index.d.ts +5 -0
- package/lib/types/components/tabs/item.d.ts +6 -0
- package/lib/types/components/tabs/tabs.d.ts +5 -0
- package/lib/types/components/tabs/type.d.ts +43 -0
- package/lib/types/components/tag/index.d.ts +5 -0
- package/lib/types/components/tag/tag.d.ts +6 -0
- package/lib/types/components/tag/type.d.ts +14 -0
- package/lib/types/components/text/highlight.d.ts +6 -0
- package/lib/types/components/text/index.d.ts +5 -0
- package/lib/types/components/text/number.d.ts +6 -0
- package/lib/types/components/text/text.d.ts +5 -0
- package/lib/types/components/text/time.d.ts +6 -0
- package/lib/types/components/text/type.d.ts +43 -0
- package/lib/types/components/tree/index.d.ts +5 -0
- package/lib/types/components/tree/tree.d.ts +6 -0
- package/lib/types/components/tree/type.d.ts +48 -0
- package/lib/types/components/upload/index.d.ts +5 -0
- package/lib/types/components/upload/type.d.ts +37 -0
- package/lib/types/components/upload/upload.d.ts +6 -0
- package/lib/types/components/video/index.d.ts +5 -0
- package/lib/types/components/video/type.d.ts +27 -0
- package/lib/types/components/video/video.d.ts +6 -0
- package/lib/types/index.d.ts +41 -0
- package/lib/types/js/usePreview/index.d.ts +5 -0
- package/lib/types/js/usePreview/type.d.ts +30 -0
- package/lib/types/js/useTheme/index.d.ts +8 -0
- package/lib/types/js/useTheme/type.d.ts +7 -0
- package/lib/types/type/index.d.ts +28 -0
- package/package.json +13 -9
- package/lib/cjs/_virtual/_rolldown/runtime.js +0 -23
- package/lib/types/components/affix/affix.js +0 -62
- package/lib/types/components/affix/index.js +0 -5
- package/lib/types/components/affix/totop.js +0 -21
- package/lib/types/components/badge/badge.js +0 -20
- package/lib/types/components/badge/index.js +0 -5
- package/lib/types/components/button/button.js +0 -60
- package/lib/types/components/button/confirm.js +0 -57
- package/lib/types/components/button/group.js +0 -22
- package/lib/types/components/button/index.js +0 -5
- package/lib/types/components/button/toggle.js +0 -42
- package/lib/types/components/card/card.js +0 -29
- package/lib/types/components/card/index.js +0 -5
- package/lib/types/components/checkbox/checkbox.js +0 -62
- package/lib/types/components/checkbox/index.js +0 -5
- package/lib/types/components/checkbox/item.js +0 -55
- package/lib/types/components/collapse/collapse.js +0 -80
- package/lib/types/components/collapse/index.js +0 -5
- package/lib/types/components/collapse/item.js +0 -7
- package/lib/types/components/datagrid/cell.js +0 -34
- package/lib/types/components/datagrid/datagrid.js +0 -136
- package/lib/types/components/datagrid/index.js +0 -5
- package/lib/types/components/datagrid/resize.js +0 -39
- package/lib/types/components/datagrid/row.js +0 -63
- package/lib/types/components/datagrid/sorter.js +0 -24
- package/lib/types/components/description/description.js +0 -39
- package/lib/types/components/description/index.js +0 -5
- package/lib/types/components/drawer/drawer.js +0 -80
- package/lib/types/components/drawer/index.js +0 -5
- package/lib/types/components/dropdown/dropdown.js +0 -35
- package/lib/types/components/dropdown/index.js +0 -5
- package/lib/types/components/dropdown/item.js +0 -33
- package/lib/types/components/editor/controls.js +0 -83
- package/lib/types/components/editor/editor.js +0 -86
- package/lib/types/components/editor/index.js +0 -5
- package/lib/types/components/flex/flex.js +0 -27
- package/lib/types/components/flex/index.js +0 -5
- package/lib/types/components/form/context.js +0 -5
- package/lib/types/components/form/field.js +0 -67
- package/lib/types/components/form/form.js +0 -59
- package/lib/types/components/form/index.js +0 -5
- package/lib/types/components/form/useConfig.js +0 -42
- package/lib/types/components/form/useForm.js +0 -119
- package/lib/types/components/icon/icon.js +0 -20
- package/lib/types/components/icon/index.js +0 -5
- package/lib/types/components/image/image.js +0 -82
- package/lib/types/components/image/index.js +0 -5
- package/lib/types/components/image/list.js +0 -46
- package/lib/types/components/input/container.js +0 -26
- package/lib/types/components/input/index.js +0 -5
- package/lib/types/components/input/input.js +0 -109
- package/lib/types/components/input/number.js +0 -134
- package/lib/types/components/input/range.js +0 -130
- package/lib/types/components/input/textarea.js +0 -57
- package/lib/types/components/list/index.js +0 -5
- package/lib/types/components/list/item.js +0 -26
- package/lib/types/components/list/list.js +0 -26
- package/lib/types/components/loading/index.js +0 -5
- package/lib/types/components/loading/loading.js +0 -35
- package/lib/types/components/message/index.js +0 -5
- package/lib/types/components/message/message.js +0 -193
- package/lib/types/components/modal/content.js +0 -54
- package/lib/types/components/modal/context.js +0 -5
- package/lib/types/components/modal/hookModal.js +0 -25
- package/lib/types/components/modal/index.js +0 -5
- package/lib/types/components/modal/modal.js +0 -113
- package/lib/types/components/modal/useModal.js +0 -36
- package/lib/types/components/pagination/index.js +0 -5
- package/lib/types/components/pagination/page.js +0 -27
- package/lib/types/components/pagination/pagination.js +0 -82
- package/lib/types/components/picker/colors/footer.js +0 -60
- package/lib/types/components/picker/colors/handle.js +0 -21
- package/lib/types/components/picker/colors/index.js +0 -77
- package/lib/types/components/picker/dates/dates.js +0 -63
- package/lib/types/components/picker/dates/index.js +0 -91
- package/lib/types/components/picker/dates/panel.js +0 -146
- package/lib/types/components/picker/time/index.js +0 -69
- package/lib/types/components/picker/time/item.js +0 -16
- package/lib/types/components/picker/time/panel.js +0 -141
- package/lib/types/components/popconfirm/index.js +0 -5
- package/lib/types/components/popconfirm/popconfirm.js +0 -83
- package/lib/types/components/popup/content.js +0 -52
- package/lib/types/components/popup/index.js +0 -5
- package/lib/types/components/popup/popup.js +0 -422
- package/lib/types/components/progress/circle.js +0 -42
- package/lib/types/components/progress/index.js +0 -5
- package/lib/types/components/progress/line.js +0 -23
- package/lib/types/components/progress/progress.js +0 -96
- package/lib/types/components/radio/index.js +0 -5
- package/lib/types/components/radio/item.js +0 -30
- package/lib/types/components/radio/radio.js +0 -58
- package/lib/types/components/resizable/index.js +0 -5
- package/lib/types/components/resizable/resizable.js +0 -77
- package/lib/types/components/river/index.js +0 -5
- package/lib/types/components/river/river.js +0 -112
- package/lib/types/components/select/index.js +0 -5
- package/lib/types/components/select/options.js +0 -71
- package/lib/types/components/select/select.js +0 -151
- package/lib/types/components/step/divider.js +0 -7
- package/lib/types/components/step/index.js +0 -5
- package/lib/types/components/step/item.js +0 -56
- package/lib/types/components/step/step.js +0 -38
- package/lib/types/components/swiper/index.js +0 -5
- package/lib/types/components/swiper/item.js +0 -35
- package/lib/types/components/swiper/swiper.js +0 -258
- package/lib/types/components/tabs/index.js +0 -5
- package/lib/types/components/tabs/item.js +0 -7
- package/lib/types/components/tabs/tabs.js +0 -268
- package/lib/types/components/tag/index.js +0 -5
- package/lib/types/components/tag/tag.js +0 -28
- package/lib/types/components/text/highlight.js +0 -32
- package/lib/types/components/text/index.js +0 -5
- package/lib/types/components/text/number.js +0 -29
- package/lib/types/components/text/text.js +0 -35
- package/lib/types/components/text/time.js +0 -21
- package/lib/types/components/tree/index.js +0 -5
- package/lib/types/components/tree/item.js +0 -132
- package/lib/types/components/tree/tree.js +0 -124
- package/lib/types/components/upload/index.js +0 -5
- package/lib/types/components/upload/renderFile.js +0 -94
- package/lib/types/components/upload/upload.js +0 -161
- package/lib/types/components/utils/empty/index.js +0 -13
- package/lib/types/components/utils/helpericon/helpericon.js +0 -20
- package/lib/types/components/utils/helpericon/index.js +0 -5
- package/lib/types/components/video/index.js +0 -5
- package/lib/types/components/video/video.js +0 -233
- package/lib/types/index.js +0 -42
- package/lib/types/js/hooks.js +0 -249
- package/lib/types/js/usePreview/content.js +0 -193
- package/lib/types/js/usePreview/index.js +0 -36
- package/lib/types/js/usePreview/renderFile.js +0 -25
- package/lib/types/js/usePreview/type.js +0 -13
- package/lib/types/js/useRipple/index.js +0 -43
- package/lib/types/js/useTheme/index.js +0 -27
- package/lib/types/js/utils.js +0 -267
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"popup.js","names":[],"sources":["../../../../packages/components/popup/popup.tsx"],"sourcesContent":["import { debounce } from \"radash\";\nimport {\n\tChildren,\n\tMouseEvent,\n\tRef,\n\tcloneElement,\n\tisValidElement,\n\tuseEffect,\n\tuseLayoutEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from \"react\";\nimport { useMouseUp, useResizeObserver } from \"../../js/hooks\";\nimport { getPointPosition, getPosition } from \"../../js/utils\";\nimport Content from \"./content\";\nimport \"./index.css\";\nimport { IPopup } from \"./type\";\n\nexport default function Popup(props: IPopup) {\n\tconst {\n\t\tvisible = false,\n\t\tcontent,\n\t\ttrigger = \"hover\",\n\t\tgap = 12,\n\t\toffset = 8,\n\t\tposition = \"top\",\n\t\tshowDelay = 16,\n\t\thideDelay = 12,\n\t\ttouchable,\n\t\tarrow = true,\n\t\talign = \"center\",\n\t\tfitSize,\n\t\tdisabled,\n\t\tstyle,\n\t\tclassName,\n\t\tchildren,\n\t\tonVisibleChange,\n\t} = props;\n\n\tconst triggerRef = useRef<HTMLElement>(null);\n\tconst contentRef = useRef<HTMLDivElement>(null);\n\tconst timerRef = useRef<any>(null);\n\tconst afterHideTimerRef = useRef<any>(null);\n\tconst rafRef = useRef<number | null>(null);\n\n\tconst [show, setShow] = useState(false);\n\tconst showRef = useRef(false);\n\tshowRef.current = show;\n\n\tconst latestRef = useRef({\n\t\tdisabled,\n\t\ttrigger,\n\t\ttouchable,\n\t\tshowDelay,\n\t\thideDelay,\n\t\tposition,\n\t\tgap,\n\t\toffset,\n\t\talign,\n\t\tfitSize,\n\t\tonVisibleChange,\n\t});\n\tlatestRef.current = {\n\t\tdisabled,\n\t\ttrigger,\n\t\ttouchable,\n\t\tshowDelay,\n\t\thideDelay,\n\t\tposition,\n\t\tgap,\n\t\toffset,\n\t\talign,\n\t\tfitSize,\n\t\tonVisibleChange,\n\t};\n\n\tconst phaseRef = useRef<\"\" | \"showing\" | \"hiding\">(\"\");\n\tconst lastPosRef = useRef<{ left: number; top: number } | null>(null);\n\tconst lastArrowRef = useRef<{\n\t\tleft: number;\n\t\ttop: number;\n\t\ttransform: string;\n\t} | null>(null);\n\tconst arrowElRef = useRef<HTMLElement | null>(null);\n\tconst pointRef = useRef<{ pageX: number; pageY: number } | null>(null);\n\n\tconst clearTimer = () => {\n\t\tif (!timerRef.current) return;\n\t\tclearTimeout(timerRef.current);\n\t\ttimerRef.current = null;\n\t\tphaseRef.current = \"\";\n\t};\n\n\tconst clearAllTimers = () => {\n\t\tclearTimer();\n\t\tif (afterHideTimerRef.current) {\n\t\t\tclearTimeout(afterHideTimerRef.current);\n\t\t\tafterHideTimerRef.current = null;\n\t\t}\n\t\tif (rafRef.current !== null) {\n\t\t\tcancelAnimationFrame(rafRef.current);\n\t\t\trafRef.current = null;\n\t\t}\n\t};\n\n\tconst setContentVisible = (visible: boolean) => {\n\t\tconst el = contentRef.current;\n\t\tif (!el) return;\n\t\tel.style.opacity = visible ? \"1\" : \"0\";\n\t\tel.style.transform = visible ? \"none\" : \"translate(0, 2px)\";\n\t};\n\n\tconst ensureBaseStyle = () => {\n\t\tconst el = contentRef.current;\n\t\tif (!el) return;\n\t\tconst pos = \"fixed\";\n\t\tif (el.style.position !== pos) el.style.position = pos;\n\t};\n\n\tconst applyFitSize = () => {\n\t\tconst o = latestRef.current;\n\t\tconst triggerEl = triggerRef.current;\n\t\tconst contentEl = contentRef.current;\n\t\tif (!triggerEl || !contentEl) return;\n\n\t\tconst vertical = [\"top\", \"bottom\"].includes(o.position);\n\t\tconst key = vertical ? \"width\" : \"height\";\n\t\tif (!o.fitSize) {\n\t\t\t(contentEl.style as any)[key] = \"\";\n\t\t\treturn;\n\t\t}\n\n\t\tconst size = triggerEl[vertical ? \"offsetWidth\" : \"offsetHeight\"];\n\t\t(contentEl.style as any)[key] =\n\t\t\ttypeof size === \"number\" ? `${size}px` : \"\";\n\t};\n\n\tconst applyArrow = (arrowX: number, arrowY: number, arrowPos: string) => {\n\t\tconst contentEl = contentRef.current;\n\t\tif (!contentEl) return;\n\n\t\tconst arrowEl =\n\t\t\tarrowElRef.current ??\n\t\t\t(contentEl.querySelector(\".i-popup-arrow\") as HTMLElement | null);\n\t\tarrowElRef.current = arrowEl;\n\t\tif (!arrowEl) return;\n\n\t\tlet left = arrowX ?? 0;\n\t\tlet top = arrowY ?? 0;\n\t\tlet transform = \"\";\n\n\t\tswitch (arrowPos) {\n\t\t\tcase \"left\":\n\t\t\t\tleft += 2;\n\t\t\t\ttransform = `translate(-100%, -50%) rotate(180deg)`;\n\t\t\t\tbreak;\n\t\t\tcase \"right\":\n\t\t\t\tleft -= 2;\n\t\t\t\ttransform = `translate(0, -50%)`;\n\t\t\t\tbreak;\n\t\t\tcase \"top\":\n\t\t\t\ttop -= 2;\n\t\t\t\ttransform = `translate(-50%, -50%) rotate(-90deg)`;\n\t\t\t\tbreak;\n\t\t\tcase \"bottom\":\n\t\t\t\ttop += 2;\n\t\t\t\ttransform = `translate(-50%, -50%) rotate(90deg)`;\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tbreak;\n\t\t}\n\n\t\tconst prev = lastArrowRef.current;\n\t\tif (\n\t\t\tprev &&\n\t\t\tprev.left === left &&\n\t\t\tprev.top === top &&\n\t\t\tprev.transform === transform\n\t\t) {\n\t\t\treturn;\n\t\t}\n\n\t\tlastArrowRef.current = { left, top, transform };\n\t\tarrowEl.style.left = `${left}px`;\n\t\tarrowEl.style.top = `${top}px`;\n\t\tarrowEl.style.transform = transform;\n\t};\n\n\tconst applyLeftTop = (left: number, top: number) => {\n\t\tconst contentEl = contentRef.current;\n\t\tif (!contentEl) return;\n\n\t\tconst prev = lastPosRef.current;\n\t\tif (prev && prev.left === left && prev.top === top) return;\n\n\t\tlastPosRef.current = { left, top };\n\t\tcontentEl.style.left = `${left}px`;\n\t\tcontentEl.style.top = `${top}px`;\n\t};\n\n\tconst computeRelativePosition = () => {\n\t\tconst triggerEl = triggerRef.current;\n\t\tconst contentEl = contentRef.current;\n\t\tif (!triggerEl || !contentEl) return;\n\n\t\tconst o = latestRef.current;\n\t\tapplyFitSize();\n\n\t\tconst [left, top, { arrowX, arrowY, arrowPos }] = getPosition(\n\t\t\ttriggerEl,\n\t\t\tcontentEl,\n\t\t\t{\n\t\t\t\tposition: o.position,\n\t\t\t\tgap: o.gap,\n\t\t\t\toffset: o.offset,\n\t\t\t\talign: o.align,\n\t\t\t\trefWindow: true,\n\t\t\t},\n\t\t);\n\n\t\tapplyLeftTop(left, top);\n\t\tapplyArrow(arrowX, arrowY, arrowPos);\n\t};\n\n\tconst computePointPosition = () => {\n\t\tconst contentEl = contentRef.current as HTMLElement | null;\n\t\tif (!contentEl) return;\n\t\tconst point = pointRef.current;\n\t\tif (!point) return;\n\n\t\tconst [left, top] = getPointPosition(point as any, contentEl);\n\t\tapplyLeftTop(left, top);\n\t};\n\n\tconst scheduleComputePosition = () => {\n\t\tif (!showRef.current) return;\n\t\tif (rafRef.current !== null) return;\n\t\trafRef.current = requestAnimationFrame(() => {\n\t\t\trafRef.current = null;\n\t\t\tif (!showRef.current) return;\n\t\t\tensureBaseStyle();\n\n\t\t\tif (latestRef.current.trigger === \"contextmenu\") {\n\t\t\t\tcomputePointPosition();\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tcomputeRelativePosition();\n\t\t});\n\t};\n\n\tconst handleShow = () => {\n\t\tconst opts = latestRef.current;\n\t\tif (opts.disabled) return;\n\t\tclearAllTimers();\n\t\tif (\n\t\t\tshowRef.current &&\n\t\t\t(opts.trigger !== \"hover\" ||\n\t\t\t\t(opts.trigger === \"hover\" && !opts.touchable))\n\t\t) {\n\t\t\tensureBaseStyle();\n\t\t\tcomputeRelativePosition();\n\t\t\tsetContentVisible(true);\n\t\t\treturn;\n\t\t}\n\n\t\tphaseRef.current = \"showing\";\n\t\tif (!showRef.current) {\n\t\t\tlastPosRef.current = null;\n\t\t\tlastArrowRef.current = null;\n\t\t\tarrowElRef.current = null;\n\t\t\tsetShow(true);\n\t\t}\n\n\t\ttimerRef.current = setTimeout(() => {\n\t\t\tif (phaseRef.current !== \"showing\") return;\n\n\t\t\trafRef.current = requestAnimationFrame(() => {\n\t\t\t\trafRef.current = null;\n\t\t\t\tif (phaseRef.current !== \"showing\") return;\n\t\t\t\tif (!contentRef.current) return;\n\n\t\t\t\tensureBaseStyle();\n\t\t\t\tif (opts.trigger === \"contextmenu\") {\n\t\t\t\t\tcomputePointPosition();\n\t\t\t\t} else {\n\t\t\t\t\tcomputeRelativePosition();\n\t\t\t\t}\n\t\t\t\tsetContentVisible(true);\n\t\t\t\topts.onVisibleChange?.(true);\n\t\t\t\tclearTimer();\n\t\t\t\tphaseRef.current = \"\";\n\t\t\t});\n\t\t}, opts.showDelay);\n\t};\n\n\tconst handleHide = () => {\n\t\tif (!showRef.current) return;\n\n\t\tclearAllTimers();\n\t\tphaseRef.current = \"hiding\";\n\t\ttimerRef.current = setTimeout(() => {\n\t\t\tif (phaseRef.current !== \"hiding\") {\n\t\t\t\tclearTimer();\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tsetContentVisible(false);\n\n\t\t\tafterHideTimerRef.current = setTimeout(() => {\n\t\t\t\tafterHideTimerRef.current = null;\n\t\t\t\tsetShow(false);\n\t\t\t\tclearAllTimers();\n\t\t\t\tlatestRef.current.onVisibleChange?.(false);\n\t\t\t\tphaseRef.current = \"\";\n\t\t\t}, 160);\n\t\t}, latestRef.current.hideDelay);\n\t};\n\n\tconst handleToggle = (action?: boolean) => {\n\t\tif (action !== undefined) {\n\t\t\taction ? handleShow() : handleHide();\n\t\t\treturn;\n\t\t}\n\t\tshowRef.current ? handleHide() : handleShow();\n\t};\n\n\tconst hideRef = useRef(handleHide);\n\tconst toggleRef = useRef(handleToggle);\n\thideRef.current = handleHide;\n\ttoggleRef.current = handleToggle;\n\n\tconst doHide = useMemo(() => () => hideRef.current(), []);\n\tconst doToggle = useMemo(\n\t\t() => (action?: boolean) => toggleRef.current(action),\n\t\t[],\n\t);\n\n\tconst eventMaps = useMemo(() => {\n\t\treturn {\n\t\t\tclick: {\n\t\t\t\tonClick: () => doToggle(true),\n\t\t\t},\n\t\t\thover: {\n\t\t\t\tonMouseEnter: () => doToggle(true),\n\t\t\t\tonMouseLeave: () => doToggle(false),\n\t\t\t},\n\t\t\tfocus: {\n\t\t\t\tonFocus: () => doToggle(true),\n\t\t\t\tonBlur: () => doToggle(false),\n\t\t\t},\n\t\t\tcontextmenu: {\n\t\t\t\tonContextMenu: (e: MouseEvent) => {\n\t\t\t\t\te.preventDefault();\n\t\t\t\t\te.stopPropagation();\n\n\t\t\t\t\tpointRef.current = {\n\t\t\t\t\t\tpageX: (e as any).pageX,\n\t\t\t\t\t\tpageY: (e as any).pageY,\n\t\t\t\t\t};\n\n\t\t\t\t\tif (showRef.current) {\n\t\t\t\t\t\tensureBaseStyle();\n\t\t\t\t\t\tcomputePointPosition();\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tclearAllTimers();\n\t\t\t\t\tphaseRef.current = \"showing\";\n\t\t\t\t\tlastPosRef.current = null;\n\t\t\t\t\tlastArrowRef.current = null;\n\t\t\t\t\tarrowElRef.current = null;\n\t\t\t\t\tsetShow(true);\n\n\t\t\t\t\ttimerRef.current = setTimeout(() => {\n\t\t\t\t\t\tif (phaseRef.current !== \"showing\") return;\n\t\t\t\t\t\tif (!contentRef.current) return;\n\n\t\t\t\t\t\tensureBaseStyle();\n\t\t\t\t\t\tcomputePointPosition();\n\t\t\t\t\t\tsetContentVisible(true);\n\t\t\t\t\t\tclearTimer();\n\t\t\t\t\t\tlatestRef.current.onVisibleChange?.(true);\n\t\t\t\t\t\tphaseRef.current = \"\";\n\t\t\t\t\t}, latestRef.current.showDelay);\n\t\t\t\t},\n\t\t\t},\n\t\t\tnone: {},\n\t\t};\n\t}, [doToggle]);\n\n\tconst contentTouch = useMemo(() => {\n\t\tif (!touchable) return {};\n\t\tconst events: { [key: string]: () => void } = {};\n\n\t\tif (trigger === \"hover\") {\n\t\t\tevents[\"onMouseEnter\"] = () => {\n\t\t\t\tclearTimer();\n\t\t\t};\n\t\t\tevents[\"onMouseLeave\"] = () => handleToggle(false);\n\t\t}\n\n\t\treturn events;\n\t}, [touchable, trigger]);\n\n\tconst { observe, unobserve, disconnect } = useResizeObserver();\n\tuseEffect(() => {\n\t\tif (!observe) return;\n\t\tconst triggerEl = triggerRef.current;\n\t\tconst contentEl = contentRef.current;\n\t\tif (triggerEl) observe(triggerEl, scheduleComputePosition);\n\t\tif (contentEl) observe(contentEl, scheduleComputePosition);\n\t\treturn () => {\n\t\t\tif (contentEl) unobserve(contentEl);\n\t\t\tif (triggerEl) unobserve(triggerEl);\n\t\t\tdisconnect();\n\t\t};\n\t}, [trigger, observe, unobserve, disconnect, show]);\n\n\tuseLayoutEffect(() => {\n\t\tif (!show) return;\n\t\tensureBaseStyle();\n\t\tif (latestRef.current.trigger === \"contextmenu\") {\n\t\t\tcomputePointPosition();\n\t\t} else {\n\t\t\tcomputeRelativePosition();\n\t\t}\n\t}, [show]);\n\n\tuseLayoutEffect(() => {\n\t\tdoToggle(visible);\n\t}, [visible]);\n\n\tuseEffect(() => {\n\t\treturn () => {\n\t\t\tclearAllTimers();\n\t\t};\n\t}, []);\n\n\tconst mouseUpHandlerRef = useRef<(e: any) => void>(() => {});\n\tmouseUpHandlerRef.current = (e) => {\n\t\tif (!showRef.current) return;\n\t\tconst triggerEl = triggerRef.current;\n\t\tconst contentEl = contentRef.current;\n\t\tif (!triggerEl || !contentEl) return;\n\t\tconst tar = e.target as HTMLElement;\n\t\tif (triggerEl.contains(tar) || contentEl.contains(tar)) return;\n\t\tdoHide();\n\t};\n\tconst onGlobalMouseUp = useMemo(\n\t\t() => (e: any) => mouseUpHandlerRef.current(e),\n\t\t[],\n\t);\n\tuseMouseUp(onGlobalMouseUp);\n\n\tuseEffect(() => {\n\t\tif (!show) return;\n\t\tif (typeof window === \"undefined\") return;\n\n\t\tconst onScrollOrResize = debounce({ delay: 160 }, () => {\n\t\t\tscheduleComputePosition();\n\t\t});\n\n\t\twindow.addEventListener(\"scroll\", onScrollOrResize, {\n\t\t\tpassive: true,\n\t\t\tcapture: true,\n\t\t});\n\n\t\treturn () => {\n\t\t\twindow.removeEventListener(\"scroll\", onScrollOrResize, true);\n\t\t};\n\t}, [show]);\n\n\tconst mergeRefs = (...refs: Array<Ref<HTMLElement> | undefined>) => {\n\t\treturn (node: HTMLElement | null) => {\n\t\t\tfor (const ref of refs) {\n\t\t\t\tif (!ref) continue;\n\t\t\t\tif (typeof ref === \"function\") {\n\t\t\t\t\tref(node);\n\t\t\t\t} else {\n\t\t\t\t\t(ref as any).current = node;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t};\n\n\treturn (\n\t\t<>\n\t\t\t{(() => {\n\t\t\t\tconst events = eventMaps[trigger] as any;\n\t\t\t\tconst items = Children.toArray(children);\n\t\t\t\tconst canAttachRef = (el: any) => {\n\t\t\t\t\tif (!isValidElement(el)) return false;\n\t\t\t\t\tconst t: any = el.type;\n\t\t\t\t\tif (typeof t === \"string\") return true;\n\t\t\t\t\tif (t?.prototype?.isReactComponent) return true;\n\t\t\t\t\tif (t?.$$typeof === Symbol.for(\"react.forward_ref\"))\n\t\t\t\t\t\treturn true;\n\t\t\t\t\treturn false;\n\t\t\t\t};\n\n\t\t\t\tif (items.length !== 1) {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tref={triggerRef as any}\n\t\t\t\t\t\t\t{...events}\n\t\t\t\t\t\t\tclassName='i-popup-trigger'\n\t\t\t\t\t\t\tstyle={{ display: \"inline-block\" }}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{children}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tconst only = items[0] as any;\n\t\t\t\tif (!isValidElement(only) || !canAttachRef(only)) {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tref={triggerRef as any}\n\t\t\t\t\t\t\t{...events}\n\t\t\t\t\t\t\tclassName='i-popup-trigger'\n\t\t\t\t\t\t\tstyle={{ display: \"inline-block\" }}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{only}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tconst { className: childClassName, ...restProps } =\n\t\t\t\t\tonly.props as any;\n\t\t\t\tconst nextProps: Record<string, any> = { ...restProps };\n\t\t\t\tfor (const evt of Object.keys(events)) {\n\t\t\t\t\tconst theirs = restProps[evt];\n\t\t\t\t\tconst ours = events[evt];\n\t\t\t\t\tnextProps[evt] =\n\t\t\t\t\t\ttypeof theirs === \"function\"\n\t\t\t\t\t\t\t? (e: any) => {\n\t\t\t\t\t\t\t\t\tours(e);\n\t\t\t\t\t\t\t\t\ttheirs(e);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t: ours;\n\t\t\t\t}\n\t\t\t\treturn cloneElement(only as any, {\n\t\t\t\t\tref: mergeRefs((only as any).ref, triggerRef as any),\n\t\t\t\t\tclassName: childClassName,\n\t\t\t\t\t...nextProps,\n\t\t\t\t});\n\t\t\t})()}\n\n\t\t\t{show && (\n\t\t\t\t<Content\n\t\t\t\t\tref={contentRef}\n\t\t\t\t\tarrow={arrow && trigger !== \"contextmenu\"}\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\t...style,\n\t\t\t\t\t\tposition: \"fixed\",\n\t\t\t\t\t}}\n\t\t\t\t\tclassName={className}\n\t\t\t\t\t{...contentTouch}\n\t\t\t\t\ttrigger={triggerRef.current as HTMLElement}\n\t\t\t\t>\n\t\t\t\t\t{content}\n\t\t\t\t</Content>\n\t\t\t)}\n\t\t</>\n\t);\n}\n"],"mappings":""}
|
|
1
|
+
{"version":3,"file":"popup.js","sources":["../../../../packages/components/popup/popup.tsx"],"sourcesContent":["import { debounce } from \"radash\";\nimport {\n\tChildren,\n\tMouseEvent,\n\tRef,\n\tcloneElement,\n\tisValidElement,\n\tuseEffect,\n\tuseLayoutEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from \"react\";\nimport { useMouseUp, useResizeObserver } from \"../../js/hooks\";\nimport { getPointPosition, getPosition } from \"../../js/utils\";\nimport Content from \"./content\";\nimport \"./index.css\";\nimport { IPopup } from \"./type\";\n\nexport default function Popup(props: IPopup) {\n\tconst {\n\t\tvisible = false,\n\t\tcontent,\n\t\ttrigger = \"hover\",\n\t\tgap = 12,\n\t\toffset = 8,\n\t\tposition = \"top\",\n\t\tshowDelay = 16,\n\t\thideDelay = 12,\n\t\ttouchable,\n\t\tarrow = true,\n\t\talign = \"center\",\n\t\tfitSize,\n\t\tdisabled,\n\t\tstyle,\n\t\tclassName,\n\t\tchildren,\n\t\tonVisibleChange,\n\t} = props;\n\n\tconst triggerRef = useRef<HTMLElement>(null);\n\tconst contentRef = useRef<HTMLDivElement>(null);\n\tconst timerRef = useRef<any>(null);\n\tconst afterHideTimerRef = useRef<any>(null);\n\tconst rafRef = useRef<number | null>(null);\n\n\tconst [show, setShow] = useState(false);\n\tconst showRef = useRef(false);\n\tshowRef.current = show;\n\n\tconst latestRef = useRef({\n\t\tdisabled,\n\t\ttrigger,\n\t\ttouchable,\n\t\tshowDelay,\n\t\thideDelay,\n\t\tposition,\n\t\tgap,\n\t\toffset,\n\t\talign,\n\t\tfitSize,\n\t\tonVisibleChange,\n\t});\n\tlatestRef.current = {\n\t\tdisabled,\n\t\ttrigger,\n\t\ttouchable,\n\t\tshowDelay,\n\t\thideDelay,\n\t\tposition,\n\t\tgap,\n\t\toffset,\n\t\talign,\n\t\tfitSize,\n\t\tonVisibleChange,\n\t};\n\n\tconst phaseRef = useRef<\"\" | \"showing\" | \"hiding\">(\"\");\n\tconst lastPosRef = useRef<{ left: number; top: number } | null>(null);\n\tconst lastArrowRef = useRef<{\n\t\tleft: number;\n\t\ttop: number;\n\t\ttransform: string;\n\t} | null>(null);\n\tconst arrowElRef = useRef<HTMLElement | null>(null);\n\tconst pointRef = useRef<{ pageX: number; pageY: number } | null>(null);\n\n\tconst clearTimer = () => {\n\t\tif (!timerRef.current) return;\n\t\tclearTimeout(timerRef.current);\n\t\ttimerRef.current = null;\n\t\tphaseRef.current = \"\";\n\t};\n\n\tconst clearAllTimers = () => {\n\t\tclearTimer();\n\t\tif (afterHideTimerRef.current) {\n\t\t\tclearTimeout(afterHideTimerRef.current);\n\t\t\tafterHideTimerRef.current = null;\n\t\t}\n\t\tif (rafRef.current !== null) {\n\t\t\tcancelAnimationFrame(rafRef.current);\n\t\t\trafRef.current = null;\n\t\t}\n\t};\n\n\tconst setContentVisible = (visible: boolean) => {\n\t\tconst el = contentRef.current;\n\t\tif (!el) return;\n\t\tel.style.opacity = visible ? \"1\" : \"0\";\n\t\tel.style.transform = visible ? \"none\" : \"translate(0, 2px)\";\n\t};\n\n\tconst ensureBaseStyle = () => {\n\t\tconst el = contentRef.current;\n\t\tif (!el) return;\n\t\tconst pos = \"fixed\";\n\t\tif (el.style.position !== pos) el.style.position = pos;\n\t};\n\n\tconst applyFitSize = () => {\n\t\tconst o = latestRef.current;\n\t\tconst triggerEl = triggerRef.current;\n\t\tconst contentEl = contentRef.current;\n\t\tif (!triggerEl || !contentEl) return;\n\n\t\tconst vertical = [\"top\", \"bottom\"].includes(o.position);\n\t\tconst key = vertical ? \"width\" : \"height\";\n\t\tif (!o.fitSize) {\n\t\t\t(contentEl.style as any)[key] = \"\";\n\t\t\treturn;\n\t\t}\n\n\t\tconst size = triggerEl[vertical ? \"offsetWidth\" : \"offsetHeight\"];\n\t\t(contentEl.style as any)[key] =\n\t\t\ttypeof size === \"number\" ? `${size}px` : \"\";\n\t};\n\n\tconst applyArrow = (arrowX: number, arrowY: number, arrowPos: string) => {\n\t\tconst contentEl = contentRef.current;\n\t\tif (!contentEl) return;\n\n\t\tconst arrowEl =\n\t\t\tarrowElRef.current ??\n\t\t\t(contentEl.querySelector(\".i-popup-arrow\") as HTMLElement | null);\n\t\tarrowElRef.current = arrowEl;\n\t\tif (!arrowEl) return;\n\n\t\tlet left = arrowX ?? 0;\n\t\tlet top = arrowY ?? 0;\n\t\tlet transform = \"\";\n\n\t\tswitch (arrowPos) {\n\t\t\tcase \"left\":\n\t\t\t\tleft += 2;\n\t\t\t\ttransform = `translate(-100%, -50%) rotate(180deg)`;\n\t\t\t\tbreak;\n\t\t\tcase \"right\":\n\t\t\t\tleft -= 2;\n\t\t\t\ttransform = `translate(0, -50%)`;\n\t\t\t\tbreak;\n\t\t\tcase \"top\":\n\t\t\t\ttop -= 2;\n\t\t\t\ttransform = `translate(-50%, -50%) rotate(-90deg)`;\n\t\t\t\tbreak;\n\t\t\tcase \"bottom\":\n\t\t\t\ttop += 2;\n\t\t\t\ttransform = `translate(-50%, -50%) rotate(90deg)`;\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tbreak;\n\t\t}\n\n\t\tconst prev = lastArrowRef.current;\n\t\tif (\n\t\t\tprev &&\n\t\t\tprev.left === left &&\n\t\t\tprev.top === top &&\n\t\t\tprev.transform === transform\n\t\t) {\n\t\t\treturn;\n\t\t}\n\n\t\tlastArrowRef.current = { left, top, transform };\n\t\tarrowEl.style.left = `${left}px`;\n\t\tarrowEl.style.top = `${top}px`;\n\t\tarrowEl.style.transform = transform;\n\t};\n\n\tconst applyLeftTop = (left: number, top: number) => {\n\t\tconst contentEl = contentRef.current;\n\t\tif (!contentEl) return;\n\n\t\tconst prev = lastPosRef.current;\n\t\tif (prev && prev.left === left && prev.top === top) return;\n\n\t\tlastPosRef.current = { left, top };\n\t\tcontentEl.style.left = `${left}px`;\n\t\tcontentEl.style.top = `${top}px`;\n\t};\n\n\tconst computeRelativePosition = () => {\n\t\tconst triggerEl = triggerRef.current;\n\t\tconst contentEl = contentRef.current;\n\t\tif (!triggerEl || !contentEl) return;\n\n\t\tconst o = latestRef.current;\n\t\tapplyFitSize();\n\n\t\tconst [left, top, { arrowX, arrowY, arrowPos }] = getPosition(\n\t\t\ttriggerEl,\n\t\t\tcontentEl,\n\t\t\t{\n\t\t\t\tposition: o.position,\n\t\t\t\tgap: o.gap,\n\t\t\t\toffset: o.offset,\n\t\t\t\talign: o.align,\n\t\t\t\trefWindow: true,\n\t\t\t},\n\t\t);\n\n\t\tapplyLeftTop(left, top);\n\t\tapplyArrow(arrowX, arrowY, arrowPos);\n\t};\n\n\tconst computePointPosition = () => {\n\t\tconst contentEl = contentRef.current as HTMLElement | null;\n\t\tif (!contentEl) return;\n\t\tconst point = pointRef.current;\n\t\tif (!point) return;\n\n\t\tconst [left, top] = getPointPosition(point as any, contentEl);\n\t\tapplyLeftTop(left, top);\n\t};\n\n\tconst scheduleComputePosition = () => {\n\t\tif (!showRef.current) return;\n\t\tif (rafRef.current !== null) return;\n\t\trafRef.current = requestAnimationFrame(() => {\n\t\t\trafRef.current = null;\n\t\t\tif (!showRef.current) return;\n\t\t\tensureBaseStyle();\n\n\t\t\tif (latestRef.current.trigger === \"contextmenu\") {\n\t\t\t\tcomputePointPosition();\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tcomputeRelativePosition();\n\t\t});\n\t};\n\n\tconst handleShow = () => {\n\t\tconst opts = latestRef.current;\n\t\tif (opts.disabled) return;\n\t\tclearAllTimers();\n\t\tif (\n\t\t\tshowRef.current &&\n\t\t\t(opts.trigger !== \"hover\" ||\n\t\t\t\t(opts.trigger === \"hover\" && !opts.touchable))\n\t\t) {\n\t\t\tensureBaseStyle();\n\t\t\tcomputeRelativePosition();\n\t\t\tsetContentVisible(true);\n\t\t\treturn;\n\t\t}\n\n\t\tphaseRef.current = \"showing\";\n\t\tif (!showRef.current) {\n\t\t\tlastPosRef.current = null;\n\t\t\tlastArrowRef.current = null;\n\t\t\tarrowElRef.current = null;\n\t\t\tsetShow(true);\n\t\t}\n\n\t\ttimerRef.current = setTimeout(() => {\n\t\t\tif (phaseRef.current !== \"showing\") return;\n\n\t\t\trafRef.current = requestAnimationFrame(() => {\n\t\t\t\trafRef.current = null;\n\t\t\t\tif (phaseRef.current !== \"showing\") return;\n\t\t\t\tif (!contentRef.current) return;\n\n\t\t\t\tensureBaseStyle();\n\t\t\t\tif (opts.trigger === \"contextmenu\") {\n\t\t\t\t\tcomputePointPosition();\n\t\t\t\t} else {\n\t\t\t\t\tcomputeRelativePosition();\n\t\t\t\t}\n\t\t\t\tsetContentVisible(true);\n\t\t\t\topts.onVisibleChange?.(true);\n\t\t\t\tclearTimer();\n\t\t\t\tphaseRef.current = \"\";\n\t\t\t});\n\t\t}, opts.showDelay);\n\t};\n\n\tconst handleHide = () => {\n\t\tif (!showRef.current) return;\n\n\t\tclearAllTimers();\n\t\tphaseRef.current = \"hiding\";\n\t\ttimerRef.current = setTimeout(() => {\n\t\t\tif (phaseRef.current !== \"hiding\") {\n\t\t\t\tclearTimer();\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tsetContentVisible(false);\n\n\t\t\tafterHideTimerRef.current = setTimeout(() => {\n\t\t\t\tafterHideTimerRef.current = null;\n\t\t\t\tsetShow(false);\n\t\t\t\tclearAllTimers();\n\t\t\t\tlatestRef.current.onVisibleChange?.(false);\n\t\t\t\tphaseRef.current = \"\";\n\t\t\t}, 160);\n\t\t}, latestRef.current.hideDelay);\n\t};\n\n\tconst handleToggle = (action?: boolean) => {\n\t\tif (action !== undefined) {\n\t\t\taction ? handleShow() : handleHide();\n\t\t\treturn;\n\t\t}\n\t\tshowRef.current ? handleHide() : handleShow();\n\t};\n\n\tconst hideRef = useRef(handleHide);\n\tconst toggleRef = useRef(handleToggle);\n\thideRef.current = handleHide;\n\ttoggleRef.current = handleToggle;\n\n\tconst doHide = useMemo(() => () => hideRef.current(), []);\n\tconst doToggle = useMemo(\n\t\t() => (action?: boolean) => toggleRef.current(action),\n\t\t[],\n\t);\n\n\tconst eventMaps = useMemo(() => {\n\t\treturn {\n\t\t\tclick: {\n\t\t\t\tonClick: () => doToggle(true),\n\t\t\t},\n\t\t\thover: {\n\t\t\t\tonMouseEnter: () => doToggle(true),\n\t\t\t\tonMouseLeave: () => doToggle(false),\n\t\t\t},\n\t\t\tfocus: {\n\t\t\t\tonFocus: () => doToggle(true),\n\t\t\t\tonBlur: () => doToggle(false),\n\t\t\t},\n\t\t\tcontextmenu: {\n\t\t\t\tonContextMenu: (e: MouseEvent) => {\n\t\t\t\t\te.preventDefault();\n\t\t\t\t\te.stopPropagation();\n\n\t\t\t\t\tpointRef.current = {\n\t\t\t\t\t\tpageX: (e as any).pageX,\n\t\t\t\t\t\tpageY: (e as any).pageY,\n\t\t\t\t\t};\n\n\t\t\t\t\tif (showRef.current) {\n\t\t\t\t\t\tensureBaseStyle();\n\t\t\t\t\t\tcomputePointPosition();\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tclearAllTimers();\n\t\t\t\t\tphaseRef.current = \"showing\";\n\t\t\t\t\tlastPosRef.current = null;\n\t\t\t\t\tlastArrowRef.current = null;\n\t\t\t\t\tarrowElRef.current = null;\n\t\t\t\t\tsetShow(true);\n\n\t\t\t\t\ttimerRef.current = setTimeout(() => {\n\t\t\t\t\t\tif (phaseRef.current !== \"showing\") return;\n\t\t\t\t\t\tif (!contentRef.current) return;\n\n\t\t\t\t\t\tensureBaseStyle();\n\t\t\t\t\t\tcomputePointPosition();\n\t\t\t\t\t\tsetContentVisible(true);\n\t\t\t\t\t\tclearTimer();\n\t\t\t\t\t\tlatestRef.current.onVisibleChange?.(true);\n\t\t\t\t\t\tphaseRef.current = \"\";\n\t\t\t\t\t}, latestRef.current.showDelay);\n\t\t\t\t},\n\t\t\t},\n\t\t\tnone: {},\n\t\t};\n\t}, [doToggle]);\n\n\tconst contentTouch = useMemo(() => {\n\t\tif (!touchable) return {};\n\t\tconst events: { [key: string]: () => void } = {};\n\n\t\tif (trigger === \"hover\") {\n\t\t\tevents[\"onMouseEnter\"] = () => {\n\t\t\t\tclearTimer();\n\t\t\t};\n\t\t\tevents[\"onMouseLeave\"] = () => handleToggle(false);\n\t\t}\n\n\t\treturn events;\n\t}, [touchable, trigger]);\n\n\tconst { observe, unobserve, disconnect } = useResizeObserver();\n\tuseEffect(() => {\n\t\tif (!observe) return;\n\t\tconst triggerEl = triggerRef.current;\n\t\tconst contentEl = contentRef.current;\n\t\tif (triggerEl) observe(triggerEl, scheduleComputePosition);\n\t\tif (contentEl) observe(contentEl, scheduleComputePosition);\n\t\treturn () => {\n\t\t\tif (contentEl) unobserve(contentEl);\n\t\t\tif (triggerEl) unobserve(triggerEl);\n\t\t\tdisconnect();\n\t\t};\n\t}, [trigger, observe, unobserve, disconnect, show]);\n\n\tuseLayoutEffect(() => {\n\t\tif (!show) return;\n\t\tensureBaseStyle();\n\t\tif (latestRef.current.trigger === \"contextmenu\") {\n\t\t\tcomputePointPosition();\n\t\t} else {\n\t\t\tcomputeRelativePosition();\n\t\t}\n\t}, [show]);\n\n\tuseLayoutEffect(() => {\n\t\tdoToggle(visible);\n\t}, [visible]);\n\n\tuseEffect(() => {\n\t\treturn () => {\n\t\t\tclearAllTimers();\n\t\t};\n\t}, []);\n\n\tconst mouseUpHandlerRef = useRef<(e: any) => void>(() => {});\n\tmouseUpHandlerRef.current = (e) => {\n\t\tif (!showRef.current) return;\n\t\tconst triggerEl = triggerRef.current;\n\t\tconst contentEl = contentRef.current;\n\t\tif (!triggerEl || !contentEl) return;\n\t\tconst tar = e.target as HTMLElement;\n\t\tif (triggerEl.contains(tar) || contentEl.contains(tar)) return;\n\t\tdoHide();\n\t};\n\tconst onGlobalMouseUp = useMemo(\n\t\t() => (e: any) => mouseUpHandlerRef.current(e),\n\t\t[],\n\t);\n\tuseMouseUp(onGlobalMouseUp);\n\n\tuseEffect(() => {\n\t\tif (!show) return;\n\t\tif (typeof window === \"undefined\") return;\n\n\t\tconst onScrollOrResize = debounce({ delay: 160 }, () => {\n\t\t\tscheduleComputePosition();\n\t\t});\n\n\t\twindow.addEventListener(\"scroll\", onScrollOrResize, {\n\t\t\tpassive: true,\n\t\t\tcapture: true,\n\t\t});\n\n\t\treturn () => {\n\t\t\twindow.removeEventListener(\"scroll\", onScrollOrResize, true);\n\t\t};\n\t}, [show]);\n\n\tconst mergeRefs = (...refs: Array<Ref<HTMLElement> | undefined>) => {\n\t\treturn (node: HTMLElement | null) => {\n\t\t\tfor (const ref of refs) {\n\t\t\t\tif (!ref) continue;\n\t\t\t\tif (typeof ref === \"function\") {\n\t\t\t\t\tref(node);\n\t\t\t\t} else {\n\t\t\t\t\t(ref as any).current = node;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t};\n\n\treturn (\n\t\t<>\n\t\t\t{(() => {\n\t\t\t\tconst events = eventMaps[trigger] as any;\n\t\t\t\tconst items = Children.toArray(children);\n\t\t\t\tconst canAttachRef = (el: any) => {\n\t\t\t\t\tif (!isValidElement(el)) return false;\n\t\t\t\t\tconst t: any = el.type;\n\t\t\t\t\tif (typeof t === \"string\") return true;\n\t\t\t\t\tif (t?.prototype?.isReactComponent) return true;\n\t\t\t\t\tif (t?.$$typeof === Symbol.for(\"react.forward_ref\"))\n\t\t\t\t\t\treturn true;\n\t\t\t\t\treturn false;\n\t\t\t\t};\n\n\t\t\t\tif (items.length !== 1) {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tref={triggerRef as any}\n\t\t\t\t\t\t\t{...events}\n\t\t\t\t\t\t\tclassName='i-popup-trigger'\n\t\t\t\t\t\t\tstyle={{ display: \"inline-block\" }}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{children}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tconst only = items[0] as any;\n\t\t\t\tif (!isValidElement(only) || !canAttachRef(only)) {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tref={triggerRef as any}\n\t\t\t\t\t\t\t{...events}\n\t\t\t\t\t\t\tclassName='i-popup-trigger'\n\t\t\t\t\t\t\tstyle={{ display: \"inline-block\" }}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{only}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tconst { className: childClassName, ...restProps } =\n\t\t\t\t\tonly.props as any;\n\t\t\t\tconst nextProps: Record<string, any> = { ...restProps };\n\t\t\t\tfor (const evt of Object.keys(events)) {\n\t\t\t\t\tconst theirs = restProps[evt];\n\t\t\t\t\tconst ours = events[evt];\n\t\t\t\t\tnextProps[evt] =\n\t\t\t\t\t\ttypeof theirs === \"function\"\n\t\t\t\t\t\t\t? (e: any) => {\n\t\t\t\t\t\t\t\t\tours(e);\n\t\t\t\t\t\t\t\t\ttheirs(e);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t: ours;\n\t\t\t\t}\n\t\t\t\treturn cloneElement(only as any, {\n\t\t\t\t\tref: mergeRefs((only as any).ref, triggerRef as any),\n\t\t\t\t\tclassName: childClassName,\n\t\t\t\t\t...nextProps,\n\t\t\t\t});\n\t\t\t})()}\n\n\t\t\t{show && (\n\t\t\t\t<Content\n\t\t\t\t\tref={contentRef}\n\t\t\t\t\tarrow={arrow && trigger !== \"contextmenu\"}\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\t...style,\n\t\t\t\t\t\tposition: \"fixed\",\n\t\t\t\t\t}}\n\t\t\t\t\tclassName={className}\n\t\t\t\t\t{...contentTouch}\n\t\t\t\t\ttrigger={triggerRef.current as HTMLElement}\n\t\t\t\t>\n\t\t\t\t\t{content}\n\t\t\t\t</Content>\n\t\t\t)}\n\t\t</>\n\t);\n}\n"],"names":["_jsxs","_Fragment","_jsx"],"mappings":";;;;;;;AAmBc,SAAU,KAAK,CAAC,KAAa,EAAA;IAC1C,MAAM,EACL,OAAO,GAAG,KAAK,EACf,OAAO,EACP,OAAO,GAAG,OAAO,EACjB,GAAG,GAAG,EAAE,EACR,MAAM,GAAG,CAAC,EACV,QAAQ,GAAG,KAAK,EAChB,SAAS,GAAG,EAAE,EACd,SAAS,GAAG,EAAE,EACd,SAAS,EACT,KAAK,GAAG,IAAI,EACZ,KAAK,GAAG,QAAQ,EAChB,OAAO,EACP,QAAQ,EACR,KAAK,EACL,SAAS,EACT,QAAQ,EACR,eAAe,GACf,GAAG,KAAK;AAET,IAAA,MAAM,UAAU,GAAG,MAAM,CAAc,IAAI,CAAC;AAC5C,IAAA,MAAM,UAAU,GAAG,MAAM,CAAiB,IAAI,CAAC;AAC/C,IAAA,MAAM,QAAQ,GAAG,MAAM,CAAM,IAAI,CAAC;AAClC,IAAA,MAAM,iBAAiB,GAAG,MAAM,CAAM,IAAI,CAAC;AAC3C,IAAA,MAAM,MAAM,GAAG,MAAM,CAAgB,IAAI,CAAC;IAE1C,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;AACvC,IAAA,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC;AAC7B,IAAA,OAAO,CAAC,OAAO,GAAG,IAAI;IAEtB,MAAM,SAAS,GAAG,MAAM,CAAC;QACxB,QAAQ;QACR,OAAO;QACP,SAAS;QACT,SAAS;QACT,SAAS;QACT,QAAQ;QACR,GAAG;QACH,MAAM;QACN,KAAK;QACL,OAAO;QACP,eAAe;AACf,KAAA,CAAC;IACF,SAAS,CAAC,OAAO,GAAG;QACnB,QAAQ;QACR,OAAO;QACP,SAAS;QACT,SAAS;QACT,SAAS;QACT,QAAQ;QACR,GAAG;QACH,MAAM;QACN,KAAK;QACL,OAAO;QACP,eAAe;KACf;AAED,IAAA,MAAM,QAAQ,GAAG,MAAM,CAA4B,EAAE,CAAC;AACtD,IAAA,MAAM,UAAU,GAAG,MAAM,CAAuC,IAAI,CAAC;AACrE,IAAA,MAAM,YAAY,GAAG,MAAM,CAIjB,IAAI,CAAC;AACf,IAAA,MAAM,UAAU,GAAG,MAAM,CAAqB,IAAI,CAAC;AACnD,IAAA,MAAM,QAAQ,GAAG,MAAM,CAA0C,IAAI,CAAC;IAEtE,MAAM,UAAU,GAAG,MAAK;QACvB,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE;AACvB,QAAA,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC;AAC9B,QAAA,QAAQ,CAAC,OAAO,GAAG,IAAI;AACvB,QAAA,QAAQ,CAAC,OAAO,GAAG,EAAE;AACtB,IAAA,CAAC;IAED,MAAM,cAAc,GAAG,MAAK;AAC3B,QAAA,UAAU,EAAE;AACZ,QAAA,IAAI,iBAAiB,CAAC,OAAO,EAAE;AAC9B,YAAA,YAAY,CAAC,iBAAiB,CAAC,OAAO,CAAC;AACvC,YAAA,iBAAiB,CAAC,OAAO,GAAG,IAAI;QACjC;AACA,QAAA,IAAI,MAAM,CAAC,OAAO,KAAK,IAAI,EAAE;AAC5B,YAAA,oBAAoB,CAAC,MAAM,CAAC,OAAO,CAAC;AACpC,YAAA,MAAM,CAAC,OAAO,GAAG,IAAI;QACtB;AACD,IAAA,CAAC;AAED,IAAA,MAAM,iBAAiB,GAAG,CAAC,OAAgB,KAAI;AAC9C,QAAA,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO;AAC7B,QAAA,IAAI,CAAC,EAAE;YAAE;AACT,QAAA,EAAE,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,GAAG,GAAG,GAAG,GAAG;AACtC,QAAA,EAAE,CAAC,KAAK,CAAC,SAAS,GAAG,OAAO,GAAG,MAAM,GAAG,mBAAmB;AAC5D,IAAA,CAAC;IAED,MAAM,eAAe,GAAG,MAAK;AAC5B,QAAA,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO;AAC7B,QAAA,IAAI,CAAC,EAAE;YAAE;QACT,MAAM,GAAG,GAAG,OAAO;AACnB,QAAA,IAAI,EAAE,CAAC,KAAK,CAAC,QAAQ,KAAK,GAAG;AAAE,YAAA,EAAE,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG;AACvD,IAAA,CAAC;IAED,MAAM,YAAY,GAAG,MAAK;AACzB,QAAA,MAAM,CAAC,GAAG,SAAS,CAAC,OAAO;AAC3B,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS;YAAE;AAE9B,QAAA,MAAM,QAAQ,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC;QACvD,MAAM,GAAG,GAAG,QAAQ,GAAG,OAAO,GAAG,QAAQ;AACzC,QAAA,IAAI,CAAC,CAAC,CAAC,OAAO,EAAE;AACd,YAAA,SAAS,CAAC,KAAa,CAAC,GAAG,CAAC,GAAG,EAAE;YAClC;QACD;AAEA,QAAA,MAAM,IAAI,GAAG,SAAS,CAAC,QAAQ,GAAG,aAAa,GAAG,cAAc,CAAC;AAChE,QAAA,SAAS,CAAC,KAAa,CAAC,GAAG,CAAC;AAC5B,YAAA,OAAO,IAAI,KAAK,QAAQ,GAAG,CAAA,EAAG,IAAI,CAAA,EAAA,CAAI,GAAG,EAAE;AAC7C,IAAA,CAAC;IAED,MAAM,UAAU,GAAG,CAAC,MAAc,EAAE,MAAc,EAAE,QAAgB,KAAI;AACvE,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,IAAI,CAAC,SAAS;YAAE;AAEhB,QAAA,MAAM,OAAO,GACZ,UAAU,CAAC,OAAO;AACjB,YAAA,SAAS,CAAC,aAAa,CAAC,gBAAgB,CAAwB;AAClE,QAAA,UAAU,CAAC,OAAO,GAAG,OAAO;AAC5B,QAAA,IAAI,CAAC,OAAO;YAAE;AAEd,QAAA,IAAI,IAAI,GAAG,MAAM,IAAI,CAAC;AACtB,QAAA,IAAI,GAAG,GAAG,MAAM,IAAI,CAAC;QACrB,IAAI,SAAS,GAAG,EAAE;QAElB,QAAQ,QAAQ;AACf,YAAA,KAAK,MAAM;gBACV,IAAI,IAAI,CAAC;gBACT,SAAS,GAAG,uCAAuC;gBACnD;AACD,YAAA,KAAK,OAAO;gBACX,IAAI,IAAI,CAAC;gBACT,SAAS,GAAG,oBAAoB;gBAChC;AACD,YAAA,KAAK,KAAK;gBACT,GAAG,IAAI,CAAC;gBACR,SAAS,GAAG,sCAAsC;gBAClD;AACD,YAAA,KAAK,QAAQ;gBACZ,GAAG,IAAI,CAAC;gBACR,SAAS,GAAG,qCAAqC;gBACjD;;AAKF,QAAA,MAAM,IAAI,GAAG,YAAY,CAAC,OAAO;AACjC,QAAA,IACC,IAAI;YACJ,IAAI,CAAC,IAAI,KAAK,IAAI;YAClB,IAAI,CAAC,GAAG,KAAK,GAAG;AAChB,YAAA,IAAI,CAAC,SAAS,KAAK,SAAS,EAC3B;YACD;QACD;QAEA,YAAY,CAAC,OAAO,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE;QAC/C,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,CAAA,EAAG,IAAI,IAAI;QAChC,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,CAAA,EAAG,GAAG,IAAI;AAC9B,QAAA,OAAO,CAAC,KAAK,CAAC,SAAS,GAAG,SAAS;AACpC,IAAA,CAAC;AAED,IAAA,MAAM,YAAY,GAAG,CAAC,IAAY,EAAE,GAAW,KAAI;AAClD,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,IAAI,CAAC,SAAS;YAAE;AAEhB,QAAA,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO;AAC/B,QAAA,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,IAAI,IAAI,CAAC,GAAG,KAAK,GAAG;YAAE;QAEpD,UAAU,CAAC,OAAO,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE;QAClC,SAAS,CAAC,KAAK,CAAC,IAAI,GAAG,CAAA,EAAG,IAAI,IAAI;QAClC,SAAS,CAAC,KAAK,CAAC,GAAG,GAAG,CAAA,EAAG,GAAG,IAAI;AACjC,IAAA,CAAC;IAED,MAAM,uBAAuB,GAAG,MAAK;AACpC,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS;YAAE;AAE9B,QAAA,MAAM,CAAC,GAAG,SAAS,CAAC,OAAO;AAC3B,QAAA,YAAY,EAAE;AAEd,QAAA,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,GAAG,WAAW,CAC5D,SAAS,EACT,SAAS,EACT;YACC,QAAQ,EAAE,CAAC,CAAC,QAAQ;YACpB,GAAG,EAAE,CAAC,CAAC,GAAG;YACV,MAAM,EAAE,CAAC,CAAC,MAAM;YAChB,KAAK,EAAE,CAAC,CAAC,KAAK;AACd,YAAA,SAAS,EAAE,IAAI;AACf,SAAA,CACD;AAED,QAAA,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC;AACvB,QAAA,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC;AACrC,IAAA,CAAC;IAED,MAAM,oBAAoB,GAAG,MAAK;AACjC,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAA6B;AAC1D,QAAA,IAAI,CAAC,SAAS;YAAE;AAChB,QAAA,MAAM,KAAK,GAAG,QAAQ,CAAC,OAAO;AAC9B,QAAA,IAAI,CAAC,KAAK;YAAE;AAEZ,QAAA,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,gBAAgB,CAAC,KAAY,EAAE,SAAS,CAAC;AAC7D,QAAA,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC;AACxB,IAAA,CAAC;IAED,MAAM,uBAAuB,GAAG,MAAK;QACpC,IAAI,CAAC,OAAO,CAAC,OAAO;YAAE;AACtB,QAAA,IAAI,MAAM,CAAC,OAAO,KAAK,IAAI;YAAE;AAC7B,QAAA,MAAM,CAAC,OAAO,GAAG,qBAAqB,CAAC,MAAK;AAC3C,YAAA,MAAM,CAAC,OAAO,GAAG,IAAI;YACrB,IAAI,CAAC,OAAO,CAAC,OAAO;gBAAE;AACtB,YAAA,eAAe,EAAE;YAEjB,IAAI,SAAS,CAAC,OAAO,CAAC,OAAO,KAAK,aAAa,EAAE;AAChD,gBAAA,oBAAoB,EAAE;gBACtB;YACD;AAEA,YAAA,uBAAuB,EAAE;AAC1B,QAAA,CAAC,CAAC;AACH,IAAA,CAAC;IAED,MAAM,UAAU,GAAG,MAAK;AACvB,QAAA,MAAM,IAAI,GAAG,SAAS,CAAC,OAAO;QAC9B,IAAI,IAAI,CAAC,QAAQ;YAAE;AACnB,QAAA,cAAc,EAAE;QAChB,IACC,OAAO,CAAC,OAAO;AACf,aAAC,IAAI,CAAC,OAAO,KAAK,OAAO;AACxB,iBAAC,IAAI,CAAC,OAAO,KAAK,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAC9C;AACD,YAAA,eAAe,EAAE;AACjB,YAAA,uBAAuB,EAAE;YACzB,iBAAiB,CAAC,IAAI,CAAC;YACvB;QACD;AAEA,QAAA,QAAQ,CAAC,OAAO,GAAG,SAAS;AAC5B,QAAA,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;AACrB,YAAA,UAAU,CAAC,OAAO,GAAG,IAAI;AACzB,YAAA,YAAY,CAAC,OAAO,GAAG,IAAI;AAC3B,YAAA,UAAU,CAAC,OAAO,GAAG,IAAI;YACzB,OAAO,CAAC,IAAI,CAAC;QACd;AAEA,QAAA,QAAQ,CAAC,OAAO,GAAG,UAAU,CAAC,MAAK;AAClC,YAAA,IAAI,QAAQ,CAAC,OAAO,KAAK,SAAS;gBAAE;AAEpC,YAAA,MAAM,CAAC,OAAO,GAAG,qBAAqB,CAAC,MAAK;AAC3C,gBAAA,MAAM,CAAC,OAAO,GAAG,IAAI;AACrB,gBAAA,IAAI,QAAQ,CAAC,OAAO,KAAK,SAAS;oBAAE;gBACpC,IAAI,CAAC,UAAU,CAAC,OAAO;oBAAE;AAEzB,gBAAA,eAAe,EAAE;AACjB,gBAAA,IAAI,IAAI,CAAC,OAAO,KAAK,aAAa,EAAE;AACnC,oBAAA,oBAAoB,EAAE;gBACvB;qBAAO;AACN,oBAAA,uBAAuB,EAAE;gBAC1B;gBACA,iBAAiB,CAAC,IAAI,CAAC;AACvB,gBAAA,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;AAC5B,gBAAA,UAAU,EAAE;AACZ,gBAAA,QAAQ,CAAC,OAAO,GAAG,EAAE;AACtB,YAAA,CAAC,CAAC;AACH,QAAA,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC;AACnB,IAAA,CAAC;IAED,MAAM,UAAU,GAAG,MAAK;QACvB,IAAI,CAAC,OAAO,CAAC,OAAO;YAAE;AAEtB,QAAA,cAAc,EAAE;AAChB,QAAA,QAAQ,CAAC,OAAO,GAAG,QAAQ;AAC3B,QAAA,QAAQ,CAAC,OAAO,GAAG,UAAU,CAAC,MAAK;AAClC,YAAA,IAAI,QAAQ,CAAC,OAAO,KAAK,QAAQ,EAAE;AAClC,gBAAA,UAAU,EAAE;gBACZ;YACD;YAEA,iBAAiB,CAAC,KAAK,CAAC;AAExB,YAAA,iBAAiB,CAAC,OAAO,GAAG,UAAU,CAAC,MAAK;AAC3C,gBAAA,iBAAiB,CAAC,OAAO,GAAG,IAAI;gBAChC,OAAO,CAAC,KAAK,CAAC;AACd,gBAAA,cAAc,EAAE;gBAChB,SAAS,CAAC,OAAO,CAAC,eAAe,GAAG,KAAK,CAAC;AAC1C,gBAAA,QAAQ,CAAC,OAAO,GAAG,EAAE;YACtB,CAAC,EAAE,GAAG,CAAC;AACR,QAAA,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC;AAChC,IAAA,CAAC;AAED,IAAA,MAAM,YAAY,GAAG,CAAC,MAAgB,KAAI;AACzC,QAAA,IAAI,MAAM,KAAK,SAAS,EAAE;YACzB,MAAM,GAAG,UAAU,EAAE,GAAG,UAAU,EAAE;YACpC;QACD;AACA,QAAA,OAAO,CAAC,OAAO,GAAG,UAAU,EAAE,GAAG,UAAU,EAAE;AAC9C,IAAA,CAAC;AAED,IAAA,MAAM,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC;AAClC,IAAA,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,CAAC;AACtC,IAAA,OAAO,CAAC,OAAO,GAAG,UAAU;AAC5B,IAAA,SAAS,CAAC,OAAO,GAAG,YAAY;AAEhC,IAAA,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,MAAM,OAAO,CAAC,OAAO,EAAE,EAAE,EAAE,CAAC;IACzD,MAAM,QAAQ,GAAG,OAAO,CACvB,MAAM,CAAC,MAAgB,KAAK,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,EACrD,EAAE,CACF;AAED,IAAA,MAAM,SAAS,GAAG,OAAO,CAAC,MAAK;QAC9B,OAAO;AACN,YAAA,KAAK,EAAE;AACN,gBAAA,OAAO,EAAE,MAAM,QAAQ,CAAC,IAAI,CAAC;AAC7B,aAAA;AACD,YAAA,KAAK,EAAE;AACN,gBAAA,YAAY,EAAE,MAAM,QAAQ,CAAC,IAAI,CAAC;AAClC,gBAAA,YAAY,EAAE,MAAM,QAAQ,CAAC,KAAK,CAAC;AACnC,aAAA;AACD,YAAA,KAAK,EAAE;AACN,gBAAA,OAAO,EAAE,MAAM,QAAQ,CAAC,IAAI,CAAC;AAC7B,gBAAA,MAAM,EAAE,MAAM,QAAQ,CAAC,KAAK,CAAC;AAC7B,aAAA;AACD,YAAA,WAAW,EAAE;AACZ,gBAAA,aAAa,EAAE,CAAC,CAAa,KAAI;oBAChC,CAAC,CAAC,cAAc,EAAE;oBAClB,CAAC,CAAC,eAAe,EAAE;oBAEnB,QAAQ,CAAC,OAAO,GAAG;wBAClB,KAAK,EAAG,CAAS,CAAC,KAAK;wBACvB,KAAK,EAAG,CAAS,CAAC,KAAK;qBACvB;AAED,oBAAA,IAAI,OAAO,CAAC,OAAO,EAAE;AACpB,wBAAA,eAAe,EAAE;AACjB,wBAAA,oBAAoB,EAAE;wBACtB;oBACD;AAEA,oBAAA,cAAc,EAAE;AAChB,oBAAA,QAAQ,CAAC,OAAO,GAAG,SAAS;AAC5B,oBAAA,UAAU,CAAC,OAAO,GAAG,IAAI;AACzB,oBAAA,YAAY,CAAC,OAAO,GAAG,IAAI;AAC3B,oBAAA,UAAU,CAAC,OAAO,GAAG,IAAI;oBACzB,OAAO,CAAC,IAAI,CAAC;AAEb,oBAAA,QAAQ,CAAC,OAAO,GAAG,UAAU,CAAC,MAAK;AAClC,wBAAA,IAAI,QAAQ,CAAC,OAAO,KAAK,SAAS;4BAAE;wBACpC,IAAI,CAAC,UAAU,CAAC,OAAO;4BAAE;AAEzB,wBAAA,eAAe,EAAE;AACjB,wBAAA,oBAAoB,EAAE;wBACtB,iBAAiB,CAAC,IAAI,CAAC;AACvB,wBAAA,UAAU,EAAE;wBACZ,SAAS,CAAC,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;AACzC,wBAAA,QAAQ,CAAC,OAAO,GAAG,EAAE;AACtB,oBAAA,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC;gBAChC,CAAC;AACD,aAAA;AACD,YAAA,IAAI,EAAE,EAAE;SACR;AACF,IAAA,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;AAEd,IAAA,MAAM,YAAY,GAAG,OAAO,CAAC,MAAK;AACjC,QAAA,IAAI,CAAC,SAAS;AAAE,YAAA,OAAO,EAAE;QACzB,MAAM,MAAM,GAAkC,EAAE;AAEhD,QAAA,IAAI,OAAO,KAAK,OAAO,EAAE;AACxB,YAAA,MAAM,CAAC,cAAc,CAAC,GAAG,MAAK;AAC7B,gBAAA,UAAU,EAAE;AACb,YAAA,CAAC;YACD,MAAM,CAAC,cAAc,CAAC,GAAG,MAAM,YAAY,CAAC,KAAK,CAAC;QACnD;AAEA,QAAA,OAAO,MAAM;AACd,IAAA,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IAExB,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,iBAAiB,EAAE;IAC9D,SAAS,CAAC,MAAK;AACd,QAAA,IAAI,CAAC,OAAO;YAAE;AACd,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,IAAI,SAAS;AAAE,YAAA,OAAO,CAAC,SAAS,EAAE,uBAAuB,CAAC;AAC1D,QAAA,IAAI,SAAS;AAAE,YAAA,OAAO,CAAC,SAAS,EAAE,uBAAuB,CAAC;AAC1D,QAAA,OAAO,MAAK;AACX,YAAA,IAAI,SAAS;gBAAE,SAAS,CAAC,SAAS,CAAC;AACnC,YAAA,IAAI,SAAS;gBAAE,SAAS,CAAC,SAAS,CAAC;AACnC,YAAA,UAAU,EAAE;AACb,QAAA,CAAC;AACF,IAAA,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;IAEnD,eAAe,CAAC,MAAK;AACpB,QAAA,IAAI,CAAC,IAAI;YAAE;AACX,QAAA,eAAe,EAAE;QACjB,IAAI,SAAS,CAAC,OAAO,CAAC,OAAO,KAAK,aAAa,EAAE;AAChD,YAAA,oBAAoB,EAAE;QACvB;aAAO;AACN,YAAA,uBAAuB,EAAE;QAC1B;AACD,IAAA,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;IAEV,eAAe,CAAC,MAAK;QACpB,QAAQ,CAAC,OAAO,CAAC;AAClB,IAAA,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;IAEb,SAAS,CAAC,MAAK;AACd,QAAA,OAAO,MAAK;AACX,YAAA,cAAc,EAAE;AACjB,QAAA,CAAC;IACF,CAAC,EAAE,EAAE,CAAC;IAEN,MAAM,iBAAiB,GAAG,MAAM,CAAmB,MAAK,EAAE,CAAC,CAAC;AAC5D,IAAA,iBAAiB,CAAC,OAAO,GAAG,CAAC,CAAC,KAAI;QACjC,IAAI,CAAC,OAAO,CAAC,OAAO;YAAE;AACtB,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO;AACpC,QAAA,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS;YAAE;AAC9B,QAAA,MAAM,GAAG,GAAG,CAAC,CAAC,MAAqB;AACnC,QAAA,IAAI,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC;YAAE;AACxD,QAAA,MAAM,EAAE;AACT,IAAA,CAAC;IACD,MAAM,eAAe,GAAG,OAAO,CAC9B,MAAM,CAAC,CAAM,KAAK,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,EAC9C,EAAE,CACF;IACD,UAAU,CAAC,eAAe,CAAC;IAE3B,SAAS,CAAC,MAAK;AACd,QAAA,IAAI,CAAC,IAAI;YAAE;QACX,IAAI,OAAO,MAAM,KAAK,WAAW;YAAE;QAEnC,MAAM,gBAAgB,GAAG,QAAQ,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,MAAK;AACtD,YAAA,uBAAuB,EAAE;AAC1B,QAAA,CAAC,CAAC;AAEF,QAAA,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,gBAAgB,EAAE;AACnD,YAAA,OAAO,EAAE,IAAI;AACb,YAAA,OAAO,EAAE,IAAI;AACb,SAAA,CAAC;AAEF,QAAA,OAAO,MAAK;YACX,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,IAAI,CAAC;AAC7D,QAAA,CAAC;AACF,IAAA,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;AAEV,IAAA,MAAM,SAAS,GAAG,CAAC,GAAG,IAAyC,KAAI;QAClE,OAAO,CAAC,IAAwB,KAAI;AACnC,YAAA,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;AACvB,gBAAA,IAAI,CAAC,GAAG;oBAAE;AACV,gBAAA,IAAI,OAAO,GAAG,KAAK,UAAU,EAAE;oBAC9B,GAAG,CAAC,IAAI,CAAC;gBACV;qBAAO;AACL,oBAAA,GAAW,CAAC,OAAO,GAAG,IAAI;gBAC5B;YACD;AACD,QAAA,CAAC;AACF,IAAA,CAAC;AAED,IAAA,QACCA,IAAA,CAAAC,QAAA,EAAA,EAAA,QAAA,EAAA,CACE,CAAC,MAAK;AACN,gBAAA,MAAM,MAAM,GAAG,SAAS,CAAC,OAAO,CAAQ;gBACxC,MAAM,KAAK,GAAG,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC;AACxC,gBAAA,MAAM,YAAY,GAAG,CAAC,EAAO,KAAI;AAChC,oBAAA,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC;AAAE,wBAAA,OAAO,KAAK;AACrC,oBAAA,MAAM,CAAC,GAAQ,EAAE,CAAC,IAAI;oBACtB,IAAI,OAAO,CAAC,KAAK,QAAQ;AAAE,wBAAA,OAAO,IAAI;AACtC,oBAAA,IAAI,CAAC,EAAE,SAAS,EAAE,gBAAgB;AAAE,wBAAA,OAAO,IAAI;oBAC/C,IAAI,CAAC,EAAE,QAAQ,KAAK,MAAM,CAAC,GAAG,CAAC,mBAAmB,CAAC;AAClD,wBAAA,OAAO,IAAI;AACZ,oBAAA,OAAO,KAAK;AACb,gBAAA,CAAC;AAED,gBAAA,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;oBACvB,QACCC,aACC,GAAG,EAAE,UAAiB,EAAA,GAClB,MAAM,EACV,SAAS,EAAC,iBAAiB,EAC3B,KAAK,EAAE,EAAE,OAAO,EAAE,cAAc,EAAE,EAAA,QAAA,EAEjC,QAAQ,EAAA,CACJ;gBAER;AAEA,gBAAA,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAQ;AAC5B,gBAAA,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;oBACjD,QACCA,aACC,GAAG,EAAE,UAAiB,EAAA,GAClB,MAAM,EACV,SAAS,EAAC,iBAAiB,EAC3B,KAAK,EAAE,EAAE,OAAO,EAAE,cAAc,EAAE,EAAA,QAAA,EAEjC,IAAI,EAAA,CACA;gBAER;AAEA,gBAAA,MAAM,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,SAAS,EAAE,GAChD,IAAI,CAAC,KAAY;AAClB,gBAAA,MAAM,SAAS,GAAwB,EAAE,GAAG,SAAS,EAAE;gBACvD,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;AACtC,oBAAA,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC;AAC7B,oBAAA,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC;oBACxB,SAAS,CAAC,GAAG,CAAC;wBACb,OAAO,MAAM,KAAK;AACjB,8BAAE,CAAC,CAAM,KAAI;gCACX,IAAI,CAAC,CAAC,CAAC;gCACP,MAAM,CAAC,CAAC,CAAC;4BACV;8BACC,IAAI;gBACT;gBACA,OAAO,YAAY,CAAC,IAAW,EAAE;oBAChC,GAAG,EAAE,SAAS,CAAE,IAAY,CAAC,GAAG,EAAE,UAAiB,CAAC;AACpD,oBAAA,SAAS,EAAE,cAAc;AACzB,oBAAA,GAAG,SAAS;AACZ,iBAAA,CAAC;YACH,CAAC,GAAG,EAEH,IAAI,KACJA,GAAA,CAAC,OAAO,EAAA,EACP,GAAG,EAAE,UAAU,EACf,KAAK,EAAE,KAAK,IAAI,OAAO,KAAK,aAAa,EACzC,KAAK,EAAE;AACN,oBAAA,GAAG,KAAK;AACR,oBAAA,QAAQ,EAAE,OAAO;AACjB,iBAAA,EACD,SAAS,EAAE,SAAS,EAAA,GAChB,YAAY,EAChB,OAAO,EAAE,UAAU,CAAC,OAAsB,EAAA,QAAA,EAEzC,OAAO,GACC,CACV,CAAA,EAAA,CACC;AAEL;;;;"}
|
|
@@ -1,44 +1,12 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import Text from '../text/text.js';
|
|
3
|
+
|
|
4
4
|
function Circle(props) {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
width: circleSize,
|
|
10
|
-
height: circleSize,
|
|
11
|
-
children: [/* @__PURE__ */ jsx("circle", {
|
|
12
|
-
cx: circleSize / 2,
|
|
13
|
-
cy: circleSize / 2,
|
|
14
|
-
r: circleSize / 2 - lineWidth / 2,
|
|
15
|
-
fill: "none",
|
|
16
|
-
stroke: "var(--background-opacity-2)",
|
|
17
|
-
strokeWidth: lineWidth
|
|
18
|
-
}), /* @__PURE__ */ jsx("circle", {
|
|
19
|
-
cx: circleSize / 2,
|
|
20
|
-
cy: circleSize / 2,
|
|
21
|
-
r: circleSize / 2 - lineWidth / 2,
|
|
22
|
-
fill: "none",
|
|
23
|
-
stroke: "var(--color-main)",
|
|
24
|
-
strokeWidth: lineWidth,
|
|
25
|
-
strokeDasharray: 100,
|
|
26
|
-
pathLength: 100,
|
|
27
|
-
className: "i-progress-circle-path",
|
|
28
|
-
strokeLinecap: "round",
|
|
29
|
-
style: { strokeDashoffset: `calc(100 - ${value})` }
|
|
30
|
-
})]
|
|
31
|
-
}), /* @__PURE__ */ jsxs("span", {
|
|
32
|
-
className: "i-progress-circle-value",
|
|
33
|
-
children: [/* @__PURE__ */ jsx("span", { children: value }), /* @__PURE__ */ jsx(text_default, {
|
|
34
|
-
size: ".81em",
|
|
35
|
-
className: "color-7",
|
|
36
|
-
children: "%"
|
|
37
|
-
})]
|
|
38
|
-
})]
|
|
39
|
-
});
|
|
5
|
+
const { value, circleSize = 40, lineWidth = 8 } = props;
|
|
6
|
+
return (jsxs("div", { className: 'i-progress-circle', children: [jsxs("svg", { width: circleSize, height: circleSize, children: [jsx("circle", { cx: circleSize / 2, cy: circleSize / 2, r: circleSize / 2 - lineWidth / 2, fill: 'none', stroke: 'var(--background-opacity-2)', strokeWidth: lineWidth }), jsx("circle", { cx: circleSize / 2, cy: circleSize / 2, r: circleSize / 2 - lineWidth / 2, fill: 'none', stroke: 'var(--color-main)', strokeWidth: lineWidth, strokeDasharray: 100, pathLength: 100, className: 'i-progress-circle-path', strokeLinecap: 'round', style: {
|
|
7
|
+
strokeDashoffset: `calc(100 - ${value})`,
|
|
8
|
+
} })] }), jsxs("span", { className: 'i-progress-circle-value', children: [jsx("span", { children: value }), jsx(Text, { size: '.81em', className: 'color-7', children: "%" })] })] }));
|
|
40
9
|
}
|
|
41
|
-
//#endregion
|
|
42
|
-
export { Circle as default };
|
|
43
10
|
|
|
44
|
-
|
|
11
|
+
export { Circle as default };
|
|
12
|
+
//# sourceMappingURL=circle.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"circle.js","
|
|
1
|
+
{"version":3,"file":"circle.js","sources":["../../../../packages/components/progress/circle.tsx"],"sourcesContent":["import Text from \"../text\";\nimport { IProgress } from \"./type\";\n\nexport default function Circle(\n\tprops: Pick<IProgress, \"value\" | \"circleSize\" | \"lineWidth\">\n) {\n\tconst { value, circleSize = 40, lineWidth = 8 } = props;\n\n\treturn (\n\t\t<div className='i-progress-circle'>\n\t\t\t<svg width={circleSize} height={circleSize}>\n\t\t\t\t<circle\n\t\t\t\t\tcx={circleSize / 2}\n\t\t\t\t\tcy={circleSize / 2}\n\t\t\t\t\tr={circleSize / 2 - lineWidth / 2}\n\t\t\t\t\tfill='none'\n\t\t\t\t\tstroke='var(--background-opacity-2)'\n\t\t\t\t\tstrokeWidth={lineWidth}\n\t\t\t\t/>\n\t\t\t\t<circle\n\t\t\t\t\tcx={circleSize / 2}\n\t\t\t\t\tcy={circleSize / 2}\n\t\t\t\t\tr={circleSize / 2 - lineWidth / 2}\n\t\t\t\t\tfill='none'\n\t\t\t\t\tstroke='var(--color-main)'\n\t\t\t\t\tstrokeWidth={lineWidth}\n\t\t\t\t\tstrokeDasharray={100}\n\t\t\t\t\tpathLength={100}\n\t\t\t\t\tclassName='i-progress-circle-path'\n\t\t\t\t\tstrokeLinecap='round'\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\tstrokeDashoffset: `calc(100 - ${value})`,\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t</svg>\n\n\t\t\t<span className='i-progress-circle-value'>\n\t\t\t\t<span>{value}</span>\n\t\t\t\t<Text size='.81em' className='color-7'>\n\t\t\t\t\t%\n\t\t\t\t</Text>\n\t\t\t</span>\n\t\t</div>\n\t);\n}\n"],"names":["_jsxs","_jsx"],"mappings":";;;AAGc,SAAU,MAAM,CAC7B,KAA4D,EAAA;AAE5D,IAAA,MAAM,EAAE,KAAK,EAAE,UAAU,GAAG,EAAE,EAAE,SAAS,GAAG,CAAC,EAAE,GAAG,KAAK;IAEvD,QACCA,cAAK,SAAS,EAAC,mBAAmB,EAAA,QAAA,EAAA,CACjCA,IAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,aACzCC,GAAA,CAAA,QAAA,EAAA,EACC,EAAE,EAAE,UAAU,GAAG,CAAC,EAClB,EAAE,EAAE,UAAU,GAAG,CAAC,EAClB,CAAC,EAAE,UAAU,GAAG,CAAC,GAAG,SAAS,GAAG,CAAC,EACjC,IAAI,EAAC,MAAM,EACX,MAAM,EAAC,6BAA6B,EACpC,WAAW,EAAE,SAAS,EAAA,CACrB,EACFA,gBACC,EAAE,EAAE,UAAU,GAAG,CAAC,EAClB,EAAE,EAAE,UAAU,GAAG,CAAC,EAClB,CAAC,EAAE,UAAU,GAAG,CAAC,GAAG,SAAS,GAAG,CAAC,EACjC,IAAI,EAAC,MAAM,EACX,MAAM,EAAC,mBAAmB,EAC1B,WAAW,EAAE,SAAS,EACtB,eAAe,EAAE,GAAG,EACpB,UAAU,EAAE,GAAG,EACf,SAAS,EAAC,wBAAwB,EAClC,aAAa,EAAC,OAAO,EACrB,KAAK,EAAE;4BACN,gBAAgB,EAAE,CAAA,WAAA,EAAc,KAAK,CAAA,CAAA,CAAG;yBACxC,EAAA,CACA,CAAA,EAAA,CACG,EAEND,IAAA,CAAA,MAAA,EAAA,EAAM,SAAS,EAAC,yBAAyB,EAAA,QAAA,EAAA,CACxCC,GAAA,CAAA,MAAA,EAAA,EAAA,QAAA,EAAO,KAAK,EAAA,CAAQ,EACpBA,GAAA,CAAC,IAAI,EAAA,EAAC,IAAI,EAAC,OAAO,EAAC,SAAS,EAAC,SAAS,EAAA,QAAA,EAAA,GAAA,EAAA,CAE/B,CAAA,EAAA,CACD,CAAA,EAAA,CACF;AAER;;;;"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import Progress from
|
|
2
|
-
//#region packages/components/progress/index.tsx
|
|
3
|
-
var progress_default = Progress;
|
|
4
|
-
//#endregion
|
|
5
|
-
export { progress_default as default };
|
|
1
|
+
import Progress from './progress.js';
|
|
6
2
|
|
|
7
|
-
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
export { Progress as default };
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -1,25 +1,14 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
|
|
4
4
|
const Line = (props) => {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
onTouchStart,
|
|
12
|
-
children: /* @__PURE__ */ jsx("div", {
|
|
13
|
-
className: classNames("i-progress-bar", barClass, { "no-transition": dragging }),
|
|
14
|
-
style: { [vertical ? "height" : "width"]: `${value}%` },
|
|
15
|
-
children: renderCursor && /* @__PURE__ */ jsx("a", {
|
|
16
|
-
className: "i-progress-cursor",
|
|
17
|
-
children: renderCursor(value ?? 0)
|
|
18
|
-
})
|
|
19
|
-
})
|
|
20
|
-
});
|
|
5
|
+
const { ref, value, lineWidth, vertical, barClass, dragging, renderCursor, onMouseDown, onTouchStart, } = props;
|
|
6
|
+
return (jsx("div", { ref: ref, className: classNames("i-progress", {
|
|
7
|
+
"i-progress-vertical": vertical,
|
|
8
|
+
}), style: { [vertical ? "width" : "height"]: lineWidth }, onMouseDown: onMouseDown, onTouchStart: onTouchStart, children: jsx("div", { className: classNames("i-progress-bar", barClass, {
|
|
9
|
+
"no-transition": dragging,
|
|
10
|
+
}), style: { [vertical ? "height" : "width"]: `${value}%` }, children: renderCursor && (jsx("a", { className: 'i-progress-cursor', children: renderCursor(value ?? 0) })) }) }));
|
|
21
11
|
};
|
|
22
|
-
//#endregion
|
|
23
|
-
export { Line as default };
|
|
24
12
|
|
|
25
|
-
|
|
13
|
+
export { Line as default };
|
|
14
|
+
//# sourceMappingURL=line.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"line.js","
|
|
1
|
+
{"version":3,"file":"line.js","sources":["../../../../packages/components/progress/line.tsx"],"sourcesContent":["import classNames from \"classnames\";\nimport { MouseEvent, RefObject } from \"react\";\nimport { IProgress } from \"./type\";\n\nconst Line = (\n\tprops: Pick<\n\t\tIProgress,\n\t\t\"value\" | \"vertical\" | \"lineWidth\" | \"barClass\" | \"renderCursor\"\n\t> & {\n\t\tref: RefObject<HTMLDivElement | null>;\n\t\tdragging: boolean;\n\t\tonMouseDown: (e: MouseEvent) => void;\n\t\tonTouchStart: (e) => void;\n\t}\n) => {\n\tconst {\n\t\tref,\n\t\tvalue,\n\t\tlineWidth,\n\t\tvertical,\n\t\tbarClass,\n\t\tdragging,\n\t\trenderCursor,\n\t\tonMouseDown,\n\t\tonTouchStart,\n\t} = props;\n\n\treturn (\n\t\t<div\n\t\t\tref={ref}\n\t\t\tclassName={classNames(\"i-progress\", {\n\t\t\t\t\"i-progress-vertical\": vertical,\n\t\t\t})}\n\t\t\tstyle={{ [vertical ? \"width\" : \"height\"]: lineWidth }}\n\t\t\tonMouseDown={onMouseDown}\n\t\t\tonTouchStart={onTouchStart}\n\t\t>\n\t\t\t<div\n\t\t\t\tclassName={classNames(\"i-progress-bar\", barClass, {\n\t\t\t\t\t\"no-transition\": dragging,\n\t\t\t\t})}\n\t\t\t\tstyle={{ [vertical ? \"height\" : \"width\"]: `${value}%` }}\n\t\t\t>\n\t\t\t\t{renderCursor && (\n\t\t\t\t\t<a className='i-progress-cursor'>\n\t\t\t\t\t\t{renderCursor(value ?? 0)}\n\t\t\t\t\t</a>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t</div>\n\t);\n};\n\nexport default Line;\n"],"names":["_jsx"],"mappings":";;;AAIA,MAAM,IAAI,GAAG,CACZ,KAQC,KACE;IACH,MAAM,EACL,GAAG,EACH,KAAK,EACL,SAAS,EACT,QAAQ,EACR,QAAQ,EACR,QAAQ,EACR,YAAY,EACZ,WAAW,EACX,YAAY,GACZ,GAAG,KAAK;IAET,QACCA,GAAA,CAAA,KAAA,EAAA,EACC,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,UAAU,CAAC,YAAY,EAAE;AACnC,YAAA,qBAAqB,EAAE,QAAQ;AAC/B,SAAA,CAAC,EACF,KAAK,EAAE,EAAE,CAAC,QAAQ,GAAG,OAAO,GAAG,QAAQ,GAAG,SAAS,EAAE,EACrD,WAAW,EAAE,WAAW,EACxB,YAAY,EAAE,YAAY,EAAA,QAAA,EAE1BA,GAAA,CAAA,KAAA,EAAA,EACC,SAAS,EAAE,UAAU,CAAC,gBAAgB,EAAE,QAAQ,EAAE;AACjD,gBAAA,eAAe,EAAE,QAAQ;AACzB,aAAA,CAAC,EACF,KAAK,EAAE,EAAE,CAAC,QAAQ,GAAG,QAAQ,GAAG,OAAO,GAAG,CAAA,EAAG,KAAK,CAAA,CAAA,CAAG,EAAE,EAAA,QAAA,EAEtD,YAAY,KACZA,GAAA,CAAA,GAAA,EAAA,EAAG,SAAS,EAAC,mBAAmB,YAC9B,YAAY,CAAC,KAAK,IAAI,CAAC,CAAC,EAAA,CACtB,CACJ,EAAA,CACI,EAAA,CACD;AAER;;;;"}
|
|
@@ -1,98 +1,82 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import { useRef, useEffect } from 'react';
|
|
4
|
+
import { useReactive, useMouseMove, useMouseUp } from '../../js/hooks.js';
|
|
5
|
+
import Circle from './circle.js';
|
|
6
|
+
import Line from './line.js';
|
|
7
|
+
|
|
8
8
|
const Progress = (props) => {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
lineWidth,
|
|
80
|
-
barClass,
|
|
81
|
-
dragging: state.dragging,
|
|
82
|
-
value: state.value,
|
|
83
|
-
renderCursor,
|
|
84
|
-
onMouseDown: handleMouseDown,
|
|
85
|
-
onTouchStart: handleMouseDown
|
|
86
|
-
}),
|
|
87
|
-
type === "circle" && /* @__PURE__ */ jsx(Circle, {
|
|
88
|
-
value: state.value,
|
|
89
|
-
circleSize,
|
|
90
|
-
lineWidth
|
|
91
|
-
})
|
|
92
|
-
]
|
|
93
|
-
});
|
|
9
|
+
const { value = 0, lineWidth = 8, circleSize = 40, precision = 0, style, draggable = true, type = "line", barClass, vertical, label, labelInline, className, renderCursor, onChange, onDraggingChange, } = props;
|
|
10
|
+
const ref = useRef(null);
|
|
11
|
+
const state = useReactive({
|
|
12
|
+
value,
|
|
13
|
+
dragging: false,
|
|
14
|
+
size: 0,
|
|
15
|
+
start: 0,
|
|
16
|
+
});
|
|
17
|
+
const pageXY = vertical ? "pageY" : "pageX";
|
|
18
|
+
const rectTL = vertical ? "top" : "left";
|
|
19
|
+
const rectWH = vertical ? "height" : "width";
|
|
20
|
+
const getFixedValue = () => {
|
|
21
|
+
let value = +state.value.toFixed(precision);
|
|
22
|
+
value = Math.min(100, value);
|
|
23
|
+
value = Math.max(0, value);
|
|
24
|
+
return value;
|
|
25
|
+
};
|
|
26
|
+
const handleMouseDown = (e) => {
|
|
27
|
+
if (!ref.current || !draggable)
|
|
28
|
+
return;
|
|
29
|
+
if (e.touches) {
|
|
30
|
+
e = e.touches[0];
|
|
31
|
+
}
|
|
32
|
+
const rect = ref.current.getBoundingClientRect();
|
|
33
|
+
const value = ((e[pageXY] - rect[rectTL]) * 100) / rect[rectWH];
|
|
34
|
+
Object.assign(state, {
|
|
35
|
+
value: vertical ? 100 - value : value,
|
|
36
|
+
size: rect[rectWH],
|
|
37
|
+
start: rect[rectTL],
|
|
38
|
+
dragging: true,
|
|
39
|
+
});
|
|
40
|
+
onDraggingChange?.(true);
|
|
41
|
+
};
|
|
42
|
+
const handleMouseMove = (e) => {
|
|
43
|
+
if (!state.dragging || !draggable)
|
|
44
|
+
return;
|
|
45
|
+
e.preventDefault();
|
|
46
|
+
if (e.touches) {
|
|
47
|
+
e = e.touches[0];
|
|
48
|
+
}
|
|
49
|
+
const { start, size } = state;
|
|
50
|
+
const offset = e[pageXY] - start;
|
|
51
|
+
if (offset < 0 || offset > size)
|
|
52
|
+
return;
|
|
53
|
+
const value = ((e[pageXY] - start) * 100) / size;
|
|
54
|
+
state.value = vertical ? 100 - value : value;
|
|
55
|
+
};
|
|
56
|
+
const handleMouseUp = () => {
|
|
57
|
+
if (!state.dragging || !draggable)
|
|
58
|
+
return;
|
|
59
|
+
onChange?.(getFixedValue());
|
|
60
|
+
state.dragging = false;
|
|
61
|
+
onDraggingChange?.(false);
|
|
62
|
+
};
|
|
63
|
+
useMouseMove(handleMouseMove);
|
|
64
|
+
useMouseUp(handleMouseUp);
|
|
65
|
+
useEffect(() => {
|
|
66
|
+
if (value > 100) {
|
|
67
|
+
state.value = 100;
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
if (value < 0) {
|
|
71
|
+
state.value = 0;
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
state.value = value;
|
|
75
|
+
}, [value]);
|
|
76
|
+
return (jsxs("div", { className: classNames("i-input-label", className, {
|
|
77
|
+
"i-input-inline": labelInline,
|
|
78
|
+
}), style: style, children: [label && jsx("span", { className: 'i-input-label-text', children: label }), type === "line" && (jsx(Line, { ref: ref, vertical: vertical, lineWidth: lineWidth, barClass: barClass, dragging: state.dragging, value: state.value, renderCursor: renderCursor, onMouseDown: handleMouseDown, onTouchStart: handleMouseDown })), type === "circle" && (jsx(Circle, { value: state.value, circleSize: circleSize, lineWidth: lineWidth }))] }));
|
|
94
79
|
};
|
|
95
|
-
//#endregion
|
|
96
|
-
export { Progress as default };
|
|
97
80
|
|
|
98
|
-
|
|
81
|
+
export { Progress as default };
|
|
82
|
+
//# sourceMappingURL=progress.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"progress.js","
|
|
1
|
+
{"version":3,"file":"progress.js","sources":["../../../../packages/components/progress/progress.tsx"],"sourcesContent":["import classNames from \"classnames\";\nimport { useEffect, useRef } from \"react\";\nimport \"../../css/input.css\";\nimport { useMouseMove, useMouseUp, useReactive } from \"../../js/hooks\";\nimport Circle from \"./circle\";\nimport \"./index.css\";\nimport Line from \"./line\";\nimport { IProgress } from \"./type\";\n\nconst Progress = (props: IProgress) => {\n\tconst {\n\t\tvalue = 0,\n\t\tlineWidth = 8,\n\t\tcircleSize = 40,\n\t\tprecision = 0,\n\t\tstyle,\n\t\tdraggable = true,\n\t\ttype = \"line\",\n\t\tbarClass,\n\t\tvertical,\n\t\tlabel,\n\t\tlabelInline,\n\t\tclassName,\n\t\trenderCursor,\n\t\tonChange,\n\t\tonDraggingChange,\n\t} = props;\n\n\tconst ref = useRef<HTMLDivElement>(null);\n\tconst state = useReactive({\n\t\tvalue,\n\t\tdragging: false,\n\t\tsize: 0,\n\t\tstart: 0,\n\t});\n\n\tconst pageXY = vertical ? \"pageY\" : \"pageX\";\n\tconst rectTL = vertical ? \"top\" : \"left\";\n\tconst rectWH = vertical ? \"height\" : \"width\";\n\n\tconst getFixedValue = () => {\n\t\tlet value = +state.value.toFixed(precision);\n\t\tvalue = Math.min(100, value);\n\t\tvalue = Math.max(0, value);\n\n\t\treturn value;\n\t};\n\n\tconst handleMouseDown = (e) => {\n\t\tif (!ref.current || !draggable) return;\n\n\t\tif (e.touches) {\n\t\t\te = e.touches[0];\n\t\t}\n\n\t\tconst rect = ref.current.getBoundingClientRect();\n\t\tconst value = ((e[pageXY] - rect[rectTL]) * 100) / rect[rectWH];\n\n\t\tObject.assign(state, {\n\t\t\tvalue: vertical ? 100 - value : value,\n\t\t\tsize: rect[rectWH],\n\t\t\tstart: rect[rectTL],\n\t\t\tdragging: true,\n\t\t});\n\t\tonDraggingChange?.(true);\n\t};\n\n\tconst handleMouseMove = (e) => {\n\t\tif (!state.dragging || !draggable) return;\n\t\te.preventDefault();\n\n\t\tif (e.touches) {\n\t\t\te = e.touches[0];\n\t\t}\n\n\t\tconst { start, size } = state;\n\t\tconst offset = e[pageXY] - start;\n\n\t\tif (offset < 0 || offset > size) return;\n\n\t\tconst value = ((e[pageXY] - start) * 100) / size;\n\t\tstate.value = vertical ? 100 - value : value;\n\t};\n\n\tconst handleMouseUp = () => {\n\t\tif (!state.dragging || !draggable) return;\n\n\t\tonChange?.(getFixedValue());\n\t\tstate.dragging = false;\n\t\tonDraggingChange?.(false);\n\t};\n\n\tuseMouseMove(handleMouseMove);\n\tuseMouseUp(handleMouseUp);\n\n\tuseEffect(() => {\n\t\tif (value > 100) {\n\t\t\tstate.value = 100;\n\t\t\treturn;\n\t\t}\n\n\t\tif (value < 0) {\n\t\t\tstate.value = 0;\n\t\t\treturn;\n\t\t}\n\n\t\tstate.value = value;\n\t}, [value]);\n\n\treturn (\n\t\t<div\n\t\t\tclassName={classNames(\"i-input-label\", className, {\n\t\t\t\t\"i-input-inline\": labelInline,\n\t\t\t})}\n\t\t\tstyle={style}\n\t\t>\n\t\t\t{label && <span className='i-input-label-text'>{label}</span>}\n\n\t\t\t{type === \"line\" && (\n\t\t\t\t<Line\n\t\t\t\t\tref={ref}\n\t\t\t\t\tvertical={vertical}\n\t\t\t\t\tlineWidth={lineWidth}\n\t\t\t\t\tbarClass={barClass}\n\t\t\t\t\tdragging={state.dragging}\n\t\t\t\t\tvalue={state.value}\n\t\t\t\t\trenderCursor={renderCursor}\n\t\t\t\t\tonMouseDown={handleMouseDown}\n\t\t\t\t\tonTouchStart={handleMouseDown}\n\t\t\t\t/>\n\t\t\t)}\n\n\t\t\t{type === \"circle\" && (\n\t\t\t\t<Circle\n\t\t\t\t\tvalue={state.value}\n\t\t\t\t\tcircleSize={circleSize}\n\t\t\t\t\tlineWidth={lineWidth}\n\t\t\t\t/>\n\t\t\t)}\n\t\t</div>\n\t);\n};\n\nexport default Progress;\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import Radio from
|
|
2
|
-
//#region packages/components/radio/index.tsx
|
|
3
|
-
var radio_default = Radio;
|
|
4
|
-
//#endregion
|
|
5
|
-
export { radio_default as default };
|
|
1
|
+
import Radio from './radio.js';
|
|
6
2
|
|
|
7
|
-
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
export { Radio as default };
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -1,32 +1,17 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
|
|
4
4
|
function RadioItem(props) {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
}),
|
|
15
|
-
children: [/* @__PURE__ */ jsx("input", {
|
|
16
|
-
type: "radio",
|
|
17
|
-
name,
|
|
18
|
-
checked,
|
|
19
|
-
className: classNames("i-radio-input", `i-radio-${type}`),
|
|
20
|
-
disabled,
|
|
21
|
-
hidden: isChildrenFn,
|
|
22
|
-
onChange: handleChange
|
|
23
|
-
}), isChildrenFn ? children(!!checked, value) : /* @__PURE__ */ jsx("span", {
|
|
24
|
-
className: "i-radio-text",
|
|
25
|
-
children
|
|
26
|
-
})]
|
|
27
|
-
});
|
|
5
|
+
const { type = "default", name, value, checked, disabled, children, onChange, } = props;
|
|
6
|
+
const isChildrenFn = typeof children === "function";
|
|
7
|
+
const handleChange = (e) => {
|
|
8
|
+
onChange?.(value, e);
|
|
9
|
+
};
|
|
10
|
+
return (jsxs("label", { className: classNames("i-radio-item", {
|
|
11
|
+
disabled,
|
|
12
|
+
"i-radio-item-custom": isChildrenFn,
|
|
13
|
+
}), children: [jsx("input", { type: 'radio', name: name, checked: checked, className: classNames("i-radio-input", `i-radio-${type}`), disabled: disabled, hidden: isChildrenFn, onChange: handleChange }), isChildrenFn ? (children(!!checked, value)) : (jsx("span", { className: 'i-radio-text', children: children }))] }));
|
|
28
14
|
}
|
|
29
|
-
//#endregion
|
|
30
|
-
export { RadioItem as default };
|
|
31
15
|
|
|
32
|
-
|
|
16
|
+
export { RadioItem as default };
|
|
17
|
+
//# sourceMappingURL=item.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"item.js","
|
|
1
|
+
{"version":3,"file":"item.js","sources":["../../../../packages/components/radio/item.tsx"],"sourcesContent":["import classNames from \"classnames\";\nimport { ChangeEvent } from \"react\";\nimport { IRadioItem } from \"./type\";\n\nexport default function RadioItem(props: IRadioItem) {\n\tconst {\n\t\ttype = \"default\",\n\t\tname,\n\t\tvalue,\n\t\tchecked,\n\t\tdisabled,\n\t\tchildren,\n\t\tonChange,\n\t} = props;\n\tconst isChildrenFn = typeof children === \"function\";\n\n\tconst handleChange = (e: ChangeEvent) => {\n\t\tonChange?.(value, e);\n\t};\n\n\treturn (\n\t\t<label\n\t\t\tclassName={classNames(\"i-radio-item\", {\n\t\t\t\tdisabled,\n\t\t\t\t\"i-radio-item-custom\": isChildrenFn,\n\t\t\t})}\n\t\t>\n\t\t\t<input\n\t\t\t\ttype='radio'\n\t\t\t\tname={name}\n\t\t\t\tchecked={checked}\n\t\t\t\tclassName={classNames(\"i-radio-input\", `i-radio-${type}`)}\n\t\t\t\tdisabled={disabled}\n\t\t\t\thidden={isChildrenFn}\n\t\t\t\tonChange={handleChange}\n\t\t\t/>\n\n\t\t\t{isChildrenFn ? (\n\t\t\t\tchildren(!!checked, value)\n\t\t\t) : (\n\t\t\t\t<span className='i-radio-text'>{children}</span>\n\t\t\t)}\n\t\t</label>\n\t);\n}\n"],"names":["_jsxs","_jsx"],"mappings":";;;AAIc,SAAU,SAAS,CAAC,KAAiB,EAAA;AAClD,IAAA,MAAM,EACL,IAAI,GAAG,SAAS,EAChB,IAAI,EACJ,KAAK,EACL,OAAO,EACP,QAAQ,EACR,QAAQ,EACR,QAAQ,GACR,GAAG,KAAK;AACT,IAAA,MAAM,YAAY,GAAG,OAAO,QAAQ,KAAK,UAAU;AAEnD,IAAA,MAAM,YAAY,GAAG,CAAC,CAAc,KAAI;AACvC,QAAA,QAAQ,GAAG,KAAK,EAAE,CAAC,CAAC;AACrB,IAAA,CAAC;AAED,IAAA,QACCA,IAAA,CAAA,OAAA,EAAA,EACC,SAAS,EAAE,UAAU,CAAC,cAAc,EAAE;YACrC,QAAQ;AACR,YAAA,qBAAqB,EAAE,YAAY;AACnC,SAAA,CAAC,EAAA,QAAA,EAAA,CAEFC,GAAA,CAAA,OAAA,EAAA,EACC,IAAI,EAAC,OAAO,EACZ,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,UAAU,CAAC,eAAe,EAAE,CAAA,QAAA,EAAW,IAAI,CAAA,CAAE,CAAC,EACzD,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,YAAY,EACpB,QAAQ,EAAE,YAAY,EAAA,CACrB,EAED,YAAY,IACZ,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,CAAC,KAE1BA,cAAM,SAAS,EAAC,cAAc,EAAA,QAAA,EAAE,QAAQ,EAAA,CAAQ,CAChD,CAAA,EAAA,CACM;AAEV;;;;"}
|