@steroidsjs/core 3.0.0-beta.9 → 3.0.0-beta.91
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +23 -6
- package/actions/list.d.ts +71 -4
- package/actions/list.js +7 -9
- package/base/Enum.d.ts +3 -3
- package/components/ClientStorageComponent.d.ts +27 -1
- package/components/ClientStorageComponent.js +4 -3
- package/components/HttpComponent.d.ts +1 -0
- package/components/HttpComponent.js +4 -3
- package/components/LocaleComponent.d.ts +53 -6
- package/components/LocaleComponent.js +9 -8
- package/components/ResourceComponent.d.ts +88 -6
- package/components/ResourceComponent.js +11 -11
- package/components/UiComponent.d.ts +130 -1
- package/docs-autogen-result.json +30076 -0
- package/en.json +824 -0
- package/hooks/index.d.ts +7 -1
- package/hooks/index.js +13 -1
- package/hooks/useAbsolutePositioning.d.ts +56 -7
- package/hooks/useAbsolutePositioning.js +39 -131
- package/hooks/useAddressBar.d.ts +11 -0
- package/hooks/useApplication.d.ts +4 -1
- package/hooks/useApplication.js +19 -1
- package/hooks/useDataProvider.d.ts +29 -29
- package/hooks/useDataProvider.js +4 -5
- package/hooks/useDataSelect.d.ts +10 -3
- package/hooks/useDataSelect.js +40 -23
- package/hooks/useFetch.d.ts +5 -6
- package/hooks/useFetch.js +0 -3
- package/hooks/useFile.d.ts +51 -2
- package/hooks/useForm.d.ts +0 -1
- package/hooks/useForm.js +0 -1
- package/hooks/useList.d.ts +20 -5
- package/hooks/useList.js +64 -15
- package/hooks/useSaveCursorPosition.d.ts +6 -0
- package/hooks/useSaveCursorPosition.js +29 -0
- package/hooks/useTheme.d.ts +2 -0
- package/hooks/useTheme.js +8 -0
- package/index.d.ts +28 -15
- package/package.json +12 -7
- package/providers/ComponentsProvider.d.ts +8 -5
- package/providers/ThemeProvider.d.ts +14 -0
- package/providers/ThemeProvider.js +62 -0
- package/reducers/list.d.ts +1 -0
- package/reducers/list.js +4 -1
- package/reducers/router.d.ts +0 -1
- package/reducers/router.js +2 -2
- package/ui/content/Accordion/Accordion.d.ts +40 -15
- package/ui/content/Accordion/AccordionItem.d.ts +4 -3
- package/ui/content/Alert/Alert.d.ts +29 -10
- package/ui/content/Avatar/Avatar.d.ts +26 -24
- package/ui/content/Avatar/Avatar.js +1 -1
- package/ui/content/Avatar/AvatarGroup.d.ts +3 -3
- package/ui/content/Badge/Badge.d.ts +29 -16
- package/ui/content/Badge/Badge.js +1 -1
- package/ui/content/Calendar/Calendar.d.ts +19 -10
- package/ui/content/Calendar/Calendar.js +9 -2
- package/ui/content/CalendarSystem/CalendarSystem.d.ts +56 -0
- package/ui/content/CalendarSystem/CalendarSystem.js +106 -0
- package/ui/content/CalendarSystem/enums/CalendarType.d.ts +6 -0
- package/ui/content/CalendarSystem/enums/CalendarType.js +38 -0
- package/ui/content/CalendarSystem/enums/DateControlType.d.ts +10 -0
- package/ui/content/CalendarSystem/enums/DateControlType.js +42 -0
- package/ui/content/CalendarSystem/helpers/addEventIfMatchDate.d.ts +3 -0
- package/ui/content/CalendarSystem/helpers/addEventIfMatchDate.js +21 -0
- package/ui/content/CalendarSystem/hooks/useCalendarControls.d.ts +8 -0
- package/ui/content/CalendarSystem/hooks/useCalendarControls.js +47 -0
- package/ui/content/CalendarSystem/hooks/useDisplayDate.d.ts +6 -0
- package/ui/content/CalendarSystem/hooks/useDisplayDate.js +27 -0
- package/ui/content/CalendarSystem/hooks/useMonthCalendar.d.ts +16 -0
- package/ui/content/CalendarSystem/hooks/useMonthCalendar.js +87 -0
- package/ui/content/CalendarSystem/hooks/useWeekCalendar.d.ts +15 -0
- package/ui/content/CalendarSystem/hooks/useWeekCalendar.js +86 -0
- package/ui/content/CalendarSystem/index.d.ts +2 -0
- package/ui/{list/LayoutNames/demo/basic.js → content/CalendarSystem/index.js} +2 -7
- package/ui/content/CalendarSystem/utils/utils.d.ts +3 -0
- package/ui/content/CalendarSystem/utils/utils.js +29 -0
- package/ui/content/Card/Card.d.ts +75 -45
- package/ui/content/Card/Card.js +0 -5
- package/ui/content/Chart/Chart.d.ts +37 -0
- package/ui/content/Chart/Chart.js +19 -0
- package/ui/content/Chart/index.d.ts +2 -0
- package/ui/content/Chart/index.js +7 -0
- package/ui/content/CopyToClipboard/CopyToClipboard.d.ts +68 -8
- package/ui/content/CopyToClipboard/CopyToClipboard.js +26 -59
- package/ui/content/Detail/Detail.d.ts +16 -11
- package/ui/content/Detail/DetailItem.d.ts +1 -1
- package/ui/content/DropDown/DropDown.d.ts +22 -10
- package/ui/content/DropDown/DropDown.js +15 -3
- package/ui/content/Icon/Icon.d.ts +13 -7
- package/ui/content/Icon/Icon.js +4 -1
- package/ui/content/Kanban/Kanban.d.ts +104 -0
- package/ui/content/Kanban/Kanban.js +56 -0
- package/ui/content/Kanban/actions/index.d.ts +2 -0
- package/ui/content/Kanban/actions/index.js +10 -0
- package/ui/content/Kanban/actions/kanban.d.ts +19 -0
- package/ui/content/Kanban/actions/kanban.js +25 -0
- package/ui/content/Kanban/hooks/index.d.ts +2 -0
- package/ui/content/Kanban/hooks/index.js +8 -0
- package/ui/content/Kanban/hooks/useKanban.d.ts +25 -0
- package/ui/content/Kanban/hooks/useKanban.js +76 -0
- package/ui/content/Kanban/index.d.ts +2 -0
- package/ui/content/Kanban/index.js +7 -0
- package/ui/content/Kanban/reducers/index.d.ts +3 -0
- package/ui/content/{Icon/demo/icon.js → Kanban/reducers/index.js} +4 -7
- package/ui/content/Kanban/reducers/kanban.d.ts +5 -0
- package/ui/content/Kanban/reducers/kanban.js +77 -0
- package/ui/content/Menu/Menu.d.ts +56 -0
- package/ui/content/Menu/Menu.js +23 -0
- package/ui/content/Menu/index.d.ts +2 -0
- package/ui/content/Menu/index.js +7 -0
- package/ui/content/Slider/Slider.d.ts +28 -0
- package/ui/content/Slider/Slider.js +19 -0
- package/ui/content/Slider/index.d.ts +2 -0
- package/ui/content/Slider/index.js +7 -0
- package/ui/content/index.d.ts +9 -1
- package/ui/content/index.js +18 -1
- package/ui/crud/Crud/Crud.d.ts +116 -4
- package/ui/crud/Crud/CrudContent.d.ts +1 -2
- package/ui/crud/Crud/utils.js +10 -14
- package/ui/crud/index.d.ts +0 -1
- package/ui/form/AutoCompleteField/AutoCompleteField.d.ts +26 -6
- package/ui/form/AutoCompleteField/AutoCompleteField.js +17 -3
- package/ui/form/BlankField/BlankField.d.ts +19 -1
- package/ui/form/Button/Button.d.ts +19 -26
- package/ui/form/Button/Button.js +1 -10
- package/ui/form/CheckboxField/CheckboxField.d.ts +9 -8
- package/ui/form/CheckboxField/CheckboxField.js +36 -6
- package/ui/form/CheckboxListField/CheckboxListField.d.ts +23 -8
- package/ui/form/CheckboxListField/CheckboxListField.js +36 -8
- package/ui/form/DateField/DateField.d.ts +20 -15
- package/ui/form/DateField/DateField.js +7 -2
- package/ui/form/DateField/useDateInputState.js +4 -3
- package/ui/form/DateField/useDateRange.d.ts +2 -1
- package/ui/form/DateField/useDateRange.js +23 -0
- package/ui/form/DateField/useDateTime.js +3 -2
- package/ui/form/DateRangeField/DateRangeField.d.ts +12 -21
- package/ui/form/DateRangeField/DateRangeField.js +6 -3
- package/ui/form/DateTimeField/DateTimeField.d.ts +9 -15
- package/ui/form/DateTimeField/DateTimeField.js +6 -8
- package/ui/form/DateTimeRangeField/DateTimeRangeField.d.ts +7 -21
- package/ui/form/DateTimeRangeField/DateTimeRangeField.js +16 -3
- package/ui/form/DropDownField/DropDownField.d.ts +94 -23
- package/ui/form/DropDownField/DropDownField.js +113 -8
- package/ui/form/Field/Field.d.ts +3 -2
- package/ui/form/Field/fieldWrapper.d.ts +35 -14
- package/ui/form/Field/fieldWrapper.js +5 -5
- package/ui/form/FieldLayout/FieldLayout.d.ts +13 -20
- package/ui/form/FieldLayout/FieldLayout.js +1 -13
- package/ui/form/FieldList/FieldList.d.ts +11 -20
- package/ui/form/FieldList/FieldList.js +2 -3
- package/ui/form/FieldSet/FieldSet.d.ts +1 -1
- package/ui/form/FieldSet/FieldSet.js +2 -4
- package/ui/form/FileField/FileField.d.ts +54 -34
- package/ui/form/FileField/FileField.js +30 -10
- package/ui/form/Form/Form.d.ts +32 -40
- package/ui/form/Form/Form.js +26 -34
- package/ui/form/HtmlField/HtmlField.d.ts +2 -11
- package/ui/form/ImageField/ImageField.d.ts +15 -14
- package/ui/form/ImageField/ImageField.js +4 -0
- package/ui/form/InputField/InputField.d.ts +51 -50
- package/ui/form/InputField/InputField.js +57 -17
- package/ui/form/MaskField/MaskField.d.ts +10 -0
- package/ui/form/MaskField/MaskField.js +34 -0
- package/ui/form/MaskField/index.d.ts +2 -0
- package/ui/form/MaskField/index.js +7 -0
- package/ui/form/NavField/NavField.d.ts +6 -3
- package/ui/form/NumberField/NumberField.d.ts +15 -11
- package/ui/form/NumberField/NumberField.js +33 -10
- package/ui/form/NumberField/hooks/useInputTypeNumber.d.ts +10 -0
- package/ui/form/NumberField/hooks/useInputTypeNumber.js +45 -0
- package/ui/form/PasswordField/PasswordField.d.ts +20 -14
- package/ui/form/PasswordField/PasswordField.js +21 -11
- package/ui/form/RadioField/RadioField.d.ts +31 -0
- package/{hoc/file.js → ui/form/RadioField/RadioField.js} +21 -5
- package/ui/form/RadioField/index.d.ts +2 -0
- package/ui/form/RadioField/index.js +7 -0
- package/ui/form/RadioListField/RadioListField.d.ts +10 -9
- package/ui/form/RadioListField/RadioListField.js +32 -2
- package/ui/form/RateField/RateField.d.ts +11 -13
- package/ui/form/RateField/RateField.js +2 -1
- package/ui/form/RateField/demo/errors.js +1 -1
- package/ui/form/ReCaptchaField/ReCaptchaField.d.ts +66 -5
- package/ui/form/ReCaptchaField/ReCaptchaField.js +22 -1
- package/ui/form/SliderField/SliderField.d.ts +3 -12
- package/ui/form/SliderField/SliderField.js +1 -1
- package/ui/form/SwitcherField/SwitcherField.d.ts +21 -15
- package/ui/form/SwitcherField/SwitcherField.js +34 -4
- package/ui/form/SwitcherField/demo/errors.js +1 -1
- package/ui/form/TextField/TextField.d.ts +8 -27
- package/ui/form/TextField/TextField.js +10 -9
- package/ui/form/TimeField/TimeField.d.ts +2 -16
- package/ui/form/TimeField/TimeField.js +3 -2
- package/ui/form/TimeField/demo/errors.js +1 -1
- package/ui/form/TimeRangeField/TimeRangeField.d.ts +58 -0
- package/ui/form/TimeRangeField/TimeRangeField.js +85 -0
- package/ui/form/TimeRangeField/index.d.ts +2 -0
- package/ui/form/TimeRangeField/index.js +7 -0
- package/ui/form/index.d.ts +37 -1
- package/ui/form/index.js +37 -1
- package/ui/form/validate.js +3 -2
- package/ui/format/BooleanFormatter/BooleanFormatter.d.ts +13 -0
- package/ui/format/DateFormatter/DateFormatter.d.ts +11 -1
- package/ui/format/DateFormatter/DateFormatter.js +1 -1
- package/ui/format/DateTimeFormatter/DateTimeFormatter.d.ts +11 -1
- package/ui/format/DateTimeFormatter/DateTimeFormatter.js +4 -3
- package/ui/format/EnumFormatter/EnumFormatter.d.ts +10 -0
- package/ui/format/FileSize/FileSize.d.ts +8 -3
- package/ui/format/FileSize/FileSize.js +1 -1
- package/ui/format/Format/Format.d.ts +6 -0
- package/ui/format/MoneyFormatter/MoneyFormatter.d.ts +9 -1
- package/ui/format/MoneyFormatter/MoneyFormatter.js +3 -2
- package/ui/layout/Header/Header.d.ts +92 -9
- package/ui/layout/Header/Header.js +20 -1
- package/ui/layout/Loader/Loader.d.ts +15 -1
- package/ui/layout/Meta/Meta.js +3 -3
- package/ui/layout/Notifications/Notifications.d.ts +32 -1
- package/ui/layout/ProgressBar/ProgressBar.js +8 -4
- package/ui/layout/Sidebar/Sidebar.d.ts +82 -0
- package/ui/{list/ControlsColumn/demo/basic.js → layout/Sidebar/Sidebar.js} +21 -13
- package/ui/layout/Sidebar/index.d.ts +2 -0
- package/ui/layout/Sidebar/index.js +7 -0
- package/ui/layout/Skeleton/Skeleton.d.ts +25 -2
- package/ui/layout/Tooltip/Tooltip.d.ts +39 -12
- package/ui/layout/Tooltip/Tooltip.js +17 -46
- package/ui/layout/index.d.ts +2 -1
- package/ui/layout/index.js +3 -1
- package/ui/list/CheckboxColumn/CheckboxColumn.d.ts +3 -2
- package/ui/list/CheckboxColumn/CheckboxColumn.js +4 -1
- package/ui/list/ControlsColumn/ControlsColumn.d.ts +4 -3
- package/ui/list/Empty/Empty.d.ts +1 -10
- package/ui/list/Empty/Empty.js +2 -2
- package/ui/list/FlexGrid/FlexGrid.d.ts +85 -0
- package/ui/list/FlexGrid/FlexGrid.js +51 -0
- package/ui/list/FlexGrid/index.d.ts +2 -0
- package/ui/list/FlexGrid/index.js +7 -0
- package/ui/list/Grid/Grid.d.ts +69 -3
- package/ui/list/Grid/Grid.js +14 -4
- package/ui/list/List/List.d.ts +2 -0
- package/ui/list/List/List.js +1 -0
- package/ui/list/Pagination/Pagination.d.ts +18 -5
- package/ui/list/Pagination/Pagination.js +15 -7
- package/ui/list/PaginationSize/PaginationSize.d.ts +10 -12
- package/ui/list/PaginationSize/PaginationSize.js +10 -9
- package/ui/list/SearchForm/SearchForm.d.ts +3 -0
- package/ui/list/SearchForm/demo/basic.js +5 -2
- package/ui/list/Steps/Steps.d.ts +6 -3
- package/ui/list/Steps/Steps.js +11 -5
- package/ui/list/TreeTable/TreeTable.d.ts +39 -0
- package/ui/list/{Grid/demo/indexing.js → TreeTable/TreeTable.js} +30 -9
- package/ui/list/TreeTable/index.d.ts +2 -0
- package/ui/list/TreeTable/index.js +7 -0
- package/ui/modal/Modal/Modal.d.ts +5 -5
- package/ui/modal/Modal/Modal.js +1 -1
- package/ui/modal/ModalPortal/ModalPortal.d.ts +3 -0
- package/ui/modal/TwoFactorModal/TwoFactorModal.d.ts +10 -2
- package/ui/nav/Breadcrumbs/Breadcrumbs.d.ts +12 -2
- package/ui/nav/ButtonGroup/ButtonGroup.d.ts +44 -0
- package/ui/nav/ButtonGroup/ButtonGroup.js +59 -0
- package/ui/nav/ButtonGroup/index.d.ts +2 -0
- package/ui/nav/ButtonGroup/index.js +7 -0
- package/ui/nav/Controls/Controls.d.ts +3 -3
- package/ui/nav/Controls/Controls.js +6 -5
- package/ui/nav/Link/Link.d.ts +1 -0
- package/ui/nav/Link/Link.js +1 -1
- package/ui/nav/Nav/Nav.d.ts +13 -6
- package/ui/nav/Nav/Nav.js +29 -14
- package/ui/nav/Router/Router.d.ts +0 -10
- package/ui/nav/Router/Router.js +13 -77
- package/ui/nav/Router/helpers.d.ts +4 -0
- package/ui/nav/Router/helpers.js +81 -0
- package/ui/nav/Tree/Tree.d.ts +7 -2
- package/ui/nav/Tree/Tree.js +41 -18
- package/ui/nav/index.d.ts +2 -1
- package/ui/nav/index.js +3 -1
- package/ui/typography/Text/Text.d.ts +11 -9
- package/ui/typography/Title/Title.d.ts +10 -8
- package/utils/calculateComponentAbsolutePosition.d.ts +6 -0
- package/{ui/layout/Tooltip/calculate.js → utils/calculateComponentAbsolutePosition.js} +67 -58
- package/utils/calendar.d.ts +1 -1
- package/utils/calendar.js +17 -15
- package/utils/form.d.ts +0 -2
- package/utils/form.js +1 -12
- package/utils/list.d.ts +1 -0
- package/utils/list.js +5 -0
- package/components/ApiComponent.d.ts +0 -23
- package/components/ApiComponent.js +0 -75
- package/hoc/application.d.ts +0 -8
- package/hoc/application.js +0 -50
- package/hoc/bem.d.ts +0 -14
- package/hoc/bem.js +0 -42
- package/hoc/components.d.ts +0 -11
- package/hoc/components.js +0 -62
- package/hoc/connect.d.ts +0 -6
- package/hoc/connect.js +0 -3
- package/hoc/fetch.d.ts +0 -13
- package/hoc/fetch.js +0 -60
- package/hoc/file.d.ts +0 -28
- package/hoc/http.d.ts +0 -7
- package/hoc/http.js +0 -53
- package/hoc/index.d.ts +0 -8
- package/hoc/index.js +0 -20
- package/hoc/layout.d.ts +0 -30
- package/hoc/layout.js +0 -48
- package/ui/content/Card/demo/basic.d.ts +0 -8
- package/ui/content/Card/demo/basic.js +0 -39
- package/ui/content/Card/demo/border color.d.ts +0 -3
- package/ui/content/Card/demo/border color.js +0 -52
- package/ui/content/Card/demo/color.d.ts +0 -3
- package/ui/content/Card/demo/color.js +0 -52
- package/ui/content/Card/demo/header.d.ts +0 -3
- package/ui/content/Card/demo/header.js +0 -47
- package/ui/content/Card/demo/hover.d.ts +0 -3
- package/ui/content/Card/demo/hover.js +0 -42
- package/ui/content/Card/demo/link.d.ts +0 -3
- package/ui/content/Card/demo/link.js +0 -43
- package/ui/content/Card/demo/orientation.d.ts +0 -3
- package/ui/content/Card/demo/orientation.js +0 -46
- package/ui/content/Detail/demo/basic.d.ts +0 -8
- package/ui/content/Detail/demo/basic.js +0 -60
- package/ui/content/Detail/demo/colors.d.ts +0 -3
- package/ui/content/Detail/demo/colors.js +0 -44
- package/ui/content/Detail/demo/controls.d.ts +0 -8
- package/ui/content/Detail/demo/controls.js +0 -60
- package/ui/content/Detail/demo/layout.d.ts +0 -8
- package/ui/content/Detail/demo/layout.js +0 -60
- package/ui/content/Detail/demo/responsive.d.ts +0 -8
- package/ui/content/Detail/demo/responsive.js +0 -75
- package/ui/content/Detail/demo/sizes.d.ts +0 -8
- package/ui/content/Detail/demo/sizes.js +0 -65
- package/ui/content/Icon/demo/icon.d.ts +0 -3
- package/ui/crud/Crud/demo/default.d.ts +0 -8
- package/ui/crud/Crud/demo/default.js +0 -76
- package/ui/form/AutoCompleteField/demo/basic.d.ts +0 -12
- package/ui/form/AutoCompleteField/demo/basic.js +0 -52
- package/ui/form/AutoCompleteField/demo/disabled.d.ts +0 -8
- package/ui/form/AutoCompleteField/demo/disabled.js +0 -38
- package/ui/form/AutoCompleteField/demo/errors.d.ts +0 -8
- package/ui/form/AutoCompleteField/demo/errors.js +0 -38
- package/ui/form/AutoCompleteField/demo/placeholder.d.ts +0 -8
- package/ui/form/AutoCompleteField/demo/placeholder.js +0 -38
- package/ui/form/AutoCompleteField/demo/required.d.ts +0 -8
- package/ui/form/AutoCompleteField/demo/required.js +0 -38
- package/ui/form/AutoCompleteField/demo/sizes.d.ts +0 -3
- package/ui/form/AutoCompleteField/demo/sizes.js +0 -43
- package/ui/form/BlankField/demo/basic.d.ts +0 -12
- package/ui/form/BlankField/demo/basic.js +0 -55
- package/ui/form/CheckboxListField/demo/basic.d.ts +0 -9
- package/ui/form/CheckboxListField/demo/basic.js +0 -43
- package/ui/form/CheckboxListField/demo/disabled.d.ts +0 -8
- package/ui/form/CheckboxListField/demo/disabled.js +0 -38
- package/ui/form/CheckboxListField/demo/errors.d.ts +0 -8
- package/ui/form/CheckboxListField/demo/errors.js +0 -38
- package/ui/form/CheckboxListField/demo/required.d.ts +0 -8
- package/ui/form/CheckboxListField/demo/required.js +0 -38
- package/ui/form/DateField/demo/basic.d.ts +0 -8
- package/ui/form/DateField/demo/basic.js +0 -37
- package/ui/form/DateField/demo/disabled.d.ts +0 -8
- package/ui/form/DateField/demo/disabled.js +0 -37
- package/ui/form/DateField/demo/errors.d.ts +0 -8
- package/ui/form/DateField/demo/errors.js +0 -37
- package/ui/form/DateField/demo/icon.d.ts +0 -8
- package/ui/form/DateField/demo/icon.js +0 -39
- package/ui/form/DateField/demo/placeholder.d.ts +0 -8
- package/ui/form/DateField/demo/placeholder.js +0 -37
- package/ui/form/DateField/demo/required.d.ts +0 -8
- package/ui/form/DateField/demo/required.js +0 -37
- package/ui/form/DateField/demo/sizes.d.ts +0 -8
- package/ui/form/DateField/demo/sizes.js +0 -43
- package/ui/form/DateRangeField/demo/basic.d.ts +0 -8
- package/ui/form/DateRangeField/demo/basic.js +0 -37
- package/ui/form/DateRangeField/demo/disabled.d.ts +0 -8
- package/ui/form/DateRangeField/demo/disabled.js +0 -37
- package/ui/form/DateRangeField/demo/errors.d.ts +0 -8
- package/ui/form/DateRangeField/demo/errors.js +0 -37
- package/ui/form/DateRangeField/demo/icon.d.ts +0 -8
- package/ui/form/DateRangeField/demo/icon.js +0 -39
- package/ui/form/DateRangeField/demo/placeholder.d.ts +0 -8
- package/ui/form/DateRangeField/demo/placeholder.js +0 -37
- package/ui/form/DateRangeField/demo/required.d.ts +0 -8
- package/ui/form/DateRangeField/demo/required.js +0 -37
- package/ui/form/DateTimeField/demo/basic.d.ts +0 -8
- package/ui/form/DateTimeField/demo/basic.js +0 -37
- package/ui/form/DateTimeField/demo/disabled.d.ts +0 -8
- package/ui/form/DateTimeField/demo/disabled.js +0 -38
- package/ui/form/DateTimeField/demo/errors.d.ts +0 -8
- package/ui/form/DateTimeField/demo/errors.js +0 -37
- package/ui/form/DateTimeField/demo/icon.d.ts +0 -8
- package/ui/form/DateTimeField/demo/icon.js +0 -39
- package/ui/form/DateTimeField/demo/placeholder.d.ts +0 -8
- package/ui/form/DateTimeField/demo/placeholder.js +0 -37
- package/ui/form/DateTimeField/demo/required.d.ts +0 -8
- package/ui/form/DateTimeField/demo/required.js +0 -37
- package/ui/form/DateTimeField/demo/showRemove.d.ts +0 -8
- package/ui/form/DateTimeField/demo/showRemove.js +0 -36
- package/ui/form/DateTimeRangeField/demo/basic.d.ts +0 -8
- package/ui/form/DateTimeRangeField/demo/basic.js +0 -36
- package/ui/form/DateTimeRangeField/demo/disabled.d.ts +0 -8
- package/ui/form/DateTimeRangeField/demo/disabled.js +0 -36
- package/ui/form/DateTimeRangeField/demo/errors.d.ts +0 -8
- package/ui/form/DateTimeRangeField/demo/errors.js +0 -37
- package/ui/form/DateTimeRangeField/demo/icon.d.ts +0 -8
- package/ui/form/DateTimeRangeField/demo/icon.js +0 -36
- package/ui/form/DateTimeRangeField/demo/placeholder.d.ts +0 -8
- package/ui/form/DateTimeRangeField/demo/placeholder.js +0 -37
- package/ui/form/DateTimeRangeField/demo/required.d.ts +0 -8
- package/ui/form/DateTimeRangeField/demo/required.js +0 -37
- package/ui/form/DateTimeRangeField/demo/showRemove.d.ts +0 -8
- package/ui/form/DateTimeRangeField/demo/showRemove.js +0 -36
- package/ui/form/DropDownField/demo/auto-complete.d.ts +0 -8
- package/ui/form/DropDownField/demo/auto-complete.js +0 -38
- package/ui/form/DropDownField/demo/basic.d.ts +0 -12
- package/ui/form/DropDownField/demo/basic.js +0 -56
- package/ui/form/DropDownField/demo/disabled.d.ts +0 -8
- package/ui/form/DropDownField/demo/disabled.js +0 -38
- package/ui/form/DropDownField/demo/errors.d.ts +0 -8
- package/ui/form/DropDownField/demo/errors.js +0 -38
- package/ui/form/DropDownField/demo/multiple.d.ts +0 -8
- package/ui/form/DropDownField/demo/multiple.js +0 -38
- package/ui/form/DropDownField/demo/no-border.d.ts +0 -8
- package/ui/form/DropDownField/demo/no-border.js +0 -38
- package/ui/form/DropDownField/demo/placeholder.d.ts +0 -8
- package/ui/form/DropDownField/demo/placeholder.js +0 -38
- package/ui/form/DropDownField/demo/required.d.ts +0 -8
- package/ui/form/DropDownField/demo/required.js +0 -38
- package/ui/form/DropDownField/demo/show-reset.d.ts +0 -8
- package/ui/form/DropDownField/demo/show-reset.js +0 -38
- package/ui/form/DropDownField/demo/size.d.ts +0 -8
- package/ui/form/DropDownField/demo/size.js +0 -45
- package/ui/form/Field/demo/basic.d.ts +0 -8
- package/ui/form/Field/demo/basic.js +0 -37
- package/ui/form/Field/demo/component.d.ts +0 -8
- package/ui/form/Field/demo/component.js +0 -38
- package/ui/form/Field/demo/model.d.ts +0 -8
- package/ui/form/Field/demo/model.js +0 -48
- package/ui/form/FieldLayout/demo/errors.d.ts +0 -8
- package/ui/form/FieldLayout/demo/errors.js +0 -38
- package/ui/form/FieldLayout/demo/layouts.d.ts +0 -8
- package/ui/form/FieldLayout/demo/layouts.js +0 -43
- package/ui/form/FieldLayout/demo/required.d.ts +0 -8
- package/ui/form/FieldLayout/demo/required.js +0 -38
- package/ui/form/FieldList/demo/basic.d.ts +0 -8
- package/ui/form/FieldList/demo/basic.js +0 -62
- package/ui/form/FieldList/demo/disabled.d.ts +0 -8
- package/ui/form/FieldList/demo/disabled.js +0 -62
- package/ui/form/FieldSet/demo/basic.d.ts +0 -8
- package/ui/form/FieldSet/demo/basic.js +0 -53
- package/ui/form/FileField/demo/basic.d.ts +0 -8
- package/ui/form/FileField/demo/basic.js +0 -37
- package/ui/form/Form/demo/basic.d.ts +0 -8
- package/ui/form/Form/demo/basic.js +0 -62
- package/ui/form/Form/demo/border.d.ts +0 -8
- package/ui/form/Form/demo/border.js +0 -62
- package/ui/form/Form/demo/horizontal.d.ts +0 -8
- package/ui/form/Form/demo/horizontal.js +0 -55
- package/ui/form/Form/demo/inline.d.ts +0 -8
- package/ui/form/Form/demo/inline.js +0 -53
- package/ui/form/HtmlField/demo/basic.d.ts +0 -8
- package/ui/form/HtmlField/demo/basic.js +0 -37
- package/ui/form/InputField/demo/addons.d.ts +0 -8
- package/ui/form/InputField/demo/addons.js +0 -37
- package/ui/form/InputField/demo/basic.d.ts +0 -8
- package/ui/form/InputField/demo/basic.js +0 -36
- package/ui/form/InputField/demo/disabled.d.ts +0 -8
- package/ui/form/InputField/demo/disabled.js +0 -36
- package/ui/form/InputField/demo/errors.d.ts +0 -8
- package/ui/form/InputField/demo/errors.js +0 -37
- package/ui/form/InputField/demo/mask.d.ts +0 -8
- package/ui/form/InputField/demo/mask.js +0 -39
- package/ui/form/InputField/demo/placeholder.d.ts +0 -8
- package/ui/form/InputField/demo/placeholder.js +0 -37
- package/ui/form/InputField/demo/required.d.ts +0 -8
- package/ui/form/InputField/demo/required.js +0 -37
- package/ui/form/InputField/demo/sizes.d.ts +0 -3
- package/ui/form/InputField/demo/sizes.js +0 -42
- package/ui/form/InputField/demo/textAddons.d.ts +0 -8
- package/ui/form/InputField/demo/textAddons.js +0 -37
- package/ui/form/InputField/demo/types.d.ts +0 -3
- package/ui/form/InputField/demo/types.js +0 -44
- package/ui/form/NavField/demo/basic.d.ts +0 -12
- package/ui/form/NavField/demo/basic.js +0 -56
- package/ui/form/NavField/demo/disabled.d.ts +0 -8
- package/ui/form/NavField/demo/disabled.js +0 -38
- package/ui/form/NavField/demo/errors.d.ts +0 -8
- package/ui/form/NavField/demo/errors.js +0 -38
- package/ui/form/NavField/demo/layouts.d.ts +0 -12
- package/ui/form/NavField/demo/layouts.js +0 -61
- package/ui/form/NavField/demo/required.d.ts +0 -8
- package/ui/form/NavField/demo/required.js +0 -38
- package/ui/form/NumberField/demo/basic.d.ts +0 -8
- package/ui/form/NumberField/demo/basic.js +0 -37
- package/ui/form/NumberField/demo/disabled.d.ts +0 -8
- package/ui/form/NumberField/demo/disabled.js +0 -37
- package/ui/form/NumberField/demo/errors.d.ts +0 -8
- package/ui/form/NumberField/demo/errors.js +0 -37
- package/ui/form/NumberField/demo/placeholder.d.ts +0 -8
- package/ui/form/NumberField/demo/placeholder.js +0 -37
- package/ui/form/NumberField/demo/required.d.ts +0 -8
- package/ui/form/NumberField/demo/required.js +0 -37
- package/ui/form/NumberField/demo/sizes.d.ts +0 -8
- package/ui/form/NumberField/demo/sizes.js +0 -42
- package/ui/form/PasswordField/demo/basic.d.ts +0 -8
- package/ui/form/PasswordField/demo/basic.js +0 -37
- package/ui/form/PasswordField/demo/disabled.d.ts +0 -8
- package/ui/form/PasswordField/demo/disabled.js +0 -37
- package/ui/form/PasswordField/demo/errors.d.ts +0 -8
- package/ui/form/PasswordField/demo/errors.js +0 -37
- package/ui/form/PasswordField/demo/placeholder.d.ts +0 -8
- package/ui/form/PasswordField/demo/placeholder.js +0 -37
- package/ui/form/PasswordField/demo/required.d.ts +0 -8
- package/ui/form/PasswordField/demo/required.js +0 -37
- package/ui/form/PasswordField/demo/security.d.ts +0 -8
- package/ui/form/PasswordField/demo/security.js +0 -37
- package/ui/form/PasswordField/demo/sizes.d.ts +0 -8
- package/ui/form/PasswordField/demo/sizes.js +0 -42
- package/ui/form/RadioListField/demo/basic.d.ts +0 -12
- package/ui/form/RadioListField/demo/basic.js +0 -56
- package/ui/form/RadioListField/demo/disabled.d.ts +0 -8
- package/ui/form/RadioListField/demo/disabled.js +0 -38
- package/ui/form/RadioListField/demo/errors.d.ts +0 -8
- package/ui/form/RadioListField/demo/errors.js +0 -38
- package/ui/form/RadioListField/demo/required.d.ts +0 -8
- package/ui/form/RadioListField/demo/required.js +0 -38
- package/ui/form/ReCaptchaField/demo/basic.d.ts +0 -8
- package/ui/form/ReCaptchaField/demo/basic.js +0 -43
- package/ui/form/SliderField/demo/basic.d.ts +0 -8
- package/ui/form/SliderField/demo/basic.js +0 -37
- package/ui/form/SliderField/demo/disabled.d.ts +0 -8
- package/ui/form/SliderField/demo/disabled.js +0 -37
- package/ui/form/SliderField/demo/errors.d.ts +0 -8
- package/ui/form/SliderField/demo/errors.js +0 -37
- package/ui/form/SliderField/demo/marks.d.ts +0 -3
- package/ui/form/SliderField/demo/marks.js +0 -49
- package/ui/form/SliderField/demo/min-max.d.ts +0 -8
- package/ui/form/SliderField/demo/min-max.js +0 -37
- package/ui/form/SliderField/demo/onAfterChange.d.ts +0 -8
- package/ui/form/SliderField/demo/onAfterChange.js +0 -43
- package/ui/form/SliderField/demo/onChange.d.ts +0 -8
- package/ui/form/SliderField/demo/onChange.js +0 -43
- package/ui/form/SliderField/demo/range.d.ts +0 -8
- package/ui/form/SliderField/demo/range.js +0 -37
- package/ui/form/TextField/demo/basic.d.ts +0 -8
- package/ui/form/TextField/demo/basic.js +0 -37
- package/ui/form/TextField/demo/disabled.d.ts +0 -8
- package/ui/form/TextField/demo/disabled.js +0 -37
- package/ui/form/TextField/demo/errors.d.ts +0 -8
- package/ui/form/TextField/demo/errors.js +0 -37
- package/ui/form/TextField/demo/placeholder.d.ts +0 -8
- package/ui/form/TextField/demo/placeholder.js +0 -37
- package/ui/form/TextField/demo/required.d.ts +0 -8
- package/ui/form/TextField/demo/required.js +0 -37
- package/ui/form/TextField/demo/sizes.d.ts +0 -3
- package/ui/form/TextField/demo/sizes.js +0 -43
- package/ui/form/TextField/demo/submit.d.ts +0 -8
- package/ui/form/TextField/demo/submit.js +0 -37
- package/ui/format/DateFormatter/demo/basic.d.ts +0 -3
- package/ui/format/DateFormatter/demo/basic.js +0 -32
- package/ui/format/DateTimeFormatter/demo/basic.d.ts +0 -3
- package/ui/format/DateTimeFormatter/demo/basic.js +0 -32
- package/ui/layout/Notifications/demo/basic.d.ts +0 -8
- package/ui/layout/Notifications/demo/basic.js +0 -57
- package/ui/layout/Notifications/demo/position.d.ts +0 -3
- package/ui/layout/Notifications/demo/position.js +0 -49
- package/ui/layout/Notifications/demo/timeOut.d.ts +0 -3
- package/ui/layout/Notifications/demo/timeOut.js +0 -49
- package/ui/layout/Tooltip/calculate.d.ts +0 -6
- package/ui/layout/Tooltip/demo/basic.d.ts +0 -8
- package/ui/layout/Tooltip/demo/basic.js +0 -56
- package/ui/list/CheckboxColumn/demo/basic.d.ts +0 -8
- package/ui/list/CheckboxColumn/demo/basic.js +0 -51
- package/ui/list/ControlsColumn/demo/basic.d.ts +0 -8
- package/ui/list/Empty/demo/basic.d.ts +0 -8
- package/ui/list/Empty/demo/basic.js +0 -37
- package/ui/list/Empty/demo/custom-text.d.ts +0 -8
- package/ui/list/Empty/demo/custom-text.js +0 -37
- package/ui/list/Grid/demo/basic.d.ts +0 -18
- package/ui/list/Grid/demo/basic.js +0 -72
- package/ui/list/Grid/demo/controls.d.ts +0 -8
- package/ui/list/Grid/demo/controls.js +0 -44
- package/ui/list/Grid/demo/empty.d.ts +0 -8
- package/ui/list/Grid/demo/empty.js +0 -38
- package/ui/list/Grid/demo/formatter.d.ts +0 -8
- package/ui/list/Grid/demo/formatter.js +0 -67
- package/ui/list/Grid/demo/indexing.d.ts +0 -8
- package/ui/list/Grid/demo/inner-search-form.d.ts +0 -16
- package/ui/list/Grid/demo/inner-search-form.js +0 -60
- package/ui/list/Grid/demo/load-more.d.ts +0 -8
- package/ui/list/Grid/demo/load-more.js +0 -43
- package/ui/list/Grid/demo/pagination.d.ts +0 -8
- package/ui/list/Grid/demo/pagination.js +0 -41
- package/ui/list/Grid/demo/search-form.d.ts +0 -8
- package/ui/list/Grid/demo/search-form.js +0 -50
- package/ui/list/Grid/demo/sort.d.ts +0 -8
- package/ui/list/Grid/demo/sort.js +0 -48
- package/ui/list/Grid/demo/visible.d.ts +0 -8
- package/ui/list/Grid/demo/visible.js +0 -52
- package/ui/list/LayoutNames/demo/basic.d.ts +0 -7
- package/ui/list/List/demo/basic.d.ts +0 -12
- package/ui/list/List/demo/basic.js +0 -61
- package/ui/list/List/demo/condition.d.ts +0 -8
- package/ui/list/List/demo/condition.js +0 -90
- package/ui/list/List/demo/empty.d.ts +0 -8
- package/ui/list/List/demo/empty.js +0 -36
- package/ui/list/List/demo/layout.d.ts +0 -8
- package/ui/list/List/demo/layout.js +0 -49
- package/ui/list/List/demo/load-more.d.ts +0 -8
- package/ui/list/List/demo/load-more.js +0 -45
- package/ui/list/List/demo/pagination.d.ts +0 -8
- package/ui/list/List/demo/pagination.js +0 -45
- package/ui/list/List/demo/search-form.d.ts +0 -30
- package/ui/list/List/demo/search-form.js +0 -107
- package/ui/list/List/demo/sort.d.ts +0 -17
- package/ui/list/List/demo/sort.js +0 -92
- package/ui/list/Pagination/demo/basic.d.ts +0 -8
- package/ui/list/Pagination/demo/basic.js +0 -45
- package/ui/list/Pagination/demo/load-more.d.ts +0 -8
- package/ui/list/Pagination/demo/load-more.js +0 -41
- package/ui/list/Pagination/demo/sizes.d.ts +0 -8
- package/ui/list/Pagination/demo/sizes.js +0 -48
- package/ui/list/PaginationSize/demo/basic.d.ts +0 -8
- package/ui/list/PaginationSize/demo/basic.js +0 -41
- package/ui/list/PaginationSize/demo/size.d.ts +0 -8
- package/ui/list/PaginationSize/demo/size.js +0 -49
- package/ui/modal/Modal/demo/basic.d.ts +0 -8
- package/ui/modal/Modal/demo/basic.js +0 -63
- package/ui/modal/Modal/demo/closeTimeout.d.ts +0 -8
- package/ui/modal/Modal/demo/closeTimeout.js +0 -64
- package/ui/modal/Modal/demo/closing.d.ts +0 -9
- package/ui/modal/Modal/demo/closing.js +0 -67
- package/ui/modal/Modal/demo/component.d.ts +0 -10
- package/ui/modal/Modal/demo/component.js +0 -55
- package/ui/modal/Modal/demo/controls.d.ts +0 -8
- package/ui/modal/Modal/demo/controls.js +0 -66
- package/ui/modal/Modal/demo/size.d.ts +0 -8
- package/ui/modal/Modal/demo/size.js +0 -70
- package/ui/nav/Breadcrumbs/demo/basic.d.ts +0 -8
- package/ui/nav/Breadcrumbs/demo/basic.js +0 -37
- package/ui/nav/Breadcrumbs/demo/items.d.ts +0 -8
- package/ui/nav/Breadcrumbs/demo/items.js +0 -42
- package/ui/nav/Breadcrumbs/demo/page-title.d.ts +0 -8
- package/ui/nav/Breadcrumbs/demo/page-title.js +0 -37
- package/ui/nav/Controls/demo/basic.d.ts +0 -12
- package/ui/nav/Controls/demo/basic.js +0 -59
- package/ui/nav/Link/demo/badge.d.ts +0 -8
- package/ui/nav/Link/demo/badge.js +0 -37
- package/ui/nav/Link/demo/basic.d.ts +0 -8
- package/ui/nav/Link/demo/basic.js +0 -37
- package/ui/nav/Link/demo/colors.d.ts +0 -8
- package/ui/nav/Link/demo/colors.js +0 -46
- package/ui/nav/Link/demo/confirm.d.ts +0 -8
- package/ui/nav/Link/demo/confirm.js +0 -37
- package/ui/nav/Link/demo/disabled.d.ts +0 -8
- package/ui/nav/Link/demo/disabled.js +0 -37
- package/ui/nav/Link/demo/hint.d.ts +0 -8
- package/ui/nav/Link/demo/hint.js +0 -37
- package/ui/nav/Link/demo/icon.d.ts +0 -8
- package/ui/nav/Link/demo/icon.js +0 -37
- package/ui/nav/Link/demo/sizes.d.ts +0 -8
- package/ui/nav/Link/demo/sizes.js +0 -41
- package/ui/nav/Nav/demo/basic.d.ts +0 -13
- package/ui/nav/Nav/demo/basic.js +0 -58
- package/ui/nav/Nav/demo/layout.d.ts +0 -8
- package/ui/nav/Nav/demo/layout.js +0 -56
- package/ui/nav/Router/ConnectedRouter.d.ts +0 -16
- package/ui/nav/Router/ConnectedRouter.js +0 -107
- package/ui/nav/Tree/demo/auto-open-levels.d.ts +0 -8
- package/ui/nav/Tree/demo/auto-open-levels.js +0 -38
- package/ui/nav/Tree/demo/basic.d.ts +0 -32
- package/ui/nav/Tree/demo/basic.js +0 -72
- package/ui/nav/Tree/demo/level.d.ts +0 -8
- package/ui/nav/Tree/demo/level.js +0 -38
- package/ui/nav/Tree/demo/routes.d.ts +0 -8
- package/ui/nav/Tree/demo/routes.js +0 -37
- package/ui/nav/Tree/demo/selected-item.d.ts +0 -8
- package/ui/nav/Tree/demo/selected-item.js +0 -38
|
@@ -1,25 +1,36 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { IAbsolutePositioningInputProps, IAbsolutePositioningOutputProps } from '../../../hooks/useAbsolutePositioning';
|
|
3
|
+
/**
|
|
4
|
+
* Menu
|
|
5
|
+
*
|
|
6
|
+
* Компонент, представляющий меню с элементами, которые могут быть выбраны или нажаты.
|
|
7
|
+
* Компонент позволяет отображать и скрывать содержимое меню, а также управлять его позиционированием.
|
|
8
|
+
*/
|
|
3
9
|
export interface IDropDownProps extends IAbsolutePositioningInputProps {
|
|
4
|
-
/**
|
|
5
|
-
* Дополнительный CSS-класс
|
|
6
|
-
*/
|
|
7
|
-
className?: CssClassName;
|
|
8
10
|
/**
|
|
9
11
|
* Содержимое DropDown (компонент или jsx-код)
|
|
10
12
|
* @example () => Component
|
|
11
13
|
*/
|
|
12
14
|
content?: () => React.ReactNode;
|
|
13
|
-
/**
|
|
14
|
-
* Переопределение view React компонента для кастомизациии отображения
|
|
15
|
-
* @example MyCustomView
|
|
16
|
-
*/
|
|
17
|
-
view?: any;
|
|
18
15
|
/**
|
|
19
16
|
* В каком случае закрывать DropDown. По-умолчанию - `click-away`
|
|
20
17
|
* @example click-any
|
|
21
18
|
*/
|
|
22
|
-
closeMode?: 'click-away' | 'click-any';
|
|
19
|
+
closeMode?: 'click-away' | 'click-any' | string;
|
|
20
|
+
/**
|
|
21
|
+
* Позволяет управлять отображением указателя
|
|
22
|
+
* @example true
|
|
23
|
+
*/
|
|
24
|
+
hasArrow?: boolean;
|
|
25
|
+
/**
|
|
26
|
+
* Переопределение view React компонента для кастомизациии отображения
|
|
27
|
+
* @example MyCustomView
|
|
28
|
+
*/
|
|
29
|
+
view?: CustomView;
|
|
30
|
+
/**
|
|
31
|
+
* Дополнительный CSS-класс
|
|
32
|
+
*/
|
|
33
|
+
className?: CssClassName;
|
|
23
34
|
}
|
|
24
35
|
export interface IDropDownViewProps extends IDropDownProps, IAbsolutePositioningOutputProps {
|
|
25
36
|
/**
|
|
@@ -40,6 +51,7 @@ declare namespace DropDown {
|
|
|
40
51
|
gap: number;
|
|
41
52
|
position: string;
|
|
42
53
|
closeMode: string;
|
|
54
|
+
hasArrow: boolean;
|
|
43
55
|
};
|
|
44
56
|
}
|
|
45
57
|
export default DropDown;
|
|
@@ -1,4 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
2
13
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
14
|
if (k2 === undefined) k2 = k;
|
|
4
15
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
@@ -82,14 +93,15 @@ function DropDown(props) {
|
|
|
82
93
|
isComponentExist && (
|
|
83
94
|
// TODO Change Portal to global
|
|
84
95
|
React.createElement(TooltipPortalInner_1["default"], null,
|
|
85
|
-
React.createElement(DropDownView, { className: props.className, forwardedRef: forwardedRef, content: props.content, position: position, style: style, calculatePosition: calculatePosition, isComponentVisible: isComponentVisible, onClose: onHide })))));
|
|
96
|
+
React.createElement(DropDownView, __assign({}, props, { className: props.className, forwardedRef: forwardedRef, content: props.content, position: position, style: style, calculatePosition: calculatePosition, isComponentVisible: isComponentVisible, onClose: onHide }))))));
|
|
86
97
|
}
|
|
87
98
|
DropDown.defaultProps = {
|
|
88
|
-
autoPositioning:
|
|
99
|
+
autoPositioning: true,
|
|
89
100
|
componentDestroyDelay: 300,
|
|
90
101
|
defaultVisible: false,
|
|
91
102
|
gap: 15,
|
|
92
103
|
position: 'bottom',
|
|
93
|
-
closeMode: 'click-away'
|
|
104
|
+
closeMode: 'click-away',
|
|
105
|
+
hasArrow: true
|
|
94
106
|
};
|
|
95
107
|
exports["default"] = DropDown;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
1
|
+
/// <reference types="react" />
|
|
2
2
|
/**
|
|
3
3
|
* Install the latest free version of Font Awesome via yarn:
|
|
4
4
|
* ```
|
|
@@ -17,7 +17,12 @@ import * as React from 'react';
|
|
|
17
17
|
*
|
|
18
18
|
* That get the icon used <Icon name={'icon-name'} />
|
|
19
19
|
*/
|
|
20
|
-
|
|
20
|
+
/**
|
|
21
|
+
* Icon
|
|
22
|
+
*
|
|
23
|
+
* Компонент, представляющий иконку. Иконки могут быть импортированы при старте приложения.
|
|
24
|
+
*/
|
|
25
|
+
export interface IIconProps extends Omit<IUiComponent, 'className' | 'style'>, Partial<HTMLElement> {
|
|
21
26
|
/**
|
|
22
27
|
* Имя иконки (латиницей). Импорт иконок происходит на старте приложения.
|
|
23
28
|
* @example create
|
|
@@ -28,12 +33,13 @@ export interface IIconProps {
|
|
|
28
33
|
* @example Добавить запись
|
|
29
34
|
*/
|
|
30
35
|
title?: string;
|
|
31
|
-
className?: CssClassName;
|
|
32
36
|
/**
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
+
* Должен ли данный элемент участвовать в последовательной навигации
|
|
38
|
+
*/
|
|
39
|
+
tabIndex?: number;
|
|
40
|
+
/**
|
|
41
|
+
* Функция которая вызывается при клике по иконке
|
|
42
|
+
*/
|
|
37
43
|
onClick?: any;
|
|
38
44
|
[key: string]: any;
|
|
39
45
|
}
|
package/ui/content/Icon/Icon.js
CHANGED
|
@@ -17,6 +17,7 @@ exports.__esModule = true;
|
|
|
17
17
|
var isObject_1 = __importDefault(require("lodash-es/isObject"));
|
|
18
18
|
var isString_1 = __importDefault(require("lodash-es/isString"));
|
|
19
19
|
var hooks_1 = require("../../../hooks");
|
|
20
|
+
var DEFAULT_ICON_NAME = 'default_24x24';
|
|
20
21
|
function Icon(props) {
|
|
21
22
|
var components = (0, hooks_1.useComponents)();
|
|
22
23
|
var name = props.name;
|
|
@@ -42,7 +43,9 @@ function Icon(props) {
|
|
|
42
43
|
}
|
|
43
44
|
}
|
|
44
45
|
if (!icon) {
|
|
45
|
-
|
|
46
|
+
// eslint-disable-next-line no-console
|
|
47
|
+
console.warn('Not found icon with name "' + name + '"');
|
|
48
|
+
icon = components.ui.getIcon(DEFAULT_ICON_NAME);
|
|
46
49
|
}
|
|
47
50
|
}
|
|
48
51
|
return components.ui.renderView(props.view || 'content.IconView', __assign(__assign({}, props), { icon: icon }));
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
export interface ITaskTag {
|
|
3
|
+
id: number;
|
|
4
|
+
message: string;
|
|
5
|
+
type: string;
|
|
6
|
+
}
|
|
7
|
+
export interface IKanbanTask {
|
|
8
|
+
id: string;
|
|
9
|
+
title: string;
|
|
10
|
+
description?: string;
|
|
11
|
+
priority?: string;
|
|
12
|
+
assigner?: any;
|
|
13
|
+
tags?: ITaskTag[];
|
|
14
|
+
status?: any;
|
|
15
|
+
}
|
|
16
|
+
export interface IDragEndResult {
|
|
17
|
+
draggableId: number;
|
|
18
|
+
type: string;
|
|
19
|
+
source: {
|
|
20
|
+
index: number;
|
|
21
|
+
droppableId: number;
|
|
22
|
+
};
|
|
23
|
+
reason: string;
|
|
24
|
+
mode: string;
|
|
25
|
+
destination: {
|
|
26
|
+
droppableId: number;
|
|
27
|
+
index: number;
|
|
28
|
+
};
|
|
29
|
+
combine: null;
|
|
30
|
+
}
|
|
31
|
+
export interface IKanbanColumn {
|
|
32
|
+
id: string;
|
|
33
|
+
title: string;
|
|
34
|
+
tasks: IKanbanTask[];
|
|
35
|
+
}
|
|
36
|
+
interface IKanbanProps extends IUiComponent {
|
|
37
|
+
/**
|
|
38
|
+
* Компонент обертка для инициализации области куда можно переместить элемент из библиотеки react-beautiful-dnd
|
|
39
|
+
* @example Droppable
|
|
40
|
+
*/
|
|
41
|
+
droppableComponent: any;
|
|
42
|
+
/**
|
|
43
|
+
* Компонент обертка для регистрации элемента который можно переместить из библиотеки react-beautiful-dnd
|
|
44
|
+
* @example Draggable
|
|
45
|
+
*/
|
|
46
|
+
draggableComponent: any;
|
|
47
|
+
/**
|
|
48
|
+
* Общий контекст обертка из библиотеки react-beautiful-dnd
|
|
49
|
+
* @example DragDropContext
|
|
50
|
+
*/
|
|
51
|
+
dndContext: any;
|
|
52
|
+
/**
|
|
53
|
+
* Коллекция с наименованиями и свойствами колонок в таблице
|
|
54
|
+
* @example [
|
|
55
|
+
* {
|
|
56
|
+
* id: 'column-1',
|
|
57
|
+
* title: 'col1',
|
|
58
|
+
* tasks: [{ content: 'item1', id: 'task-1' }],
|
|
59
|
+
* },
|
|
60
|
+
* {
|
|
61
|
+
* id: 'column-2',
|
|
62
|
+
* title: 'col2',
|
|
63
|
+
* tasks: [],
|
|
64
|
+
* }
|
|
65
|
+
* ]
|
|
66
|
+
*/
|
|
67
|
+
columns?: IKanbanColumn[];
|
|
68
|
+
/**
|
|
69
|
+
* Обработчик события окончания перетаскивания карточки или колонки
|
|
70
|
+
* В result передается объект с информацией о событии
|
|
71
|
+
* @example {
|
|
72
|
+
* draggableId: 1,
|
|
73
|
+
* type: 'task',
|
|
74
|
+
* source: {
|
|
75
|
+
* index: 0,
|
|
76
|
+
* droppableId: 2
|
|
77
|
+
* },
|
|
78
|
+
* reason: 'DROP',
|
|
79
|
+
* mode: 'FLUID',
|
|
80
|
+
* destination: {
|
|
81
|
+
* droppableId: 2,
|
|
82
|
+
* index: 1
|
|
83
|
+
* },
|
|
84
|
+
* combine: null
|
|
85
|
+
* }
|
|
86
|
+
*/
|
|
87
|
+
onDragEnd?: (result: IDragEndResult) => void;
|
|
88
|
+
[key: string]: any;
|
|
89
|
+
}
|
|
90
|
+
export interface IKanbanTaskViewProps {
|
|
91
|
+
task: IKanbanTask;
|
|
92
|
+
index: number;
|
|
93
|
+
draggableComponent: any;
|
|
94
|
+
}
|
|
95
|
+
export interface IKanbanColumnViewProps {
|
|
96
|
+
column: IKanbanColumn;
|
|
97
|
+
columnIndex: number;
|
|
98
|
+
droppableComponent: any;
|
|
99
|
+
draggableComponent: any;
|
|
100
|
+
renderTask: (task: IKanbanTask, index: number) => JSX.Element;
|
|
101
|
+
}
|
|
102
|
+
export type IKanbanViewProps = IKanbanProps;
|
|
103
|
+
export default function Kanban(props: IKanbanProps): JSX.Element;
|
|
104
|
+
export {};
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
14
|
+
if (k2 === undefined) k2 = k;
|
|
15
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
16
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
17
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
18
|
+
}
|
|
19
|
+
Object.defineProperty(o, k2, desc);
|
|
20
|
+
}) : (function(o, m, k, k2) {
|
|
21
|
+
if (k2 === undefined) k2 = k;
|
|
22
|
+
o[k2] = m[k];
|
|
23
|
+
}));
|
|
24
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
25
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
26
|
+
}) : function(o, v) {
|
|
27
|
+
o["default"] = v;
|
|
28
|
+
});
|
|
29
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
30
|
+
if (mod && mod.__esModule) return mod;
|
|
31
|
+
var result = {};
|
|
32
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
33
|
+
__setModuleDefault(result, mod);
|
|
34
|
+
return result;
|
|
35
|
+
};
|
|
36
|
+
exports.__esModule = true;
|
|
37
|
+
var react_1 = __importStar(require("react"));
|
|
38
|
+
var hooks_1 = require("../../../hooks");
|
|
39
|
+
var hooks_2 = require("./hooks");
|
|
40
|
+
function Kanban(props) {
|
|
41
|
+
var components = (0, hooks_1.useComponents)();
|
|
42
|
+
var DragDropContext = props.dndContext;
|
|
43
|
+
var _a = (0, hooks_2.useKanban)({
|
|
44
|
+
kanbanId: props.kanbanId,
|
|
45
|
+
columns: props.columns,
|
|
46
|
+
onDragEnd: props.onDragEnd
|
|
47
|
+
}), columns = _a.columns, onDragEnd = _a.onDragEnd;
|
|
48
|
+
// Task
|
|
49
|
+
var Task = components.ui.getView('content.KanbanTaskView');
|
|
50
|
+
var renderTask = (0, react_1.useCallback)(function (task, index) { return (react_1["default"].createElement(Task, { key: task.id, task: task, index: index, draggableComponent: props.draggableComponent })); }, [Task, props.draggableComponent]);
|
|
51
|
+
// Column
|
|
52
|
+
var Column = components.ui.getView('content.KanbanColumnView');
|
|
53
|
+
var renderColumn = (0, react_1.useCallback)(function (column, index) { return (react_1["default"].createElement(Column, { key: column.id, column: column, columnIndex: index, draggableComponent: props.draggableComponent, droppableComponent: props.droppableComponent, renderTask: renderTask })); }, [Column, props.draggableComponent, props.droppableComponent, renderTask]);
|
|
54
|
+
return (react_1["default"].createElement(DragDropContext, { onDragEnd: onDragEnd }, components.ui.renderView(props.view || 'content.KanbanView', __assign(__assign({}, props), { columns: columns, renderColumn: renderColumn }))));
|
|
55
|
+
}
|
|
56
|
+
exports["default"] = Kanban;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
exports.__esModule = true;
|
|
3
|
+
exports.kanbanMoveTask = exports.kanbanMoveColumn = exports.kanbanInit = exports.KANBAN_MOVE_TASK = exports.KANBAN_INIT = exports.KANBAN_MOVE_COLUMN = void 0;
|
|
4
|
+
var kanban_1 = require("./kanban");
|
|
5
|
+
exports.KANBAN_MOVE_COLUMN = kanban_1.KANBAN_MOVE_COLUMN;
|
|
6
|
+
exports.KANBAN_INIT = kanban_1.KANBAN_INIT;
|
|
7
|
+
exports.KANBAN_MOVE_TASK = kanban_1.KANBAN_MOVE_TASK;
|
|
8
|
+
exports.kanbanInit = kanban_1.kanbanInit;
|
|
9
|
+
exports.kanbanMoveColumn = kanban_1.kanbanMoveColumn;
|
|
10
|
+
exports.kanbanMoveTask = kanban_1.kanbanMoveTask;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export declare const KANBAN_INIT = "@kanban/init";
|
|
2
|
+
export declare const KANBAN_MOVE_TASK = "@kanban/move_task";
|
|
3
|
+
export declare const KANBAN_MOVE_COLUMN = "@kanban/move_column";
|
|
4
|
+
export declare const kanbanInit: (kanbanId: any, payload: any) => {
|
|
5
|
+
type: string;
|
|
6
|
+
payload: any;
|
|
7
|
+
};
|
|
8
|
+
export declare const kanbanMoveTask: (kanbanId: any, source: any, destination: any) => {
|
|
9
|
+
type: string;
|
|
10
|
+
kanbanId: any;
|
|
11
|
+
source: any;
|
|
12
|
+
destination: any;
|
|
13
|
+
};
|
|
14
|
+
export declare const kanbanMoveColumn: (kanbanId: any, source: any, destination: any) => {
|
|
15
|
+
type: string;
|
|
16
|
+
kanbanId: any;
|
|
17
|
+
source: any;
|
|
18
|
+
destination: any;
|
|
19
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
exports.__esModule = true;
|
|
3
|
+
exports.kanbanMoveColumn = exports.kanbanMoveTask = exports.kanbanInit = exports.KANBAN_MOVE_COLUMN = exports.KANBAN_MOVE_TASK = exports.KANBAN_INIT = void 0;
|
|
4
|
+
exports.KANBAN_INIT = '@kanban/init';
|
|
5
|
+
exports.KANBAN_MOVE_TASK = '@kanban/move_task';
|
|
6
|
+
exports.KANBAN_MOVE_COLUMN = '@kanban/move_column';
|
|
7
|
+
var kanbanInit = function (kanbanId, payload) { return ({
|
|
8
|
+
type: exports.KANBAN_INIT,
|
|
9
|
+
payload: payload
|
|
10
|
+
}); };
|
|
11
|
+
exports.kanbanInit = kanbanInit;
|
|
12
|
+
var kanbanMoveTask = function (kanbanId, source, destination) { return ({
|
|
13
|
+
type: exports.KANBAN_MOVE_TASK,
|
|
14
|
+
kanbanId: kanbanId,
|
|
15
|
+
source: source,
|
|
16
|
+
destination: destination
|
|
17
|
+
}); };
|
|
18
|
+
exports.kanbanMoveTask = kanbanMoveTask;
|
|
19
|
+
var kanbanMoveColumn = function (kanbanId, source, destination) { return ({
|
|
20
|
+
type: exports.KANBAN_MOVE_COLUMN,
|
|
21
|
+
kanbanId: kanbanId,
|
|
22
|
+
source: source,
|
|
23
|
+
destination: destination
|
|
24
|
+
}); };
|
|
25
|
+
exports.kanbanMoveColumn = kanbanMoveColumn;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
exports.__esModule = true;
|
|
6
|
+
exports.useKanban = void 0;
|
|
7
|
+
var useKanban_1 = __importDefault(require("./useKanban"));
|
|
8
|
+
exports.useKanban = useKanban_1["default"];
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { IDragEndResult, IKanbanColumn } from '../Kanban';
|
|
2
|
+
export interface IKanbanConfig {
|
|
3
|
+
/**
|
|
4
|
+
* Идентификатор канбан доски
|
|
5
|
+
* @example TasksKanban
|
|
6
|
+
*/
|
|
7
|
+
kanbanId?: string;
|
|
8
|
+
/**
|
|
9
|
+
* Колонки канбан доски
|
|
10
|
+
*/
|
|
11
|
+
columns?: IKanbanColumn[];
|
|
12
|
+
/**
|
|
13
|
+
* Обработчик события окончания перетаскивания карточки или колонки
|
|
14
|
+
*/
|
|
15
|
+
onDragEnd: (result: IDragEndResult) => void;
|
|
16
|
+
}
|
|
17
|
+
export declare const DEFAULT_COLUMNS: {
|
|
18
|
+
id: string;
|
|
19
|
+
title: string;
|
|
20
|
+
tasks: any[];
|
|
21
|
+
}[];
|
|
22
|
+
export default function useKanban(config: IKanbanConfig): {
|
|
23
|
+
columns: any;
|
|
24
|
+
onDragEnd: (result: any) => void;
|
|
25
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
exports.__esModule = true;
|
|
3
|
+
exports.DEFAULT_COLUMNS = void 0;
|
|
4
|
+
var react_use_1 = require("react-use");
|
|
5
|
+
var react_1 = require("react");
|
|
6
|
+
var hooks_1 = require("../../../../hooks");
|
|
7
|
+
var reducers_1 = require("../reducers");
|
|
8
|
+
var actions_1 = require("../actions");
|
|
9
|
+
var COLUMNS_DROPPABLE_ID = 'all-columns';
|
|
10
|
+
exports.DEFAULT_COLUMNS = [
|
|
11
|
+
{
|
|
12
|
+
id: 'column-1',
|
|
13
|
+
title: 'TO DO',
|
|
14
|
+
tasks: []
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
id: 'column-2',
|
|
18
|
+
title: 'IN PROGRESS',
|
|
19
|
+
tasks: []
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
id: 'column-3',
|
|
23
|
+
title: 'IN REVIEW',
|
|
24
|
+
tasks: []
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
id: 'column-4',
|
|
28
|
+
title: 'DONE',
|
|
29
|
+
tasks: []
|
|
30
|
+
},
|
|
31
|
+
];
|
|
32
|
+
function useKanban(config) {
|
|
33
|
+
// Get kanban from redux state
|
|
34
|
+
var kanban = (0, hooks_1.useSelector)(function (state) { return (0, reducers_1.getKanban)(state, config.kanbanId); });
|
|
35
|
+
var dispatch = (0, hooks_1.useDispatch)();
|
|
36
|
+
// move card
|
|
37
|
+
var moveCard = (0, react_1.useCallback)(function (source, destination) {
|
|
38
|
+
dispatch((0, actions_1.kanbanMoveTask)(config.kanbanId, source, destination));
|
|
39
|
+
}, [config.kanbanId, dispatch]);
|
|
40
|
+
// move column
|
|
41
|
+
var moveColumn = (0, react_1.useCallback)(function (source, destination) {
|
|
42
|
+
dispatch((0, actions_1.kanbanMoveColumn)(config.kanbanId, source, destination));
|
|
43
|
+
}, [config.kanbanId, dispatch]);
|
|
44
|
+
var onDragEnd = function (result) {
|
|
45
|
+
if (config.onDragEnd) {
|
|
46
|
+
config.onDragEnd(result);
|
|
47
|
+
}
|
|
48
|
+
// drop outside the column
|
|
49
|
+
if (!result.destination) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
var source = result.source, destination = result.destination;
|
|
53
|
+
if (source.droppableId === COLUMNS_DROPPABLE_ID) {
|
|
54
|
+
// handle the column movement
|
|
55
|
+
moveColumn(source, destination);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
// handle the task card movement
|
|
59
|
+
moveCard(source, destination);
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
// Init kanban in redux store
|
|
63
|
+
(0, react_use_1.useMount)(function () {
|
|
64
|
+
if (!kanban) {
|
|
65
|
+
dispatch((0, actions_1.kanbanInit)(config.kanbanId, {
|
|
66
|
+
kanbanId: config.kanbanId,
|
|
67
|
+
columns: config.columns || exports.DEFAULT_COLUMNS
|
|
68
|
+
}));
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
return {
|
|
72
|
+
columns: kanban === null || kanban === void 0 ? void 0 : kanban.columns,
|
|
73
|
+
onDragEnd: onDragEnd
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
exports["default"] = useKanban;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
exports.__esModule = true;
|
|
6
|
+
var Kanban_1 = __importDefault(require("./Kanban"));
|
|
7
|
+
exports["default"] = Kanban_1["default"];
|
|
@@ -22,11 +22,8 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
22
22
|
__setModuleDefault(result, mod);
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
-
};
|
|
28
25
|
exports.__esModule = true;
|
|
29
|
-
|
|
30
|
-
var
|
|
31
|
-
exports
|
|
32
|
-
|
|
26
|
+
exports.getKanban = void 0;
|
|
27
|
+
var kanban_1 = __importStar(require("./kanban"));
|
|
28
|
+
exports.getKanban = kanban_1.getKanban;
|
|
29
|
+
exports["default"] = kanban_1["default"];
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
14
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
15
|
+
if (ar || !(i in from)) {
|
|
16
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
17
|
+
ar[i] = from[i];
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
21
|
+
};
|
|
22
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
23
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
24
|
+
};
|
|
25
|
+
var _a;
|
|
26
|
+
exports.__esModule = true;
|
|
27
|
+
exports.getKanban = void 0;
|
|
28
|
+
var get_1 = __importDefault(require("lodash-es/get"));
|
|
29
|
+
var actions_1 = require("../actions");
|
|
30
|
+
var initialState = {
|
|
31
|
+
kanbans: {}
|
|
32
|
+
};
|
|
33
|
+
var getKanbanColumns = function (state, kanbanId) { return (0, get_1["default"])(state, ['kanbans', kanbanId, 'columns']) || []; };
|
|
34
|
+
var reducerMap = (_a = {},
|
|
35
|
+
_a[actions_1.KANBAN_INIT] = function (state, action) {
|
|
36
|
+
var _a;
|
|
37
|
+
return (__assign(__assign({}, state), { kanbans: __assign(__assign({}, state.kanbans), (_a = {}, _a[action.payload.kanbanId] = __assign({}, action.payload), _a)) }));
|
|
38
|
+
},
|
|
39
|
+
_a[actions_1.KANBAN_MOVE_TASK] = function (state, action) {
|
|
40
|
+
var _a;
|
|
41
|
+
if (state.kanbans[action.kanbanId]) {
|
|
42
|
+
var columns = getKanbanColumns(state, action.kanbanId);
|
|
43
|
+
var sourceColumn = columns.find(function (column) { return column.id === action.source.droppableId; });
|
|
44
|
+
var sourceTasks = sourceColumn.tasks;
|
|
45
|
+
var removedTask = sourceTasks.splice(action.source.index, 1)[0];
|
|
46
|
+
// move task to different column
|
|
47
|
+
if (action.source.droppableId !== action.destination.droppableId) {
|
|
48
|
+
var destinationColumn = columns.find(function (column) { return column.id === action.destination.droppableId; });
|
|
49
|
+
var destinationTasks = destinationColumn.tasks;
|
|
50
|
+
destinationTasks.splice(action.destination.index, 0, removedTask);
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
sourceTasks.splice(action.destination.index, 0, removedTask);
|
|
54
|
+
}
|
|
55
|
+
return __assign(__assign({}, state), { kanbans: __assign(__assign({}, state.kanbans), (_a = {}, _a[action.kanbanId] = __assign(__assign({}, state.kanbans[action.kanbanId]), { columns: __spreadArray([], columns, true) }), _a)) });
|
|
56
|
+
}
|
|
57
|
+
return [];
|
|
58
|
+
},
|
|
59
|
+
_a[actions_1.KANBAN_MOVE_COLUMN] = function (state, action) {
|
|
60
|
+
var _a;
|
|
61
|
+
if (state.kanbans[action.kanbanId]) {
|
|
62
|
+
var columns = getKanbanColumns(state, action.kanbanId);
|
|
63
|
+
var removedColumn = columns.splice(action.source.index, 1)[0];
|
|
64
|
+
columns.splice(action.destination.index, 0, removedColumn);
|
|
65
|
+
return __assign(__assign({}, state), { kanbans: __assign(__assign({}, state.kanbans), (_a = {}, _a[action.kanbanId] = __assign(__assign({}, state.kanbans[action.kanbanId]), { columns: __spreadArray([], columns, true) }), _a)) });
|
|
66
|
+
}
|
|
67
|
+
return [];
|
|
68
|
+
},
|
|
69
|
+
_a);
|
|
70
|
+
exports["default"] = (function (state, action) {
|
|
71
|
+
if (state === void 0) { state = initialState; }
|
|
72
|
+
return reducerMap[action.type]
|
|
73
|
+
? reducerMap[action.type](state, action)
|
|
74
|
+
: state;
|
|
75
|
+
});
|
|
76
|
+
var getKanban = function (state, kanbanId) { return (0, get_1["default"])(state, ['kanban', 'kanbans', kanbanId]) || null; };
|
|
77
|
+
exports.getKanban = getKanban;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { IDropDownProps } from '../DropDown/DropDown';
|
|
3
|
+
export interface IMenuItem {
|
|
4
|
+
/**
|
|
5
|
+
* Заголовок элемента меню
|
|
6
|
+
*/
|
|
7
|
+
label: string;
|
|
8
|
+
/**
|
|
9
|
+
* Функция вызываемая при клике
|
|
10
|
+
*/
|
|
11
|
+
onClick: VoidFunction;
|
|
12
|
+
/**
|
|
13
|
+
* Кастомная иконка
|
|
14
|
+
*/
|
|
15
|
+
icon?: string | React.ReactElement;
|
|
16
|
+
/**
|
|
17
|
+
* Нижний border
|
|
18
|
+
*/
|
|
19
|
+
hasBorder?: boolean;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Menu
|
|
23
|
+
*
|
|
24
|
+
* Компонент-меню позволяет создавать выпадающие списки с элементами, которые могут быть выбраны
|
|
25
|
+
* или выполнить определенные действия при клике на них.
|
|
26
|
+
*
|
|
27
|
+
* Компонент `Menu` обычно используется для создания навигационных меню или контекстных меню,
|
|
28
|
+
* где пользователь может выбирать опции или выполнять определенные действия в зависимости от выбранного элемента.
|
|
29
|
+
*
|
|
30
|
+
* Компонент `Menu` принимает массив `items`, каждый элемент которого представляет собой отдельный пункт меню.
|
|
31
|
+
* Каждый пункт меню имеет заголовок `label`, функцию `onClick`, которая будет вызываться при клике на элемент,
|
|
32
|
+
* кастомную иконку `icon` (необязательно) и флаг `hasBorder`, определяющий наличие нижней границы у элемента.
|
|
33
|
+
*
|
|
34
|
+
* Примечание: Компонент `Menu` требует указания хотя бы одного элемента меню в свойстве `items`.
|
|
35
|
+
*/
|
|
36
|
+
export interface IMenuProps extends IUiComponent {
|
|
37
|
+
/**
|
|
38
|
+
* Элементы меню
|
|
39
|
+
*/
|
|
40
|
+
items: IMenuItem[];
|
|
41
|
+
/**
|
|
42
|
+
* Кастомная иконка, по клику на которую открывается меню
|
|
43
|
+
*/
|
|
44
|
+
icon?: string | React.ReactElement;
|
|
45
|
+
/**
|
|
46
|
+
* Пропсы для DropDown
|
|
47
|
+
*/
|
|
48
|
+
dropDownProps?: IDropDownProps;
|
|
49
|
+
/**
|
|
50
|
+
* Переопределение view React элемента меню для кастомизации отображения
|
|
51
|
+
*/
|
|
52
|
+
itemView?: CustomView | any;
|
|
53
|
+
}
|
|
54
|
+
export type IMenuViewProps = IMenuProps;
|
|
55
|
+
declare function Menu(props: IMenuProps): JSX.Element;
|
|
56
|
+
export default Menu;
|