@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
|
@@ -0,0 +1,86 @@
|
|
|
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 Divider element.'
|
|
21
|
+
},
|
|
22
|
+
properties: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
additionalProperties: false,
|
|
25
|
+
properties: {
|
|
26
|
+
dashed: {
|
|
27
|
+
type: 'boolean',
|
|
28
|
+
default: false,
|
|
29
|
+
description: 'Whether line is dashed.'
|
|
30
|
+
},
|
|
31
|
+
orientation: {
|
|
32
|
+
type: 'string',
|
|
33
|
+
default: 'horizontal',
|
|
34
|
+
enum: [
|
|
35
|
+
'horizontal',
|
|
36
|
+
'vertical'
|
|
37
|
+
],
|
|
38
|
+
description: 'Direction of the divider line.'
|
|
39
|
+
},
|
|
40
|
+
title: {
|
|
41
|
+
type: 'string',
|
|
42
|
+
description: 'Divider title - supports html.'
|
|
43
|
+
},
|
|
44
|
+
titlePlacement: {
|
|
45
|
+
type: 'string',
|
|
46
|
+
default: 'center',
|
|
47
|
+
enum: [
|
|
48
|
+
'start',
|
|
49
|
+
'end',
|
|
50
|
+
'center'
|
|
51
|
+
],
|
|
52
|
+
description: 'Position of title text within the divider.'
|
|
53
|
+
},
|
|
54
|
+
plain: {
|
|
55
|
+
type: 'boolean',
|
|
56
|
+
default: false,
|
|
57
|
+
description: 'Show text as plain style.'
|
|
58
|
+
},
|
|
59
|
+
theme: {
|
|
60
|
+
type: 'object',
|
|
61
|
+
description: 'Antd design token overrides for this block. See <a href="https://ant.design/components/overview#design-token">antd design tokens</a>.',
|
|
62
|
+
docs: {
|
|
63
|
+
displayType: 'yaml',
|
|
64
|
+
link: 'https://ant.design/components/divider#design-token'
|
|
65
|
+
},
|
|
66
|
+
properties: {
|
|
67
|
+
textPaddingInline: {
|
|
68
|
+
type: 'string',
|
|
69
|
+
default: '1em',
|
|
70
|
+
description: 'Horizontal padding of text content in the divider.'
|
|
71
|
+
},
|
|
72
|
+
orientationMargin: {
|
|
73
|
+
type: 'number',
|
|
74
|
+
default: 0.05,
|
|
75
|
+
description: 'Distance between text and edge when orientation is left or right. Value between 0 and 1 representing a percentage.'
|
|
76
|
+
},
|
|
77
|
+
verticalMarginInline: {
|
|
78
|
+
type: 'number',
|
|
79
|
+
default: 8,
|
|
80
|
+
description: 'Horizontal margin for vertical dividers.'
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
};
|
|
@@ -15,7 +15,8 @@
|
|
|
15
15
|
*/ import React, { useState, useEffect } from 'react';
|
|
16
16
|
import { Drawer } from 'antd';
|
|
17
17
|
import { get } from '@lowdefy/helpers';
|
|
18
|
-
import {
|
|
18
|
+
import { withBlockDefaults } from '@lowdefy/block-utils';
|
|
19
|
+
import withTheme from '../withTheme.js';
|
|
19
20
|
const handleClose = async ({ methods, rename, setOpen })=>{
|
|
20
21
|
const response = await methods.triggerEvent({
|
|
21
22
|
name: get(rename, 'events.onClose', {
|
|
@@ -87,7 +88,7 @@ const setOpenState = ({ open, methods, rename, setOpen })=>{
|
|
|
87
88
|
});
|
|
88
89
|
}
|
|
89
90
|
};
|
|
90
|
-
const DrawerBlock = ({ blockId, content, properties, methods, rename, onClose })=>{
|
|
91
|
+
const DrawerBlock = ({ blockId, classNames = {}, content, properties, methods, rename, onClose, styles = {} })=>{
|
|
91
92
|
const [openState, setOpen] = useState(false);
|
|
92
93
|
useEffect(()=>{
|
|
93
94
|
methods.registerMethod(get(rename, 'methods.toggleOpen', {
|
|
@@ -131,19 +132,23 @@ const DrawerBlock = ({ blockId, content, properties, methods, rename, onClose })
|
|
|
131
132
|
methods,
|
|
132
133
|
rename
|
|
133
134
|
}),
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
135
|
+
className: classNames.element,
|
|
136
|
+
classNames: {
|
|
137
|
+
header: classNames.header,
|
|
138
|
+
body: classNames.body,
|
|
139
|
+
footer: classNames.footer,
|
|
140
|
+
mask: classNames.mask,
|
|
141
|
+
wrapper: classNames.wrapper,
|
|
142
|
+
content: classNames.content
|
|
143
|
+
},
|
|
144
|
+
style: styles.element,
|
|
145
|
+
styles: {
|
|
146
|
+
header: styles.header,
|
|
147
|
+
body: styles.body,
|
|
148
|
+
mask: styles.mask,
|
|
149
|
+
wrapper: styles.wrapper,
|
|
150
|
+
content: styles.content
|
|
151
|
+
}
|
|
139
152
|
}, content.content && content.content());
|
|
140
153
|
};
|
|
141
|
-
|
|
142
|
-
DrawerBlock.meta = {
|
|
143
|
-
category: 'container',
|
|
144
|
-
icons: [],
|
|
145
|
-
styles: [
|
|
146
|
-
'blocks/Drawer/style.less'
|
|
147
|
-
]
|
|
148
|
-
};
|
|
149
|
-
export default DrawerBlock;
|
|
154
|
+
export default withTheme('Drawer', withBlockDefaults(DrawerBlock));
|
|
@@ -13,7 +13,29 @@
|
|
|
13
13
|
See the License for the specific language governing permissions and
|
|
14
14
|
limitations under the License.
|
|
15
15
|
*/ export default {
|
|
16
|
-
|
|
16
|
+
category: 'container',
|
|
17
|
+
icons: [],
|
|
18
|
+
valueType: null,
|
|
19
|
+
slots: {
|
|
20
|
+
content: 'Main Drawer body.',
|
|
21
|
+
extra: 'Extra content in the header.'
|
|
22
|
+
},
|
|
23
|
+
cssKeys: {
|
|
24
|
+
element: 'The Drawer element.',
|
|
25
|
+
header: 'The Drawer header.',
|
|
26
|
+
body: 'The Drawer body.',
|
|
27
|
+
footer: 'The Drawer footer.',
|
|
28
|
+
mask: 'The Drawer mask.',
|
|
29
|
+
wrapper: 'The Drawer wrapper.',
|
|
30
|
+
content: 'The Drawer content.'
|
|
31
|
+
},
|
|
32
|
+
events: {
|
|
33
|
+
onToggle: 'Trigger actions when drawer is toggled.',
|
|
34
|
+
onClose: 'Trigger actions when drawer is closed.',
|
|
35
|
+
onOpen: 'Trigger actions when drawer is opened.',
|
|
36
|
+
afterClose: 'Trigger actions after drawer is closed.',
|
|
37
|
+
afterOpenChange: 'Trigger actions after drawer is opened.'
|
|
38
|
+
},
|
|
17
39
|
properties: {
|
|
18
40
|
type: 'object',
|
|
19
41
|
additionalProperties: false,
|
|
@@ -59,41 +81,6 @@
|
|
|
59
81
|
displayType: 'string'
|
|
60
82
|
}
|
|
61
83
|
},
|
|
62
|
-
headerStyle: {
|
|
63
|
-
type: 'object',
|
|
64
|
-
description: 'Css style to applied to drawer header.',
|
|
65
|
-
docs: {
|
|
66
|
-
displayType: 'yaml'
|
|
67
|
-
}
|
|
68
|
-
},
|
|
69
|
-
bodyStyle: {
|
|
70
|
-
type: 'object',
|
|
71
|
-
description: 'Css style to applied to drawer body.',
|
|
72
|
-
docs: {
|
|
73
|
-
displayType: 'yaml'
|
|
74
|
-
}
|
|
75
|
-
},
|
|
76
|
-
contentWrapperStyle: {
|
|
77
|
-
type: 'object',
|
|
78
|
-
description: 'Css style to applied to content area.',
|
|
79
|
-
docs: {
|
|
80
|
-
displayType: 'yaml'
|
|
81
|
-
}
|
|
82
|
-
},
|
|
83
|
-
maskStyle: {
|
|
84
|
-
type: 'object',
|
|
85
|
-
description: 'Css style to applied to drawer mask.',
|
|
86
|
-
docs: {
|
|
87
|
-
displayType: 'yaml'
|
|
88
|
-
}
|
|
89
|
-
},
|
|
90
|
-
drawerStyle: {
|
|
91
|
-
type: 'object',
|
|
92
|
-
description: 'Css style to applied to drawer.',
|
|
93
|
-
docs: {
|
|
94
|
-
displayType: 'yaml'
|
|
95
|
-
}
|
|
96
|
-
},
|
|
97
84
|
zIndex: {
|
|
98
85
|
type: 'integer',
|
|
99
86
|
default: 1000,
|
|
@@ -114,32 +101,45 @@
|
|
|
114
101
|
type: 'boolean',
|
|
115
102
|
default: true,
|
|
116
103
|
description: 'Whether support press esc to close.'
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
},
|
|
120
|
-
events: {
|
|
121
|
-
type: 'object',
|
|
122
|
-
additionalProperties: false,
|
|
123
|
-
properties: {
|
|
124
|
-
onToggle: {
|
|
125
|
-
type: 'array',
|
|
126
|
-
description: 'Trigger actions when drawer is toggled.'
|
|
127
|
-
},
|
|
128
|
-
onClose: {
|
|
129
|
-
type: 'array',
|
|
130
|
-
description: 'Trigger actions when drawer is closed.'
|
|
131
|
-
},
|
|
132
|
-
onOpen: {
|
|
133
|
-
type: 'array',
|
|
134
|
-
description: 'Trigger actions when drawer is opened.'
|
|
135
104
|
},
|
|
136
|
-
|
|
137
|
-
type: '
|
|
138
|
-
description: '
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
105
|
+
theme: {
|
|
106
|
+
type: 'object',
|
|
107
|
+
description: 'Antd design token overrides for this block. See <a href="https://ant.design/components/overview#design-token">antd design tokens</a>.',
|
|
108
|
+
docs: {
|
|
109
|
+
displayType: 'yaml',
|
|
110
|
+
link: 'https://ant.design/components/drawer#design-token'
|
|
111
|
+
},
|
|
112
|
+
properties: {
|
|
113
|
+
footerPaddingBlock: {
|
|
114
|
+
type: 'number',
|
|
115
|
+
default: 8,
|
|
116
|
+
description: 'Vertical padding of the footer.'
|
|
117
|
+
},
|
|
118
|
+
footerPaddingInline: {
|
|
119
|
+
type: 'number',
|
|
120
|
+
default: 16,
|
|
121
|
+
description: 'Horizontal padding of the footer.'
|
|
122
|
+
},
|
|
123
|
+
zIndexPopup: {
|
|
124
|
+
type: 'number',
|
|
125
|
+
default: 1000,
|
|
126
|
+
description: 'Z-index of the drawer.'
|
|
127
|
+
},
|
|
128
|
+
draggerSize: {
|
|
129
|
+
type: 'number',
|
|
130
|
+
default: 4,
|
|
131
|
+
description: 'Size of the resize handle.'
|
|
132
|
+
},
|
|
133
|
+
colorBgElevated: {
|
|
134
|
+
type: 'string',
|
|
135
|
+
description: 'Background color of the drawer.'
|
|
136
|
+
},
|
|
137
|
+
colorBgMask: {
|
|
138
|
+
type: 'string',
|
|
139
|
+
default: 'rgba(0, 0, 0, 0.45)',
|
|
140
|
+
description: 'Background color of the drawer mask.'
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
143
|
}
|
|
144
144
|
}
|
|
145
145
|
}
|
|
@@ -0,0 +1,221 @@
|
|
|
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 { Button, ConfigProvider, Dropdown, Space } from 'antd';
|
|
17
|
+
import { DownOutlined } from '@ant-design/icons';
|
|
18
|
+
import { get, type } from '@lowdefy/helpers';
|
|
19
|
+
import { withBlockDefaults } from '@lowdefy/block-utils';
|
|
20
|
+
import useItemShortcuts from '../useItemShortcuts.js';
|
|
21
|
+
const ANTD_COLOR_PRESETS = new Set([
|
|
22
|
+
'default',
|
|
23
|
+
'primary',
|
|
24
|
+
'danger',
|
|
25
|
+
'blue',
|
|
26
|
+
'purple',
|
|
27
|
+
'cyan',
|
|
28
|
+
'green',
|
|
29
|
+
'magenta',
|
|
30
|
+
'pink',
|
|
31
|
+
'red',
|
|
32
|
+
'orange',
|
|
33
|
+
'yellow',
|
|
34
|
+
'volcano',
|
|
35
|
+
'geekblue',
|
|
36
|
+
'lime',
|
|
37
|
+
'gold'
|
|
38
|
+
]);
|
|
39
|
+
function getButtonProps(properties) {
|
|
40
|
+
if (properties.variant) {
|
|
41
|
+
return {
|
|
42
|
+
color: properties.color,
|
|
43
|
+
variant: properties.variant
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
const buttonType = properties.type ?? 'default';
|
|
47
|
+
if (buttonType === 'danger') {
|
|
48
|
+
return {
|
|
49
|
+
color: 'danger',
|
|
50
|
+
variant: 'solid'
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
return {
|
|
54
|
+
type: buttonType
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
function DropdownButtonBlock({ blockId, classNames = {}, components: { Icon, ShortcutBadge }, events, loading, methods, properties, rename, styles = {} }) {
|
|
58
|
+
const items = (properties.items ?? []).map((item, i)=>{
|
|
59
|
+
if (item.type === 'divider') {
|
|
60
|
+
return {
|
|
61
|
+
type: 'divider',
|
|
62
|
+
key: `divider-${i}`
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
return {
|
|
66
|
+
key: item.eventName ?? `item-${i}`,
|
|
67
|
+
label: /*#__PURE__*/ React.createElement("span", null, item.title, item.shortcut && /*#__PURE__*/ React.createElement(ShortcutBadge, {
|
|
68
|
+
shortcut: item.shortcut
|
|
69
|
+
})),
|
|
70
|
+
icon: item.icon ? /*#__PURE__*/ React.createElement(Icon, {
|
|
71
|
+
blockId: `${blockId}_icon_${i}`,
|
|
72
|
+
classNames: {
|
|
73
|
+
element: classNames.itemIcon
|
|
74
|
+
},
|
|
75
|
+
events: events,
|
|
76
|
+
properties: item.icon,
|
|
77
|
+
styles: {
|
|
78
|
+
element: styles.itemIcon
|
|
79
|
+
}
|
|
80
|
+
}) : undefined,
|
|
81
|
+
danger: item.danger,
|
|
82
|
+
disabled: item.disabled
|
|
83
|
+
};
|
|
84
|
+
});
|
|
85
|
+
const shortcutItems = (properties.items ?? []).filter((item)=>item.shortcut && item.eventName && !item.disabled).map((item)=>({
|
|
86
|
+
key: item.eventName,
|
|
87
|
+
shortcut: item.shortcut
|
|
88
|
+
}));
|
|
89
|
+
const onShortcutMatch = useCallback((key)=>{
|
|
90
|
+
methods.triggerEvent({
|
|
91
|
+
name: key
|
|
92
|
+
});
|
|
93
|
+
}, [
|
|
94
|
+
methods
|
|
95
|
+
]);
|
|
96
|
+
useItemShortcuts({
|
|
97
|
+
items: shortcutItems,
|
|
98
|
+
onMatch: onShortcutMatch
|
|
99
|
+
});
|
|
100
|
+
const onClickActionName = get(rename, 'events.onClick', {
|
|
101
|
+
default: 'onClick'
|
|
102
|
+
});
|
|
103
|
+
const dropdownProps = {
|
|
104
|
+
menu: {
|
|
105
|
+
items,
|
|
106
|
+
onClick: ({ key })=>methods.triggerEvent({
|
|
107
|
+
name: key
|
|
108
|
+
})
|
|
109
|
+
},
|
|
110
|
+
trigger: [
|
|
111
|
+
properties.trigger ?? 'click'
|
|
112
|
+
],
|
|
113
|
+
placement: properties.placement ?? 'bottomRight',
|
|
114
|
+
arrow: properties.arrow,
|
|
115
|
+
disabled: properties.disabled,
|
|
116
|
+
popupClassName: classNames.menu,
|
|
117
|
+
popupStyle: styles.menu,
|
|
118
|
+
onOpenChange: (open)=>methods.triggerEvent({
|
|
119
|
+
name: get(rename, 'events.onOpenChange', {
|
|
120
|
+
default: 'onOpenChange'
|
|
121
|
+
}),
|
|
122
|
+
event: {
|
|
123
|
+
open
|
|
124
|
+
}
|
|
125
|
+
})
|
|
126
|
+
};
|
|
127
|
+
const { color: buttonColor, variant, type: buttonType } = getButtonProps(properties);
|
|
128
|
+
const isPresetColor = ANTD_COLOR_PRESETS.has(properties.color);
|
|
129
|
+
const resolvedColor = isPresetColor ? buttonColor : properties.color ? 'primary' : buttonColor;
|
|
130
|
+
const buttonIcon = properties.icon && /*#__PURE__*/ React.createElement(Icon, {
|
|
131
|
+
blockId: `${blockId}_icon`,
|
|
132
|
+
classNames: {
|
|
133
|
+
element: classNames.icon
|
|
134
|
+
},
|
|
135
|
+
events: events,
|
|
136
|
+
properties: properties.icon,
|
|
137
|
+
styles: {
|
|
138
|
+
element: styles.icon
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
const theme = properties.theme;
|
|
142
|
+
const { button: buttonTheme, ...dropdownTheme } = type.isObject(theme) ? theme : {};
|
|
143
|
+
function renderContent() {
|
|
144
|
+
if (properties.split) {
|
|
145
|
+
return /*#__PURE__*/ React.createElement(Space.Compact, {
|
|
146
|
+
id: blockId,
|
|
147
|
+
className: classNames.element,
|
|
148
|
+
style: styles.element
|
|
149
|
+
}, /*#__PURE__*/ React.createElement(Button, {
|
|
150
|
+
color: resolvedColor,
|
|
151
|
+
variant: variant,
|
|
152
|
+
type: buttonType,
|
|
153
|
+
size: properties.size,
|
|
154
|
+
shape: properties.shape,
|
|
155
|
+
ghost: properties.ghost,
|
|
156
|
+
danger: properties.danger,
|
|
157
|
+
disabled: properties.disabled || get(events, `${onClickActionName}.loading`) || loading,
|
|
158
|
+
loading: get(events, `${onClickActionName}.loading`),
|
|
159
|
+
className: classNames.button,
|
|
160
|
+
style: styles.button,
|
|
161
|
+
icon: buttonIcon,
|
|
162
|
+
onClick: ()=>methods.triggerEvent({
|
|
163
|
+
name: onClickActionName
|
|
164
|
+
})
|
|
165
|
+
}, properties.title), /*#__PURE__*/ React.createElement(Dropdown, dropdownProps, /*#__PURE__*/ React.createElement(Button, {
|
|
166
|
+
color: resolvedColor,
|
|
167
|
+
variant: variant,
|
|
168
|
+
type: buttonType,
|
|
169
|
+
size: properties.size,
|
|
170
|
+
ghost: properties.ghost,
|
|
171
|
+
danger: properties.danger,
|
|
172
|
+
disabled: properties.disabled,
|
|
173
|
+
icon: /*#__PURE__*/ React.createElement(DownOutlined, null)
|
|
174
|
+
})));
|
|
175
|
+
}
|
|
176
|
+
return /*#__PURE__*/ React.createElement(Dropdown, {
|
|
177
|
+
id: blockId,
|
|
178
|
+
className: classNames.element,
|
|
179
|
+
style: styles.element,
|
|
180
|
+
...dropdownProps
|
|
181
|
+
}, /*#__PURE__*/ React.createElement(Button, {
|
|
182
|
+
color: resolvedColor,
|
|
183
|
+
variant: variant,
|
|
184
|
+
type: buttonType,
|
|
185
|
+
size: properties.size,
|
|
186
|
+
shape: properties.shape,
|
|
187
|
+
ghost: properties.ghost,
|
|
188
|
+
danger: properties.danger,
|
|
189
|
+
disabled: properties.disabled,
|
|
190
|
+
className: classNames.button,
|
|
191
|
+
style: styles.button,
|
|
192
|
+
icon: buttonIcon
|
|
193
|
+
}, properties.title));
|
|
194
|
+
}
|
|
195
|
+
// Build ConfigProvider theme with both Dropdown and Button tokens
|
|
196
|
+
const themeConfig = {};
|
|
197
|
+
if (type.isObject(dropdownTheme) && Object.keys(dropdownTheme).length > 0) {
|
|
198
|
+
themeConfig.Dropdown = dropdownTheme;
|
|
199
|
+
}
|
|
200
|
+
if (type.isObject(buttonTheme)) {
|
|
201
|
+
themeConfig.Button = buttonTheme;
|
|
202
|
+
}
|
|
203
|
+
const hasTheme = Object.keys(themeConfig).length > 0;
|
|
204
|
+
const hasCustomColor = properties.color && !isPresetColor;
|
|
205
|
+
if (hasTheme || hasCustomColor) {
|
|
206
|
+
const providerTheme = {};
|
|
207
|
+
if (hasTheme) {
|
|
208
|
+
providerTheme.components = themeConfig;
|
|
209
|
+
}
|
|
210
|
+
if (hasCustomColor) {
|
|
211
|
+
providerTheme.token = {
|
|
212
|
+
colorPrimary: properties.color
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
return /*#__PURE__*/ React.createElement(ConfigProvider, {
|
|
216
|
+
theme: providerTheme
|
|
217
|
+
}, renderContent());
|
|
218
|
+
}
|
|
219
|
+
return renderContent();
|
|
220
|
+
}
|
|
221
|
+
export default withBlockDefaults(DropdownButtonBlock);
|
|
@@ -0,0 +1,30 @@
|
|
|
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).locator('button').first().click(),
|
|
22
|
+
clickItem: (_page, _blockId, title)=>_page.locator(`.ant-dropdown-menu-item:has-text("${title}")`).click(),
|
|
23
|
+
clickSplitArrow: (page, blockId)=>locator(page, blockId).locator('.ant-space-compact button').last().click()
|
|
24
|
+
},
|
|
25
|
+
expect: {
|
|
26
|
+
menuVisible: (_page)=>expect(_page.locator('.ant-dropdown').first()).toBeVisible(),
|
|
27
|
+
menuHidden: (_page)=>expect(_page.locator('.ant-dropdown').first()).toBeHidden(),
|
|
28
|
+
text: (page, blockId, text)=>expect(locator(page, blockId).locator('button').first()).toHaveText(text)
|
|
29
|
+
}
|
|
30
|
+
});
|