@likable-hair/svelte 3.3.20 → 3.3.21
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/components/composed/buttons/ActivableButton.svelte +2 -6
- package/dist/components/composed/buttons/ActivableButton.svelte.d.ts +32 -36
- package/dist/components/composed/common/MenuOrDrawer.svelte +5 -21
- package/dist/components/composed/common/MenuOrDrawer.svelte.d.ts +36 -50
- package/dist/components/composed/common/MenuOrDrawerOptions.svelte +13 -29
- package/dist/components/composed/common/MenuOrDrawerOptions.svelte.d.ts +30 -34
- package/dist/components/composed/common/QuickActions.svelte +20 -52
- package/dist/components/composed/common/QuickActions.svelte.d.ts +20 -24
- package/dist/components/composed/common/ToolTip.svelte +22 -31
- package/dist/components/composed/common/ToolTip.svelte.d.ts +43 -32
- package/dist/components/composed/forms/AsyncAutocomplete.svelte +23 -44
- package/dist/components/composed/forms/AsyncAutocomplete.svelte.d.ts +39 -44
- package/dist/components/composed/forms/AvatarDropdown.svelte +27 -57
- package/dist/components/composed/forms/AvatarDropdown.svelte.d.ts +41 -45
- package/dist/components/composed/forms/ConfirmOrCancelButtons.svelte +17 -35
- package/dist/components/composed/forms/ConfirmOrCancelButtons.svelte.d.ts +37 -41
- package/dist/components/composed/forms/CountriesAutocomplete.svelte +7 -16
- package/dist/components/composed/forms/CountriesAutocomplete.svelte.d.ts +60 -31
- package/dist/components/composed/forms/DatePickerTextField.svelte +114 -166
- package/dist/components/composed/forms/DatePickerTextField.svelte.d.ts +63 -67
- package/dist/components/composed/forms/Dropdown.svelte +21 -51
- package/dist/components/composed/forms/Dropdown.svelte.d.ts +43 -48
- package/dist/components/composed/forms/IconsDropdown.svelte +33 -61
- package/dist/components/composed/forms/IconsDropdown.svelte.d.ts +26 -30
- package/dist/components/composed/forms/LabelAndSelect.svelte +7 -32
- package/dist/components/composed/forms/LabelAndSelect.svelte.d.ts +31 -35
- package/dist/components/composed/forms/LabelAndTextField.svelte +5 -30
- package/dist/components/composed/forms/LabelAndTextField.svelte.d.ts +42 -46
- package/dist/components/composed/forms/ToggleList.svelte +33 -59
- package/dist/components/composed/forms/ToggleList.svelte.d.ts +17 -21
- package/dist/components/composed/forms/YearPickerTextField.svelte +74 -114
- package/dist/components/composed/forms/YearPickerTextField.svelte.d.ts +49 -53
- package/dist/components/composed/list/DynamicTable.svelte +707 -1102
- package/dist/components/composed/list/DynamicTable.svelte.d.ts +365 -369
- package/dist/components/composed/list/PaginatedTable.svelte +76 -139
- package/dist/components/composed/list/PaginatedTable.svelte.d.ts +108 -108
- package/dist/components/composed/progress/HorizontalStackedProgress.svelte +30 -58
- package/dist/components/composed/progress/HorizontalStackedProgress.svelte.d.ts +21 -25
- package/dist/components/composed/search/DynamicFilters.svelte +82 -103
- package/dist/components/composed/search/DynamicFilters.svelte.d.ts +27 -31
- package/dist/components/composed/search/FilterEditor.svelte +77 -106
- package/dist/components/composed/search/FilterEditor.svelte.d.ts +33 -37
- package/dist/components/composed/search/Filters.svelte +292 -361
- package/dist/components/composed/search/Filters.svelte.d.ts +51 -55
- package/dist/components/composed/search/GlobalSearchTextField.svelte +41 -79
- package/dist/components/composed/search/GlobalSearchTextField.svelte.d.ts +39 -43
- package/dist/components/composed/search/MobileFilterEditor.svelte +93 -135
- package/dist/components/composed/search/MobileFilterEditor.svelte.d.ts +35 -39
- package/dist/components/composed/search/SearchBar.svelte +5 -28
- package/dist/components/composed/search/SearchBar.svelte.d.ts +30 -34
- package/dist/components/composed/search/SearchResults.svelte +7 -42
- package/dist/components/composed/search/SearchResults.svelte.d.ts +36 -40
- package/dist/components/composed/shop/ProductCard.svelte +4 -18
- package/dist/components/composed/shop/ProductCard.svelte.d.ts +28 -32
- package/dist/components/composed/shop/ProductsGrid.svelte +2 -22
- package/dist/components/composed/shop/ProductsGrid.svelte.d.ts +40 -44
- package/dist/components/layouts/CollapsibleSideBarLayout.svelte +38 -77
- package/dist/components/layouts/CollapsibleSideBarLayout.svelte.d.ts +69 -109
- package/dist/components/layouts/StableDividedSideBarLayout.svelte +17 -47
- package/dist/components/layouts/StableDividedSideBarLayout.svelte.d.ts +32 -50
- package/dist/components/layouts/UnstableDividedSideBarLayout.svelte +30 -53
- package/dist/components/layouts/UnstableDividedSideBarLayout.svelte.d.ts +63 -103
- package/dist/components/simple/buttons/Button.svelte +32 -78
- package/dist/components/simple/buttons/Button.svelte.d.ts +35 -47
- package/dist/components/simple/buttons/LinkButton.svelte +22 -54
- package/dist/components/simple/buttons/LinkButton.svelte.d.ts +33 -50
- package/dist/components/simple/charts/GanymedeBarChart.svelte +134 -172
- package/dist/components/simple/charts/GanymedeBarChart.svelte.d.ts +46 -50
- package/dist/components/simple/charts/GanymedeLineChart.svelte +115 -157
- package/dist/components/simple/charts/GanymedeLineChart.svelte.d.ts +47 -51
- package/dist/components/simple/charts/GanymedePieChart.svelte +39 -62
- package/dist/components/simple/charts/GanymedePieChart.svelte.d.ts +33 -37
- package/dist/components/simple/common/Card.svelte +1 -20
- package/dist/components/simple/common/Card.svelte.d.ts +38 -51
- package/dist/components/simple/common/CollapsibleDivider.svelte +11 -23
- package/dist/components/simple/common/CollapsibleDivider.svelte.d.ts +25 -29
- package/dist/components/simple/common/Divider.svelte +2 -8
- package/dist/components/simple/common/Divider.svelte.d.ts +19 -23
- package/dist/components/simple/common/Gesture.svelte +46 -64
- package/dist/components/simple/common/Gesture.svelte.d.ts +17 -21
- package/dist/components/simple/common/InfiniteScroll.svelte +29 -52
- package/dist/components/simple/common/InfiniteScroll.svelte.d.ts +20 -24
- package/dist/components/simple/common/IntersectionObserver.svelte +32 -45
- package/dist/components/simple/common/IntersectionObserver.svelte.d.ts +21 -34
- package/dist/components/simple/common/MediaQuery.svelte +21 -30
- package/dist/components/simple/common/MediaQuery.svelte.d.ts +30 -34
- package/dist/components/simple/common/Menu.svelte +201 -290
- package/dist/components/simple/common/Menu.svelte.d.ts +40 -51
- package/dist/components/simple/common/Playground.svelte +17 -18
- package/dist/components/simple/common/Playground.svelte.d.ts +15 -19
- package/dist/components/simple/common/VerticalDraggableList.svelte +16 -35
- package/dist/components/simple/common/VerticalDraggableList.svelte.d.ts +29 -33
- package/dist/components/simple/dashboards/DashboardGridShaper.svelte +26 -32
- package/dist/components/simple/dashboards/DashboardGridShaper.svelte.d.ts +12 -16
- package/dist/components/simple/dates/Calendar.svelte +28 -52
- package/dist/components/simple/dates/Calendar.svelte.d.ts +41 -45
- package/dist/components/simple/dates/DatePicker.svelte +60 -90
- package/dist/components/simple/dates/DatePicker.svelte.d.ts +40 -44
- package/dist/components/simple/dates/MonthSelector.svelte +15 -37
- package/dist/components/simple/dates/MonthSelector.svelte.d.ts +31 -35
- package/dist/components/simple/dates/TimePicker.svelte +31 -45
- package/dist/components/simple/dates/TimePicker.svelte.d.ts +20 -24
- package/dist/components/simple/dates/TimePickerTextField.svelte +35 -56
- package/dist/components/simple/dates/TimePickerTextField.svelte.d.ts +24 -28
- package/dist/components/simple/dates/YearSelector.svelte +29 -54
- package/dist/components/simple/dates/YearSelector.svelte.d.ts +31 -35
- package/dist/components/simple/dialogs/Dialog.svelte +62 -92
- package/dist/components/simple/dialogs/Dialog.svelte.d.ts +28 -42
- package/dist/components/simple/forms/Autocomplete.svelte +142 -201
- package/dist/components/simple/forms/Autocomplete.svelte.d.ts +79 -83
- package/dist/components/simple/forms/Checkbox.svelte +24 -40
- package/dist/components/simple/forms/Checkbox.svelte.d.ts +21 -25
- package/dist/components/simple/forms/FileInput.svelte +48 -88
- package/dist/components/simple/forms/FileInput.svelte.d.ts +33 -37
- package/dist/components/simple/forms/FileInputList.svelte +34 -52
- package/dist/components/simple/forms/FileInputList.svelte.d.ts +39 -43
- package/dist/components/simple/forms/RadioButton.svelte +3 -11
- package/dist/components/simple/forms/RadioButton.svelte.d.ts +27 -31
- package/dist/components/simple/forms/Select.svelte +3 -16
- package/dist/components/simple/forms/Select.svelte.d.ts +20 -24
- package/dist/components/simple/forms/SimpleTextField.svelte +6 -53
- package/dist/components/simple/forms/SimpleTextField.svelte.d.ts +60 -64
- package/dist/components/simple/forms/Switch.svelte +16 -30
- package/dist/components/simple/forms/Switch.svelte.d.ts +21 -25
- package/dist/components/simple/forms/Textarea.svelte +2 -27
- package/dist/components/simple/forms/Textarea.svelte.d.ts +37 -41
- package/dist/components/simple/forms/Textfield.svelte +18 -56
- package/dist/components/simple/forms/Textfield.svelte.d.ts +51 -55
- package/dist/components/simple/forms/TreeEditor.svelte +95 -141
- package/dist/components/simple/forms/TreeEditor.svelte.d.ts +38 -42
- package/dist/components/simple/forms/TreeEditorItem.svelte +42 -77
- package/dist/components/simple/forms/TreeEditorItem.svelte.d.ts +50 -54
- package/dist/components/simple/forms/VerticalSwitch.svelte +1 -11
- package/dist/components/simple/forms/VerticalSwitch.svelte.d.ts +28 -32
- package/dist/components/simple/forms/VerticalTextSwitch.svelte +3 -15
- package/dist/components/simple/forms/VerticalTextSwitch.svelte.d.ts +26 -30
- package/dist/components/simple/lists/ColorInvertedSelector.svelte +23 -53
- package/dist/components/simple/lists/ColorInvertedSelector.svelte.d.ts +42 -46
- package/dist/components/simple/lists/HierarchyMenu.svelte +19 -38
- package/dist/components/simple/lists/HierarchyMenu.svelte.d.ts +30 -34
- package/dist/components/simple/lists/Paginator.svelte +41 -50
- package/dist/components/simple/lists/Paginator.svelte.d.ts +19 -23
- package/dist/components/simple/lists/SelectableMenuList.svelte +15 -43
- package/dist/components/simple/lists/SelectableMenuList.svelte.d.ts +20 -24
- package/dist/components/simple/lists/SelectableVerticalList.svelte +57 -99
- package/dist/components/simple/lists/SelectableVerticalList.svelte.d.ts +47 -51
- package/dist/components/simple/lists/SidebarMenuList.svelte +70 -115
- package/dist/components/simple/lists/SidebarMenuList.svelte.d.ts +22 -26
- package/dist/components/simple/lists/SimpleTable.svelte +154 -264
- package/dist/components/simple/lists/SimpleTable.svelte.d.ts +66 -70
- package/dist/components/simple/loaders/CircularLoader.svelte +5 -16
- package/dist/components/simple/loaders/CircularLoader.svelte.d.ts +15 -19
- package/dist/components/simple/loaders/Skeleton.svelte +2 -3
- package/dist/components/simple/loaders/Skeleton.svelte.d.ts +12 -16
- package/dist/components/simple/media/AttachmentDownloader.svelte +3 -17
- package/dist/components/simple/media/AttachmentDownloader.svelte.d.ts +28 -32
- package/dist/components/simple/media/Avatar.svelte +12 -18
- package/dist/components/simple/media/Avatar.svelte.d.ts +20 -31
- package/dist/components/simple/media/Carousel.svelte +11 -29
- package/dist/components/simple/media/Carousel.svelte.d.ts +24 -28
- package/dist/components/simple/media/DescriptiveAvatar.svelte +4 -12
- package/dist/components/simple/media/DescriptiveAvatar.svelte.d.ts +28 -44
- package/dist/components/simple/media/FlagIcon.svelte +5 -8
- package/dist/components/simple/media/FlagIcon.svelte.d.ts +15 -19
- package/dist/components/simple/media/Gallery.svelte +29 -49
- package/dist/components/simple/media/Gallery.svelte.d.ts +23 -27
- package/dist/components/simple/media/Icon.svelte +4 -9
- package/dist/components/simple/media/Icon.svelte.d.ts +20 -24
- package/dist/components/simple/media/Image.svelte +20 -42
- package/dist/components/simple/media/Image.svelte.d.ts +33 -44
- package/dist/components/simple/media/ImageGrid.svelte +12 -37
- package/dist/components/simple/media/ImageGrid.svelte.d.ts +28 -32
- package/dist/components/simple/navigation/Breadcrumb.svelte +10 -28
- package/dist/components/simple/navigation/Breadcrumb.svelte.d.ts +22 -26
- package/dist/components/simple/navigation/Chip.svelte +23 -44
- package/dist/components/simple/navigation/Chip.svelte.d.ts +31 -42
- package/dist/components/simple/navigation/Drawer.svelte +65 -107
- package/dist/components/simple/navigation/Drawer.svelte.d.ts +37 -50
- package/dist/components/simple/navigation/HeaderMenu.svelte +23 -40
- package/dist/components/simple/navigation/HeaderMenu.svelte.d.ts +35 -39
- package/dist/components/simple/navigation/Navigator.svelte +8 -30
- package/dist/components/simple/navigation/Navigator.svelte.d.ts +24 -28
- package/dist/components/simple/navigation/TabSwitcher.svelte +47 -83
- package/dist/components/simple/navigation/TabSwitcher.svelte.d.ts +34 -38
- package/dist/components/simple/notifiers/AlertBanner.svelte +15 -43
- package/dist/components/simple/notifiers/AlertBanner.svelte.d.ts +37 -41
- package/dist/components/simple/progress/ProgressBar.svelte +13 -20
- package/dist/components/simple/progress/ProgressBar.svelte.d.ts +17 -21
- package/dist/components/simple/timeline/SimpleTimeLine.svelte +5 -19
- package/dist/components/simple/timeline/SimpleTimeLine.svelte.d.ts +35 -39
- package/dist/components/simple/typography/Code.svelte +12 -27
- package/dist/components/simple/typography/Code.svelte.d.ts +24 -28
- package/dist/stores/debounce.d.ts +1 -0
- package/dist/stores/layouts/unstableSidebarOpened.d.ts +1 -0
- package/dist/stores/mediaQuery.d.ts +1 -0
- package/dist/stores/theme.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,358 +1,269 @@
|
|
|
1
|
-
<script
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
inAnimation: (
|
|
31
|
-
node: Element,
|
|
32
|
-
params?: SlideParams | FlyParams | FadeParams
|
|
33
|
-
) => TransitionConfig = fly,
|
|
34
|
-
inAnimationConfig: SlideParams | FlyParams | FadeParams = {
|
|
35
|
-
duration: 100,
|
|
36
|
-
y: 10,
|
|
37
|
-
},
|
|
38
|
-
outAnimation: (
|
|
39
|
-
node: Element,
|
|
40
|
-
params?: SlideParams | FlyParams | FadeParams
|
|
41
|
-
) => TransitionConfig = fly,
|
|
42
|
-
outAnimationConfig: SlideParams | FlyParams | FadeParams = {
|
|
43
|
-
duration: 100,
|
|
44
|
-
y: 10,
|
|
45
|
-
},
|
|
46
|
-
menuElement: HTMLElement | undefined = undefined,
|
|
47
|
-
flipOnOverflow: boolean = false,
|
|
48
|
-
stayInViewport: boolean = false,
|
|
49
|
-
openingId: string | undefined = undefined;
|
|
50
|
-
|
|
51
|
-
let zIndex = 50,
|
|
52
|
-
currentUid: string = createId(),
|
|
53
|
-
closeController: HTMLElement;
|
|
54
|
-
|
|
55
|
-
function calculateMenuPosition(params: {
|
|
56
|
-
activator: HTMLElement;
|
|
57
|
-
menuElement: HTMLElement;
|
|
58
|
-
}) {
|
|
59
|
-
if (params.menuElement) {
|
|
60
|
-
if (params.activator) {
|
|
61
|
-
if (anchor == "bottom") {
|
|
62
|
-
let { left: activatorLeft, top: activatorTop } =
|
|
63
|
-
params.activator.getBoundingClientRect();
|
|
64
|
-
let activatorHeight = params.activator.offsetHeight;
|
|
65
|
-
_top = activatorTop + activatorHeight + _activatorGap;
|
|
66
|
-
_left = activatorLeft;
|
|
67
|
-
|
|
68
|
-
let { top: fixedParentTop, left: fixedParentLeft, fixedParent, validStickyParent } = getParentInstanceFromViewport(activator?.parentElement);
|
|
69
|
-
if(!!fixedParent) {
|
|
70
|
-
_top = _top - fixedParentTop
|
|
71
|
-
_left = _left - fixedParentLeft
|
|
72
|
-
} else if(!validStickyParent && !fixedParent) {
|
|
73
|
-
_top = _top + window.scrollY
|
|
74
|
-
_left = _left + window.scrollX
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
} else if (anchor == "bottom-center") {
|
|
78
|
-
let { left: activatorLeft, top: activatorTop } =
|
|
79
|
-
params.activator.getBoundingClientRect();
|
|
80
|
-
let activatorHeight = params.activator.offsetHeight;
|
|
81
|
-
let activatorWidth = params.activator.offsetWidth;
|
|
82
|
-
let menuWidth = params.menuElement.offsetWidth;
|
|
83
|
-
_top = activatorTop + activatorHeight + _activatorGap;
|
|
84
|
-
_left = activatorLeft;
|
|
85
|
-
|
|
86
|
-
let { top: fixedParentTop, left: fixedParentLeft, fixedParent, validStickyParent } = getParentInstanceFromViewport(activator?.parentElement);
|
|
87
|
-
if(!!fixedParent) {
|
|
88
|
-
_top = _top - fixedParentTop
|
|
89
|
-
_left = _left - fixedParentLeft
|
|
90
|
-
} else if(!validStickyParent && !fixedParent) {
|
|
91
|
-
_top = _top + window.scrollY
|
|
92
|
-
_left = _left + window.scrollX
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
if (menuWidth > activatorWidth) {
|
|
96
|
-
_left = _left - (menuWidth - activatorWidth) / 2;
|
|
97
|
-
} else {
|
|
98
|
-
_left = _left + (activatorWidth - menuWidth) / 2;
|
|
99
|
-
}
|
|
100
|
-
} else if (anchor == 'right-center') {
|
|
101
|
-
let { left: activatorLeft, top: activatorTop } =
|
|
102
|
-
params.activator.getBoundingClientRect();
|
|
103
|
-
let activatorHeight = params.activator.offsetHeight;
|
|
104
|
-
let activatorWidth = params.activator.offsetWidth;
|
|
105
|
-
let menuHeight = params.menuElement.offsetHeight;
|
|
106
|
-
let { top: fixedParentTop, left: fixedParentLeft } = getParentInstanceFromViewport(activator?.parentElement);
|
|
107
|
-
|
|
108
|
-
_top = activatorTop + window.scrollY + (activatorHeight / 2) - (menuHeight / 2) - fixedParentTop;
|
|
109
|
-
_left = activatorLeft + window.scrollX + activatorWidth + _activatorGap - fixedParentLeft;
|
|
1
|
+
<script>import { createId } from "@paralleldrive/cuid2";
|
|
2
|
+
import {
|
|
3
|
+
fly
|
|
4
|
+
} from "svelte/transition";
|
|
5
|
+
import { sidebarOpened } from "../../../stores/layouts/unstableSidebarOpened";
|
|
6
|
+
export let _top = void 0, _left = void 0, _width = "auto", _height = "auto", _maxHeight = void 0, _minWidth = void 0, _overflow = "auto", _boxShadow = void 0, _borderRadius = void 0, _activatorGap = 5;
|
|
7
|
+
export let open = false, refreshPosition = false, activator = void 0, anchor = "bottom", closeOnClickOutside = false, inAnimation = fly, inAnimationConfig = {
|
|
8
|
+
duration: 100,
|
|
9
|
+
y: 10
|
|
10
|
+
}, outAnimation = fly, outAnimationConfig = {
|
|
11
|
+
duration: 100,
|
|
12
|
+
y: 10
|
|
13
|
+
}, menuElement = void 0, flipOnOverflow = false, stayInViewport = false, openingId = void 0;
|
|
14
|
+
let zIndex = 50, currentUid = createId(), closeController;
|
|
15
|
+
function calculateMenuPosition(params) {
|
|
16
|
+
if (params.menuElement) {
|
|
17
|
+
if (params.activator) {
|
|
18
|
+
if (anchor == "bottom") {
|
|
19
|
+
let { left: activatorLeft, top: activatorTop } = params.activator.getBoundingClientRect();
|
|
20
|
+
let activatorHeight = params.activator.offsetHeight;
|
|
21
|
+
_top = activatorTop + activatorHeight + _activatorGap;
|
|
22
|
+
_left = activatorLeft;
|
|
23
|
+
let { top: fixedParentTop, left: fixedParentLeft, fixedParent, validStickyParent } = getParentInstanceFromViewport(activator?.parentElement);
|
|
24
|
+
if (!!fixedParent) {
|
|
25
|
+
_top = _top - fixedParentTop;
|
|
26
|
+
_left = _left - fixedParentLeft;
|
|
27
|
+
} else if (!validStickyParent && !fixedParent) {
|
|
28
|
+
_top = _top + window.scrollY;
|
|
29
|
+
_left = _left + window.scrollX;
|
|
110
30
|
}
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
let
|
|
115
|
-
|
|
116
|
-
|
|
31
|
+
} else if (anchor == "bottom-center") {
|
|
32
|
+
let { left: activatorLeft, top: activatorTop } = params.activator.getBoundingClientRect();
|
|
33
|
+
let activatorHeight = params.activator.offsetHeight;
|
|
34
|
+
let activatorWidth = params.activator.offsetWidth;
|
|
35
|
+
let menuWidth = params.menuElement.offsetWidth;
|
|
36
|
+
_top = activatorTop + activatorHeight + _activatorGap;
|
|
37
|
+
_left = activatorLeft;
|
|
38
|
+
let { top: fixedParentTop, left: fixedParentLeft, fixedParent, validStickyParent } = getParentInstanceFromViewport(activator?.parentElement);
|
|
39
|
+
if (!!fixedParent) {
|
|
40
|
+
_top = _top - fixedParentTop;
|
|
41
|
+
_left = _left - fixedParentLeft;
|
|
42
|
+
} else if (!validStickyParent && !fixedParent) {
|
|
43
|
+
_top = _top + window.scrollY;
|
|
44
|
+
_left = _left + window.scrollX;
|
|
117
45
|
}
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
(_left || 0) + (menuElement?.offsetWidth || 0)
|
|
123
|
-
) {
|
|
124
|
-
let { left: activatorLeft } = params.activator.getBoundingClientRect();
|
|
125
|
-
_left = activatorLeft + window.scrollX - _activatorGap - (menuElement?.offsetWidth || 0)
|
|
46
|
+
if (menuWidth > activatorWidth) {
|
|
47
|
+
_left = _left - (menuWidth - activatorWidth) / 2;
|
|
48
|
+
} else {
|
|
49
|
+
_left = _left + (activatorWidth - menuWidth) / 2;
|
|
126
50
|
}
|
|
51
|
+
} else if (anchor == "right-center") {
|
|
52
|
+
let { left: activatorLeft, top: activatorTop } = params.activator.getBoundingClientRect();
|
|
53
|
+
let activatorHeight = params.activator.offsetHeight;
|
|
54
|
+
let activatorWidth = params.activator.offsetWidth;
|
|
55
|
+
let menuHeight = params.menuElement.offsetHeight;
|
|
56
|
+
let { top: fixedParentTop, left: fixedParentLeft } = getParentInstanceFromViewport(activator?.parentElement);
|
|
57
|
+
_top = activatorTop + window.scrollY + activatorHeight / 2 - menuHeight / 2 - fixedParentTop;
|
|
58
|
+
_left = activatorLeft + window.scrollX + activatorWidth + _activatorGap - fixedParentLeft;
|
|
127
59
|
}
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
) {
|
|
134
|
-
_left = Math.max(
|
|
135
|
-
window.innerWidth + window.scrollX - (menuElement?.offsetWidth || 0),
|
|
136
|
-
0
|
|
137
|
-
);
|
|
138
|
-
}
|
|
60
|
+
}
|
|
61
|
+
if (flipOnOverflow && !!params.activator) {
|
|
62
|
+
let { top: activatorTopDistance } = params.activator.getBoundingClientRect();
|
|
63
|
+
if (window.innerHeight < activatorTopDistance + (menuElement?.offsetHeight || 0) + (menuElement?.offsetHeight || 0) * 0.1) {
|
|
64
|
+
_top = getTopDistance(params.activator) - _activatorGap - (menuElement?.offsetHeight || 0);
|
|
139
65
|
}
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
_left =
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
66
|
+
if (anchor == "right-center" && window.innerWidth + window.scrollX < (_left || 0) + (menuElement?.offsetWidth || 0)) {
|
|
67
|
+
let { left: activatorLeft } = params.activator.getBoundingClientRect();
|
|
68
|
+
_left = activatorLeft + window.scrollX - _activatorGap - (menuElement?.offsetWidth || 0);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
if (stayInViewport) {
|
|
72
|
+
if (window.innerWidth + window.scrollX < (_left || 0) + (menuElement?.offsetWidth || 0)) {
|
|
73
|
+
_left = Math.max(
|
|
74
|
+
window.innerWidth + window.scrollX - (menuElement?.offsetWidth || 0),
|
|
75
|
+
0
|
|
76
|
+
);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
if (!!positionedAncestor) {
|
|
80
|
+
let { left: positionedAncestorLeft, top: positionedAncestorTop } = positionedAncestor.getBoundingClientRect();
|
|
81
|
+
if (!_left)
|
|
82
|
+
_left = 0;
|
|
83
|
+
if (!_top)
|
|
84
|
+
_top = 0;
|
|
85
|
+
_left = _left - (positionedAncestorLeft + window.scrollX);
|
|
86
|
+
_top = _top - (positionedAncestorTop + window.scrollY);
|
|
87
|
+
if (!!activator) {
|
|
88
|
+
let { validStickyParent, fixedParent } = getParentInstanceFromViewport(activator?.parentElement);
|
|
89
|
+
if (!!validStickyParent || !!fixedParent) {
|
|
90
|
+
_left = _left + window.scrollX;
|
|
91
|
+
_top = _top + window.scrollY;
|
|
156
92
|
}
|
|
157
93
|
}
|
|
158
94
|
}
|
|
159
95
|
}
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
}
|
|
167
|
-
return window.scrollY + elem.getBoundingClientRect().top
|
|
96
|
+
}
|
|
97
|
+
function getTopDistance(elem) {
|
|
98
|
+
let positionedAncestor2 = getPositionedAncestor(elem);
|
|
99
|
+
if (!!positionedAncestor2) {
|
|
100
|
+
let top = parseInt(getComputedStyle(positionedAncestor2).top);
|
|
101
|
+
return (isNaN(top) ? 0 : top) + elem.offsetTop - calcScrollY(elem);
|
|
168
102
|
}
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
103
|
+
return window.scrollY + elem.getBoundingClientRect().top;
|
|
104
|
+
}
|
|
105
|
+
function calcScrollY(elem) {
|
|
106
|
+
let parent = elem.parentElement;
|
|
107
|
+
let scroll = 0;
|
|
108
|
+
while (!!parent) {
|
|
109
|
+
scroll += parent.scrollTop;
|
|
110
|
+
let parentPosition = getComputedStyle(parent).position;
|
|
111
|
+
if (parentPosition === "absolute" || parentPosition === "fixed" || parentPosition === "relative")
|
|
112
|
+
break;
|
|
113
|
+
parent = parent.parentElement;
|
|
180
114
|
}
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
parent.
|
|
189
|
-
|
|
190
|
-
|
|
115
|
+
return scroll;
|
|
116
|
+
}
|
|
117
|
+
$:
|
|
118
|
+
if (open) {
|
|
119
|
+
if (!!activator) {
|
|
120
|
+
let parent = activator.parentElement;
|
|
121
|
+
while (!!parent) {
|
|
122
|
+
let parentPosition = getComputedStyle(parent).position;
|
|
123
|
+
parent.addEventListener("scroll", refreshMenuPosition);
|
|
124
|
+
if (parentPosition == "absolute" || parentPosition == "fixed" || parentPosition === "relative")
|
|
125
|
+
break;
|
|
126
|
+
parent = parent.parentElement;
|
|
191
127
|
}
|
|
192
128
|
}
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
const clickEvent = new MouseEvent('click', {
|
|
129
|
+
if (!!openingId) {
|
|
130
|
+
const controllers = document.querySelectorAll(`[data-operation="close"][data-opening-id="${openingId}"]`);
|
|
131
|
+
for (let k = 0; k < controllers.length; k += 1) {
|
|
132
|
+
if (controllers[k] !== closeController) {
|
|
133
|
+
const clickEvent = new MouseEvent("click", {
|
|
199
134
|
bubbles: true,
|
|
200
135
|
cancelable: true,
|
|
201
136
|
view: window
|
|
202
|
-
})
|
|
203
|
-
|
|
204
|
-
controllers[k].dispatchEvent(clickEvent)
|
|
137
|
+
});
|
|
138
|
+
controllers[k].dispatchEvent(clickEvent);
|
|
205
139
|
}
|
|
206
140
|
}
|
|
207
141
|
}
|
|
208
|
-
|
|
209
|
-
let
|
|
210
|
-
|
|
211
|
-
let otherDialogs: NodeListOf<HTMLElement> =
|
|
212
|
-
document.querySelectorAll("[data-dialog]");
|
|
213
|
-
|
|
214
|
-
let maxZIndex: number | undefined = undefined;
|
|
142
|
+
let otherMenus = document.querySelectorAll("[data-menu]");
|
|
143
|
+
let otherDialogs = document.querySelectorAll("[data-dialog]");
|
|
144
|
+
let maxZIndex = void 0;
|
|
215
145
|
if (otherDialogs.length > 0) {
|
|
216
146
|
otherDialogs.forEach((dialog) => {
|
|
217
147
|
if (!maxZIndex || maxZIndex < Number(dialog.style.zIndex))
|
|
218
148
|
maxZIndex = Number(dialog.style.zIndex);
|
|
219
149
|
});
|
|
220
150
|
}
|
|
221
|
-
|
|
222
151
|
if (otherMenus.length > 0) {
|
|
223
152
|
otherMenus.forEach((menu) => {
|
|
224
153
|
if (!maxZIndex || maxZIndex < Number(menu.style.zIndex))
|
|
225
154
|
maxZIndex = Number(menu.style.zIndex);
|
|
226
155
|
});
|
|
227
156
|
}
|
|
228
|
-
|
|
229
157
|
if (!!activator && !!menuElement)
|
|
230
158
|
calculateMenuPosition({ activator, menuElement });
|
|
231
|
-
|
|
232
|
-
|
|
159
|
+
if (maxZIndex)
|
|
160
|
+
zIndex = maxZIndex + 2;
|
|
233
161
|
}
|
|
234
|
-
|
|
162
|
+
$:
|
|
163
|
+
if (!!_width && !!activator && !!menuElement) {
|
|
235
164
|
setTimeout(() => {
|
|
236
|
-
if(!!activator && !!menuElement)
|
|
165
|
+
if (!!activator && !!menuElement)
|
|
237
166
|
calculateMenuPosition({ activator, menuElement });
|
|
238
|
-
}, 1)
|
|
167
|
+
}, 1);
|
|
239
168
|
}
|
|
240
|
-
|
|
169
|
+
$:
|
|
170
|
+
if (refreshPosition && !!activator && !!menuElement) {
|
|
241
171
|
calculateMenuPosition({ activator, menuElement });
|
|
242
172
|
refreshPosition = false;
|
|
243
173
|
}
|
|
244
|
-
|
|
174
|
+
$:
|
|
175
|
+
if (closeOnClickOutside && !!menuElement) {
|
|
245
176
|
window.addEventListener("mousedown", () => {
|
|
246
177
|
open = false;
|
|
247
178
|
});
|
|
248
|
-
|
|
249
179
|
window.addEventListener("touchstart", () => {
|
|
250
180
|
open = false;
|
|
251
181
|
});
|
|
252
|
-
|
|
253
182
|
if (activator) {
|
|
254
183
|
activator.addEventListener("mousedown", (event) => {
|
|
255
184
|
event.stopPropagation();
|
|
256
185
|
});
|
|
257
|
-
|
|
258
186
|
activator.addEventListener("touchstart", (event) => {
|
|
259
187
|
event.stopPropagation();
|
|
260
188
|
});
|
|
261
189
|
}
|
|
262
|
-
|
|
263
190
|
menuElement.addEventListener("mousedown", (event) => {
|
|
264
191
|
event.stopPropagation();
|
|
265
192
|
});
|
|
266
|
-
|
|
267
193
|
menuElement.addEventListener("touchstart", (event) => {
|
|
268
194
|
event.stopPropagation();
|
|
269
195
|
});
|
|
270
196
|
}
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
positionedAncestor = elem == null ? undefined : elem
|
|
278
|
-
calculateMenuPosition({menuElement, activator})
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
function getPositionedAncestor(elem: HTMLElement | null): HTMLElement | null {
|
|
282
|
-
if (!elem) return null
|
|
283
|
-
if (['fixed', 'absolute', 'sticky', 'relative'].includes(getComputedStyle(elem).position)) return elem
|
|
284
|
-
return getPositionedAncestor(elem.parentElement)
|
|
197
|
+
let positionedAncestor = void 0;
|
|
198
|
+
$:
|
|
199
|
+
if (!!menuElement && !!activator) {
|
|
200
|
+
let elem = getPositionedAncestor(menuElement.parentElement);
|
|
201
|
+
positionedAncestor = elem == null ? void 0 : elem;
|
|
202
|
+
calculateMenuPosition({ menuElement, activator });
|
|
285
203
|
}
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
left = left + boundingClientRect.left
|
|
315
|
-
fixedParent = activatorParent
|
|
316
|
-
}
|
|
317
|
-
|
|
318
|
-
if(position === 'sticky') {
|
|
319
|
-
stickyParent = activatorParent
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
if(position === 'relative' && !!stickyParent) {
|
|
323
|
-
isStickyValid = true
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
activatorParent = activatorParent.parentElement
|
|
327
|
-
|
|
204
|
+
function getPositionedAncestor(elem) {
|
|
205
|
+
if (!elem)
|
|
206
|
+
return null;
|
|
207
|
+
if (["fixed", "absolute", "sticky", "relative"].includes(getComputedStyle(elem).position))
|
|
208
|
+
return elem;
|
|
209
|
+
return getPositionedAncestor(elem.parentElement);
|
|
210
|
+
}
|
|
211
|
+
function handleCloseControllerClick() {
|
|
212
|
+
open = false;
|
|
213
|
+
}
|
|
214
|
+
function getParentInstanceFromViewport(activatorParent) {
|
|
215
|
+
let top = 0;
|
|
216
|
+
let left = 0;
|
|
217
|
+
let fixedParent = void 0;
|
|
218
|
+
let stickyParent = !!activatorParent && getComputedStyle(activatorParent).position === "sticky" ? activatorParent : void 0;
|
|
219
|
+
let isStickyValid = false;
|
|
220
|
+
while (!!activatorParent && activatorParent.nodeName.toLowerCase() !== "html" && activatorParent.nodeName.toLowerCase() !== "body") {
|
|
221
|
+
const currentParent = activatorParent.parentElement;
|
|
222
|
+
if (!currentParent)
|
|
223
|
+
break;
|
|
224
|
+
const computedStyle = getComputedStyle(currentParent);
|
|
225
|
+
const position = computedStyle.position;
|
|
226
|
+
const display = computedStyle.display;
|
|
227
|
+
if ((position === "fixed" || position === "absolute" || position === "relative") && display === "flex") {
|
|
228
|
+
const boundingClientRect = activatorParent.getBoundingClientRect();
|
|
229
|
+
top = top + boundingClientRect.top;
|
|
230
|
+
left = left + boundingClientRect.left;
|
|
231
|
+
fixedParent = activatorParent;
|
|
328
232
|
}
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
233
|
+
if (position === "sticky") {
|
|
234
|
+
stickyParent = activatorParent;
|
|
235
|
+
}
|
|
236
|
+
if (position === "relative" && !!stickyParent) {
|
|
237
|
+
isStickyValid = true;
|
|
238
|
+
}
|
|
239
|
+
activatorParent = activatorParent.parentElement;
|
|
334
240
|
}
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
241
|
+
return { top, left, fixedParent, validStickyParent: isStickyValid ? stickyParent : void 0 };
|
|
242
|
+
}
|
|
243
|
+
function refreshMenuPosition() {
|
|
244
|
+
if (open && !!menuElement && !!activator)
|
|
245
|
+
calculateMenuPosition({ menuElement, activator });
|
|
246
|
+
}
|
|
247
|
+
function handleMenuClick(e, zIndex2) {
|
|
248
|
+
let otherMenus = document.querySelectorAll(`[data-menu]`);
|
|
249
|
+
otherMenus.forEach((m) => {
|
|
250
|
+
let uid = m.getAttribute("data-uid");
|
|
251
|
+
if (uid !== currentUid && Number(m.style.zIndex) > zIndex2) {
|
|
252
|
+
let controller = document.querySelector(`[data-operation="close"][data-uid="${uid}"]`);
|
|
253
|
+
if (!!controller) {
|
|
254
|
+
const clickEvent = new MouseEvent("click", {
|
|
255
|
+
bubbles: false,
|
|
256
|
+
cancelable: true,
|
|
257
|
+
view: window
|
|
258
|
+
});
|
|
259
|
+
controller.dispatchEvent(clickEvent);
|
|
350
260
|
}
|
|
351
|
-
}
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
261
|
+
}
|
|
262
|
+
});
|
|
263
|
+
}
|
|
264
|
+
$:
|
|
265
|
+
if ($sidebarOpened !== void 0)
|
|
266
|
+
setTimeout(refreshMenuPosition, 300);
|
|
356
267
|
</script>
|
|
357
268
|
|
|
358
269
|
<svelte:window on:scroll={refreshMenuPosition} on:resize={refreshMenuPosition} ></svelte:window>
|
|
@@ -1,54 +1,43 @@
|
|
|
1
|
+
import { SvelteComponent } from "svelte";
|
|
1
2
|
import { type FadeParams, type FlyParams, type SlideParams, type TransitionConfig } from "svelte/transition";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
3
|
+
declare const __propDef: {
|
|
4
|
+
props: {
|
|
5
|
+
_top?: number | undefined;
|
|
6
|
+
_left?: number | undefined;
|
|
7
|
+
_width?: string | undefined;
|
|
8
|
+
_height?: string | undefined;
|
|
9
|
+
_maxHeight?: string | undefined;
|
|
10
|
+
_minWidth?: string | undefined;
|
|
11
|
+
_overflow?: string | undefined;
|
|
12
|
+
_boxShadow?: string | undefined;
|
|
13
|
+
_borderRadius?: string | undefined;
|
|
14
|
+
_activatorGap?: number | undefined;
|
|
15
|
+
open?: boolean | undefined;
|
|
16
|
+
refreshPosition?: boolean | undefined;
|
|
17
|
+
activator?: HTMLElement | undefined;
|
|
18
|
+
anchor?: "bottom" | "bottom-center" | "right-center" | undefined;
|
|
19
|
+
closeOnClickOutside?: boolean | undefined;
|
|
20
|
+
inAnimation?: ((node: Element, params?: SlideParams | FlyParams | FadeParams) => TransitionConfig) | undefined;
|
|
21
|
+
inAnimationConfig?: SlideParams | FlyParams | FadeParams | undefined;
|
|
22
|
+
outAnimation?: ((node: Element, params?: SlideParams | FlyParams | FadeParams) => TransitionConfig) | undefined;
|
|
23
|
+
outAnimationConfig?: SlideParams | FlyParams | FadeParams | undefined;
|
|
24
|
+
menuElement?: HTMLElement | undefined;
|
|
25
|
+
flipOnOverflow?: boolean | undefined;
|
|
26
|
+
stayInViewport?: boolean | undefined;
|
|
27
|
+
openingId?: string | undefined;
|
|
12
28
|
};
|
|
13
|
-
|
|
29
|
+
events: {
|
|
30
|
+
keydown: KeyboardEvent;
|
|
31
|
+
} & {
|
|
32
|
+
[evt: string]: CustomEvent<any>;
|
|
33
|
+
};
|
|
34
|
+
slots: {
|
|
35
|
+
default: {};
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
export type MenuProps = typeof __propDef.props;
|
|
39
|
+
export type MenuEvents = typeof __propDef.events;
|
|
40
|
+
export type MenuSlots = typeof __propDef.slots;
|
|
41
|
+
export default class Menu extends SvelteComponent<MenuProps, MenuEvents, MenuSlots> {
|
|
14
42
|
}
|
|
15
|
-
|
|
16
|
-
default: any;
|
|
17
|
-
} ? Props extends Record<string, never> ? any : {
|
|
18
|
-
children?: any;
|
|
19
|
-
} : {});
|
|
20
|
-
declare const Menu: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
|
|
21
|
-
_top?: number | undefined;
|
|
22
|
-
_left?: number | undefined;
|
|
23
|
-
_width?: string;
|
|
24
|
-
_height?: string;
|
|
25
|
-
_maxHeight?: string | undefined;
|
|
26
|
-
_minWidth?: string | undefined;
|
|
27
|
-
_overflow?: string;
|
|
28
|
-
_boxShadow?: string | undefined;
|
|
29
|
-
_borderRadius?: string | undefined;
|
|
30
|
-
_activatorGap?: number;
|
|
31
|
-
open?: boolean;
|
|
32
|
-
refreshPosition?: boolean;
|
|
33
|
-
activator?: HTMLElement | undefined;
|
|
34
|
-
anchor?: "bottom" | "bottom-center" | "right-center";
|
|
35
|
-
closeOnClickOutside?: boolean;
|
|
36
|
-
inAnimation?: (node: Element, params?: SlideParams | FlyParams | FadeParams) => TransitionConfig;
|
|
37
|
-
inAnimationConfig?: SlideParams | FlyParams | FadeParams;
|
|
38
|
-
outAnimation?: (node: Element, params?: SlideParams | FlyParams | FadeParams) => TransitionConfig;
|
|
39
|
-
outAnimationConfig?: SlideParams | FlyParams | FadeParams;
|
|
40
|
-
menuElement?: HTMLElement | undefined;
|
|
41
|
-
flipOnOverflow?: boolean;
|
|
42
|
-
stayInViewport?: boolean;
|
|
43
|
-
openingId?: string | undefined;
|
|
44
|
-
}, {
|
|
45
|
-
default: {};
|
|
46
|
-
}>, {
|
|
47
|
-
keydown: KeyboardEvent;
|
|
48
|
-
} & {
|
|
49
|
-
[evt: string]: CustomEvent<any>;
|
|
50
|
-
}, {
|
|
51
|
-
default: {};
|
|
52
|
-
}, {}, string>;
|
|
53
|
-
type Menu = InstanceType<typeof Menu>;
|
|
54
|
-
export default Menu;
|
|
43
|
+
export {};
|