@lowdefy/blocks-antd 4.7.3 → 5.1.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 +21 -22
- package/dist/blocks/AutoComplete/meta.js +266 -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 +153 -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 +23 -16
- package/dist/blocks/Drawer/{schema.js → meta.js} +62 -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 +153 -124
- 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 +28 -23
- package/dist/blocks/MobileMenu/{schema.js → meta.js} +48 -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 +57 -37
- package/dist/blocks/MultipleSelector/{schema.js → meta.js} +178 -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/PageSidebarLayout/PageSidebarLayout.js +511 -0
- package/dist/blocks/PageSidebarLayout/e2e.js +34 -0
- package/dist/blocks/PageSidebarLayout/meta.js +516 -0
- package/dist/blocks/PageSiderMenu/PageSiderMenu.js +188 -196
- package/dist/blocks/PageSiderMenu/meta.js +486 -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 +41 -30
- package/dist/blocks/Selector/meta.js +380 -0
- package/dist/blocks/Sider/Sider.js +19 -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 +17 -1
- package/dist/disabledDate.js +15 -7
- package/dist/e2e.js +4 -1
- package/dist/metas.js +92 -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
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
limitations under the License.
|
|
15
15
|
*/ import React, { useState, useEffect } from 'react';
|
|
16
16
|
import { get, mergeObjects, type } from '@lowdefy/helpers';
|
|
17
|
-
import {
|
|
17
|
+
import { withBlockDefaults } from '@lowdefy/block-utils';
|
|
18
18
|
import Affix from '../Affix/Affix.js';
|
|
19
19
|
import Breadcrumb from '../Breadcrumb/Breadcrumb.js';
|
|
20
20
|
import Button from '../Button/Button.js';
|
|
@@ -25,164 +25,128 @@ import Layout from '../Layout/Layout.js';
|
|
|
25
25
|
import Menu from '../Menu/Menu.js';
|
|
26
26
|
import MobileMenu from '../MobileMenu/MobileMenu.js';
|
|
27
27
|
import Sider from '../Sider/Sider.js';
|
|
28
|
-
|
|
29
|
-
|
|
28
|
+
import { getDarkMode, renderHeaderActions, registerDarkModeMethod } from '../headerActions.js';
|
|
29
|
+
function getInitialSiderState({ properties }) {
|
|
30
|
+
const storageKey = `lf-${properties.siderStorageKey ?? 'sider'}-open`;
|
|
31
|
+
try {
|
|
32
|
+
const stored = localStorage.getItem(storageKey);
|
|
33
|
+
if (stored === 'true') return true;
|
|
34
|
+
if (stored === 'false') return false;
|
|
35
|
+
} catch {
|
|
36
|
+
// localStorage unavailable (SSR, privacy mode)
|
|
37
|
+
}
|
|
38
|
+
return !properties.sider?.initialCollapsed;
|
|
39
|
+
}
|
|
40
|
+
function writeSiderState({ properties, open }) {
|
|
41
|
+
const storageKey = `lf-${properties.siderStorageKey ?? 'sider'}-open`;
|
|
42
|
+
try {
|
|
43
|
+
localStorage.setItem(storageKey, String(open));
|
|
44
|
+
} catch {
|
|
45
|
+
// localStorage unavailable
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
const PageSiderMenu = ({ basePath, blockId, classNames = {}, components: { Icon, Link, ShortcutBadge }, events, content, menus, methods, pageId, properties, styles = {} })=>{
|
|
49
|
+
const [openSiderState, setSiderOpen] = useState(()=>getInitialSiderState({
|
|
50
|
+
properties
|
|
51
|
+
}));
|
|
30
52
|
useEffect(()=>{
|
|
53
|
+
registerDarkModeMethod(methods);
|
|
31
54
|
methods.registerMethod('toggleSiderOpen', ()=>{
|
|
32
|
-
|
|
33
|
-
|
|
55
|
+
const next = !openSiderState;
|
|
56
|
+
methods._setSiderOpen({
|
|
57
|
+
open: next
|
|
58
|
+
});
|
|
59
|
+
setSiderOpen(next);
|
|
60
|
+
writeSiderState({
|
|
61
|
+
properties,
|
|
62
|
+
open: next
|
|
34
63
|
});
|
|
35
|
-
setSiderOpen(!openSiderState);
|
|
36
64
|
});
|
|
37
65
|
methods.registerMethod('setSiderOpen', ({ open })=>{
|
|
38
|
-
methods.
|
|
66
|
+
methods._setSiderOpen({
|
|
39
67
|
open
|
|
40
68
|
});
|
|
41
69
|
setSiderOpen(open);
|
|
70
|
+
writeSiderState({
|
|
71
|
+
properties,
|
|
72
|
+
open
|
|
73
|
+
});
|
|
42
74
|
});
|
|
43
75
|
});
|
|
44
|
-
const styles = {
|
|
45
|
-
layout: {
|
|
46
|
-
minHeight: '100vh'
|
|
47
|
-
},
|
|
48
|
-
header: {
|
|
49
|
-
display: 'flex',
|
|
50
|
-
alignItems: 'center',
|
|
51
|
-
padding: '0 46px',
|
|
52
|
-
xs: {
|
|
53
|
-
padding: '0 10px'
|
|
54
|
-
},
|
|
55
|
-
sm: {
|
|
56
|
-
padding: '0 15px'
|
|
57
|
-
},
|
|
58
|
-
md: {
|
|
59
|
-
padding: '0 30px'
|
|
60
|
-
},
|
|
61
|
-
lg: {
|
|
62
|
-
padding: '0 46px'
|
|
63
|
-
},
|
|
64
|
-
flexDirection: 'row-reverse'
|
|
65
|
-
},
|
|
66
|
-
headerContent: {
|
|
67
|
-
alignItems: 'center',
|
|
68
|
-
flex: '1 1 auto',
|
|
69
|
-
display: 'flex',
|
|
70
|
-
justifyContent: 'flex-end'
|
|
71
|
-
},
|
|
72
|
-
logo: {
|
|
73
|
-
margin: '0 30px 0 0',
|
|
74
|
-
flex: '0 1 auto',
|
|
75
|
-
width: 130,
|
|
76
|
-
xs: {
|
|
77
|
-
margin: '0 5px',
|
|
78
|
-
width: 40
|
|
79
|
-
},
|
|
80
|
-
sm: {
|
|
81
|
-
margin: '0 10px',
|
|
82
|
-
width: 130
|
|
83
|
-
},
|
|
84
|
-
md: {
|
|
85
|
-
margin: '0 15px'
|
|
86
|
-
}
|
|
87
|
-
},
|
|
88
|
-
desktop: {
|
|
89
|
-
display: 'none',
|
|
90
|
-
lg: {
|
|
91
|
-
display: 'block'
|
|
92
|
-
}
|
|
93
|
-
},
|
|
94
|
-
mobile: {
|
|
95
|
-
display: 'block',
|
|
96
|
-
lg: {
|
|
97
|
-
display: 'none'
|
|
98
|
-
}
|
|
99
|
-
},
|
|
100
|
-
mdMenu: {
|
|
101
|
-
paddingLeft: '1rem'
|
|
102
|
-
},
|
|
103
|
-
body: {
|
|
104
|
-
padding: '0 40px 40px 40px',
|
|
105
|
-
xs: {
|
|
106
|
-
padding: '0 5px 5px 5px'
|
|
107
|
-
},
|
|
108
|
-
sm: {
|
|
109
|
-
padding: '0 10px 10px 10px'
|
|
110
|
-
},
|
|
111
|
-
md: {
|
|
112
|
-
padding: '0 20px 20px 20px'
|
|
113
|
-
},
|
|
114
|
-
lg: {
|
|
115
|
-
padding: '0 40px 40px 40px'
|
|
116
|
-
}
|
|
117
|
-
},
|
|
118
|
-
sider: {
|
|
119
|
-
display: 'flex',
|
|
120
|
-
height: '100%',
|
|
121
|
-
flexDirection: 'column'
|
|
122
|
-
},
|
|
123
|
-
content: {},
|
|
124
|
-
breadcrumb: {
|
|
125
|
-
margin: '16px 0'
|
|
126
|
-
},
|
|
127
|
-
noBreadcrumb: {
|
|
128
|
-
padding: '20px 0',
|
|
129
|
-
xs: {
|
|
130
|
-
padding: '5px 0'
|
|
131
|
-
},
|
|
132
|
-
sm: {
|
|
133
|
-
padding: '5px 0'
|
|
134
|
-
},
|
|
135
|
-
md: {
|
|
136
|
-
padding: '10px 0'
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
};
|
|
140
76
|
return /*#__PURE__*/ React.createElement(Layout, {
|
|
141
77
|
blockId: blockId,
|
|
142
78
|
components: {
|
|
143
79
|
Icon,
|
|
144
|
-
Link
|
|
80
|
+
Link,
|
|
81
|
+
ShortcutBadge
|
|
145
82
|
},
|
|
146
83
|
events: events,
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
84
|
+
styles: {
|
|
85
|
+
element: mergeObjects([
|
|
86
|
+
{
|
|
87
|
+
minHeight: '100vh'
|
|
88
|
+
},
|
|
89
|
+
styles.element
|
|
151
90
|
])
|
|
152
91
|
},
|
|
153
92
|
content: {
|
|
154
|
-
// TODO: use next/image
|
|
155
93
|
content: ()=>/*#__PURE__*/ React.createElement(React.Fragment, null, /*#__PURE__*/ React.createElement(Header, {
|
|
156
94
|
blockId: `${blockId}_header`,
|
|
157
95
|
components: {
|
|
158
96
|
Icon,
|
|
159
|
-
Link
|
|
97
|
+
Link,
|
|
98
|
+
ShortcutBadge
|
|
99
|
+
},
|
|
100
|
+
classNames: {
|
|
101
|
+
element: classNames.header
|
|
160
102
|
},
|
|
161
103
|
events: events,
|
|
162
|
-
properties:
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
104
|
+
properties: {},
|
|
105
|
+
styles: {
|
|
106
|
+
element: mergeObjects([
|
|
107
|
+
{
|
|
108
|
+
background: 'var(--ant-color-bg-container)',
|
|
109
|
+
flexDirection: 'row-reverse',
|
|
110
|
+
borderBottom: '1px solid var(--ant-color-border)'
|
|
111
|
+
},
|
|
112
|
+
styles.header
|
|
113
|
+
])
|
|
114
|
+
},
|
|
168
115
|
content: {
|
|
169
116
|
content: ()=>/*#__PURE__*/ React.createElement(React.Fragment, null, /*#__PURE__*/ React.createElement("div", {
|
|
170
|
-
className:
|
|
117
|
+
className: "flex flex-auto items-center justify-end"
|
|
171
118
|
}, content.header && content.header(mergeObjects([
|
|
172
119
|
{
|
|
173
|
-
width: 'auto'
|
|
120
|
+
width: 'auto',
|
|
121
|
+
alignItems: 'center',
|
|
122
|
+
flexWrap: 'nowrap'
|
|
123
|
+
},
|
|
124
|
+
styles.headerContent
|
|
125
|
+
])), renderHeaderActions({
|
|
126
|
+
blockId,
|
|
127
|
+
classNames,
|
|
128
|
+
styles,
|
|
129
|
+
properties,
|
|
130
|
+
methods,
|
|
131
|
+
events,
|
|
132
|
+
components: {
|
|
133
|
+
Icon,
|
|
134
|
+
Link,
|
|
135
|
+
ShortcutBadge
|
|
136
|
+
},
|
|
137
|
+
iconsColor: properties.iconsColor
|
|
138
|
+
}), /*#__PURE__*/ React.createElement(MobileMenu, {
|
|
139
|
+
classNames: {
|
|
140
|
+
element: classNames.mobileMenu ?? 'block lg:hidden pl-4'
|
|
141
|
+
},
|
|
142
|
+
styles: {
|
|
143
|
+
element: styles.mobileMenu
|
|
174
144
|
},
|
|
175
|
-
properties.header?.contentStyle
|
|
176
|
-
])), /*#__PURE__*/ React.createElement("div", {
|
|
177
|
-
className: methods.makeCssClass([
|
|
178
|
-
styles.mobile,
|
|
179
|
-
styles.mdMenu
|
|
180
|
-
])
|
|
181
|
-
}, /*#__PURE__*/ React.createElement(MobileMenu, {
|
|
182
145
|
blockId: `${blockId}_mobile_menu`,
|
|
183
146
|
components: {
|
|
184
147
|
Icon,
|
|
185
|
-
Link
|
|
148
|
+
Link,
|
|
149
|
+
ShortcutBadge
|
|
186
150
|
},
|
|
187
151
|
basePath: basePath,
|
|
188
152
|
events: events,
|
|
@@ -191,8 +155,7 @@ const PageSiderMenu = ({ basePath, blockId, components: { Icon, Link }, events,
|
|
|
191
155
|
pageId: pageId,
|
|
192
156
|
properties: mergeObjects([
|
|
193
157
|
{
|
|
194
|
-
mode: 'inline'
|
|
195
|
-
theme: get(properties, 'sider.theme') ?? 'light'
|
|
158
|
+
mode: 'inline'
|
|
196
159
|
},
|
|
197
160
|
properties.menu,
|
|
198
161
|
properties.menuMd
|
|
@@ -207,44 +170,61 @@ const PageSiderMenu = ({ basePath, blockId, components: { Icon, Link }, events,
|
|
|
207
170
|
onOpen: 'onMobileMenuOpen'
|
|
208
171
|
}
|
|
209
172
|
}
|
|
210
|
-
}))
|
|
173
|
+
})), /*#__PURE__*/ React.createElement(Link, {
|
|
211
174
|
home: true
|
|
212
175
|
}, /*#__PURE__*/ React.createElement("picture", null, /*#__PURE__*/ React.createElement("source", {
|
|
213
176
|
media: `(min-width:${properties.logo?.breakpoint ?? 577}px)`,
|
|
214
|
-
srcSet: properties.logo?.src ?? `${basePath}/logo-${
|
|
177
|
+
srcSet: properties.logo?.src ?? `${basePath}/logo-${getDarkMode() ? 'dark' : 'light'}-theme.png`
|
|
215
178
|
}), /*#__PURE__*/ React.createElement("img", {
|
|
216
|
-
src: properties.logo?.srcMobile ?? properties.logo?.src ?? `${basePath}/logo-square-${
|
|
179
|
+
src: properties.logo?.srcMobile ?? properties.logo?.src ?? `${basePath}/logo-square-${getDarkMode() ? 'dark' : 'light'}-theme.png`,
|
|
217
180
|
alt: properties.logo?.alt ?? 'Lowdefy',
|
|
218
|
-
className:
|
|
219
|
-
|
|
220
|
-
properties.logo?.style
|
|
221
|
-
])
|
|
181
|
+
className: classNames.logo ?? 'mr-[30px] shrink w-10 sm:w-[130px] mx-1.5 sm:mx-2.5 md:mx-4',
|
|
182
|
+
style: styles.logo
|
|
222
183
|
}))))
|
|
223
184
|
}
|
|
224
185
|
}), /*#__PURE__*/ React.createElement(Layout, {
|
|
225
186
|
blockId: `${blockId}_layout`,
|
|
226
187
|
components: {
|
|
227
188
|
Icon,
|
|
228
|
-
Link
|
|
189
|
+
Link,
|
|
190
|
+
ShortcutBadge
|
|
229
191
|
},
|
|
230
192
|
events: events,
|
|
231
|
-
properties:
|
|
193
|
+
properties: {
|
|
194
|
+
hasSider: true,
|
|
195
|
+
...properties.layout
|
|
196
|
+
},
|
|
197
|
+
styles: {
|
|
198
|
+
element: styles.layout
|
|
199
|
+
},
|
|
200
|
+
classNames: {
|
|
201
|
+
element: classNames.layout
|
|
202
|
+
},
|
|
232
203
|
content: {
|
|
233
204
|
content: ()=>/*#__PURE__*/ React.createElement(React.Fragment, null, /*#__PURE__*/ React.createElement(Sider, {
|
|
234
205
|
blockId: `${blockId}_sider`,
|
|
235
206
|
components: {
|
|
236
207
|
Icon,
|
|
237
|
-
Link
|
|
208
|
+
Link,
|
|
209
|
+
ShortcutBadge
|
|
238
210
|
},
|
|
239
211
|
events: events,
|
|
240
212
|
methods: methods,
|
|
241
|
-
properties:
|
|
242
|
-
{
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
213
|
+
properties: {
|
|
214
|
+
...properties.sider ?? {},
|
|
215
|
+
initialCollapsed: !openSiderState
|
|
216
|
+
},
|
|
217
|
+
classNames: {
|
|
218
|
+
element: classNames.sider ?? 'hidden lg:block'
|
|
219
|
+
},
|
|
220
|
+
styles: {
|
|
221
|
+
element: mergeObjects([
|
|
222
|
+
{
|
|
223
|
+
borderInlineEnd: '1px solid var(--ant-color-border)'
|
|
224
|
+
},
|
|
225
|
+
styles.sider
|
|
226
|
+
])
|
|
227
|
+
},
|
|
248
228
|
rename: {
|
|
249
229
|
methods: {
|
|
250
230
|
toggleOpen: '_toggleSiderOpen',
|
|
@@ -253,37 +233,40 @@ const PageSiderMenu = ({ basePath, blockId, components: { Icon, Link }, events,
|
|
|
253
233
|
},
|
|
254
234
|
content: {
|
|
255
235
|
content: ()=>/*#__PURE__*/ React.createElement("div", {
|
|
256
|
-
style:
|
|
236
|
+
style: {
|
|
237
|
+
display: 'flex',
|
|
238
|
+
height: '100%',
|
|
239
|
+
flexDirection: 'column'
|
|
240
|
+
}
|
|
257
241
|
}, /*#__PURE__*/ React.createElement(Menu, {
|
|
258
242
|
blockId: `${blockId}_menu`,
|
|
259
243
|
components: {
|
|
260
244
|
Icon,
|
|
261
|
-
Link
|
|
245
|
+
Link,
|
|
246
|
+
ShortcutBadge
|
|
262
247
|
},
|
|
263
248
|
basePath: basePath,
|
|
249
|
+
classNames: {
|
|
250
|
+
element: classNames.menu ?? 'hidden lg:block'
|
|
251
|
+
},
|
|
264
252
|
events: events,
|
|
265
253
|
methods: methods,
|
|
266
254
|
menus: menus,
|
|
267
255
|
pageId: pageId,
|
|
268
256
|
properties: mergeObjects([
|
|
269
257
|
{
|
|
270
|
-
mode: 'inline'
|
|
271
|
-
theme: get(properties, 'sider.theme') ?? 'light'
|
|
272
|
-
},
|
|
273
|
-
{
|
|
274
|
-
style: styles.desktop
|
|
258
|
+
mode: 'inline'
|
|
275
259
|
},
|
|
276
260
|
properties.menu,
|
|
277
261
|
properties.menuLg
|
|
278
262
|
]),
|
|
263
|
+
styles: {
|
|
264
|
+
element: styles.menu
|
|
265
|
+
},
|
|
279
266
|
rename: {
|
|
280
|
-
methods: {
|
|
281
|
-
toggleOpen: 'toggleMobileMenuOpen',
|
|
282
|
-
setOpen: 'setMobileMenuOpen'
|
|
283
|
-
},
|
|
284
267
|
events: {
|
|
285
268
|
onClick: 'onMenuItemClick',
|
|
286
|
-
onSelect: '
|
|
269
|
+
onSelect: 'onMenuItemSelect',
|
|
287
270
|
onToggleMenuGroup: 'onToggleMenuGroup'
|
|
288
271
|
}
|
|
289
272
|
}
|
|
@@ -291,11 +274,12 @@ const PageSiderMenu = ({ basePath, blockId, components: { Icon, Link }, events,
|
|
|
291
274
|
style: {
|
|
292
275
|
flex: '1 0 auto'
|
|
293
276
|
}
|
|
294
|
-
}, content.sider && content.sider()), !get(properties, 'sider.hideToggleButton')
|
|
277
|
+
}, content.sider && content.sider()), !get(properties, 'sider.hideToggleButton') && /*#__PURE__*/ React.createElement(Affix, {
|
|
295
278
|
blockId: `${blockId}_toggle_sider_affix`,
|
|
296
279
|
components: {
|
|
297
280
|
Icon,
|
|
298
|
-
Link
|
|
281
|
+
Link,
|
|
282
|
+
ShortcutBadge
|
|
299
283
|
},
|
|
300
284
|
events: events,
|
|
301
285
|
properties: {
|
|
@@ -308,20 +292,18 @@ const PageSiderMenu = ({ basePath, blockId, components: { Icon, Link }, events,
|
|
|
308
292
|
}
|
|
309
293
|
},
|
|
310
294
|
content: {
|
|
311
|
-
content: ()=>/*#__PURE__*/ React.createElement(
|
|
312
|
-
style: {
|
|
313
|
-
background: get(properties, 'sider.theme') === 'dark' ? '#30393e' : 'white'
|
|
314
|
-
}
|
|
315
|
-
}, /*#__PURE__*/ React.createElement(Button, {
|
|
295
|
+
content: ()=>/*#__PURE__*/ React.createElement(Button, {
|
|
316
296
|
blockId: `${blockId}_toggle_sider`,
|
|
317
297
|
components: {
|
|
318
298
|
Icon,
|
|
319
|
-
Link
|
|
299
|
+
Link,
|
|
300
|
+
ShortcutBadge
|
|
320
301
|
},
|
|
321
302
|
events: events,
|
|
322
303
|
properties: {
|
|
323
304
|
hideTitle: true,
|
|
324
|
-
|
|
305
|
+
color: 'default',
|
|
306
|
+
variant: 'filled',
|
|
325
307
|
block: true,
|
|
326
308
|
icon: {
|
|
327
309
|
name: openSiderState ? 'AiOutlineMenuFold' : 'AiOutlineMenuUnfold'
|
|
@@ -335,7 +317,7 @@ const PageSiderMenu = ({ basePath, blockId, components: { Icon, Link }, events,
|
|
|
335
317
|
onClick: 'onToggleSider'
|
|
336
318
|
}
|
|
337
319
|
}
|
|
338
|
-
})
|
|
320
|
+
})
|
|
339
321
|
}
|
|
340
322
|
}))
|
|
341
323
|
}
|
|
@@ -343,46 +325,68 @@ const PageSiderMenu = ({ basePath, blockId, components: { Icon, Link }, events,
|
|
|
343
325
|
blockId: `${blockId}_content`,
|
|
344
326
|
components: {
|
|
345
327
|
Icon,
|
|
346
|
-
Link
|
|
328
|
+
Link,
|
|
329
|
+
ShortcutBadge
|
|
330
|
+
},
|
|
331
|
+
classNames: {
|
|
332
|
+
element: classNames.content
|
|
347
333
|
},
|
|
348
334
|
events: events,
|
|
349
|
-
properties:
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
335
|
+
properties: properties.content ?? {},
|
|
336
|
+
styles: {
|
|
337
|
+
element: mergeObjects([
|
|
338
|
+
{
|
|
339
|
+
padding: '0 40px 40px 40px',
|
|
340
|
+
minWidth: 0
|
|
341
|
+
},
|
|
342
|
+
styles.content
|
|
343
|
+
])
|
|
344
|
+
},
|
|
355
345
|
content: {
|
|
356
346
|
content: ()=>/*#__PURE__*/ React.createElement(React.Fragment, null, !type.isNone(properties.breadcrumb) ? /*#__PURE__*/ React.createElement(Breadcrumb, {
|
|
357
347
|
blockId: `${blockId}_breadcrumb`,
|
|
358
348
|
basePath: basePath,
|
|
359
349
|
components: {
|
|
360
350
|
Icon,
|
|
361
|
-
Link
|
|
351
|
+
Link,
|
|
352
|
+
ShortcutBadge
|
|
353
|
+
},
|
|
354
|
+
classNames: {
|
|
355
|
+
element: classNames.breadcrumb
|
|
362
356
|
},
|
|
363
357
|
events: events,
|
|
364
358
|
methods: methods,
|
|
365
|
-
properties:
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
359
|
+
properties: properties.breadcrumb,
|
|
360
|
+
styles: {
|
|
361
|
+
element: mergeObjects([
|
|
362
|
+
{
|
|
363
|
+
margin: '16px 0'
|
|
364
|
+
},
|
|
365
|
+
styles.breadcrumb
|
|
366
|
+
])
|
|
367
|
+
},
|
|
371
368
|
rename: {
|
|
372
369
|
events: {
|
|
373
370
|
onClick: 'onBreadcrumbClick'
|
|
374
371
|
}
|
|
375
372
|
}
|
|
376
373
|
}) : /*#__PURE__*/ React.createElement("div", {
|
|
377
|
-
className:
|
|
374
|
+
className: "py-1.5 sm:py-1.5 md:py-2.5 lg:py-5"
|
|
378
375
|
}), content.content && content.content(), content.footer && /*#__PURE__*/ React.createElement(Footer, {
|
|
379
376
|
blockId: `${blockId}_footer`,
|
|
380
377
|
components: {
|
|
381
378
|
Icon,
|
|
382
|
-
Link
|
|
379
|
+
Link,
|
|
380
|
+
ShortcutBadge
|
|
381
|
+
},
|
|
382
|
+
classNames: {
|
|
383
|
+
element: classNames.footer
|
|
383
384
|
},
|
|
384
385
|
events: events,
|
|
385
386
|
properties: properties.footer,
|
|
387
|
+
styles: {
|
|
388
|
+
element: styles.footer
|
|
389
|
+
},
|
|
386
390
|
content: {
|
|
387
391
|
content: ()=>content.footer()
|
|
388
392
|
}
|
|
@@ -394,16 +398,4 @@ const PageSiderMenu = ({ basePath, blockId, components: { Icon, Link }, events,
|
|
|
394
398
|
}
|
|
395
399
|
});
|
|
396
400
|
};
|
|
397
|
-
|
|
398
|
-
PageSiderMenu.meta = {
|
|
399
|
-
category: 'container',
|
|
400
|
-
icons: [
|
|
401
|
-
'AiOutlineMenuFold',
|
|
402
|
-
'AiOutlineMenuUnfold',
|
|
403
|
-
...MobileMenu.meta.icons
|
|
404
|
-
],
|
|
405
|
-
styles: [
|
|
406
|
-
'blocks/PageSiderMenu/style.less'
|
|
407
|
-
]
|
|
408
|
-
};
|
|
409
|
-
export default PageSiderMenu;
|
|
401
|
+
export default withBlockDefaults(PageSiderMenu);
|