@lowdefy/blocks-antd 4.7.3 → 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
|
@@ -0,0 +1,317 @@
|
|
|
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
|
+
*/ export default {
|
|
16
|
+
category: 'display',
|
|
17
|
+
icons: [],
|
|
18
|
+
valueType: null,
|
|
19
|
+
cssKeys: {
|
|
20
|
+
element: 'The outer container.',
|
|
21
|
+
button: 'The trigger button.',
|
|
22
|
+
icon: 'The icon in the button.',
|
|
23
|
+
menu: 'The floating menu container.',
|
|
24
|
+
item: 'Individual menu items.',
|
|
25
|
+
itemIcon: 'Icon within menu items.',
|
|
26
|
+
arrow: 'Dropdown arrow indicator.'
|
|
27
|
+
},
|
|
28
|
+
events: {
|
|
29
|
+
onClick: 'Trigger action when the button is clicked (split mode).',
|
|
30
|
+
onOpenChange: 'Trigger action when dropdown opens or closes.'
|
|
31
|
+
},
|
|
32
|
+
properties: {
|
|
33
|
+
type: 'object',
|
|
34
|
+
additionalProperties: false,
|
|
35
|
+
properties: {
|
|
36
|
+
title: {
|
|
37
|
+
type: 'string',
|
|
38
|
+
description: 'Button label text.'
|
|
39
|
+
},
|
|
40
|
+
icon: {
|
|
41
|
+
type: [
|
|
42
|
+
'string',
|
|
43
|
+
'object'
|
|
44
|
+
],
|
|
45
|
+
description: 'Name of a React-Icon or properties of an Icon block to use icon in button.',
|
|
46
|
+
docs: {
|
|
47
|
+
displayType: 'icon'
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
type: {
|
|
51
|
+
type: 'string',
|
|
52
|
+
enum: [
|
|
53
|
+
'primary',
|
|
54
|
+
'default',
|
|
55
|
+
'dashed',
|
|
56
|
+
'text',
|
|
57
|
+
'link'
|
|
58
|
+
],
|
|
59
|
+
default: 'default',
|
|
60
|
+
description: 'Deprecated - use color and variant instead. The button type.'
|
|
61
|
+
},
|
|
62
|
+
color: {
|
|
63
|
+
type: 'string',
|
|
64
|
+
description: 'Button color. Preset values: default, primary, danger, blue, purple, cyan, green, magenta, pink, red, orange, yellow, volcano, geekblue, lime, gold. Also accepts custom hex color strings.',
|
|
65
|
+
docs: {
|
|
66
|
+
displayType: 'color'
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
variant: {
|
|
70
|
+
type: 'string',
|
|
71
|
+
enum: [
|
|
72
|
+
'solid',
|
|
73
|
+
'outlined',
|
|
74
|
+
'dashed',
|
|
75
|
+
'filled',
|
|
76
|
+
'text',
|
|
77
|
+
'link'
|
|
78
|
+
],
|
|
79
|
+
description: 'Button visual variant. When set, takes precedence over type.'
|
|
80
|
+
},
|
|
81
|
+
size: {
|
|
82
|
+
type: 'string',
|
|
83
|
+
enum: [
|
|
84
|
+
'small',
|
|
85
|
+
'middle',
|
|
86
|
+
'large'
|
|
87
|
+
],
|
|
88
|
+
default: 'middle',
|
|
89
|
+
description: 'Button size.'
|
|
90
|
+
},
|
|
91
|
+
shape: {
|
|
92
|
+
type: 'string',
|
|
93
|
+
enum: [
|
|
94
|
+
'circle',
|
|
95
|
+
'round',
|
|
96
|
+
'square'
|
|
97
|
+
],
|
|
98
|
+
default: 'square',
|
|
99
|
+
description: 'Shape of the button.'
|
|
100
|
+
},
|
|
101
|
+
danger: {
|
|
102
|
+
type: 'boolean',
|
|
103
|
+
default: false,
|
|
104
|
+
description: 'Set button style to danger.'
|
|
105
|
+
},
|
|
106
|
+
ghost: {
|
|
107
|
+
type: 'boolean',
|
|
108
|
+
default: false,
|
|
109
|
+
description: "Make the button's background transparent."
|
|
110
|
+
},
|
|
111
|
+
disabled: {
|
|
112
|
+
type: 'boolean',
|
|
113
|
+
default: false,
|
|
114
|
+
description: 'Disable the entire dropdown.'
|
|
115
|
+
},
|
|
116
|
+
trigger: {
|
|
117
|
+
type: 'string',
|
|
118
|
+
enum: [
|
|
119
|
+
'click',
|
|
120
|
+
'hover'
|
|
121
|
+
],
|
|
122
|
+
default: 'click',
|
|
123
|
+
description: 'How the dropdown opens.'
|
|
124
|
+
},
|
|
125
|
+
placement: {
|
|
126
|
+
type: 'string',
|
|
127
|
+
enum: [
|
|
128
|
+
'bottomLeft',
|
|
129
|
+
'bottom',
|
|
130
|
+
'bottomRight',
|
|
131
|
+
'topLeft',
|
|
132
|
+
'top',
|
|
133
|
+
'topRight'
|
|
134
|
+
],
|
|
135
|
+
default: 'bottomRight',
|
|
136
|
+
description: 'Dropdown position.'
|
|
137
|
+
},
|
|
138
|
+
arrow: {
|
|
139
|
+
anyOf: [
|
|
140
|
+
{
|
|
141
|
+
type: 'boolean'
|
|
142
|
+
},
|
|
143
|
+
{
|
|
144
|
+
type: 'object',
|
|
145
|
+
properties: {
|
|
146
|
+
pointAtCenter: {
|
|
147
|
+
type: 'boolean'
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
],
|
|
152
|
+
default: false,
|
|
153
|
+
description: 'Show arrow pointing to trigger.',
|
|
154
|
+
docs: {
|
|
155
|
+
displayType: 'switch'
|
|
156
|
+
}
|
|
157
|
+
},
|
|
158
|
+
split: {
|
|
159
|
+
type: 'boolean',
|
|
160
|
+
default: false,
|
|
161
|
+
description: 'Split button mode. Left button fires onClick, right arrow opens dropdown.'
|
|
162
|
+
},
|
|
163
|
+
items: {
|
|
164
|
+
type: 'array',
|
|
165
|
+
description: 'Menu items. Each with an eventName that triggers a named event.',
|
|
166
|
+
items: {
|
|
167
|
+
type: 'object',
|
|
168
|
+
properties: {
|
|
169
|
+
title: {
|
|
170
|
+
type: 'string',
|
|
171
|
+
description: 'Display text.'
|
|
172
|
+
},
|
|
173
|
+
eventName: {
|
|
174
|
+
type: 'string',
|
|
175
|
+
description: 'Event name to trigger when clicked.'
|
|
176
|
+
},
|
|
177
|
+
icon: {
|
|
178
|
+
type: [
|
|
179
|
+
'string',
|
|
180
|
+
'object'
|
|
181
|
+
],
|
|
182
|
+
description: 'Icon name or config.',
|
|
183
|
+
docs: {
|
|
184
|
+
displayType: 'icon'
|
|
185
|
+
}
|
|
186
|
+
},
|
|
187
|
+
danger: {
|
|
188
|
+
type: 'boolean',
|
|
189
|
+
description: 'Red danger styling.'
|
|
190
|
+
},
|
|
191
|
+
disabled: {
|
|
192
|
+
type: 'boolean',
|
|
193
|
+
description: 'Disable this item.'
|
|
194
|
+
},
|
|
195
|
+
type: {
|
|
196
|
+
type: 'string',
|
|
197
|
+
enum: [
|
|
198
|
+
'divider'
|
|
199
|
+
],
|
|
200
|
+
description: 'Set to divider for a separator.'
|
|
201
|
+
},
|
|
202
|
+
shortcut: {
|
|
203
|
+
type: 'string',
|
|
204
|
+
description: 'Keyboard shortcut. Binds the key and renders the badge.'
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
},
|
|
209
|
+
theme: {
|
|
210
|
+
type: 'object',
|
|
211
|
+
description: 'Antd design token overrides. Top-level keys apply to the Dropdown menu. Use the nested "button" key for Button-specific tokens. See <a href="https://ant.design/components/overview#design-token">antd design tokens</a>.',
|
|
212
|
+
docs: {
|
|
213
|
+
displayType: 'yaml',
|
|
214
|
+
link: 'https://ant.design/components/dropdown#design-token'
|
|
215
|
+
},
|
|
216
|
+
properties: {
|
|
217
|
+
zIndexPopup: {
|
|
218
|
+
type: 'number',
|
|
219
|
+
default: 1050,
|
|
220
|
+
description: 'Z-index of the dropdown popup.'
|
|
221
|
+
},
|
|
222
|
+
controlItemBgHover: {
|
|
223
|
+
type: 'string',
|
|
224
|
+
description: 'Background color on menu item hover.'
|
|
225
|
+
},
|
|
226
|
+
borderRadiusLG: {
|
|
227
|
+
type: 'number',
|
|
228
|
+
description: 'Border radius for the dropdown menu.'
|
|
229
|
+
},
|
|
230
|
+
paddingBlock: {
|
|
231
|
+
type: 'number',
|
|
232
|
+
description: 'Vertical padding for menu items.'
|
|
233
|
+
},
|
|
234
|
+
button: {
|
|
235
|
+
type: 'object',
|
|
236
|
+
description: 'Button component token overrides. See <a href="https://ant.design/components/button#design-token">Button design tokens</a>.',
|
|
237
|
+
docs: {
|
|
238
|
+
displayType: 'yaml',
|
|
239
|
+
link: 'https://ant.design/components/button#design-token'
|
|
240
|
+
},
|
|
241
|
+
properties: {
|
|
242
|
+
borderRadius: {
|
|
243
|
+
type: 'number',
|
|
244
|
+
default: 6,
|
|
245
|
+
description: 'Border radius of the button.'
|
|
246
|
+
},
|
|
247
|
+
borderRadiusLG: {
|
|
248
|
+
type: 'number',
|
|
249
|
+
default: 8,
|
|
250
|
+
description: 'Border radius for large buttons.'
|
|
251
|
+
},
|
|
252
|
+
borderRadiusSM: {
|
|
253
|
+
type: 'number',
|
|
254
|
+
default: 4,
|
|
255
|
+
description: 'Border radius for small buttons.'
|
|
256
|
+
},
|
|
257
|
+
controlHeight: {
|
|
258
|
+
type: 'number',
|
|
259
|
+
default: 32,
|
|
260
|
+
description: 'Height of the button.'
|
|
261
|
+
},
|
|
262
|
+
controlHeightLG: {
|
|
263
|
+
type: 'number',
|
|
264
|
+
default: 40,
|
|
265
|
+
description: 'Height for large buttons.'
|
|
266
|
+
},
|
|
267
|
+
controlHeightSM: {
|
|
268
|
+
type: 'number',
|
|
269
|
+
default: 24,
|
|
270
|
+
description: 'Height for small buttons.'
|
|
271
|
+
},
|
|
272
|
+
fontSize: {
|
|
273
|
+
type: 'number',
|
|
274
|
+
default: 14,
|
|
275
|
+
description: 'Font size.'
|
|
276
|
+
},
|
|
277
|
+
paddingInline: {
|
|
278
|
+
type: 'number',
|
|
279
|
+
default: 15,
|
|
280
|
+
description: 'Horizontal padding.'
|
|
281
|
+
},
|
|
282
|
+
paddingBlock: {
|
|
283
|
+
type: 'number',
|
|
284
|
+
default: 0,
|
|
285
|
+
description: 'Vertical padding.'
|
|
286
|
+
},
|
|
287
|
+
colorPrimary: {
|
|
288
|
+
type: 'string',
|
|
289
|
+
description: 'Primary color override.'
|
|
290
|
+
},
|
|
291
|
+
colorPrimaryHover: {
|
|
292
|
+
type: 'string',
|
|
293
|
+
description: 'Primary hover color.'
|
|
294
|
+
},
|
|
295
|
+
colorPrimaryActive: {
|
|
296
|
+
type: 'string',
|
|
297
|
+
description: 'Primary active color.'
|
|
298
|
+
},
|
|
299
|
+
colorBgContainer: {
|
|
300
|
+
type: 'string',
|
|
301
|
+
description: 'Background color for default buttons.'
|
|
302
|
+
},
|
|
303
|
+
colorText: {
|
|
304
|
+
type: 'string',
|
|
305
|
+
description: 'Text color for default buttons.'
|
|
306
|
+
},
|
|
307
|
+
colorBorder: {
|
|
308
|
+
type: 'string',
|
|
309
|
+
description: 'Border color for outlined and dashed buttons.'
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
};
|
|
@@ -0,0 +1,130 @@
|
|
|
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 React, { useCallback } from 'react';
|
|
16
|
+
import { Dropdown } from 'antd';
|
|
17
|
+
import { get } from '@lowdefy/helpers';
|
|
18
|
+
import { withBlockDefaults } from '@lowdefy/block-utils';
|
|
19
|
+
import withTheme from '../withTheme.js';
|
|
20
|
+
import useItemShortcuts from '../useItemShortcuts.js';
|
|
21
|
+
import { buildMenuItems, flattenLinks } from '../buildMenuItems.js';
|
|
22
|
+
function collectLinkShortcuts(links) {
|
|
23
|
+
const result = [];
|
|
24
|
+
(links ?? []).forEach((link)=>{
|
|
25
|
+
if (link.type === 'MenuLink' || !link.type) {
|
|
26
|
+
if (link.properties?.shortcut) {
|
|
27
|
+
result.push({
|
|
28
|
+
key: link.id,
|
|
29
|
+
shortcut: link.properties.shortcut
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
if (link.links) {
|
|
34
|
+
result.push(...collectLinkShortcuts(link.links));
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
return result;
|
|
38
|
+
}
|
|
39
|
+
function DropdownMenuBlock({ blockId, classNames = {}, components: { Icon, Link, ShortcutBadge }, content, events, methods, properties, rename, styles = {} }) {
|
|
40
|
+
const links = properties.links ?? [];
|
|
41
|
+
const items = buildMenuItems({
|
|
42
|
+
links,
|
|
43
|
+
components: {
|
|
44
|
+
Icon,
|
|
45
|
+
Link,
|
|
46
|
+
ShortcutBadge
|
|
47
|
+
},
|
|
48
|
+
classNames,
|
|
49
|
+
styles,
|
|
50
|
+
events
|
|
51
|
+
});
|
|
52
|
+
const linkMap = flattenLinks(links);
|
|
53
|
+
const shortcutItems = collectLinkShortcuts(links);
|
|
54
|
+
const onShortcutMatch = useCallback((key)=>{
|
|
55
|
+
const link = linkMap[key];
|
|
56
|
+
methods.triggerEvent({
|
|
57
|
+
name: get(rename, 'events.onClick', {
|
|
58
|
+
default: 'onClick'
|
|
59
|
+
}),
|
|
60
|
+
event: {
|
|
61
|
+
key,
|
|
62
|
+
pageId: link?.pageId,
|
|
63
|
+
url: link?.url
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
}, [
|
|
67
|
+
methods,
|
|
68
|
+
rename,
|
|
69
|
+
linkMap
|
|
70
|
+
]);
|
|
71
|
+
useItemShortcuts({
|
|
72
|
+
items: shortcutItems,
|
|
73
|
+
onMatch: onShortcutMatch
|
|
74
|
+
});
|
|
75
|
+
return /*#__PURE__*/ React.createElement(Dropdown, {
|
|
76
|
+
id: blockId,
|
|
77
|
+
className: classNames.element,
|
|
78
|
+
style: styles.element,
|
|
79
|
+
menu: {
|
|
80
|
+
items,
|
|
81
|
+
onClick: ({ key, keyPath })=>{
|
|
82
|
+
const link = linkMap[key];
|
|
83
|
+
methods.triggerEvent({
|
|
84
|
+
name: get(rename, 'events.onClick', {
|
|
85
|
+
default: 'onClick'
|
|
86
|
+
}),
|
|
87
|
+
event: {
|
|
88
|
+
key,
|
|
89
|
+
keyPath,
|
|
90
|
+
pageId: link?.pageId,
|
|
91
|
+
url: link?.url
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
},
|
|
95
|
+
onSelect: ({ key, selectedKeys })=>{
|
|
96
|
+
const link = linkMap[key];
|
|
97
|
+
methods.triggerEvent({
|
|
98
|
+
name: get(rename, 'events.onSelect', {
|
|
99
|
+
default: 'onSelect'
|
|
100
|
+
}),
|
|
101
|
+
event: {
|
|
102
|
+
key,
|
|
103
|
+
selectedKeys,
|
|
104
|
+
pageId: link?.pageId,
|
|
105
|
+
url: link?.url
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
},
|
|
109
|
+
selectedKeys: properties.selectedKeys
|
|
110
|
+
},
|
|
111
|
+
trigger: [
|
|
112
|
+
properties.trigger ?? 'hover'
|
|
113
|
+
],
|
|
114
|
+
placement: properties.placement,
|
|
115
|
+
arrow: properties.arrow,
|
|
116
|
+
disabled: properties.disabled,
|
|
117
|
+
destroyOnHidden: properties.destroyOnClose,
|
|
118
|
+
popupClassName: classNames.menu,
|
|
119
|
+
popupStyle: styles.menu,
|
|
120
|
+
onOpenChange: (open)=>methods.triggerEvent({
|
|
121
|
+
name: get(rename, 'events.onOpenChange', {
|
|
122
|
+
default: 'onOpenChange'
|
|
123
|
+
}),
|
|
124
|
+
event: {
|
|
125
|
+
open
|
|
126
|
+
}
|
|
127
|
+
})
|
|
128
|
+
}, /*#__PURE__*/ React.createElement("div", null, content.content && content.content()));
|
|
129
|
+
}
|
|
130
|
+
export default withTheme('Dropdown', withBlockDefaults(DropdownMenuBlock));
|
|
@@ -0,0 +1,28 @@
|
|
|
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 { createBlockHelper, escapeId } from '@lowdefy/e2e-utils';
|
|
16
|
+
import { expect } from '@playwright/test';
|
|
17
|
+
const locator = (page, blockId)=>page.locator(`#bl-${escapeId(blockId)}`);
|
|
18
|
+
export default createBlockHelper({
|
|
19
|
+
locator,
|
|
20
|
+
do: {
|
|
21
|
+
open: (page, blockId)=>locator(page, blockId).click(),
|
|
22
|
+
clickItem: (_page, _blockId, title)=>_page.locator(`.ant-dropdown-menu-item:has-text("${title}")`).click()
|
|
23
|
+
},
|
|
24
|
+
expect: {
|
|
25
|
+
menuVisible: (_page)=>expect(_page.locator('.ant-dropdown').first()).toBeVisible(),
|
|
26
|
+
menuHidden: (_page)=>expect(_page.locator('.ant-dropdown').first()).toBeHidden()
|
|
27
|
+
}
|
|
28
|
+
});
|