@lowdefy/blocks-antd 4.7.2 → 5.0.0
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/dist/blocks/Affix/Affix.js +6 -12
- package/dist/blocks/Affix/{schema.js → meta.js} +23 -14
- package/dist/blocks/Alert/Alert.js +17 -12
- package/dist/blocks/Alert/e2e.js +1 -1
- package/dist/blocks/Alert/meta.js +186 -0
- package/dist/blocks/AutoComplete/AutoComplete.js +15 -22
- package/dist/blocks/AutoComplete/meta.js +265 -0
- package/dist/blocks/Avatar/Avatar.js +58 -18
- package/dist/blocks/Avatar/meta.js +277 -0
- package/dist/blocks/Badge/Badge.js +13 -12
- package/dist/blocks/Badge/{schema.js → meta.js} +80 -1
- package/dist/blocks/Breadcrumb/Breadcrumb.js +40 -41
- package/dist/blocks/Breadcrumb/meta.js +90 -0
- package/dist/blocks/Button/Button.js +77 -39
- package/dist/blocks/Button/meta.js +230 -0
- package/dist/blocks/ButtonSelector/ButtonSelector.js +54 -59
- package/dist/blocks/ButtonSelector/meta.js +213 -0
- package/dist/blocks/Calendar/Calendar.js +111 -0
- package/dist/blocks/Calendar/e2e.js +27 -0
- package/dist/blocks/Calendar/meta.js +148 -0
- package/dist/blocks/Card/Card.js +22 -21
- package/dist/blocks/Card/meta.js +170 -0
- package/dist/blocks/Carousel/Carousel.js +6 -12
- package/dist/blocks/Carousel/{schema.js → meta.js} +61 -22
- package/dist/blocks/CheckboxSelector/CheckboxSelector.js +58 -64
- package/dist/blocks/CheckboxSelector/meta.js +150 -0
- package/dist/blocks/CheckboxSwitch/CheckboxSwitch.js +38 -44
- package/dist/blocks/CheckboxSwitch/meta.js +183 -0
- package/dist/blocks/Collapse/Collapse.js +21 -12
- package/dist/blocks/Collapse/meta.js +179 -0
- package/dist/blocks/ColorSelector/ColorSelector.js +97 -0
- package/dist/blocks/ColorSelector/e2e.js +32 -0
- package/dist/blocks/ColorSelector/meta.js +250 -0
- package/dist/blocks/ConfigProvider/ConfigProvider.js +51 -0
- package/dist/blocks/{Alert/style.less → ConfigProvider/e2e.js} +5 -3
- package/dist/blocks/{ControlledList/schema.js → ConfigProvider/meta.js} +43 -45
- package/dist/blocks/ConfirmModal/ConfirmModal.js +45 -25
- package/dist/blocks/ConfirmModal/{schema.js → meta.js} +93 -35
- package/dist/blocks/Content/Content.js +5 -12
- package/dist/blocks/{Layout/schema.js → Content/meta.js} +11 -3
- package/dist/blocks/ControlledList/ControlledList.js +42 -54
- package/dist/blocks/ControlledList/meta.js +158 -0
- package/dist/blocks/DateRangeSelector/DateRangeSelector.js +31 -29
- package/dist/blocks/DateRangeSelector/meta.js +297 -0
- package/dist/blocks/DateSelector/DateSelector.js +28 -28
- package/dist/blocks/DateSelector/meta.js +241 -0
- package/dist/blocks/DateTimeSelector/DateTimeSelector.js +28 -28
- package/dist/blocks/DateTimeSelector/meta.js +282 -0
- package/dist/blocks/Descriptions/Descriptions.js +20 -22
- package/dist/blocks/Descriptions/{schema.js → meta.js} +71 -15
- package/dist/blocks/Divider/Divider.js +8 -14
- package/dist/blocks/Divider/meta.js +86 -0
- package/dist/blocks/Drawer/Drawer.js +21 -16
- package/dist/blocks/Drawer/{schema.js → meta.js} +61 -61
- package/dist/blocks/DropdownButton/DropdownButton.js +221 -0
- package/dist/blocks/DropdownButton/e2e.js +30 -0
- package/dist/blocks/DropdownButton/meta.js +317 -0
- package/dist/blocks/DropdownMenu/DropdownMenu.js +130 -0
- package/dist/blocks/DropdownMenu/e2e.js +28 -0
- package/dist/blocks/DropdownMenu/meta.js +322 -0
- package/dist/blocks/Flex/Flex.js +31 -0
- package/dist/blocks/{Comment → Flex}/e2e.js +1 -2
- package/dist/blocks/Flex/meta.js +115 -0
- package/dist/blocks/FloatButton/FloatButton.js +46 -0
- package/dist/blocks/FloatButton/e2e.js +28 -0
- package/dist/blocks/FloatButton/meta.js +156 -0
- package/dist/blocks/Footer/Footer.js +8 -17
- package/dist/blocks/{Header/schema.js → Footer/meta.js} +11 -12
- package/dist/blocks/Header/Header.js +38 -18
- package/dist/blocks/Header/meta.js +318 -0
- package/dist/blocks/Label/Label.js +19 -27
- package/dist/blocks/Label/labelLogic.js +37 -41
- package/dist/blocks/Label/meta.js +148 -0
- package/dist/blocks/Label/style.module.css +185 -0
- package/dist/blocks/Layout/Layout.js +10 -13
- package/dist/blocks/{Content/schema.js → Layout/meta.js} +11 -3
- package/dist/blocks/Masonry/Masonry.js +37 -0
- package/dist/blocks/{Affix/style.less → Masonry/e2e.js} +9 -3
- package/dist/blocks/Masonry/meta.js +86 -0
- package/dist/blocks/MasonryList/MasonryList.js +42 -0
- package/dist/blocks/{AutoComplete/style.less → MasonryList/e2e.js} +9 -3
- package/dist/blocks/MasonryList/meta.js +86 -0
- package/dist/blocks/Menu/Menu.js +148 -122
- package/dist/blocks/Menu/meta.js +544 -0
- package/dist/blocks/Message/Message.js +18 -16
- package/dist/blocks/Message/{schema.js → meta.js} +29 -14
- package/dist/blocks/MobileMenu/MobileMenu.js +13 -21
- package/dist/blocks/MobileMenu/{schema.js → meta.js} +17 -31
- package/dist/blocks/Modal/Modal.js +20 -16
- package/dist/blocks/Modal/meta.js +234 -0
- package/dist/blocks/MonthSelector/MonthSelector.js +30 -30
- package/dist/blocks/MonthSelector/meta.js +260 -0
- package/dist/blocks/MultipleSelector/MultipleSelector.js +49 -36
- package/dist/blocks/MultipleSelector/{schema.js → meta.js} +177 -151
- package/dist/blocks/Notification/Notification.js +39 -23
- package/dist/blocks/Notification/{schema.js → meta.js} +36 -22
- package/dist/blocks/NumberInput/NumberInput.js +12 -21
- package/dist/blocks/NumberInput/meta.js +250 -0
- package/dist/blocks/PageHeaderMenu/PageHeaderMenu.js +137 -189
- package/dist/blocks/PageHeaderMenu/meta.js +420 -0
- package/dist/blocks/PageSiderMenu/PageSiderMenu.js +151 -192
- package/dist/blocks/PageSiderMenu/meta.js +476 -0
- package/dist/blocks/Pagination/Pagination.js +6 -15
- package/dist/blocks/Pagination/meta.js +233 -0
- package/dist/blocks/Paragraph/Paragraph.js +28 -16
- package/dist/blocks/Paragraph/{schema.js → meta.js} +68 -18
- package/dist/blocks/ParagraphInput/ParagraphInput.js +34 -17
- package/dist/blocks/ParagraphInput/{schema.js → meta.js} +134 -18
- package/dist/blocks/PasswordInput/PasswordInput.js +9 -16
- package/dist/blocks/PasswordInput/meta.js +195 -0
- package/dist/blocks/PhoneNumberInput/PhoneNumberInput.js +37 -33
- package/dist/blocks/PhoneNumberInput/formatPhoneNumber.js +25 -0
- package/dist/blocks/PhoneNumberInput/meta.js +225 -0
- package/dist/blocks/PhoneNumberInput/upstream-formatting-spec.md +173 -0
- package/dist/blocks/Popover/Popover.js +7 -12
- package/dist/blocks/Popover/{schema.js → meta.js} +81 -11
- package/dist/blocks/Progress/Progress.js +7 -12
- package/dist/blocks/Progress/{schema.js → meta.js} +74 -4
- package/dist/blocks/QRCode/QRCode.js +39 -0
- package/dist/blocks/{Footer/schema.js → QRCode/e2e.js} +9 -15
- package/dist/blocks/QRCode/meta.js +152 -0
- package/dist/blocks/RadioSelector/RadioSelector.js +55 -63
- package/dist/blocks/RadioSelector/meta.js +179 -0
- package/dist/blocks/RatingSlider/RatingSlider.js +95 -103
- package/dist/blocks/RatingSlider/meta.js +221 -0
- package/dist/blocks/Result/Result.js +13 -12
- package/dist/blocks/Result/meta.js +129 -0
- package/dist/blocks/Search/Search.js +135 -0
- package/dist/blocks/Search/SearchHighlight.js +33 -0
- package/dist/blocks/Search/SearchModal.js +171 -0
- package/dist/blocks/Search/SearchResults.js +129 -0
- package/dist/blocks/Search/meta.js +258 -0
- package/dist/blocks/Search/style.module.css +96 -0
- package/dist/blocks/Search/useListKeyboardNav.js +45 -0
- package/dist/blocks/Search/useRecentSearches.js +77 -0
- package/dist/blocks/Search/useSearchIndex.js +144 -0
- package/dist/blocks/SegmentedSelector/SegmentedSelector.js +93 -0
- package/dist/blocks/SegmentedSelector/e2e.js +32 -0
- package/dist/blocks/SegmentedSelector/meta.js +222 -0
- package/dist/blocks/Selector/Selector.js +35 -30
- package/dist/blocks/Selector/meta.js +379 -0
- package/dist/blocks/Sider/Sider.js +9 -18
- package/dist/blocks/Sider/{schema.js → meta.js} +20 -34
- package/dist/blocks/Slider/Slider.js +8 -20
- package/dist/blocks/Slider/meta.js +226 -0
- package/dist/blocks/Splitter/Splitter.js +70 -0
- package/dist/blocks/Splitter/e2e.js +24 -0
- package/dist/blocks/Splitter/meta.js +193 -0
- package/dist/blocks/Statistic/Statistic.js +26 -15
- package/dist/blocks/Statistic/{schema.js → meta.js} +41 -4
- package/dist/blocks/Steps/Steps.js +94 -0
- package/dist/blocks/Steps/e2e.js +31 -0
- package/dist/blocks/Steps/meta.js +246 -0
- package/dist/blocks/Switch/Switch.js +59 -54
- package/dist/blocks/Switch/meta.js +178 -0
- package/dist/blocks/Tabs/Tabs.js +49 -18
- package/dist/blocks/Tabs/meta.js +258 -0
- package/dist/blocks/Tag/Tag.js +17 -15
- package/dist/blocks/Tag/{schema.js → meta.js} +35 -13
- package/dist/blocks/TextArea/TextArea.js +10 -16
- package/dist/blocks/TextArea/meta.js +255 -0
- package/dist/blocks/TextInput/TextInput.js +23 -18
- package/dist/blocks/TextInput/meta.js +286 -0
- package/dist/blocks/TimelineList/TimelineList.js +29 -27
- package/dist/blocks/TimelineList/{schema.js → meta.js} +45 -8
- package/dist/blocks/Title/Title.js +34 -21
- package/dist/blocks/Title/{schema.js → meta.js} +117 -14
- package/dist/blocks/TitleInput/TitleInput.js +43 -25
- package/dist/blocks/TitleInput/{schema.js → meta.js} +156 -18
- package/dist/blocks/Tooltip/Tooltip.js +16 -16
- package/dist/blocks/Tooltip/{schema.js → meta.js} +74 -19
- package/dist/blocks/Tour/Tour.js +75 -0
- package/dist/blocks/Tour/e2e.js +31 -0
- package/dist/blocks/Tour/meta.js +255 -0
- package/dist/blocks/TreeSelector/TreeSelector.js +6 -12
- package/dist/blocks/TreeSelector/{schema.js → meta.js} +134 -25
- package/dist/blocks/Watermark/Watermark.js +34 -0
- package/dist/blocks/Watermark/e2e.js +23 -0
- package/dist/blocks/Watermark/meta.js +148 -0
- package/dist/blocks/WeekSelector/WeekSelector.js +35 -31
- package/dist/blocks/WeekSelector/meta.js +269 -0
- package/dist/blocks/buildMenuItems.js +95 -0
- package/dist/blocks/headerActions.js +220 -0
- package/dist/blocks/useItemShortcuts.js +64 -0
- package/dist/blocks/withTheme.js +40 -0
- package/dist/blocks.js +16 -1
- package/dist/disabledDate.js +15 -7
- package/dist/e2e.js +4 -1
- package/dist/metas.js +91 -0
- package/dist/schemas/breadcrumbList.js +64 -0
- package/dist/schemas/disabledDates.js +83 -0
- package/dist/{blocks/Avatar/style.less → schemas/icon.js} +10 -3
- package/dist/schemas/index.js +21 -0
- package/dist/schemas/inputProperties.js +70 -0
- package/dist/schemas/label.js +62 -0
- package/dist/schemas/menuLinks.js +49 -0
- package/dist/schemas/options.js +84 -0
- package/dist/types.js +4 -18
- package/package.json +19 -17
- package/dist/blocks/Affix/schema.json +0 -34
- package/dist/blocks/Alert/schema.js +0 -84
- package/dist/blocks/Alert/schema.json +0 -62
- package/dist/blocks/AutoComplete/schema.js +0 -181
- package/dist/blocks/AutoComplete/schema.json +0 -160
- package/dist/blocks/Avatar/schema.js +0 -98
- package/dist/blocks/Avatar/schema.json +0 -71
- package/dist/blocks/Badge/schema.json +0 -70
- package/dist/blocks/Badge/style.less +0 -17
- package/dist/blocks/Breadcrumb/schema.js +0 -95
- package/dist/blocks/Breadcrumb/schema.json +0 -78
- package/dist/blocks/Breadcrumb/style.less +0 -17
- package/dist/blocks/Button/schema.js +0 -123
- package/dist/blocks/Button/schema.json +0 -91
- package/dist/blocks/Button/style.less +0 -17
- package/dist/blocks/ButtonSelector/schema.js +0 -214
- package/dist/blocks/ButtonSelector/schema.json +0 -188
- package/dist/blocks/ButtonSelector/style.less +0 -18
- package/dist/blocks/Card/schema.js +0 -75
- package/dist/blocks/Card/schema.json +0 -58
- package/dist/blocks/Card/style.less +0 -17
- package/dist/blocks/Carousel/schema.json +0 -183
- package/dist/blocks/Carousel/style.less +0 -17
- package/dist/blocks/CheckboxSelector/schema.js +0 -220
- package/dist/blocks/CheckboxSelector/schema.json +0 -193
- package/dist/blocks/CheckboxSelector/style.less +0 -19
- package/dist/blocks/CheckboxSwitch/schema.js +0 -122
- package/dist/blocks/CheckboxSwitch/schema.json +0 -105
- package/dist/blocks/CheckboxSwitch/style.less +0 -19
- package/dist/blocks/Collapse/schema.js +0 -110
- package/dist/blocks/Collapse/schema.json +0 -90
- package/dist/blocks/Collapse/style.less +0 -17
- package/dist/blocks/Comment/Comment.js +0 -56
- package/dist/blocks/Comment/schema.js +0 -56
- package/dist/blocks/Comment/schema.json +0 -39
- package/dist/blocks/Comment/style.less +0 -18
- package/dist/blocks/ConfirmModal/schema.json +0 -122
- package/dist/blocks/ConfirmModal/style.less +0 -17
- package/dist/blocks/Content/schema.json +0 -16
- package/dist/blocks/Content/style.less +0 -17
- package/dist/blocks/ControlledList/schema.json +0 -73
- package/dist/blocks/ControlledList/style.less +0 -19
- package/dist/blocks/DateRangeSelector/schema.js +0 -266
- package/dist/blocks/DateRangeSelector/schema.json +0 -221
- package/dist/blocks/DateRangeSelector/style.less +0 -18
- package/dist/blocks/DateSelector/schema.js +0 -219
- package/dist/blocks/DateSelector/schema.json +0 -183
- package/dist/blocks/DateSelector/style.less +0 -18
- package/dist/blocks/DateTimeSelector/schema.js +0 -251
- package/dist/blocks/DateTimeSelector/schema.json +0 -215
- package/dist/blocks/DateTimeSelector/style.less +0 -18
- package/dist/blocks/Descriptions/schema.json +0 -186
- package/dist/blocks/Descriptions/style.less +0 -17
- package/dist/blocks/Divider/schema.js +0 -56
- package/dist/blocks/Divider/schema.json +0 -35
- package/dist/blocks/Divider/style.less +0 -17
- package/dist/blocks/Drawer/schema.json +0 -121
- package/dist/blocks/Drawer/style.less +0 -17
- package/dist/blocks/Footer/schema.json +0 -16
- package/dist/blocks/Footer/style.less +0 -17
- package/dist/blocks/Header/schema.json +0 -22
- package/dist/blocks/Header/style.less +0 -17
- package/dist/blocks/Label/schema.js +0 -83
- package/dist/blocks/Label/schema.json +0 -62
- package/dist/blocks/Label/style.less +0 -34
- package/dist/blocks/Layout/schema.json +0 -16
- package/dist/blocks/Layout/style.less +0 -17
- package/dist/blocks/Menu/schema.js +0 -283
- package/dist/blocks/Menu/schema.json +0 -236
- package/dist/blocks/Menu/style.less +0 -17
- package/dist/blocks/Message/schema.json +0 -48
- package/dist/blocks/Message/style.less +0 -17
- package/dist/blocks/MobileMenu/schema.json +0 -236
- package/dist/blocks/MobileMenu/style.less +0 -19
- package/dist/blocks/Modal/schema.js +0 -142
- package/dist/blocks/Modal/schema.json +0 -125
- package/dist/blocks/Modal/style.less +0 -17
- package/dist/blocks/MonthSelector/schema.js +0 -219
- package/dist/blocks/MonthSelector/schema.json +0 -183
- package/dist/blocks/MonthSelector/style.less +0 -18
- package/dist/blocks/MultipleSelector/schema.json +0 -297
- package/dist/blocks/MultipleSelector/style.less +0 -19
- package/dist/blocks/Notification/schema.json +0 -85
- package/dist/blocks/Notification/style.less +0 -18
- package/dist/blocks/NumberInput/schema.js +0 -193
- package/dist/blocks/NumberInput/schema.json +0 -172
- package/dist/blocks/NumberInput/style.less +0 -18
- package/dist/blocks/PageHeaderMenu/schema.js +0 -241
- package/dist/blocks/PageHeaderMenu/schema.json +0 -215
- package/dist/blocks/PageHeaderMenu/style.less +0 -23
- package/dist/blocks/PageSiderMenu/schema.js +0 -321
- package/dist/blocks/PageSiderMenu/schema.json +0 -283
- package/dist/blocks/PageSiderMenu/style.less +0 -26
- package/dist/blocks/Pagination/schema.js +0 -101
- package/dist/blocks/Pagination/schema.json +0 -75
- package/dist/blocks/Pagination/style.less +0 -17
- package/dist/blocks/Paragraph/schema.json +0 -135
- package/dist/blocks/Paragraph/style.less +0 -18
- package/dist/blocks/ParagraphInput/schema.json +0 -162
- package/dist/blocks/ParagraphInput/style.less +0 -17
- package/dist/blocks/PasswordInput/schema.js +0 -152
- package/dist/blocks/PasswordInput/schema.json +0 -131
- package/dist/blocks/PasswordInput/style.less +0 -18
- package/dist/blocks/PhoneNumberInput/schema.js +0 -243
- package/dist/blocks/PhoneNumberInput/schema.json +0 -216
- package/dist/blocks/PhoneNumberInput/style.less +0 -33
- package/dist/blocks/Popover/schema.json +0 -86
- package/dist/blocks/Popover/style.less +0 -17
- package/dist/blocks/Progress/schema.json +0 -76
- package/dist/blocks/Progress/style.less +0 -17
- package/dist/blocks/RadioSelector/schema.js +0 -217
- package/dist/blocks/RadioSelector/schema.json +0 -190
- package/dist/blocks/RadioSelector/style.less +0 -19
- package/dist/blocks/RatingSlider/schema.js +0 -196
- package/dist/blocks/RatingSlider/schema.json +0 -169
- package/dist/blocks/RatingSlider/style.less +0 -19
- package/dist/blocks/Result/schema.js +0 -55
- package/dist/blocks/Result/schema.json +0 -30
- package/dist/blocks/Result/style.less +0 -17
- package/dist/blocks/Selector/schema.js +0 -287
- package/dist/blocks/Selector/schema.json +0 -258
- package/dist/blocks/Selector/style.less +0 -18
- package/dist/blocks/Sider/schema.json +0 -71
- package/dist/blocks/Sider/style.less +0 -17
- package/dist/blocks/Slider/style.less +0 -18
- package/dist/blocks/Statistic/schema.json +0 -74
- package/dist/blocks/Statistic/style.less +0 -17
- package/dist/blocks/Switch/schema.js +0 -162
- package/dist/blocks/Switch/schema.json +0 -136
- package/dist/blocks/Switch/style.less +0 -18
- package/dist/blocks/Tabs/schema.js +0 -124
- package/dist/blocks/Tabs/schema.json +0 -93
- package/dist/blocks/Tabs/style.less +0 -17
- package/dist/blocks/Tag/schema.json +0 -45
- package/dist/blocks/Tag/style.less +0 -17
- package/dist/blocks/TextArea/schema.js +0 -196
- package/dist/blocks/TextArea/schema.json +0 -172
- package/dist/blocks/TextArea/style.less +0 -18
- package/dist/blocks/TextInput/schema.js +0 -223
- package/dist/blocks/TextInput/schema.json +0 -189
- package/dist/blocks/TextInput/style.less +0 -18
- package/dist/blocks/TimelineList/schema.json +0 -65
- package/dist/blocks/TimelineList/style.less +0 -17
- package/dist/blocks/Title/schema.json +0 -136
- package/dist/blocks/Title/style.less +0 -18
- package/dist/blocks/TitleInput/schema.json +0 -171
- package/dist/blocks/TitleInput/style.less +0 -17
- package/dist/blocks/Tooltip/schema.json +0 -91
- package/dist/blocks/Tooltip/style.less +0 -17
- package/dist/blocks/TreeSelector/schema.json +0 -166
- package/dist/blocks/TreeSelector/style.less +0 -27
- package/dist/blocks/WeekSelector/schema.js +0 -219
- package/dist/blocks/WeekSelector/schema.json +0 -183
- package/dist/blocks/WeekSelector/style.less +0 -18
- package/dist/color.js +0 -85
- package/dist/schemas.js +0 -75
- package/dist/style.less +0 -17
|
@@ -13,17 +13,59 @@
|
|
|
13
13
|
See the License for the specific language governing permissions and
|
|
14
14
|
limitations under the License.
|
|
15
15
|
*/ import React from 'react';
|
|
16
|
-
import { Radio, Space } from 'antd';
|
|
17
|
-
import {
|
|
16
|
+
import { ConfigProvider, Radio, Space } from 'antd';
|
|
17
|
+
import { renderHtml, withBlockDefaults } from '@lowdefy/block-utils';
|
|
18
18
|
import { type } from '@lowdefy/helpers';
|
|
19
19
|
import Label from '../Label/Label.js';
|
|
20
20
|
import getValueIndex from '../../getValueIndex.js';
|
|
21
21
|
import getUniqueValues from '../../getUniqueValues.js';
|
|
22
|
+
import withTheme from '../withTheme.js';
|
|
22
23
|
const RadioGroup = Radio.Group;
|
|
23
|
-
const RadioSelector = ({ blockId, components, events, loading, properties, required, validation, value, methods })=>{
|
|
24
|
+
const RadioSelector = ({ blockId, classNames = {}, components, events, loading, properties, required, styles = {}, validation, value, methods })=>{
|
|
24
25
|
const uniqueValueOptions = getUniqueValues(properties.options || []);
|
|
26
|
+
const radioGroup = /*#__PURE__*/ React.createElement(RadioGroup, {
|
|
27
|
+
id: `${blockId}_input`,
|
|
28
|
+
className: classNames.element,
|
|
29
|
+
disabled: properties.disabled || loading,
|
|
30
|
+
style: styles.element,
|
|
31
|
+
onChange: (event)=>{
|
|
32
|
+
const val = type.isPrimitive(uniqueValueOptions[event.target.value]) ? uniqueValueOptions[event.target.value] : uniqueValueOptions[event.target.value].value;
|
|
33
|
+
methods.setValue(val);
|
|
34
|
+
methods.triggerEvent({
|
|
35
|
+
name: 'onChange',
|
|
36
|
+
event: {
|
|
37
|
+
value: val
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
},
|
|
41
|
+
value: `${getValueIndex(value, uniqueValueOptions)}`
|
|
42
|
+
}, /*#__PURE__*/ React.createElement(Space, {
|
|
43
|
+
direction: properties.direction,
|
|
44
|
+
wrap: type.isNone(properties.wrap) ? true : properties.wrap,
|
|
45
|
+
align: type.isNone(properties.align) ? 'start' : properties.align
|
|
46
|
+
}, uniqueValueOptions.map((opt, i)=>type.isPrimitive(opt) ? /*#__PURE__*/ React.createElement(Radio, {
|
|
47
|
+
id: `${blockId}_${opt}`,
|
|
48
|
+
key: i,
|
|
49
|
+
value: `${i}`
|
|
50
|
+
}, renderHtml({
|
|
51
|
+
html: `${opt}`,
|
|
52
|
+
methods
|
|
53
|
+
})) : /*#__PURE__*/ React.createElement(Radio, {
|
|
54
|
+
id: `${blockId}_${i}`,
|
|
55
|
+
key: i,
|
|
56
|
+
value: `${i}`,
|
|
57
|
+
disabled: opt.disabled,
|
|
58
|
+
style: opt.style
|
|
59
|
+
}, type.isNone(opt.label) ? renderHtml({
|
|
60
|
+
html: `${opt.value}`,
|
|
61
|
+
methods
|
|
62
|
+
}) : renderHtml({
|
|
63
|
+
html: opt.label,
|
|
64
|
+
methods
|
|
65
|
+
})))));
|
|
25
66
|
return /*#__PURE__*/ React.createElement(Label, {
|
|
26
67
|
blockId: blockId,
|
|
68
|
+
classNames: classNames,
|
|
27
69
|
components: components,
|
|
28
70
|
events: events,
|
|
29
71
|
properties: {
|
|
@@ -33,68 +75,18 @@ const RadioSelector = ({ blockId, components, events, loading, properties, requi
|
|
|
33
75
|
},
|
|
34
76
|
validation: validation,
|
|
35
77
|
required: required,
|
|
78
|
+
styles: styles,
|
|
36
79
|
content: {
|
|
37
|
-
content: ()
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
borderColor: `${properties.color} !important`,
|
|
43
|
-
'&:after': {
|
|
44
|
-
backgroundColor: `${properties.color} !important`
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
},
|
|
48
|
-
properties.inputStyle
|
|
49
|
-
]),
|
|
50
|
-
disabled: properties.disabled || loading,
|
|
51
|
-
onChange: (event)=>{
|
|
52
|
-
const val = type.isPrimitive(uniqueValueOptions[event.target.value]) ? uniqueValueOptions[event.target.value] : uniqueValueOptions[event.target.value].value;
|
|
53
|
-
methods.setValue(val);
|
|
54
|
-
methods.triggerEvent({
|
|
55
|
-
name: 'onChange',
|
|
56
|
-
event: {
|
|
57
|
-
value: val
|
|
80
|
+
content: ()=>properties.color ? /*#__PURE__*/ React.createElement(ConfigProvider, {
|
|
81
|
+
theme: {
|
|
82
|
+
components: {
|
|
83
|
+
Radio: {
|
|
84
|
+
colorPrimary: properties.color
|
|
58
85
|
}
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
}, /*#__PURE__*/ React.createElement(Space, {
|
|
63
|
-
direction: properties.direction,
|
|
64
|
-
wrap: type.isNone(properties.wrap) ? true : properties.wrap,
|
|
65
|
-
align: type.isNone(properties.align) ? 'start' : properties.align
|
|
66
|
-
}, uniqueValueOptions.map((opt, i)=>type.isPrimitive(opt) ? /*#__PURE__*/ React.createElement(Radio, {
|
|
67
|
-
id: `${blockId}_${opt}`,
|
|
68
|
-
key: i,
|
|
69
|
-
value: `${i}`
|
|
70
|
-
}, renderHtml({
|
|
71
|
-
html: `${opt}`,
|
|
72
|
-
methods
|
|
73
|
-
})) : /*#__PURE__*/ React.createElement(Radio, {
|
|
74
|
-
id: `${blockId}_${i}`,
|
|
75
|
-
key: i,
|
|
76
|
-
value: `${i}`,
|
|
77
|
-
disabled: opt.disabled,
|
|
78
|
-
className: methods.makeCssClass(opt.style)
|
|
79
|
-
}, type.isNone(opt.label) ? renderHtml({
|
|
80
|
-
html: `${opt.value}`,
|
|
81
|
-
methods
|
|
82
|
-
}) : renderHtml({
|
|
83
|
-
html: opt.label,
|
|
84
|
-
methods
|
|
85
|
-
})))))
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}, radioGroup) : radioGroup
|
|
86
89
|
}
|
|
87
90
|
});
|
|
88
91
|
};
|
|
89
|
-
|
|
90
|
-
RadioSelector.meta = {
|
|
91
|
-
valueType: 'any',
|
|
92
|
-
category: 'input',
|
|
93
|
-
icons: [
|
|
94
|
-
...Label.meta.icons
|
|
95
|
-
],
|
|
96
|
-
styles: [
|
|
97
|
-
'blocks/RadioSelector/style.less'
|
|
98
|
-
]
|
|
99
|
-
};
|
|
100
|
-
export default RadioSelector;
|
|
92
|
+
export default withTheme('Radio', withBlockDefaults(RadioSelector));
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Copyright 2020-2026 Lowdefy, Inc
|
|
3
|
+
|
|
4
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
you may not use this file except in compliance with the License.
|
|
6
|
+
You may obtain a copy of the License at
|
|
7
|
+
|
|
8
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
|
|
10
|
+
Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
See the License for the specific language governing permissions and
|
|
14
|
+
limitations under the License.
|
|
15
|
+
*/ import LabelMeta from '../Label/meta.js';
|
|
16
|
+
import label from '../../schemas/label.js';
|
|
17
|
+
import options from '../../schemas/options.js';
|
|
18
|
+
import { disabled, inputTitle } from '../../schemas/inputProperties.js';
|
|
19
|
+
export default {
|
|
20
|
+
category: 'input',
|
|
21
|
+
icons: [
|
|
22
|
+
...LabelMeta.icons
|
|
23
|
+
],
|
|
24
|
+
valueType: 'any',
|
|
25
|
+
cssKeys: {
|
|
26
|
+
element: 'The RadioSelector element.',
|
|
27
|
+
label: 'The RadioSelector label.',
|
|
28
|
+
extra: 'The RadioSelector extra content.',
|
|
29
|
+
feedback: 'The RadioSelector validation feedback.'
|
|
30
|
+
},
|
|
31
|
+
events: {
|
|
32
|
+
onChange: {
|
|
33
|
+
description: 'Trigger action when selection is changed.',
|
|
34
|
+
event: {
|
|
35
|
+
value: 'The selected value.'
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
properties: {
|
|
40
|
+
type: 'object',
|
|
41
|
+
additionalProperties: false,
|
|
42
|
+
properties: {
|
|
43
|
+
align: {
|
|
44
|
+
type: 'string',
|
|
45
|
+
enum: [
|
|
46
|
+
'start',
|
|
47
|
+
'end',
|
|
48
|
+
'center',
|
|
49
|
+
'baseline'
|
|
50
|
+
],
|
|
51
|
+
default: 'start',
|
|
52
|
+
description: 'Align options.'
|
|
53
|
+
},
|
|
54
|
+
color: {
|
|
55
|
+
type: 'string',
|
|
56
|
+
description: 'Selected radio color.',
|
|
57
|
+
docs: {
|
|
58
|
+
displayType: 'color'
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
disabled,
|
|
62
|
+
direction: {
|
|
63
|
+
type: 'string',
|
|
64
|
+
enum: [
|
|
65
|
+
'horizontal',
|
|
66
|
+
'vertical'
|
|
67
|
+
],
|
|
68
|
+
default: 'horizontal',
|
|
69
|
+
description: 'List options horizontally or vertical.'
|
|
70
|
+
},
|
|
71
|
+
wrap: {
|
|
72
|
+
type: 'boolean',
|
|
73
|
+
default: true,
|
|
74
|
+
description: "Specifies wrapping of options. Applies when 'direction' is 'horizontal'."
|
|
75
|
+
},
|
|
76
|
+
label,
|
|
77
|
+
options,
|
|
78
|
+
title: inputTitle,
|
|
79
|
+
theme: {
|
|
80
|
+
type: 'object',
|
|
81
|
+
description: 'Antd design token overrides for this block. See <a href="https://ant.design/components/overview#design-token">antd design tokens</a>.',
|
|
82
|
+
docs: {
|
|
83
|
+
displayType: 'yaml',
|
|
84
|
+
link: 'https://ant.design/components/radio#design-token'
|
|
85
|
+
},
|
|
86
|
+
properties: {
|
|
87
|
+
radioSize: {
|
|
88
|
+
type: 'number',
|
|
89
|
+
default: 16,
|
|
90
|
+
description: 'Size of the radio button circle.'
|
|
91
|
+
},
|
|
92
|
+
dotSize: {
|
|
93
|
+
type: 'number',
|
|
94
|
+
default: 6,
|
|
95
|
+
description: 'Size of the inner dot indicator.'
|
|
96
|
+
},
|
|
97
|
+
dotColorDisabled: {
|
|
98
|
+
type: 'string',
|
|
99
|
+
default: 'rgba(0, 0, 0, 0.25)',
|
|
100
|
+
description: 'Dot color when the radio is disabled.'
|
|
101
|
+
},
|
|
102
|
+
colorPrimary: {
|
|
103
|
+
type: 'string',
|
|
104
|
+
description: 'Primary color for the selected radio button.'
|
|
105
|
+
},
|
|
106
|
+
colorBorder: {
|
|
107
|
+
type: 'string',
|
|
108
|
+
description: 'Border color of the radio button circle.'
|
|
109
|
+
},
|
|
110
|
+
colorBgContainer: {
|
|
111
|
+
type: 'string',
|
|
112
|
+
description: 'Background color of the radio button circle.'
|
|
113
|
+
},
|
|
114
|
+
wrapperMarginInlineEnd: {
|
|
115
|
+
type: 'number',
|
|
116
|
+
default: 8,
|
|
117
|
+
description: 'Right margin of the radio wrapper.'
|
|
118
|
+
},
|
|
119
|
+
radioColor: {
|
|
120
|
+
type: 'string',
|
|
121
|
+
default: '#fff',
|
|
122
|
+
description: 'Color of the radio indicator dot when selected.'
|
|
123
|
+
},
|
|
124
|
+
radioBgColor: {
|
|
125
|
+
type: 'string',
|
|
126
|
+
description: 'Background color of the radio circle when selected.'
|
|
127
|
+
},
|
|
128
|
+
buttonBg: {
|
|
129
|
+
type: 'string',
|
|
130
|
+
default: '#ffffff',
|
|
131
|
+
description: 'Background color for button-style radio.'
|
|
132
|
+
},
|
|
133
|
+
buttonCheckedBg: {
|
|
134
|
+
type: 'string',
|
|
135
|
+
default: '#ffffff',
|
|
136
|
+
description: 'Background color for checked button-style radio.'
|
|
137
|
+
},
|
|
138
|
+
buttonColor: {
|
|
139
|
+
type: 'string',
|
|
140
|
+
default: 'rgba(0, 0, 0, 0.88)',
|
|
141
|
+
description: 'Text color for button-style radio.'
|
|
142
|
+
},
|
|
143
|
+
buttonPaddingInline: {
|
|
144
|
+
type: 'number',
|
|
145
|
+
default: 15,
|
|
146
|
+
description: 'Horizontal padding for button-style radio.'
|
|
147
|
+
},
|
|
148
|
+
buttonCheckedBgDisabled: {
|
|
149
|
+
type: 'string',
|
|
150
|
+
default: 'rgba(0, 0, 0, 0.15)',
|
|
151
|
+
description: 'Background color for disabled checked button-style radio.'
|
|
152
|
+
},
|
|
153
|
+
buttonCheckedColorDisabled: {
|
|
154
|
+
type: 'string',
|
|
155
|
+
default: 'rgba(0, 0, 0, 0.25)',
|
|
156
|
+
description: 'Text color for disabled checked button-style radio.'
|
|
157
|
+
},
|
|
158
|
+
buttonSolidCheckedColor: {
|
|
159
|
+
type: 'string',
|
|
160
|
+
default: '#fff',
|
|
161
|
+
description: 'Text color for solid button-style radio when checked.'
|
|
162
|
+
},
|
|
163
|
+
buttonSolidCheckedBg: {
|
|
164
|
+
type: 'string',
|
|
165
|
+
description: 'Background color for solid button-style radio when checked.'
|
|
166
|
+
},
|
|
167
|
+
buttonSolidCheckedHoverBg: {
|
|
168
|
+
type: 'string',
|
|
169
|
+
description: 'Hover background for solid button-style radio when checked.'
|
|
170
|
+
},
|
|
171
|
+
buttonSolidCheckedActiveBg: {
|
|
172
|
+
type: 'string',
|
|
173
|
+
description: 'Active background for solid button-style radio when checked.'
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
};
|
|
@@ -13,12 +13,12 @@
|
|
|
13
13
|
See the License for the specific language governing permissions and
|
|
14
14
|
limitations under the License.
|
|
15
15
|
*/ import React, { useState } from 'react';
|
|
16
|
-
import { blockDefaultProps } from '@lowdefy/block-utils';
|
|
17
16
|
import { get, mergeObjects, serializer, type } from '@lowdefy/helpers';
|
|
18
|
-
import { Slider } from 'antd';
|
|
19
|
-
import
|
|
17
|
+
import { ConfigProvider, Slider } from 'antd';
|
|
18
|
+
import { withBlockDefaults } from '@lowdefy/block-utils';
|
|
20
19
|
import CheckboxSelector from '../CheckboxSelector/CheckboxSelector.js';
|
|
21
20
|
import Label from '../Label/Label.js';
|
|
21
|
+
import withTheme from '../withTheme.js';
|
|
22
22
|
const includeMarks = (minMax, minMin, step = 1)=>{
|
|
23
23
|
const marks = {};
|
|
24
24
|
marks[minMin] = {
|
|
@@ -40,30 +40,7 @@ const includeMarks = (minMax, minMin, step = 1)=>{
|
|
|
40
40
|
}
|
|
41
41
|
return marks;
|
|
42
42
|
};
|
|
43
|
-
const styles = {
|
|
44
|
-
iconLeft: {
|
|
45
|
-
flex: '0 0 1',
|
|
46
|
-
fontSize: '20px',
|
|
47
|
-
padding: '6px 6px 0 0'
|
|
48
|
-
},
|
|
49
|
-
iconRight: {
|
|
50
|
-
flex: '0 0 1',
|
|
51
|
-
fontSize: '20px',
|
|
52
|
-
padding: '6px 0 0 6px'
|
|
53
|
-
},
|
|
54
|
-
checkbox: {
|
|
55
|
-
flex: '0 0 1',
|
|
56
|
-
paddingTop: 6
|
|
57
|
-
},
|
|
58
|
-
slider: {
|
|
59
|
-
flex: 'auto'
|
|
60
|
-
},
|
|
61
|
-
content: {
|
|
62
|
-
display: 'flex',
|
|
63
|
-
flexDirection: 'row'
|
|
64
|
-
}
|
|
65
|
-
};
|
|
66
|
-
const RatingSlider = ({ blockId, components: { Icon, Link }, events, loading, methods, properties, required, validation, value })=>{
|
|
43
|
+
const RatingSlider = ({ blockId, classNames = {}, components: { Icon, Link }, events, loading, methods, properties, required, styles = {}, validation, value })=>{
|
|
67
44
|
const [check, unCheck] = useState(false);
|
|
68
45
|
let propertiesIconMin = serializer.copy(properties.minIcon);
|
|
69
46
|
if (type.isString(propertiesIconMin)) {
|
|
@@ -85,9 +62,58 @@ const RatingSlider = ({ blockId, components: { Icon, Link }, events, loading, me
|
|
|
85
62
|
].sort((a, b)=>a - b);
|
|
86
63
|
// round to fix floating point error
|
|
87
64
|
const minMin = parseFloat((minMax[0] - (properties.step ?? 1)).toPrecision(8));
|
|
88
|
-
const validationColor = validation
|
|
65
|
+
const validationColor = validation?.status === 'error' ? '#ff4d4f' : validation?.status === 'warning' ? '#faad14' : null;
|
|
66
|
+
const sliderTheme = {};
|
|
67
|
+
if (properties.color) {
|
|
68
|
+
sliderTheme.colorPrimary = properties.color;
|
|
69
|
+
}
|
|
70
|
+
if (validationColor) {
|
|
71
|
+
sliderTheme.railBg = validationColor;
|
|
72
|
+
}
|
|
73
|
+
const hasSliderTheme = Object.keys(sliderTheme).length > 0;
|
|
74
|
+
const slider = /*#__PURE__*/ React.createElement(Slider, {
|
|
75
|
+
id: `${blockId}_input`,
|
|
76
|
+
className: classNames.element,
|
|
77
|
+
components: {
|
|
78
|
+
Icon,
|
|
79
|
+
Link
|
|
80
|
+
},
|
|
81
|
+
events: events,
|
|
82
|
+
autoFocus: properties.autoFocus,
|
|
83
|
+
disabled: properties.disabled || check === true && !properties.disableNotApplicable || loading,
|
|
84
|
+
dots: get(properties, 'showDots', {
|
|
85
|
+
default: true
|
|
86
|
+
}),
|
|
87
|
+
tooltip: {
|
|
88
|
+
open: value === null || properties.tooltipVisible === 'never' ? false : properties.tooltipVisible === 'always' ? true : undefined,
|
|
89
|
+
formatter: (val)=>`${val}`
|
|
90
|
+
},
|
|
91
|
+
marks: properties.marks ?? (get(properties, 'showMarks', {
|
|
92
|
+
default: true
|
|
93
|
+
}) ? includeMarks(minMax, minMin, properties.step ?? 1) : undefined),
|
|
94
|
+
min: minMin,
|
|
95
|
+
max: minMax[1],
|
|
96
|
+
range: false,
|
|
97
|
+
step: properties.step ?? 1,
|
|
98
|
+
style: {
|
|
99
|
+
flex: 'auto',
|
|
100
|
+
...styles.element
|
|
101
|
+
},
|
|
102
|
+
onChange: (val)=>{
|
|
103
|
+
const v = val === minMin ? null : val;
|
|
104
|
+
methods.setValue(v);
|
|
105
|
+
methods.triggerEvent({
|
|
106
|
+
name: 'onChange',
|
|
107
|
+
event: {
|
|
108
|
+
value: v
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
},
|
|
112
|
+
value: value === null ? minMin : value
|
|
113
|
+
});
|
|
89
114
|
return /*#__PURE__*/ React.createElement(Label, {
|
|
90
115
|
blockId: blockId,
|
|
116
|
+
classNames: classNames,
|
|
91
117
|
components: {
|
|
92
118
|
Icon,
|
|
93
119
|
Link
|
|
@@ -100,15 +126,15 @@ const RatingSlider = ({ blockId, components: { Icon, Link }, events, loading, me
|
|
|
100
126
|
...properties.label
|
|
101
127
|
},
|
|
102
128
|
required: required,
|
|
129
|
+
styles: styles,
|
|
103
130
|
validation: validation,
|
|
104
131
|
content: {
|
|
105
132
|
content: ()=>/*#__PURE__*/ React.createElement("div", {
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
])
|
|
133
|
+
style: {
|
|
134
|
+
display: 'flex',
|
|
135
|
+
flexDirection: 'row',
|
|
136
|
+
paddingRight: validation?.status ? 30 : undefined
|
|
137
|
+
}
|
|
112
138
|
}, !required && !properties.disableNotApplicable && /*#__PURE__*/ React.createElement(CheckboxSelector, {
|
|
113
139
|
blockId: `${blockId}_checkbox_selector`,
|
|
114
140
|
components: {
|
|
@@ -131,7 +157,10 @@ const RatingSlider = ({ blockId, components: { Icon, Link }, events, loading, me
|
|
|
131
157
|
},
|
|
132
158
|
properties.CheckboxInput,
|
|
133
159
|
{
|
|
134
|
-
style:
|
|
160
|
+
style: {
|
|
161
|
+
flex: '0 0 1',
|
|
162
|
+
paddingTop: 6
|
|
163
|
+
}
|
|
135
164
|
}
|
|
136
165
|
]),
|
|
137
166
|
methods: {
|
|
@@ -150,91 +179,54 @@ const RatingSlider = ({ blockId, components: { Icon, Link }, events, loading, me
|
|
|
150
179
|
]
|
|
151
180
|
}), !properties.disableIcons && /*#__PURE__*/ React.createElement(Icon, {
|
|
152
181
|
blockId: `${blockId}_iconMin`,
|
|
182
|
+
classNames: {
|
|
183
|
+
element: classNames.minIcon
|
|
184
|
+
},
|
|
153
185
|
events: events,
|
|
154
186
|
properties: mergeObjects([
|
|
155
187
|
{
|
|
156
188
|
name: 'AiOutlineFrown',
|
|
157
|
-
style: styles.iconLeft,
|
|
158
189
|
color: properties.color
|
|
159
190
|
},
|
|
160
191
|
propertiesIconMin
|
|
161
|
-
])
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
events: events,
|
|
169
|
-
className: classNames(methods.makeCssClass([
|
|
170
|
-
properties.color && {
|
|
171
|
-
'& > div.ant-slider-track': {
|
|
172
|
-
backgroundColor: `${properties.color} !important`
|
|
173
|
-
},
|
|
174
|
-
'& > div.ant-slider-handle': {
|
|
175
|
-
borderColor: `${properties.color} !important`
|
|
176
|
-
},
|
|
177
|
-
'& > div.ant-slider-step > span.ant-slider-dot-active': {
|
|
178
|
-
borderColor: `${properties.color} !important`
|
|
179
|
-
}
|
|
180
|
-
},
|
|
181
|
-
validationColor && {
|
|
182
|
-
'& > div.ant-slider-rail': {
|
|
183
|
-
backgroundColor: `${validationColor} !important`
|
|
184
|
-
}
|
|
192
|
+
]),
|
|
193
|
+
styles: {
|
|
194
|
+
element: {
|
|
195
|
+
flex: '0 0 1',
|
|
196
|
+
fontSize: '20px',
|
|
197
|
+
padding: '6px 6px 0 0',
|
|
198
|
+
...styles.minIcon
|
|
185
199
|
}
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
marks: properties.marks ?? (get(properties, 'showMarks', {
|
|
195
|
-
default: true
|
|
196
|
-
}) ? includeMarks(minMax, minMin, properties.step ?? 1) : undefined),
|
|
197
|
-
min: minMin,
|
|
198
|
-
max: minMax[1],
|
|
199
|
-
range: false,
|
|
200
|
-
step: properties.step ?? 1,
|
|
201
|
-
onChange: (val)=>{
|
|
202
|
-
const v = val === minMin ? null : val;
|
|
203
|
-
methods.setValue(v);
|
|
204
|
-
methods.triggerEvent({
|
|
205
|
-
name: 'onChange',
|
|
206
|
-
event: {
|
|
207
|
-
value: v
|
|
208
|
-
}
|
|
209
|
-
});
|
|
210
|
-
},
|
|
211
|
-
value: value === null ? minMin : value
|
|
212
|
-
}), !properties.disableIcons && /*#__PURE__*/ React.createElement(Icon, {
|
|
200
|
+
}
|
|
201
|
+
}), hasSliderTheme ? /*#__PURE__*/ React.createElement(ConfigProvider, {
|
|
202
|
+
theme: {
|
|
203
|
+
components: {
|
|
204
|
+
Slider: sliderTheme
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}, slider) : slider, !properties.disableIcons && /*#__PURE__*/ React.createElement(Icon, {
|
|
213
208
|
blockId: `${blockId}_iconMax`,
|
|
209
|
+
classNames: {
|
|
210
|
+
element: classNames.maxIcon
|
|
211
|
+
},
|
|
214
212
|
events: events,
|
|
215
213
|
properties: mergeObjects([
|
|
216
214
|
{
|
|
217
215
|
name: 'AiOutlineSmile',
|
|
218
|
-
style: styles.iconRight,
|
|
219
216
|
color: properties.color
|
|
220
217
|
},
|
|
221
218
|
propertiesIconMax
|
|
222
|
-
])
|
|
219
|
+
]),
|
|
220
|
+
styles: {
|
|
221
|
+
element: {
|
|
222
|
+
flex: '0 0 1',
|
|
223
|
+
fontSize: '20px',
|
|
224
|
+
padding: '6px 0 0 6px',
|
|
225
|
+
...styles.maxIcon
|
|
226
|
+
}
|
|
227
|
+
}
|
|
223
228
|
}))
|
|
224
229
|
}
|
|
225
230
|
});
|
|
226
231
|
};
|
|
227
|
-
|
|
228
|
-
RatingSlider.meta = {
|
|
229
|
-
valueType: 'any',
|
|
230
|
-
category: 'input',
|
|
231
|
-
icons: [
|
|
232
|
-
...Label.meta.icons,
|
|
233
|
-
'AiOutlineFrown',
|
|
234
|
-
'AiOutlineSmile'
|
|
235
|
-
],
|
|
236
|
-
styles: [
|
|
237
|
-
'blocks/RatingSlider/style.less'
|
|
238
|
-
]
|
|
239
|
-
};
|
|
240
|
-
export default RatingSlider;
|
|
232
|
+
export default withTheme('Slider', withBlockDefaults(RatingSlider));
|