@steroidsjs/core 2.1.0-beta.3 → 2.1.0-beta.33
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 +3 -1
- package/actions/form.d.ts +9 -0
- package/actions/form.js +11 -1
- package/actions/list.d.ts +1 -0
- package/actions/list.js +1 -0
- package/actions/modal.d.ts +3 -2
- package/components/ClientStorageComponent.d.ts +3 -3
- package/components/ClientStorageComponent.js +28 -22
- package/components/HttpComponent.js +32 -15
- package/components/LocaleComponent.js +9 -9
- package/components/MetricsComponent.js +3 -1
- package/components/SocialComponent.d.ts +1 -1
- package/components/SocialComponent.js +12 -10
- package/components/StoreComponent.d.ts +6 -0
- package/components/StoreComponent.js +6 -7
- package/components/UiComponent.d.ts +1 -1
- package/components/WebSocketComponent.d.ts +1 -1
- package/components/social/FacebookProvider.d.ts +1 -1
- package/components/social/FacebookProvider.js +5 -6
- package/components/social/GitlabProvider.d.ts +8 -0
- package/components/social/GitlabProvider.js +98 -0
- package/components/social/GoogleProvider.d.ts +1 -1
- package/components/social/GoogleProvider.js +2 -2
- package/components/social/SteamProvider.d.ts +1 -1
- package/components/social/SteamProvider.js +8 -9
- package/components/social/VkProvider.d.ts +1 -1
- package/components/social/VkProvider.js +8 -9
- package/hoc/components.d.ts +1 -1
- package/hoc/components.js +1 -1
- package/hoc/file.d.ts +1 -0
- package/hooks/index.d.ts +2 -1
- package/hooks/index.js +3 -1
- package/hooks/useAbsolutePositioning.d.ts +5 -0
- package/hooks/useAbsolutePositioning.js +6 -6
- package/hooks/useApplication.d.ts +29 -26
- package/hooks/useApplication.js +17 -82
- package/hooks/useComponents.d.ts +1 -14
- package/hooks/useComponents.js +4 -5
- package/hooks/useDataProvider.d.ts +1 -0
- package/hooks/useDataProvider.js +6 -4
- package/hooks/useDataSelect.d.ts +15 -8
- package/hooks/useDataSelect.js +60 -11
- package/hooks/useDispatch.d.ts +1 -1
- package/hooks/useFetch.d.ts +11 -3
- package/hooks/useFetch.js +37 -31
- package/hooks/useFile.js +13 -2
- package/hooks/useLayout.d.ts +9 -0
- package/hooks/useLayout.js +85 -56
- package/hooks/useList.d.ts +56 -1
- package/hooks/useList.js +89 -54
- package/hooks/useModel.js +1 -1
- package/hooks/useScreen.d.ts +1 -1
- package/hooks/useScreen.js +2 -2
- package/hooks/useSsr.d.ts +2 -0
- package/hooks/useSsr.js +8 -0
- package/index.d.ts +8 -2
- package/package.json +7 -4
- package/providers/ComponentsProvider.d.ts +26 -0
- package/providers/ComponentsProvider.js +28 -0
- package/providers/ScreenProvider.d.ts +20 -0
- package/providers/ScreenProvider.js +87 -0
- package/providers/SsrProvider.d.ts +17 -0
- package/providers/SsrProvider.js +32 -0
- package/providers/index.d.ts +4 -0
- package/providers/index.js +12 -0
- package/reducers/form.d.ts +2 -1
- package/reducers/form.js +6 -2
- package/reducers/index.js +1 -1
- package/reducers/list.js +1 -3
- package/reducers/router.js +8 -4
- package/ui/content/Alert/Alert.d.ts +60 -0
- package/ui/content/Alert/Alert.js +38 -0
- package/ui/content/Alert/demo/description.d.ts +9 -0
- package/ui/content/Alert/demo/description.js +43 -0
- package/ui/content/Alert/demo/icon.d.ts +8 -0
- package/ui/content/Alert/demo/icon.js +42 -0
- package/ui/content/Alert/demo/text.d.ts +8 -0
- package/ui/content/Alert/demo/text.js +42 -0
- package/ui/content/Alert/index.d.ts +2 -0
- package/ui/content/Alert/index.js +7 -0
- package/ui/content/Avatar/Avatar.d.ts +54 -13
- package/ui/content/Avatar/Avatar.js +25 -4
- package/ui/content/Avatar/AvatarGroup.d.ts +3 -5
- package/ui/content/Avatar/AvatarGroup.js +27 -11
- package/ui/{form/TimeField/demo/show-remove.d.ts → content/Avatar/demo/custome size.d.ts } +2 -2
- package/ui/content/Avatar/demo/custome size.js +35 -0
- package/ui/{form/SwitcherField/demo/sizes.d.ts → content/Avatar/demo/group.d.ts} +1 -1
- package/ui/content/Avatar/demo/group.js +49 -0
- package/ui/content/Avatar/demo/shape.d.ts +8 -0
- package/ui/content/Avatar/demo/shape.js +41 -0
- package/ui/content/Avatar/demo/size.d.ts +8 -0
- package/ui/content/Avatar/demo/size.js +41 -0
- package/ui/content/Avatar/demo/title.d.ts +8 -0
- package/ui/content/Avatar/demo/title.js +41 -0
- package/ui/content/Avatar/index.d.ts +6 -1
- package/ui/content/Avatar/index.js +4 -0
- package/ui/content/Calendar/demo/basic.d.ts +8 -0
- package/ui/{form/FieldLayout → content/Calendar}/demo/basic.js +3 -3
- package/ui/content/Card/Card.d.ts +62 -14
- package/ui/content/Card/Card.js +3 -2
- package/ui/{form/FieldLayout/demo/hint.d.ts → content/Card/demo/basic.d.ts} +2 -2
- package/ui/{form/SwitcherField/demo/sizes.js → content/Card/demo/basic.js} +6 -12
- package/ui/content/Card/demo/border color.d.ts +3 -0
- package/ui/content/Card/demo/border color.js +47 -0
- package/ui/content/Card/demo/color.d.ts +3 -0
- package/ui/content/Card/demo/color.js +47 -0
- package/ui/{form/DateTimeField/demo/sizes.d.ts → content/Card/demo/header.d.ts} +2 -2
- package/ui/content/Card/demo/header.js +42 -0
- package/ui/content/Card/demo/hover.d.ts +8 -0
- package/ui/content/Card/demo/hover.js +37 -0
- package/ui/content/Card/demo/link.d.ts +8 -0
- package/ui/content/Card/demo/link.js +38 -0
- package/ui/content/Card/demo/orientation.d.ts +3 -0
- package/ui/content/Card/demo/orientation.js +41 -0
- package/ui/content/Collapse/Collapse.d.ts +63 -0
- package/ui/content/Collapse/Collapse.js +80 -0
- package/ui/content/Collapse/CollapseItem.d.ts +67 -0
- package/ui/content/Collapse/CollapseItem.js +22 -0
- package/ui/content/Collapse/demo/accordion.d.ts +8 -0
- package/ui/content/Collapse/demo/accordion.js +37 -0
- package/ui/{form/FieldLayout → content/Collapse}/demo/basic.d.ts +0 -0
- package/ui/content/Collapse/demo/basic.js +37 -0
- package/ui/{form/SliderField/demo/required.d.ts → content/Collapse/demo/borderless.d.ts} +2 -2
- package/ui/content/Collapse/demo/borderless.js +37 -0
- package/ui/content/Collapse/demo/disable.d.ts +8 -0
- package/ui/content/Collapse/demo/disable.js +37 -0
- package/ui/content/Collapse/demo/icon position.d.ts +8 -0
- package/ui/content/Collapse/demo/icon position.js +37 -0
- package/ui/{form/SliderField/demo/size.d.ts → content/Collapse/demo/icon.d.ts} +1 -1
- package/ui/content/Collapse/demo/icon.js +52 -0
- package/ui/content/Collapse/demo/onChange.d.ts +8 -0
- package/ui/content/Collapse/demo/onChange.js +47 -0
- package/ui/content/Collapse/demo/show icon.d.ts +8 -0
- package/ui/content/Collapse/demo/show icon.js +37 -0
- package/ui/content/Collapse/index.d.ts +7 -0
- package/ui/content/Collapse/index.js +8 -0
- package/ui/content/Detail/Detail.d.ts +102 -0
- package/ui/content/Detail/Detail.js +155 -0
- package/ui/content/Detail/DetailItem.d.ts +43 -0
- package/ui/content/Detail/DetailItem.js +10 -0
- package/ui/content/Detail/demo/basic.d.ts +8 -0
- package/ui/content/Detail/demo/basic.js +56 -0
- package/ui/content/Detail/demo/colors.d.ts +3 -0
- package/ui/content/Detail/demo/colors.js +39 -0
- package/ui/content/Detail/demo/controls.d.ts +8 -0
- package/ui/content/Detail/demo/controls.js +56 -0
- package/ui/content/Detail/demo/layout.d.ts +8 -0
- package/ui/content/Detail/demo/layout.js +56 -0
- package/ui/content/Detail/demo/responsive.d.ts +8 -0
- package/ui/content/Detail/demo/responsive.js +71 -0
- package/ui/content/Detail/demo/sizes.d.ts +8 -0
- package/ui/content/Detail/demo/sizes.js +61 -0
- package/ui/content/Detail/index.d.ts +3 -0
- package/ui/content/Detail/index.js +10 -0
- package/ui/content/DropDown/DropDown.d.ts +1 -0
- package/ui/content/DropDown/DropDown.js +1 -0
- package/ui/content/index.d.ts +13 -0
- package/ui/content/index.js +22 -0
- package/ui/crud/Crud/Crud.d.ts +1 -1
- package/ui/crud/Crud/Crud.js +5 -3
- package/ui/crud/Crud/CrudContent.d.ts +5 -1
- package/ui/crud/Crud/CrudContent.js +5 -5
- package/ui/crud/index.d.ts +2 -0
- package/ui/form/AutoCompleteField/AutoCompleteField.d.ts +1 -6
- package/ui/form/AutoCompleteField/demo/basic.d.ts +5 -5
- package/ui/form/AutoCompleteField/demo/basic.js +5 -5
- package/ui/form/AutoCompleteField/demo/disabled.d.ts +1 -1
- package/ui/form/AutoCompleteField/demo/disabled.js +1 -1
- package/ui/form/AutoCompleteField/demo/errors.d.ts +1 -1
- package/ui/form/AutoCompleteField/demo/errors.js +2 -2
- package/ui/form/AutoCompleteField/demo/placeholder.d.ts +1 -1
- package/ui/form/AutoCompleteField/demo/placeholder.js +1 -1
- package/ui/form/AutoCompleteField/demo/required.d.ts +1 -1
- package/ui/form/AutoCompleteField/demo/required.js +1 -1
- package/ui/form/AutoCompleteField/demo/sizes.d.ts +0 -5
- package/ui/form/AutoCompleteField/demo/sizes.js +5 -5
- package/ui/form/BlankField/BlankField.d.ts +6 -7
- package/ui/form/BlankField/demo/basic.d.ts +12 -0
- package/ui/form/BlankField/demo/basic.js +51 -0
- package/ui/form/Button/Button.d.ts +1 -0
- package/ui/form/Button/Button.js +1 -0
- package/ui/form/Button/demo/badge.d.ts +1 -1
- package/ui/form/Button/demo/badge.js +1 -1
- package/ui/form/Button/demo/basic.d.ts +1 -1
- package/ui/form/Button/demo/basic.js +1 -1
- package/ui/form/Button/demo/block.d.ts +1 -1
- package/ui/form/Button/demo/block.js +1 -1
- package/ui/form/Button/demo/colors.d.ts +1 -1
- package/ui/form/Button/demo/colors.js +3 -3
- package/ui/form/Button/demo/confirm.d.ts +1 -1
- package/ui/form/Button/demo/confirm.js +2 -2
- package/ui/form/Button/demo/disabled.d.ts +1 -1
- package/ui/form/Button/demo/disabled.js +1 -1
- package/ui/form/Button/demo/hint.d.ts +1 -1
- package/ui/form/Button/demo/hint.js +1 -1
- package/ui/form/Button/demo/icon.d.ts +1 -1
- package/ui/form/Button/demo/icon.js +1 -1
- package/ui/form/Button/demo/link.d.ts +1 -1
- package/ui/form/Button/demo/link.js +1 -1
- package/ui/form/Button/demo/sizes.d.ts +0 -5
- package/ui/form/Button/demo/sizes.js +5 -5
- package/ui/form/Button/demo/tags.d.ts +1 -1
- package/ui/form/Button/demo/tags.js +1 -1
- package/ui/form/CheckboxField/CheckboxField.d.ts +1 -6
- package/ui/form/CheckboxField/demo/basic.d.ts +1 -1
- package/ui/form/CheckboxField/demo/basic.js +1 -1
- package/ui/form/CheckboxField/demo/disabled.d.ts +1 -1
- package/ui/form/CheckboxField/demo/disabled.js +1 -1
- package/ui/form/CheckboxField/demo/errors.d.ts +1 -1
- package/ui/form/CheckboxField/demo/errors.js +2 -2
- package/ui/form/CheckboxField/demo/required.d.ts +1 -1
- package/ui/form/CheckboxField/demo/required.js +1 -1
- package/ui/form/CheckboxListField/CheckboxListField.d.ts +1 -6
- package/ui/form/CheckboxListField/demo/basic.d.ts +3 -3
- package/ui/form/CheckboxListField/demo/basic.js +5 -5
- package/ui/form/CheckboxListField/demo/disabled.d.ts +1 -1
- package/ui/form/CheckboxListField/demo/disabled.js +1 -1
- package/ui/form/CheckboxListField/demo/errors.d.ts +1 -1
- package/ui/form/CheckboxListField/demo/errors.js +2 -2
- package/ui/form/CheckboxListField/demo/required.d.ts +1 -1
- package/ui/form/CheckboxListField/demo/required.js +1 -1
- package/ui/form/DateField/DateField.d.ts +1 -7
- package/ui/form/DateField/DateField.js +1 -1
- package/ui/form/DateField/demo/basic.d.ts +1 -1
- package/ui/form/DateField/demo/basic.js +1 -1
- package/ui/form/DateField/demo/disabled.d.ts +1 -1
- package/ui/form/DateField/demo/disabled.js +1 -1
- package/ui/form/DateField/demo/errors.d.ts +1 -1
- package/ui/form/DateField/demo/errors.js +1 -1
- package/ui/form/DateField/demo/icon.d.ts +1 -1
- package/ui/form/DateField/demo/icon.js +2 -2
- package/ui/form/DateField/demo/placeholder.d.ts +1 -1
- package/ui/form/DateField/demo/placeholder.js +1 -1
- package/ui/form/DateField/demo/required.d.ts +1 -1
- package/ui/form/DateField/demo/required.js +1 -1
- package/ui/form/DateField/demo/sizes.d.ts +1 -1
- package/ui/form/DateField/demo/sizes.js +1 -1
- package/ui/form/DateField/useDateInputState.d.ts +4 -0
- package/ui/form/DateField/useDateInputState.js +3 -3
- package/ui/form/DateField/useDateTime.js +9 -7
- package/ui/form/DateRangeField/DateRangeField.d.ts +1 -7
- package/ui/form/DateRangeField/DateRangeField.js +3 -2
- package/ui/form/DateRangeField/demo/basic.d.ts +1 -1
- package/ui/form/DateRangeField/demo/basic.js +1 -1
- package/ui/form/DateRangeField/demo/disabled.d.ts +8 -0
- package/ui/form/DateRangeField/demo/disabled.js +33 -0
- package/ui/form/DateRangeField/demo/errors.d.ts +8 -0
- package/ui/form/DateRangeField/demo/errors.js +33 -0
- package/ui/form/DateRangeField/demo/icon.d.ts +8 -0
- package/ui/form/DateRangeField/demo/icon.js +35 -0
- package/ui/form/DateRangeField/demo/placeholder.d.ts +8 -0
- package/ui/form/DateRangeField/demo/placeholder.js +33 -0
- package/ui/form/DateRangeField/demo/required.d.ts +8 -0
- package/ui/form/DateRangeField/demo/required.js +33 -0
- package/ui/form/DateTimeField/DateTimeField.d.ts +1 -7
- package/ui/form/DateTimeField/DateTimeField.js +3 -2
- package/ui/form/DateTimeField/demo/basic.d.ts +1 -1
- package/ui/form/DateTimeField/demo/basic.js +1 -1
- package/ui/form/DateTimeField/demo/disabled.d.ts +1 -1
- package/ui/form/DateTimeField/demo/disabled.js +1 -1
- package/ui/form/DateTimeField/demo/errors.d.ts +1 -1
- package/ui/form/DateTimeField/demo/errors.js +2 -2
- package/ui/form/DateTimeField/demo/icon.d.ts +1 -1
- package/ui/form/DateTimeField/demo/icon.js +2 -2
- package/ui/form/DateTimeField/demo/placeholder.d.ts +1 -1
- package/ui/form/DateTimeField/demo/placeholder.js +2 -6
- package/ui/form/DateTimeField/demo/required.d.ts +1 -1
- package/ui/form/DateTimeField/demo/required.js +1 -1
- package/ui/form/DateTimeField/demo/showRemove.d.ts +8 -0
- package/ui/form/DateTimeField/demo/showRemove.js +32 -0
- package/ui/form/DateTimeRangeField/DateTimeRangeField.d.ts +1 -7
- package/ui/form/DateTimeRangeField/DateTimeRangeField.js +11 -2
- package/ui/form/DateTimeRangeField/demo/basic.d.ts +8 -0
- package/ui/form/DateTimeRangeField/demo/basic.js +32 -0
- package/ui/form/DateTimeRangeField/demo/disabled.d.ts +8 -0
- package/ui/form/{FieldLayout/demo/hint.js → DateTimeRangeField/demo/disabled.js} +4 -5
- package/ui/form/DateTimeRangeField/demo/errors.d.ts +8 -0
- package/ui/form/DateTimeRangeField/demo/errors.js +33 -0
- package/ui/form/DateTimeRangeField/demo/icon.d.ts +8 -0
- package/ui/form/DateTimeRangeField/demo/icon.js +32 -0
- package/ui/form/DateTimeRangeField/demo/placeholder.d.ts +8 -0
- package/ui/form/DateTimeRangeField/demo/placeholder.js +33 -0
- package/ui/form/DateTimeRangeField/demo/required.d.ts +8 -0
- package/ui/form/DateTimeRangeField/demo/required.js +33 -0
- package/ui/form/DateTimeRangeField/demo/showRemove.d.ts +8 -0
- package/ui/form/DateTimeRangeField/demo/showRemove.js +32 -0
- package/ui/form/DropDownField/DropDownField.d.ts +3 -8
- package/ui/form/DropDownField/DropDownField.js +20 -11
- package/ui/form/DropDownField/demo/auto-complete.d.ts +1 -1
- package/ui/form/DropDownField/demo/auto-complete.js +1 -1
- package/ui/form/DropDownField/demo/basic.d.ts +5 -5
- package/ui/form/DropDownField/demo/basic.js +6 -6
- package/ui/form/DropDownField/demo/disabled.d.ts +1 -1
- package/ui/form/DropDownField/demo/disabled.js +1 -1
- package/ui/form/DropDownField/demo/errors.d.ts +1 -1
- package/ui/form/DropDownField/demo/errors.js +2 -2
- package/ui/form/DropDownField/demo/multiple.d.ts +1 -1
- package/ui/form/DropDownField/demo/multiple.js +1 -1
- package/ui/form/DropDownField/demo/no-border.d.ts +1 -1
- package/ui/form/DropDownField/demo/no-border.js +1 -1
- package/ui/form/DropDownField/demo/placeholder.d.ts +1 -1
- package/ui/form/DropDownField/demo/placeholder.js +1 -1
- package/ui/form/DropDownField/demo/required.d.ts +1 -1
- package/ui/form/DropDownField/demo/required.js +1 -1
- package/ui/form/DropDownField/demo/show-reset.d.ts +1 -1
- package/ui/form/DropDownField/demo/show-reset.js +1 -1
- package/ui/form/DropDownField/demo/size.d.ts +1 -1
- package/ui/form/DropDownField/demo/size.js +1 -1
- package/ui/form/Field/demo/basic.d.ts +1 -1
- package/ui/form/Field/demo/basic.js +1 -1
- package/ui/form/Field/demo/component.d.ts +1 -1
- package/ui/form/Field/demo/component.js +1 -1
- package/ui/form/Field/demo/model.d.ts +1 -1
- package/ui/form/Field/demo/model.js +1 -1
- package/ui/form/Field/fieldWrapper.d.ts +4 -4
- package/ui/form/FieldLayout/demo/errors.d.ts +1 -1
- package/ui/form/FieldLayout/demo/errors.js +4 -3
- package/ui/form/FieldLayout/demo/layouts.d.ts +1 -1
- package/ui/form/FieldLayout/demo/layouts.js +4 -3
- package/ui/form/FieldLayout/demo/required.d.ts +1 -1
- package/ui/form/FieldLayout/demo/required.js +3 -2
- package/ui/form/FieldList/FieldList.d.ts +1 -6
- package/ui/form/FieldList/demo/basic.d.ts +1 -1
- package/ui/form/FieldList/demo/basic.js +1 -1
- package/ui/form/FieldList/demo/disabled.d.ts +8 -0
- package/ui/form/FieldList/demo/disabled.js +58 -0
- package/ui/form/FieldSet/demo/basic.d.ts +1 -1
- package/ui/form/FieldSet/demo/basic.js +1 -1
- package/ui/form/FileField/FileField.d.ts +1 -6
- package/ui/form/FileField/demo/basic.d.ts +8 -0
- package/ui/form/FileField/demo/basic.js +33 -0
- package/ui/form/Form/Form.d.ts +6 -0
- package/ui/form/Form/Form.js +119 -107
- package/ui/form/Form/demo/basic.d.ts +1 -1
- package/ui/form/Form/demo/basic.js +2 -2
- package/ui/form/Form/demo/border.d.ts +8 -0
- package/ui/form/Form/demo/border.js +58 -0
- package/ui/form/Form/demo/horizontal.d.ts +8 -0
- package/ui/form/Form/demo/horizontal.js +51 -0
- package/ui/form/Form/demo/inline.d.ts +8 -0
- package/ui/form/Form/demo/inline.js +49 -0
- package/ui/form/HtmlField/HtmlField.d.ts +1 -7
- package/ui/form/HtmlField/demo/basic.d.ts +1 -1
- package/ui/form/HtmlField/demo/basic.js +1 -1
- package/ui/form/ImageField/ImageField.d.ts +81 -0
- package/ui/form/ImageField/ImageField.js +145 -0
- package/ui/form/ImageField/index.d.ts +2 -0
- package/ui/form/ImageField/index.js +7 -0
- package/ui/form/InputField/InputField.d.ts +8 -6
- package/ui/form/InputField/InputField.js +26 -22
- package/ui/form/InputField/demo/addons.d.ts +3 -3
- package/ui/form/InputField/demo/addons.js +3 -3
- package/ui/form/InputField/demo/basic.d.ts +1 -1
- package/ui/form/InputField/demo/basic.js +2 -3
- package/ui/form/InputField/demo/disabled.d.ts +1 -1
- package/ui/form/InputField/demo/disabled.js +2 -3
- package/ui/form/InputField/demo/errors.d.ts +2 -2
- package/ui/form/InputField/demo/errors.js +3 -3
- package/ui/form/InputField/demo/mask.d.ts +2 -2
- package/ui/form/InputField/demo/mask.js +2 -2
- package/ui/form/InputField/demo/placeholder.d.ts +1 -1
- package/ui/form/InputField/demo/placeholder.js +1 -1
- package/ui/form/InputField/demo/required.d.ts +1 -1
- package/ui/form/InputField/demo/required.js +1 -1
- package/ui/form/InputField/demo/sizes.d.ts +0 -5
- package/ui/form/InputField/demo/sizes.js +5 -5
- package/ui/form/InputField/demo/textAddons.d.ts +3 -3
- package/ui/form/InputField/demo/textAddons.js +3 -3
- package/ui/form/InputField/demo/types.d.ts +0 -5
- package/ui/form/InputField/demo/types.js +7 -7
- package/ui/form/NavField/NavField.d.ts +2 -8
- package/ui/form/NavField/NavField.js +6 -3
- package/ui/form/NavField/demo/basic.d.ts +5 -5
- package/ui/form/NavField/demo/basic.js +6 -6
- package/ui/form/NavField/demo/disabled.d.ts +2 -2
- package/ui/form/NavField/demo/disabled.js +3 -3
- package/ui/form/NavField/demo/errors.d.ts +2 -2
- package/ui/form/NavField/demo/errors.js +4 -4
- package/ui/form/NavField/demo/layouts.d.ts +12 -0
- package/ui/form/NavField/demo/layouts.js +57 -0
- package/ui/form/NavField/demo/required.d.ts +2 -2
- package/ui/form/NavField/demo/required.js +3 -3
- package/ui/form/NumberField/NumberField.d.ts +1 -6
- package/ui/form/NumberField/demo/basic.d.ts +1 -1
- package/ui/form/NumberField/demo/basic.js +1 -1
- package/ui/form/NumberField/demo/disabled.d.ts +1 -1
- package/ui/form/NumberField/demo/disabled.js +1 -1
- package/ui/form/NumberField/demo/errors.d.ts +1 -1
- package/ui/form/NumberField/demo/errors.js +2 -2
- package/ui/form/NumberField/demo/placeholder.d.ts +1 -1
- package/ui/form/NumberField/demo/placeholder.js +1 -1
- package/ui/form/NumberField/demo/required.d.ts +1 -1
- package/ui/form/NumberField/demo/required.js +1 -1
- package/ui/form/NumberField/demo/sizes.d.ts +2 -2
- package/ui/form/NumberField/demo/sizes.js +2 -2
- package/ui/form/PasswordField/PasswordField.d.ts +1 -6
- package/ui/form/PasswordField/demo/basic.d.ts +1 -1
- package/ui/form/PasswordField/demo/basic.js +1 -1
- package/ui/form/PasswordField/demo/disabled.d.ts +1 -1
- package/ui/form/PasswordField/demo/disabled.js +1 -1
- package/ui/form/PasswordField/demo/errors.d.ts +1 -1
- package/ui/form/PasswordField/demo/errors.js +2 -2
- package/ui/form/PasswordField/demo/placeholder.d.ts +1 -1
- package/ui/form/PasswordField/demo/placeholder.js +1 -1
- package/ui/form/PasswordField/demo/required.d.ts +1 -1
- package/ui/form/PasswordField/demo/required.js +1 -1
- package/ui/form/PasswordField/demo/security.d.ts +1 -1
- package/ui/form/PasswordField/demo/security.js +1 -1
- package/ui/form/PasswordField/demo/sizes.d.ts +2 -2
- package/ui/form/PasswordField/demo/sizes.js +2 -2
- package/ui/form/RadioListField/RadioListField.d.ts +1 -6
- package/ui/form/RadioListField/demo/basic.d.ts +5 -5
- package/ui/form/RadioListField/demo/basic.js +5 -5
- package/ui/form/RadioListField/demo/disabled.d.ts +1 -1
- package/ui/form/RadioListField/demo/disabled.js +1 -1
- package/ui/form/RadioListField/demo/errors.d.ts +1 -1
- package/ui/form/RadioListField/demo/errors.js +2 -2
- package/ui/form/RadioListField/demo/required.d.ts +1 -1
- package/ui/form/RadioListField/demo/required.js +1 -1
- package/ui/form/RateField/RateField.d.ts +2 -8
- package/ui/form/RateField/demo/allow-clear.d.ts +1 -1
- package/ui/form/RateField/demo/allow-clear.js +1 -1
- package/ui/form/RateField/demo/basic.d.ts +1 -1
- package/ui/form/RateField/demo/basic.js +1 -1
- package/ui/form/RateField/demo/default-value.d.ts +1 -1
- package/ui/form/RateField/demo/default-value.js +1 -1
- package/ui/form/RateField/demo/disabled.d.ts +1 -1
- package/ui/form/RateField/demo/disabled.js +1 -1
- package/ui/form/RateField/demo/errors.d.ts +1 -1
- package/ui/form/RateField/demo/errors.js +2 -2
- package/ui/form/RateField/demo/items-count.d.ts +1 -1
- package/ui/form/RateField/demo/items-count.js +1 -1
- package/ui/form/RateField/demo/required.d.ts +1 -1
- package/ui/form/RateField/demo/required.js +1 -1
- package/ui/form/ReCaptchaField/ReCaptchaField.d.ts +1 -7
- package/ui/form/ReCaptchaField/demo/basic.d.ts +1 -1
- package/ui/form/ReCaptchaField/demo/basic.js +1 -1
- package/ui/form/SliderField/SliderField.d.ts +42 -15
- package/ui/form/SliderField/SliderField.js +18 -9
- package/ui/form/SliderField/demo/basic.d.ts +1 -1
- package/ui/form/SliderField/demo/basic.js +2 -2
- package/ui/form/SliderField/demo/disabled.d.ts +1 -1
- package/ui/form/SliderField/demo/disabled.js +2 -2
- package/ui/form/SliderField/demo/errors.d.ts +2 -2
- package/ui/form/SliderField/demo/errors.js +4 -4
- package/ui/form/SliderField/demo/marks.d.ts +3 -0
- package/ui/form/SliderField/demo/marks.js +45 -0
- package/ui/form/SliderField/demo/min-max.d.ts +2 -2
- package/ui/form/SliderField/demo/min-max.js +3 -3
- package/ui/form/SliderField/demo/onAfterChange.d.ts +8 -0
- package/ui/form/SliderField/demo/onAfterChange.js +39 -0
- package/ui/form/SliderField/demo/onChange.d.ts +8 -0
- package/ui/form/SliderField/demo/onChange.js +39 -0
- package/ui/form/SliderField/demo/range.d.ts +8 -0
- package/ui/form/SliderField/demo/{size.js → range.js} +5 -10
- package/ui/form/SwitcherField/SwitcherField.d.ts +1 -7
- package/ui/form/SwitcherField/demo/basic.d.ts +5 -5
- package/ui/form/SwitcherField/demo/basic.js +5 -5
- package/ui/form/SwitcherField/demo/disabled.d.ts +1 -1
- package/ui/form/SwitcherField/demo/disabled.js +2 -2
- package/ui/form/SwitcherField/demo/errors.d.ts +1 -1
- package/ui/form/SwitcherField/demo/errors.js +3 -3
- package/ui/form/SwitcherField/demo/required.d.ts +1 -1
- package/ui/form/SwitcherField/demo/required.js +2 -2
- package/ui/form/TextField/TextField.d.ts +3 -7
- package/ui/form/TextField/TextField.js +1 -1
- package/ui/form/TextField/demo/basic.d.ts +1 -1
- package/ui/form/TextField/demo/basic.js +1 -1
- package/ui/form/TextField/demo/disabled.d.ts +1 -1
- package/ui/form/TextField/demo/disabled.js +1 -1
- package/ui/form/TextField/demo/errors.d.ts +1 -1
- package/ui/form/TextField/demo/errors.js +2 -2
- package/ui/form/TextField/demo/placeholder.d.ts +1 -1
- package/ui/form/TextField/demo/placeholder.js +1 -1
- package/ui/form/TextField/demo/required.d.ts +1 -1
- package/ui/form/TextField/demo/required.js +1 -1
- package/ui/form/TextField/demo/sizes.d.ts +0 -5
- package/ui/form/TextField/demo/sizes.js +5 -5
- package/ui/form/TextField/demo/submit.d.ts +2 -2
- package/ui/form/TextField/demo/submit.js +2 -2
- package/ui/form/TimeField/TimeField.d.ts +1 -7
- package/ui/form/TimeField/TimeField.js +1 -1
- package/ui/form/TimeField/demo/basic.d.ts +1 -1
- package/ui/form/TimeField/demo/basic.js +1 -1
- package/ui/form/TimeField/demo/disabled.d.ts +1 -1
- package/ui/form/TimeField/demo/disabled.js +1 -1
- package/ui/form/TimeField/demo/errors.d.ts +1 -1
- package/ui/form/TimeField/demo/errors.js +2 -2
- package/ui/form/TimeField/demo/icon.d.ts +8 -0
- package/ui/form/TimeField/demo/icon.js +33 -0
- package/ui/form/TimeField/demo/{no-border.d.ts → noBorder.d.ts} +1 -1
- package/ui/form/TimeField/demo/{no-border.js → noBorder.js} +1 -1
- package/ui/form/TimeField/demo/placeholder.d.ts +1 -1
- package/ui/form/TimeField/demo/placeholder.js +1 -1
- package/ui/form/TimeField/demo/required.d.ts +1 -1
- package/ui/form/TimeField/demo/required.js +1 -1
- package/ui/form/TimeField/demo/showRemove.d.ts +8 -0
- package/ui/form/TimeField/demo/{show-remove.js → showRemove.js} +1 -1
- package/ui/form/index.d.ts +22 -132
- package/ui/format/EnumFormatter/EnumFormatter.js +1 -1
- package/ui/icon/Icon/Icon.js +3 -0
- package/ui/icon/Icon/demo/icon.d.ts +3 -0
- package/ui/{form/SliderField/demo/required.js → icon/Icon/demo/icon.js} +2 -7
- package/ui/layout/Meta/Meta.d.ts +56 -0
- package/ui/layout/Meta/Meta.js +38 -0
- package/ui/layout/Meta/index.d.ts +2 -0
- package/ui/layout/Meta/index.js +7 -0
- package/ui/layout/Notifications/Notifications.d.ts +14 -0
- package/ui/layout/Notifications/Notifications.js +1 -1
- package/ui/layout/Notifications/demo/basic.d.ts +8 -0
- package/ui/layout/Notifications/demo/basic.js +53 -0
- package/ui/layout/Notifications/demo/position.d.ts +3 -0
- package/ui/layout/Notifications/demo/position.js +45 -0
- package/ui/layout/Notifications/demo/timeOut.d.ts +3 -0
- package/ui/layout/Notifications/demo/timeOut.js +45 -0
- package/ui/layout/Portal.js +3 -0
- package/ui/layout/ProgressBar/ProgressBar.d.ts +55 -0
- package/ui/layout/ProgressBar/ProgressBar.js +53 -0
- package/ui/layout/ProgressBar/demo/percent.d.ts +8 -0
- package/ui/layout/ProgressBar/demo/percent.js +49 -0
- package/ui/layout/ProgressBar/demo/showLabel.d.ts +8 -0
- package/ui/layout/ProgressBar/demo/showLabel.js +40 -0
- package/ui/{form/TimeField → layout/ProgressBar}/demo/sizes.d.ts +1 -1
- package/ui/layout/ProgressBar/demo/sizes.js +40 -0
- package/ui/layout/ProgressBar/demo/status.d.ts +8 -0
- package/ui/{form/DateTimeField/demo/sizes.js → layout/ProgressBar/demo/status.js} +8 -12
- package/ui/layout/ProgressBar/demo/type.d.ts +8 -0
- package/ui/layout/ProgressBar/demo/type.js +40 -0
- package/ui/layout/ProgressBar/index.d.ts +2 -0
- package/ui/layout/ProgressBar/index.js +7 -0
- package/ui/layout/Skeleton/Skeleton.d.ts +25 -0
- package/ui/layout/Skeleton/Skeleton.js +11 -0
- package/ui/layout/Skeleton/demo/animations.d.ts +8 -0
- package/ui/layout/Skeleton/demo/animations.js +49 -0
- package/ui/layout/Skeleton/demo/width height.d.ts +8 -0
- package/ui/layout/Skeleton/demo/width height.js +38 -0
- package/ui/layout/Skeleton/index.d.ts +2 -0
- package/ui/layout/Skeleton/index.js +7 -0
- package/ui/layout/Tooltip/demo/basic.d.ts +5 -0
- package/ui/layout/Tooltip/demo/basic.js +20 -9
- package/ui/list/Grid/Grid.js +3 -1
- package/ui/list/Grid/demo/inner-search-form.d.ts +1 -6
- package/ui/list/LayoutNames/LayoutNames.js +4 -3
- package/ui/list/List/List.js +4 -6
- package/ui/list/PaginationSize/PaginationSize.d.ts +2 -2
- package/ui/list/Steps/Steps.d.ts +32 -0
- package/ui/list/Steps/Steps.js +23 -0
- package/ui/list/Steps/index.d.ts +2 -0
- package/ui/list/Steps/index.js +7 -0
- package/ui/modal/Modal/Modal.d.ts +52 -32
- package/ui/modal/Modal/Modal.js +3 -1
- package/ui/modal/Modal/demo/basic.d.ts +1 -1
- package/ui/modal/Modal/demo/basic.js +16 -7
- package/ui/modal/Modal/demo/closeTimeout.d.ts +8 -0
- package/ui/modal/Modal/demo/closeTimeout.js +60 -0
- package/ui/modal/Modal/demo/closing.d.ts +9 -0
- package/ui/modal/Modal/demo/closing.js +63 -0
- package/ui/modal/Modal/demo/component.d.ts +10 -0
- package/ui/modal/Modal/demo/component.js +51 -0
- package/ui/modal/Modal/demo/controls.d.ts +8 -0
- package/ui/modal/Modal/demo/controls.js +62 -0
- package/ui/modal/Modal/demo/size.d.ts +8 -0
- package/ui/modal/Modal/demo/size.js +66 -0
- package/ui/modal/ModalPortal/ModalPortal.d.ts +8 -0
- package/ui/modal/ModalPortal/ModalPortal.js +7 -9
- package/ui/nav/Breadcrumbs/Breadcrumbs.d.ts +10 -4
- package/ui/nav/Breadcrumbs/demo/basic.d.ts +1 -1
- package/ui/nav/Breadcrumbs/demo/basic.js +1 -1
- package/ui/nav/Breadcrumbs/demo/items.d.ts +8 -0
- package/ui/{form/TimeField/demo/sizes.js → nav/Breadcrumbs/demo/items.js} +9 -10
- package/ui/nav/Breadcrumbs/demo/page-title.d.ts +1 -1
- package/ui/nav/Breadcrumbs/demo/page-title.js +1 -1
- package/ui/nav/Nav/Nav.js +1 -1
- package/ui/nav/Router/Router.d.ts +18 -0
- package/ui/nav/Router/Router.js +1 -3
- package/utils/calendar.d.ts +1 -1
- package/utils/calendar.js +8 -1
- package/utils/form.d.ts +2 -7
- package/components/social/index.d.ts +0 -11
- package/components/social/index.js +0 -15
- package/ui/content/Avatar/SizeContext.d.ts +0 -1
- package/ui/content/Avatar/SizeContext.js +0 -14
- package/ui/nav/Router/SsrProvider.d.ts +0 -15
- package/ui/nav/Router/SsrProvider.js +0 -55
|
@@ -6,69 +6,89 @@ import { IControlItem } from '../../nav/Controls/Controls';
|
|
|
6
6
|
*/
|
|
7
7
|
export interface IModalProps {
|
|
8
8
|
/**
|
|
9
|
-
*
|
|
10
|
-
* @example
|
|
9
|
+
* Кастомный CSS-класс
|
|
10
|
+
* @example 'CustomCssClassName'
|
|
11
11
|
*/
|
|
12
|
-
|
|
12
|
+
className?: CssClassName;
|
|
13
13
|
/**
|
|
14
|
-
*
|
|
15
|
-
* @
|
|
14
|
+
* Компонент, который отрендерится внутри Modal
|
|
15
|
+
* @example () => <InnerModalComponent />
|
|
16
16
|
*/
|
|
17
|
-
|
|
17
|
+
component?: () => JSX.Element;
|
|
18
18
|
/**
|
|
19
|
-
*
|
|
20
|
-
* @example 'Заявка отправлена на модерацию'
|
|
19
|
+
* Свойства для внутреннего компонента
|
|
21
20
|
*/
|
|
22
|
-
|
|
21
|
+
componentProps?: any;
|
|
23
22
|
/**
|
|
24
|
-
*
|
|
23
|
+
* Коллекция контролов, которая отобразится в Modal
|
|
24
|
+
* @example [{label: __(('Закрыть')), onClick: () => props.onClose()}]
|
|
25
25
|
*/
|
|
26
|
-
|
|
26
|
+
controls?: IControlItem[];
|
|
27
27
|
/**
|
|
28
|
-
*
|
|
29
|
-
*
|
|
28
|
+
* Время, через которое произойдет закрытие Modal.
|
|
29
|
+
* В этот отрезок времени должны происходить все анимации закрытия компонента.
|
|
30
|
+
* Переопределяет отрезок времени, заданный в ModalPortal
|
|
31
|
+
* @example 300
|
|
30
32
|
*/
|
|
31
|
-
|
|
33
|
+
closeTimeoutMs?: number;
|
|
32
34
|
/**
|
|
33
|
-
*
|
|
35
|
+
* Группа Modal
|
|
36
|
+
* @example 'modal'
|
|
34
37
|
*/
|
|
35
|
-
|
|
38
|
+
group?: string;
|
|
39
|
+
/**
|
|
40
|
+
* Порядковый номер Modal
|
|
41
|
+
* @example 0
|
|
42
|
+
*/
|
|
43
|
+
index?: number;
|
|
36
44
|
/**
|
|
45
|
+
* Значение свойства отслеживается для показа/закрытия Modal.
|
|
37
46
|
* Если для компонента ModalPortal установлено значение задержки (animationDelayMc), то после закрытия
|
|
38
|
-
* пользователем
|
|
47
|
+
* пользователем Modal, оно исчезнет не сразу, а через указанный в animationDelayMc промежуток времени.
|
|
39
48
|
* В течение этого времени флаг isClosing будет равен true.
|
|
40
|
-
* Если задержка не установлена,
|
|
49
|
+
* Если задержка не установлена, Modal закроется сразу же и флаг isClosing всегда будет равен false.
|
|
41
50
|
* @example true
|
|
42
51
|
*/
|
|
43
52
|
isClosing?: boolean;
|
|
44
53
|
/**
|
|
45
|
-
*
|
|
46
|
-
* @
|
|
54
|
+
* Обработчик срабатывает при закрытии Modal
|
|
55
|
+
* @param args
|
|
47
56
|
*/
|
|
48
|
-
|
|
57
|
+
onClose?: (...args: any[]) => void;
|
|
49
58
|
/**
|
|
50
|
-
*
|
|
51
|
-
* @example
|
|
59
|
+
* Размер Modal
|
|
60
|
+
* @example 'middle'
|
|
52
61
|
*/
|
|
53
|
-
|
|
62
|
+
size?: Size;
|
|
54
63
|
/**
|
|
55
|
-
*
|
|
64
|
+
* Заголовок Modal
|
|
65
|
+
* @example 'Заявка отправлена на модерацию'
|
|
56
66
|
*/
|
|
57
|
-
|
|
67
|
+
title?: string;
|
|
68
|
+
/**
|
|
69
|
+
* Закрытие Modal при нажатии на клавишу 'ESC'
|
|
70
|
+
* @example true
|
|
71
|
+
*/
|
|
72
|
+
shouldCloseOnEsc?: boolean;
|
|
58
73
|
/**
|
|
59
|
-
*
|
|
60
|
-
* @example
|
|
74
|
+
* Закрытие Modal при клике на компонент overlay внутри Modal (темный фон, отделяющий контент страницы от Modal)
|
|
75
|
+
* @example true
|
|
61
76
|
*/
|
|
62
|
-
|
|
77
|
+
shouldCloseOnOverlayClick?: boolean;
|
|
78
|
+
/**
|
|
79
|
+
* Переопределение React-компонента для кастомизации view-отображения
|
|
80
|
+
* @example MyCustomView
|
|
81
|
+
*/
|
|
82
|
+
view?: CustomView;
|
|
63
83
|
[key: string]: any;
|
|
64
84
|
}
|
|
65
|
-
export
|
|
66
|
-
isClosing?: boolean;
|
|
67
|
-
}
|
|
85
|
+
export declare type IModalViewProps = IModalProps;
|
|
68
86
|
declare function Modal(props: IModalProps): JSX.Element;
|
|
69
87
|
declare namespace Modal {
|
|
70
88
|
var defaultProps: {
|
|
71
89
|
size: string;
|
|
90
|
+
shouldCloseOnEsc: boolean;
|
|
91
|
+
shouldCloseOnOverlayClick: boolean;
|
|
72
92
|
};
|
|
73
93
|
}
|
|
74
94
|
export default Modal;
|
package/ui/modal/Modal/Modal.js
CHANGED
|
@@ -39,6 +39,8 @@ function Modal(props) {
|
|
|
39
39
|
return (React.createElement(ModalView, __assign({}, props), (ContentComponent && (React.createElement(ContentComponent, __assign({}, props, props.componentProps)))) || (props.children)));
|
|
40
40
|
}
|
|
41
41
|
Modal.defaultProps = {
|
|
42
|
-
size: '
|
|
42
|
+
size: 'middle',
|
|
43
|
+
shouldCloseOnEsc: true,
|
|
44
|
+
shouldCloseOnOverlayClick: true
|
|
43
45
|
};
|
|
44
46
|
exports["default"] = Modal;
|
|
@@ -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
|
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
@@ -23,24 +34,22 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
23
34
|
};
|
|
24
35
|
exports.__esModule = true;
|
|
25
36
|
var React = __importStar(require("react"));
|
|
26
|
-
var
|
|
37
|
+
var Modal_1 = __importDefault(require("../Modal"));
|
|
27
38
|
var Button_1 = __importDefault(require("../../../form/Button"));
|
|
28
|
-
var ModalPortal_1 = __importDefault(require("../../ModalPortal"));
|
|
29
39
|
var modal_1 = require("../../../../actions/modal");
|
|
30
|
-
var
|
|
40
|
+
var useDispatch_1 = __importDefault(require("../../../../hooks/useDispatch"));
|
|
31
41
|
function DemoModal(props) {
|
|
32
|
-
return (React.createElement(Modal_1["default"], { title: '
|
|
33
|
-
React.createElement("div", {
|
|
42
|
+
return (React.createElement(Modal_1["default"], __assign({ title: 'Basic Modal', onClose: props.onClose }, props),
|
|
43
|
+
React.createElement("div", { style: { marginBottom: '20px' } }, "This is your modal content.")));
|
|
34
44
|
}
|
|
35
45
|
/**
|
|
36
|
-
*
|
|
46
|
+
* Простой пример Modal, с заданным заголовком и контентом.
|
|
37
47
|
* @order 1
|
|
38
48
|
* @col 6
|
|
39
49
|
*/
|
|
40
50
|
exports["default"] = (function () {
|
|
41
51
|
var dispatch = useDispatch_1["default"]();
|
|
42
52
|
return (React.createElement(React.Fragment, null,
|
|
43
|
-
React.createElement(ModalPortal_1["default"], null),
|
|
44
53
|
React.createElement(Button_1["default"], { label: 'Open modal', onClick: function (e) {
|
|
45
54
|
e.preventDefault();
|
|
46
55
|
dispatch(modal_1.openModal(DemoModal, {
|
|
@@ -0,0 +1,60 @@
|
|
|
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
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
16
|
+
}) : (function(o, m, k, k2) {
|
|
17
|
+
if (k2 === undefined) k2 = k;
|
|
18
|
+
o[k2] = m[k];
|
|
19
|
+
}));
|
|
20
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
21
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
22
|
+
}) : function(o, v) {
|
|
23
|
+
o["default"] = v;
|
|
24
|
+
});
|
|
25
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
26
|
+
if (mod && mod.__esModule) return mod;
|
|
27
|
+
var result = {};
|
|
28
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
29
|
+
__setModuleDefault(result, mod);
|
|
30
|
+
return result;
|
|
31
|
+
};
|
|
32
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
33
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
34
|
+
};
|
|
35
|
+
exports.__esModule = true;
|
|
36
|
+
var React = __importStar(require("react"));
|
|
37
|
+
var Modal_1 = __importDefault(require("../Modal"));
|
|
38
|
+
var Button_1 = __importDefault(require("../../../form/Button"));
|
|
39
|
+
var modal_1 = require("../../../../actions/modal");
|
|
40
|
+
var useDispatch_1 = __importDefault(require("../../../../hooks/useDispatch"));
|
|
41
|
+
function DemoModal(props) {
|
|
42
|
+
return (React.createElement(Modal_1["default"], __assign({ title: 'Custom closing time', onClose: props.onClose }, props),
|
|
43
|
+
React.createElement("div", { style: { marginBottom: '20px' } }, "This is your modal content.")));
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Настройка времени, через которое произойдет закрытие Modal.
|
|
47
|
+
* @order 5
|
|
48
|
+
* @col 6
|
|
49
|
+
*/
|
|
50
|
+
exports["default"] = (function () {
|
|
51
|
+
var dispatch = useDispatch_1["default"]();
|
|
52
|
+
return (React.createElement(React.Fragment, null,
|
|
53
|
+
React.createElement(Button_1["default"], { label: 'Open modal', onClick: function (e) {
|
|
54
|
+
e.preventDefault();
|
|
55
|
+
dispatch(modal_1.openModal(DemoModal, {
|
|
56
|
+
modalId: 'demo',
|
|
57
|
+
closeTimeoutMs: 1000
|
|
58
|
+
}));
|
|
59
|
+
} })));
|
|
60
|
+
});
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
declare const _default: () => JSX.Element;
|
|
3
|
+
/**
|
|
4
|
+
* Обработка закрытия Modal при помощи onClose.
|
|
5
|
+
* Также это модальное окно не закроется при нажатии на клавишу 'ESC' или клике на overlay.
|
|
6
|
+
* @order 4
|
|
7
|
+
* @col 6
|
|
8
|
+
*/
|
|
9
|
+
export default _default;
|
|
@@ -0,0 +1,63 @@
|
|
|
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
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
16
|
+
}) : (function(o, m, k, k2) {
|
|
17
|
+
if (k2 === undefined) k2 = k;
|
|
18
|
+
o[k2] = m[k];
|
|
19
|
+
}));
|
|
20
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
21
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
22
|
+
}) : function(o, v) {
|
|
23
|
+
o["default"] = v;
|
|
24
|
+
});
|
|
25
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
26
|
+
if (mod && mod.__esModule) return mod;
|
|
27
|
+
var result = {};
|
|
28
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
29
|
+
__setModuleDefault(result, mod);
|
|
30
|
+
return result;
|
|
31
|
+
};
|
|
32
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
33
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
34
|
+
};
|
|
35
|
+
exports.__esModule = true;
|
|
36
|
+
var React = __importStar(require("react"));
|
|
37
|
+
var Modal_1 = __importDefault(require("../Modal"));
|
|
38
|
+
var Button_1 = __importDefault(require("../../../form/Button"));
|
|
39
|
+
var modal_1 = require("../../../../actions/modal");
|
|
40
|
+
var useDispatch_1 = __importDefault(require("../../../../hooks/useDispatch"));
|
|
41
|
+
function DemoModal(props) {
|
|
42
|
+
return (React.createElement(Modal_1["default"], __assign({ title: 'Modal with custom closing', onClose: props.onClose }, props),
|
|
43
|
+
React.createElement("div", { style: { marginBottom: '20px' } }, "This is your modal content.")));
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Обработка закрытия Modal при помощи onClose.
|
|
47
|
+
* Также это модальное окно не закроется при нажатии на клавишу 'ESC' или клике на overlay.
|
|
48
|
+
* @order 4
|
|
49
|
+
* @col 6
|
|
50
|
+
*/
|
|
51
|
+
exports["default"] = (function () {
|
|
52
|
+
var dispatch = useDispatch_1["default"]();
|
|
53
|
+
return (React.createElement(React.Fragment, null,
|
|
54
|
+
React.createElement(Button_1["default"], { label: 'Open modal', onClick: function (e) {
|
|
55
|
+
e.preventDefault();
|
|
56
|
+
dispatch(modal_1.openModal(DemoModal, {
|
|
57
|
+
modalId: 'demo',
|
|
58
|
+
onClose: function () { return alert('Modal will be closed!'); },
|
|
59
|
+
shouldCloseOnOverlayClick: false,
|
|
60
|
+
shouldCloseOnEsc: false
|
|
61
|
+
}));
|
|
62
|
+
} })));
|
|
63
|
+
});
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
declare const _default: () => JSX.Element;
|
|
3
|
+
/**
|
|
4
|
+
* Контент для Modal также можно задать через свойство component.
|
|
5
|
+
* При этом, в action openModal необязательно передавать отдельный компонент, построенный на базе Modal.
|
|
6
|
+
* Можно передать сам Modal, контент настроить уже через свойства Modal.
|
|
7
|
+
* @order 6
|
|
8
|
+
* @col 6
|
|
9
|
+
*/
|
|
10
|
+
export default _default;
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
|
+
};
|
|
24
|
+
exports.__esModule = true;
|
|
25
|
+
var React = __importStar(require("react"));
|
|
26
|
+
var Modal_1 = __importDefault(require("../Modal"));
|
|
27
|
+
var Button_1 = __importDefault(require("../../../form/Button"));
|
|
28
|
+
var modal_1 = require("../../../../actions/modal");
|
|
29
|
+
var useDispatch_1 = __importDefault(require("../../../../hooks/useDispatch"));
|
|
30
|
+
/**
|
|
31
|
+
* Контент для Modal также можно задать через свойство component.
|
|
32
|
+
* При этом, в action openModal необязательно передавать отдельный компонент, построенный на базе Modal.
|
|
33
|
+
* Можно передать сам Modal, контент настроить уже через свойства Modal.
|
|
34
|
+
* @order 6
|
|
35
|
+
* @col 6
|
|
36
|
+
*/
|
|
37
|
+
exports["default"] = (function () {
|
|
38
|
+
var dispatch = useDispatch_1["default"]();
|
|
39
|
+
return (React.createElement(React.Fragment, null,
|
|
40
|
+
React.createElement(Button_1["default"], { label: 'Open modal', onClick: function (e) {
|
|
41
|
+
e.preventDefault();
|
|
42
|
+
dispatch(modal_1.openModal(Modal_1["default"], {
|
|
43
|
+
modalId: 'demo',
|
|
44
|
+
title: 'Modal based only on props',
|
|
45
|
+
component: function () { return (React.createElement("div", { style: { marginBottom: '20px' } }, "This is your modal content.")); },
|
|
46
|
+
controls: [
|
|
47
|
+
{ label: 'Show Alert', onClick: function () { return alert('This is alert!'); } },
|
|
48
|
+
]
|
|
49
|
+
}));
|
|
50
|
+
} })));
|
|
51
|
+
});
|
|
@@ -0,0 +1,62 @@
|
|
|
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
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
16
|
+
}) : (function(o, m, k, k2) {
|
|
17
|
+
if (k2 === undefined) k2 = k;
|
|
18
|
+
o[k2] = m[k];
|
|
19
|
+
}));
|
|
20
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
21
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
22
|
+
}) : function(o, v) {
|
|
23
|
+
o["default"] = v;
|
|
24
|
+
});
|
|
25
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
26
|
+
if (mod && mod.__esModule) return mod;
|
|
27
|
+
var result = {};
|
|
28
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
29
|
+
__setModuleDefault(result, mod);
|
|
30
|
+
return result;
|
|
31
|
+
};
|
|
32
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
33
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
34
|
+
};
|
|
35
|
+
exports.__esModule = true;
|
|
36
|
+
var React = __importStar(require("react"));
|
|
37
|
+
var Modal_1 = __importDefault(require("../Modal"));
|
|
38
|
+
var Button_1 = __importDefault(require("../../../form/Button"));
|
|
39
|
+
var modal_1 = require("../../../../actions/modal");
|
|
40
|
+
var useDispatch_1 = __importDefault(require("../../../../hooks/useDispatch"));
|
|
41
|
+
function DemoModal(props) {
|
|
42
|
+
return (React.createElement(Modal_1["default"], __assign({ title: 'Modal with controls', onClose: props.onClose, controls: [
|
|
43
|
+
{ label: 'Show Alert', onClick: function () { return alert('This is alert!'); } },
|
|
44
|
+
{ label: 'Close', onClick: function () { return props.onClose(); } },
|
|
45
|
+
] }, props),
|
|
46
|
+
React.createElement("div", { style: { marginBottom: '20px' } }, "This is your modal content.")));
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Modal содержит набор контролов с привязанными обработчиками.
|
|
50
|
+
* @order 2
|
|
51
|
+
* @col 6
|
|
52
|
+
*/
|
|
53
|
+
exports["default"] = (function () {
|
|
54
|
+
var dispatch = useDispatch_1["default"]();
|
|
55
|
+
return (React.createElement(React.Fragment, null,
|
|
56
|
+
React.createElement(Button_1["default"], { label: 'Open modal', onClick: function (e) {
|
|
57
|
+
e.preventDefault();
|
|
58
|
+
dispatch(modal_1.openModal(DemoModal, {
|
|
59
|
+
modalId: 'demo'
|
|
60
|
+
}));
|
|
61
|
+
} })));
|
|
62
|
+
});
|
|
@@ -0,0 +1,66 @@
|
|
|
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
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
16
|
+
}) : (function(o, m, k, k2) {
|
|
17
|
+
if (k2 === undefined) k2 = k;
|
|
18
|
+
o[k2] = m[k];
|
|
19
|
+
}));
|
|
20
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
21
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
22
|
+
}) : function(o, v) {
|
|
23
|
+
o["default"] = v;
|
|
24
|
+
});
|
|
25
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
26
|
+
if (mod && mod.__esModule) return mod;
|
|
27
|
+
var result = {};
|
|
28
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
29
|
+
__setModuleDefault(result, mod);
|
|
30
|
+
return result;
|
|
31
|
+
};
|
|
32
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
33
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
34
|
+
};
|
|
35
|
+
exports.__esModule = true;
|
|
36
|
+
var React = __importStar(require("react"));
|
|
37
|
+
var Modal_1 = __importDefault(require("../Modal"));
|
|
38
|
+
var Button_1 = __importDefault(require("../../../form/Button"));
|
|
39
|
+
var modal_1 = require("../../../../actions/modal");
|
|
40
|
+
var useDispatch_1 = __importDefault(require("../../../../hooks/useDispatch"));
|
|
41
|
+
var sizesArray = ['small', 'middle', 'large'];
|
|
42
|
+
function DemoModal(props) {
|
|
43
|
+
return (React.createElement(Modal_1["default"], __assign({ title: props.size + " modal", onClose: props.onClose }, props),
|
|
44
|
+
React.createElement("div", { style: { marginBottom: '20px' } },
|
|
45
|
+
"This is your content for",
|
|
46
|
+
React.createElement("strong", null,
|
|
47
|
+
' ',
|
|
48
|
+
props.size,
|
|
49
|
+
' '),
|
|
50
|
+
"modal.")));
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* По-умолчанию, Modal имеет 3 заданных размера.
|
|
54
|
+
* @order 3
|
|
55
|
+
* @col 12
|
|
56
|
+
*/
|
|
57
|
+
exports["default"] = (function () {
|
|
58
|
+
var dispatch = useDispatch_1["default"]();
|
|
59
|
+
return (React.createElement("div", { style: { display: 'flex' } }, sizesArray.map(function (size) { return (React.createElement(Button_1["default"], { key: size, label: "Open " + size + " modal", onClick: function (e) {
|
|
60
|
+
e.preventDefault();
|
|
61
|
+
dispatch(modal_1.openModal(DemoModal, {
|
|
62
|
+
modalId: 'demo',
|
|
63
|
+
size: size
|
|
64
|
+
}));
|
|
65
|
+
}, style: { marginRight: '20px' } })); })));
|
|
66
|
+
});
|
|
@@ -1,6 +1,14 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
export interface IModalPortalProps {
|
|
3
|
+
/**
|
|
4
|
+
* Время, через которое произойдет закрытие Modal
|
|
5
|
+
* @example 300
|
|
6
|
+
*/
|
|
3
7
|
animationDelayMc?: number;
|
|
8
|
+
/**
|
|
9
|
+
* Группа Modal
|
|
10
|
+
* @example 'modal'
|
|
11
|
+
*/
|
|
4
12
|
group?: string;
|
|
5
13
|
}
|
|
6
14
|
declare function ModalPortal(props: IModalPortalProps): JSX.Element;
|
|
@@ -51,9 +51,11 @@ function ModalPortal(props) {
|
|
|
51
51
|
dispatch(modal_1.closeModal(item.id, props.group));
|
|
52
52
|
}, [dispatch, props.group]);
|
|
53
53
|
var onClose = react_1.useCallback(function (item) {
|
|
54
|
-
|
|
54
|
+
var _a, _b;
|
|
55
|
+
var animationDelayMc = (_b = (_a = item.props) === null || _a === void 0 ? void 0 : _a.closeTimeoutMs) !== null && _b !== void 0 ? _b : props.animationDelayMc;
|
|
56
|
+
if (animationDelayMc > 0) {
|
|
55
57
|
dispatch(modal_1.modalMarkClosing(item.id, props.group));
|
|
56
|
-
setTimeout(function () { return closeInternal(item); },
|
|
58
|
+
setTimeout(function () { return closeInternal(item); }, animationDelayMc);
|
|
57
59
|
}
|
|
58
60
|
else {
|
|
59
61
|
closeInternal(item);
|
|
@@ -61,13 +63,9 @@ function ModalPortal(props) {
|
|
|
61
63
|
}, [closeInternal, dispatch, props.animationDelayMc, props.group]);
|
|
62
64
|
return orderBy_1["default"](opened, 'id').map(function (item, index) {
|
|
63
65
|
var ModalComponent = item.modal;
|
|
64
|
-
var modalProps = {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
isClosing: item.isClosing,
|
|
68
|
-
onClose: function () { return onClose(item); }
|
|
69
|
-
};
|
|
70
|
-
return (React.createElement(ModalComponent, __assign({ key: item.id }, item.props, modalProps)));
|
|
66
|
+
var modalProps = __assign(__assign({}, item.props), { index: index,
|
|
67
|
+
group: group, isClosing: item.isClosing, onClose: function () { return onClose(item); }, closeTimeoutMs: item.props.closeTimeoutMs || props.animationDelayMc });
|
|
68
|
+
return (React.createElement(ModalComponent, __assign({ key: item.id }, modalProps)));
|
|
71
69
|
});
|
|
72
70
|
}
|
|
73
71
|
ModalPortal.defaultProps = {
|
|
@@ -5,19 +5,25 @@ import { IRoute } from '../../../reducers/router';
|
|
|
5
5
|
* Хлебные крошки
|
|
6
6
|
*/
|
|
7
7
|
export interface IBreadcrumbsProps {
|
|
8
|
+
/**
|
|
9
|
+
* Кастомный CSS-класс
|
|
10
|
+
* @example 'CustomCssClassName'
|
|
11
|
+
*/
|
|
12
|
+
className?: CssClassName;
|
|
8
13
|
/**
|
|
9
14
|
* Коллекция элементов навигационной цепочки
|
|
10
|
-
* @example [{id: 'root', title: 'Home'}, {id: 'catalog', title: 'Catalog'}
|
|
15
|
+
* @example [{id: 'root', title: 'Home'}, {id: 'catalog', title: 'Catalog'}]
|
|
11
16
|
*/
|
|
12
17
|
items?: IRoute[];
|
|
13
18
|
/**
|
|
14
|
-
* Вместо items можно передать идентификатор
|
|
19
|
+
* Вместо items можно передать идентификатор роута, от которого компонент самостоятельно построит
|
|
15
20
|
* навигационную цепочку
|
|
16
21
|
* @example 'catalog'
|
|
17
22
|
*/
|
|
18
23
|
pageId?: string;
|
|
19
24
|
/**
|
|
20
|
-
* Заголовок
|
|
25
|
+
* Заголовок последней в списке страницы (обычно, это текущая страница, на которой находится пользователь).
|
|
26
|
+
* Если заголовок не задан, то подставится item.title
|
|
21
27
|
* @example 'Каталог'
|
|
22
28
|
*/
|
|
23
29
|
pageTitle?: string;
|
|
@@ -25,7 +31,7 @@ export interface IBreadcrumbsProps {
|
|
|
25
31
|
* Переопределение view React компонента для кастомизации отображения
|
|
26
32
|
* @example MyCustomView
|
|
27
33
|
*/
|
|
28
|
-
view?:
|
|
34
|
+
view?: CustomView;
|
|
29
35
|
[key: string]: any;
|
|
30
36
|
}
|
|
31
37
|
export declare type IBreadcrumbsViewProps = IBreadcrumbsProps;
|
|
@@ -25,7 +25,7 @@ exports.__esModule = true;
|
|
|
25
25
|
var React = __importStar(require("react"));
|
|
26
26
|
var Breadcrumbs_1 = __importDefault(require("../Breadcrumbs"));
|
|
27
27
|
/**
|
|
28
|
-
*
|
|
28
|
+
* Самый простой способ построить цепочку Breadcrumbs - передать id целевого роута.
|
|
29
29
|
* @order 1
|
|
30
30
|
* @col 6
|
|
31
31
|
*/
|