@sdata/web-vue 1.14.0 → 1.18.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/sd.css +364 -1
- package/dist/sd.min.css +1 -1
- package/es/_components/picker/input-range.vue.d.ts +2 -2
- package/es/_components/picker/input.vue.d.ts +1 -1
- package/es/_components/resize-trigger.vue_vue_type_script_lang.js +1 -1
- package/es/_components/select-view/select-view.d.ts +2 -2
- package/es/_components/virtual-list/virtual-list.vue.d.ts +3 -3
- package/es/_hooks/use-popup-manager.js +2 -4
- package/es/_utils/dom.d.ts +5 -2
- package/es/_utils/dom.js +1 -1
- package/es/anchor/anchor.vue.d.ts +2 -2
- package/es/anchor/index.d.ts +9 -9
- package/es/auto-complete/auto-complete.d.ts +3 -3
- package/es/auto-complete/index.d.ts +9 -9
- package/es/button/button.vue.d.ts +2 -2
- package/es/button/index.d.ts +6 -6
- package/es/calendar/calendar.d.ts +1 -1
- package/es/calendar/index.d.ts +3 -3
- package/es/card/card.d.ts +4 -4
- package/es/card/index.d.ts +9 -9
- package/es/carousel/carousel-arrow.vue.d.ts +1 -1
- package/es/carousel/carousel-indicator.vue.d.ts +1 -1
- package/es/carousel/carousel.d.ts +3 -3
- package/es/carousel/index.d.ts +9 -9
- package/es/cascader/base-cascader-panel.d.ts +1 -1
- package/es/cascader/cascader-search-panel.d.ts +1 -1
- package/es/cascader/cascader.vue.d.ts +14 -14
- package/es/checkbox/checkbox-group.d.ts +1 -1
- package/es/checkbox/index.d.ts +1 -1
- package/es/color-picker/color-picker.d.ts +5 -5
- package/es/color-picker/index.d.ts +15 -15
- package/es/color-picker/panel.d.ts +2 -2
- package/es/components.d.ts +1 -0
- package/es/config-provider/config-provider.vue.d.ts +8 -2
- package/es/config-provider/config-provider.vue_vue_type_script_lang.js +6 -0
- package/es/config-provider/context.d.ts +3 -0
- package/es/config-provider/index.d.ts +13 -3
- package/es/cropper/cropper.vue.d.ts +1 -1
- package/es/cropper/index.d.ts +3 -3
- package/es/date-picker/index.d.ts +94 -94
- package/es/date-picker/panels/date/index.vue.d.ts +15 -15
- package/es/date-picker/panels/footer.vue.d.ts +15 -15
- package/es/date-picker/panels/shortcuts.vue.d.ts +6 -6
- package/es/date-picker/panels/week/index.vue.d.ts +16 -16
- package/es/date-picker/picker-panel.vue.d.ts +54 -54
- package/es/date-picker/picker.vue.d.ts +87 -87
- package/es/date-picker/pickers/date-picker.d.ts +1 -1
- package/es/date-picker/pickers/week-picker.d.ts +1 -1
- package/es/date-picker/range-picker-panel.vue.d.ts +55 -55
- package/es/date-picker/range-picker.vue.d.ts +90 -90
- package/es/descriptions/descriptions.d.ts +1 -1
- package/es/descriptions/index.d.ts +3 -3
- package/es/drawer/drawer.vue.d.ts +11 -11
- package/es/drawer/index.d.ts +27 -27
- package/es/dropdown/dropdown-button.vue.d.ts +24 -24
- package/es/dropdown/dropdown-submenu.vue.d.ts +17 -17
- package/es/dropdown/dropdown.vue.d.ts +16 -16
- package/es/dropdown/index.d.ts +74 -74
- package/es/ellipsis/ellipsis.vue.d.ts +43 -43
- package/es/ellipsis/index.d.ts +182 -182
- package/es/ellipsis/performant-ellipsis.vue.d.ts +44 -44
- package/es/form/form-item-label.vue.d.ts +36 -36
- package/es/form/form-item.vue.d.ts +40 -40
- package/es/form/index.d.ts +40 -40
- package/es/grid/grid-row.vue.d.ts +3 -3
- package/es/grid/index.d.ts +3 -3
- package/es/image/image.vue.d.ts +38 -38
- package/es/image/preview-action.d.ts +36 -36
- package/es/image/preview-group.vue.d.ts +41 -41
- package/es/image/preview-toolbar.vue.d.ts +36 -36
- package/es/image/preview.vue.d.ts +38 -38
- package/es/index.css +364 -1
- package/es/index.d.ts +5 -1
- package/es/index.js +17 -15
- package/es/index.scss +1 -0
- package/es/input/index.d.ts +9 -9
- package/es/input/input-password.vue.d.ts +2 -2
- package/es/input/input-search.d.ts +1 -1
- package/es/input/input.d.ts +2 -2
- package/es/input-number/index.d.ts +9 -9
- package/es/input-number/input-number.d.ts +3 -3
- package/es/input-tag/index.d.ts +6 -6
- package/es/input-tag/input-tag.d.ts +2 -2
- package/es/json-form/index.d.ts +112 -0
- package/es/json-form/index.js +11 -0
- package/es/json-form/json-form-component.js +5 -0
- package/es/json-form/json-form-component.vue.d.ts +24 -0
- package/es/json-form/json-form-component.vue_vue_type_script_setup_true_lang.js +89 -0
- package/es/json-form/json-form-item.js +5 -0
- package/es/json-form/json-form-item.vue.d.ts +32 -0
- package/es/json-form/json-form-item.vue_vue_type_script_setup_true_lang.js +213 -0
- package/es/json-form/json-form.js +5 -0
- package/es/json-form/json-form.vue.d.ts +42 -0
- package/es/json-form/json-form.vue_vue_type_script_setup_true_lang.js +142 -0
- package/es/json-form/style/css.js +2 -0
- package/es/json-form/style/index.css +31 -0
- package/es/json-form/style/index.d.ts +2 -0
- package/es/json-form/style/index.js +2 -0
- package/es/json-form/style/index.scss +25 -0
- package/es/json-form/style/token.scss +8 -0
- package/es/json-form/types.d.ts +291 -0
- package/es/json-form/types.js +43 -0
- package/es/json-form/utils.d.ts +11 -0
- package/es/json-form/utils.js +336 -0
- package/es/layout/header.js +2 -18
- package/es/layout/header.vue.d.ts +38 -3
- package/es/layout/header.vue_vue_type_script_setup_true_lang.js +350 -0
- package/es/layout/index.d.ts +1029 -49
- package/es/layout/interface.d.ts +40 -0
- package/es/layout/sider.js +38 -9
- package/es/layout/sider.vue.d.ts +950 -39
- package/es/layout/sider.vue_vue_type_script_lang.js +304 -31
- package/es/layout/style/index.css +155 -1
- package/es/layout/style/index.scss +198 -16
- package/es/layout/style/token.scss +13 -0
- package/es/link/index.d.ts +9 -9
- package/es/link/link.vue.d.ts +3 -3
- package/es/list/index.d.ts +3 -3
- package/es/list/list.d.ts +1 -1
- package/es/mention/index.d.ts +12 -12
- package/es/mention/mention.d.ts +4 -4
- package/es/menu/base-menu.vue.d.ts +24 -5
- package/es/menu/base-menu.vue_vue_type_script_lang.js +19 -1
- package/es/menu/context.d.ts +1 -1
- package/es/menu/index.d.ts +1 -1
- package/es/menu/interface.d.ts +8 -0
- package/es/menu/item-group.js +9 -2
- package/es/menu/item-group.vue.d.ts +2894 -0
- package/es/menu/item-group.vue_vue_type_script_lang.js +7 -2
- package/es/menu/item.d.ts +1 -1
- package/es/menu/item.js +10 -3
- package/es/menu/menu.d.ts +54 -5
- package/es/menu/menu.js +8 -0
- package/es/menu/style/css.js +1 -0
- package/es/menu/style/index.css +194 -0
- package/es/menu/style/index.d.ts +1 -0
- package/es/menu/style/index.js +1 -0
- package/es/menu/style/index.scss +48 -1
- package/es/menu/sub-menu-inline.js +24 -3
- package/es/menu/sub-menu-inline.vue.d.ts +2894 -0
- package/es/menu/sub-menu-inline.vue_vue_type_script_lang.js +4 -1
- package/es/menu/sub-menu-pop.js +29 -2
- package/es/menu/sub-menu-pop.vue.d.ts +2924 -22
- package/es/menu/sub-menu-pop.vue_vue_type_script_lang.js +3 -1
- package/es/menu/sub-menu.d.ts +1 -1
- package/es/message/message-list.d.ts +1 -1
- package/es/message/message.vue.d.ts +1 -1
- package/es/modal/index.d.ts +27 -27
- package/es/modal/modal.vue.d.ts +11 -11
- package/es/notification/notification.vue.d.ts +1 -1
- package/es/overflow-list/index.d.ts +3 -3
- package/es/overflow-list/overflow-list.d.ts +1 -1
- package/es/pagination/page-jumper.vue.d.ts +9 -9
- package/es/pagination/page-options.vue.d.ts +66 -66
- package/es/popconfirm/index.d.ts +51 -51
- package/es/popconfirm/popconfirm.vue.d.ts +24 -24
- package/es/popover/index.d.ts +33 -33
- package/es/popover/popover.vue.d.ts +16 -16
- package/es/progress/circle.vue.d.ts +2 -2
- package/es/progress/index.d.ts +13 -13
- package/es/progress/line.vue.d.ts +1 -1
- package/es/progress/progress.vue.d.ts +6 -6
- package/es/progress/steps.vue.d.ts +2 -2
- package/es/radio/index.d.ts +4 -4
- package/es/radio/radio-group.d.ts +1 -1
- package/es/radio/radio.d.ts +1 -1
- package/es/sd-vue.js +17 -14
- package/es/select/index.d.ts +66 -66
- package/es/select/option.vue.d.ts +2 -2
- package/es/select/select-dropdown.vue.d.ts +4 -4
- package/es/select/select.d.ts +27 -27
- package/es/skeleton/index.d.ts +1 -1
- package/es/skeleton/shape.vue.d.ts +1 -1
- package/es/slider/index.d.ts +97 -97
- package/es/slider/slider-button.vue.d.ts +38 -38
- package/es/slider/slider-input.vue.d.ts +9 -9
- package/es/slider/slider.vue.d.ts +48 -48
- package/es/spin/index.d.ts +3 -3
- package/es/spin/spin.d.ts +1 -1
- package/es/statistic/index.d.ts +6 -6
- package/es/statistic/statistic.vue.d.ts +2 -2
- package/es/steps/index.d.ts +6 -6
- package/es/steps/steps.vue.d.ts +2 -2
- package/es/style/theme/z-index.d.ts +8 -0
- package/es/style/theme/z-index.js +7 -0
- package/es/switch/index.d.ts +21 -6
- package/es/switch/switch.vue.d.ts +11 -2
- package/es/switch/switch.vue_vue_type_script_lang.js +30 -5
- package/es/table/index.d.ts +15 -15
- package/es/table/table-operation-td.d.ts +5 -5
- package/es/table/table-th.js +1 -1
- package/es/table/table.d.ts +5 -5
- package/es/tabs/index.d.ts +9 -9
- package/es/tabs/tabs.d.ts +3 -3
- package/es/tag/index.d.ts +922 -922
- package/es/tag/tag.vue.d.ts +367 -367
- package/es/textarea/index.d.ts +6 -6
- package/es/textarea/textarea.vue.d.ts +2 -2
- package/es/time-picker/index.d.ts +104 -104
- package/es/time-picker/panel.vue.d.ts +14 -14
- package/es/time-picker/range-panel.d.ts +14 -14
- package/es/time-picker/time-picker.vue.d.ts +50 -50
- package/es/timeline/index.d.ts +9 -9
- package/es/timeline/timeline.d.ts +4 -4
- package/es/tooltip/index.d.ts +36 -36
- package/es/tooltip/tooltip.vue.d.ts +17 -17
- package/es/transfer/index.d.ts +37 -37
- package/es/transfer/transfer-list-item.d.ts +2 -2
- package/es/transfer/transfer-view.vue.d.ts +8 -8
- package/es/transfer/transfer-view.vue_vue_type_script_lang.js +1 -1
- package/es/transfer/transfer.vue.d.ts +17 -17
- package/es/tree/base-node.vue.d.ts +2 -2
- package/es/tree/base-node.vue_vue_type_script_lang.js +1 -1
- package/es/tree/node-switcher.vue_vue_type_script_lang.js +1 -1
- package/es/tree/transition-node-list.vue.d.ts +2 -2
- package/es/tree/tree.vue.d.ts +27 -27
- package/es/tree/tree.vue_vue_type_script_lang.js +3 -3
- package/es/tree-select/tree-select.vue.d.ts +30 -30
- package/es/tree-select/tree-select.vue_vue_type_script_lang.js +2 -2
- package/es/trigger/index.d.ts +15 -15
- package/es/trigger/trigger.d.ts +5 -5
- package/es/typography/base.d.ts +1 -1
- package/es/typography/edit-content.vue.d.ts +27 -27
- package/es/typography/operations.vue.d.ts +36 -36
- package/es/upload/index.d.ts +6 -6
- package/es/upload/upload-button.d.ts +1 -1
- package/es/upload/upload.d.ts +2 -2
- package/es/watermark/index.d.ts +3 -3
- package/es/watermark/watermark.d.ts +1 -1
- package/json/vetur-attributes.json +150 -7
- package/json/vetur-tags.json +45 -4
- package/json/web-types.json +316 -19
- package/package.json +2 -1
|
@@ -0,0 +1,350 @@
|
|
|
1
|
+
import { _objectSpread2 } from "../_virtual/_@oxc-project_runtime@0.130.0/helpers/objectSpread2.js";
|
|
2
|
+
import { getPrefixCls } from "../_utils/global-config.js";
|
|
3
|
+
import { getElement, off, on } from "../_utils/dom.js";
|
|
4
|
+
import { computed, createCommentVNode, createElementBlock, createElementVNode, createTextVNode, defineComponent, getCurrentInstance, nextTick, normalizeClass, normalizeStyle, onBeforeUnmount, onMounted, openBlock, ref, renderSlot, toDisplayString, toRef, unref, useSlots, watch } from "vue";
|
|
5
|
+
//#region components/layout/header.vue?vue&type=script&setup=true&lang.ts
|
|
6
|
+
var _hoisted_1 = ["src"];
|
|
7
|
+
var scrollbarViewportSelector = "[data-overlayscrollbars-viewport]";
|
|
8
|
+
var header_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent(_objectSpread2(_objectSpread2({}, { name: "LayoutHeader" }), {}, {
|
|
9
|
+
__name: "header",
|
|
10
|
+
props: {
|
|
11
|
+
title: {},
|
|
12
|
+
image: {},
|
|
13
|
+
modelValue: { type: Boolean },
|
|
14
|
+
defaultVisible: {
|
|
15
|
+
type: Boolean,
|
|
16
|
+
default: true
|
|
17
|
+
},
|
|
18
|
+
height: { default: 64 },
|
|
19
|
+
density: { default: "default" },
|
|
20
|
+
extended: { type: Boolean },
|
|
21
|
+
extensionHeight: { default: 48 },
|
|
22
|
+
collapse: { type: Boolean },
|
|
23
|
+
flat: {
|
|
24
|
+
type: Boolean,
|
|
25
|
+
default: false
|
|
26
|
+
},
|
|
27
|
+
floating: {
|
|
28
|
+
type: Boolean,
|
|
29
|
+
default: false
|
|
30
|
+
},
|
|
31
|
+
fixed: {
|
|
32
|
+
type: Boolean,
|
|
33
|
+
default: false
|
|
34
|
+
},
|
|
35
|
+
sticky: {
|
|
36
|
+
type: Boolean,
|
|
37
|
+
default: false
|
|
38
|
+
},
|
|
39
|
+
absolute: {
|
|
40
|
+
type: Boolean,
|
|
41
|
+
default: false
|
|
42
|
+
},
|
|
43
|
+
location: { default: "top" },
|
|
44
|
+
scrollBehavior: {},
|
|
45
|
+
scrollTarget: {},
|
|
46
|
+
scrollThreshold: { default: 300 }
|
|
47
|
+
},
|
|
48
|
+
emits: ["update:modelValue"],
|
|
49
|
+
setup(__props, { emit: __emit }) {
|
|
50
|
+
const props = __props;
|
|
51
|
+
const emit = __emit;
|
|
52
|
+
const slots = useSlots();
|
|
53
|
+
const instance = getCurrentInstance();
|
|
54
|
+
const prefixCls = getPrefixCls("layout-header");
|
|
55
|
+
const scrollbarPrefixCls = getPrefixCls("scrollbar");
|
|
56
|
+
const headerRef = ref();
|
|
57
|
+
const modelValue = toRef(props, "modelValue");
|
|
58
|
+
const localVisible = ref(props.defaultVisible);
|
|
59
|
+
const currentScroll = ref(0);
|
|
60
|
+
const isScrollingUp = ref(false);
|
|
61
|
+
const isAtBottom = ref(false);
|
|
62
|
+
const reachedBottomWhileScrollingDown = ref(false);
|
|
63
|
+
const hasEnoughScrollableSpace = ref(true);
|
|
64
|
+
const scrollTargetRef = ref(null);
|
|
65
|
+
const isMounted = ref(false);
|
|
66
|
+
let previousScroll = 0;
|
|
67
|
+
let previousScrollHeight = 0;
|
|
68
|
+
const hasModelValueProp = computed(() => {
|
|
69
|
+
var _instance$vnode$props;
|
|
70
|
+
return Object.hasOwn((_instance$vnode$props = instance === null || instance === void 0 ? void 0 : instance.vnode.props) !== null && _instance$vnode$props !== void 0 ? _instance$vnode$props : {}, "modelValue");
|
|
71
|
+
});
|
|
72
|
+
const hasExtendedProp = computed(() => {
|
|
73
|
+
var _instance$vnode$props2;
|
|
74
|
+
return Object.hasOwn((_instance$vnode$props2 = instance === null || instance === void 0 ? void 0 : instance.vnode.props) !== null && _instance$vnode$props2 !== void 0 ? _instance$vnode$props2 : {}, "extended");
|
|
75
|
+
});
|
|
76
|
+
const mergedVisible = computed(() => hasModelValueProp.value ? Boolean(modelValue.value) : localVisible.value);
|
|
77
|
+
const setVisible = (nextVisible) => {
|
|
78
|
+
if (nextVisible !== mergedVisible.value) {
|
|
79
|
+
emit("update:modelValue", nextVisible);
|
|
80
|
+
localVisible.value = nextVisible;
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
watch(modelValue, (nextVisible) => {
|
|
84
|
+
if (hasModelValueProp.value) localVisible.value = nextVisible;
|
|
85
|
+
});
|
|
86
|
+
const parseSize = (value, fallback) => {
|
|
87
|
+
if (typeof value === "number") return value;
|
|
88
|
+
if (!value) return fallback;
|
|
89
|
+
const parsed = Number.parseFloat(value);
|
|
90
|
+
return Number.isNaN(parsed) ? fallback : parsed;
|
|
91
|
+
};
|
|
92
|
+
const resolveDensityOffset = (density, baseHeight) => {
|
|
93
|
+
if (density === "prominent") return baseHeight;
|
|
94
|
+
if (density === "comfortable") return -8;
|
|
95
|
+
if (density === "compact") return -16;
|
|
96
|
+
return 0;
|
|
97
|
+
};
|
|
98
|
+
const isWindowTarget = (target) => "document" in target;
|
|
99
|
+
const getScrollMetrics = (target) => {
|
|
100
|
+
if (isWindowTarget(target)) return {
|
|
101
|
+
clientHeight: window.innerHeight,
|
|
102
|
+
scrollHeight: document.documentElement.scrollHeight
|
|
103
|
+
};
|
|
104
|
+
return {
|
|
105
|
+
clientHeight: target.clientHeight,
|
|
106
|
+
scrollHeight: target.scrollHeight
|
|
107
|
+
};
|
|
108
|
+
};
|
|
109
|
+
const resolveScrollTop = (target) => {
|
|
110
|
+
if (isWindowTarget(target)) return window.pageYOffset;
|
|
111
|
+
return target.scrollTop;
|
|
112
|
+
};
|
|
113
|
+
const resolveScopedElement = (selector) => {
|
|
114
|
+
var _headerRef$value;
|
|
115
|
+
let scope = (_headerRef$value = headerRef.value) === null || _headerRef$value === void 0 ? void 0 : _headerRef$value.parentElement;
|
|
116
|
+
while (scope) {
|
|
117
|
+
if (scope.matches(selector)) return scope;
|
|
118
|
+
const scopedTarget = getElement(selector, scope);
|
|
119
|
+
if (scopedTarget) return scopedTarget;
|
|
120
|
+
scope = scope.parentElement;
|
|
121
|
+
}
|
|
122
|
+
return getElement(selector);
|
|
123
|
+
};
|
|
124
|
+
const resolveScrollableElement = (target) => {
|
|
125
|
+
if (target.matches(scrollbarViewportSelector)) return target;
|
|
126
|
+
const viewport = getElement(scrollbarViewportSelector, target);
|
|
127
|
+
if (viewport) return viewport;
|
|
128
|
+
if (target.classList.contains(scrollbarPrefixCls)) return null;
|
|
129
|
+
return target;
|
|
130
|
+
};
|
|
131
|
+
const resolveScrollTarget = () => {
|
|
132
|
+
if (typeof window === "undefined") return null;
|
|
133
|
+
if (!props.scrollTarget) return window;
|
|
134
|
+
const resolvedTarget = resolveScopedElement(props.scrollTarget);
|
|
135
|
+
if (!resolvedTarget) return null;
|
|
136
|
+
return resolveScrollableElement(resolvedTarget);
|
|
137
|
+
};
|
|
138
|
+
const behavior = computed(() => {
|
|
139
|
+
var _props$scrollBehavior;
|
|
140
|
+
const items = new Set((_props$scrollBehavior = props.scrollBehavior) === null || _props$scrollBehavior === void 0 ? void 0 : _props$scrollBehavior.split(" ").filter(Boolean));
|
|
141
|
+
return {
|
|
142
|
+
hide: items.has("hide"),
|
|
143
|
+
fullyHide: items.has("fully-hide"),
|
|
144
|
+
inverted: items.has("inverted"),
|
|
145
|
+
collapse: items.has("collapse"),
|
|
146
|
+
elevate: items.has("elevate"),
|
|
147
|
+
fadeImage: items.has("fade-image")
|
|
148
|
+
};
|
|
149
|
+
});
|
|
150
|
+
const scrollThreshold = computed(() => parseSize(props.scrollThreshold, 300));
|
|
151
|
+
const baseContentHeight = computed(() => parseSize(props.height, 64));
|
|
152
|
+
const contentHeight = computed(() => baseContentHeight.value + resolveDensityOffset(props.density, baseContentHeight.value));
|
|
153
|
+
const baseExtensionHeight = computed(() => parseSize(props.extensionHeight, 48));
|
|
154
|
+
const extensionEnabled = computed(() => hasExtendedProp.value ? Boolean(props.extended) : Boolean(slots.extension));
|
|
155
|
+
const measuredExtensionHeight = computed(() => {
|
|
156
|
+
if (!extensionEnabled.value) return 0;
|
|
157
|
+
return Math.max(0, baseExtensionHeight.value + resolveDensityOffset(props.density, baseExtensionHeight.value) / 2);
|
|
158
|
+
});
|
|
159
|
+
const fullHeight = computed(() => contentHeight.value + measuredExtensionHeight.value);
|
|
160
|
+
const scrollRatio = computed(() => {
|
|
161
|
+
if (scrollThreshold.value <= 0) return currentScroll.value === 0 ? 1 : 0;
|
|
162
|
+
const ratio = (scrollThreshold.value - currentScroll.value) / scrollThreshold.value;
|
|
163
|
+
return Math.min(1, Math.max(0, ratio));
|
|
164
|
+
});
|
|
165
|
+
const controlsVisibilityByScroll = computed(() => behavior.value.hide || behavior.value.fullyHide);
|
|
166
|
+
const isCollapsed = computed(() => !!props.collapse || behavior.value.collapse && (behavior.value.inverted ? scrollRatio.value > 0 : scrollRatio.value === 0));
|
|
167
|
+
const showExtension = computed(() => extensionEnabled.value && mergedVisible.value && !isCollapsed.value);
|
|
168
|
+
const renderedHeight = computed(() => {
|
|
169
|
+
if (!mergedVisible.value) return 0;
|
|
170
|
+
return contentHeight.value + (showExtension.value ? measuredExtensionHeight.value : 0);
|
|
171
|
+
});
|
|
172
|
+
const imageOpacity = computed(() => {
|
|
173
|
+
if (!behavior.value.fadeImage) return 1;
|
|
174
|
+
return behavior.value.inverted ? 1 - scrollRatio.value : scrollRatio.value;
|
|
175
|
+
});
|
|
176
|
+
const isFlat = computed(() => props.flat || behavior.value.fullyHide && !mergedVisible.value || behavior.value.elevate && (behavior.value.inverted ? currentScroll.value > 0 : currentScroll.value === 0));
|
|
177
|
+
const hasImage = computed(() => Boolean(props.image || slots.image));
|
|
178
|
+
const hasTitle = computed(() => Boolean(props.title || slots.title));
|
|
179
|
+
const wrapperClassNames = computed(() => [`${prefixCls}-wrapper`]);
|
|
180
|
+
const classNames = computed(() => [prefixCls, {
|
|
181
|
+
[`${prefixCls}-bottom`]: props.location === "bottom",
|
|
182
|
+
[`${prefixCls}-fixed`]: props.fixed,
|
|
183
|
+
[`${prefixCls}-sticky`]: props.sticky,
|
|
184
|
+
[`${prefixCls}-absolute`]: props.absolute,
|
|
185
|
+
[`${prefixCls}-flat`]: isFlat.value,
|
|
186
|
+
[`${prefixCls}-floating`]: props.floating,
|
|
187
|
+
[`${prefixCls}-hidden`]: !mergedVisible.value,
|
|
188
|
+
[`${prefixCls}-collapsed`]: isCollapsed.value,
|
|
189
|
+
[`${prefixCls}-with-image`]: hasImage.value,
|
|
190
|
+
[`${prefixCls}-with-extension`]: showExtension.value,
|
|
191
|
+
[`${prefixCls}-with-title`]: hasTitle.value
|
|
192
|
+
}]);
|
|
193
|
+
const wrapperStyles = computed(() => {
|
|
194
|
+
if (!props.fixed || props.absolute) return;
|
|
195
|
+
return { height: `${renderedHeight.value}px` };
|
|
196
|
+
});
|
|
197
|
+
const headerStyles = computed(() => {
|
|
198
|
+
const styles = {
|
|
199
|
+
"--sd-layout-header-content-height": `${contentHeight.value}px`,
|
|
200
|
+
"--sd-layout-header-extension-height": `${measuredExtensionHeight.value}px`,
|
|
201
|
+
"--sd-layout-header-image-opacity": String(imageOpacity.value),
|
|
202
|
+
"height": `${renderedHeight.value}px`
|
|
203
|
+
};
|
|
204
|
+
if (!mergedVisible.value && (props.fixed || props.sticky || props.absolute)) styles.transform = `translateY(${props.location === "bottom" ? fullHeight.value : -fullHeight.value}px)`;
|
|
205
|
+
if (props.fixed) {
|
|
206
|
+
styles.position = "fixed";
|
|
207
|
+
styles.left = "0";
|
|
208
|
+
styles.right = "0";
|
|
209
|
+
styles[props.location] = "0";
|
|
210
|
+
styles.zIndex = 10;
|
|
211
|
+
} else if (props.sticky) {
|
|
212
|
+
styles.position = "sticky";
|
|
213
|
+
styles[props.location] = "0";
|
|
214
|
+
styles.zIndex = 10;
|
|
215
|
+
} else if (props.absolute) {
|
|
216
|
+
styles.position = "absolute";
|
|
217
|
+
styles.left = "0";
|
|
218
|
+
styles.right = "0";
|
|
219
|
+
styles[props.location] = "0";
|
|
220
|
+
styles.zIndex = 10;
|
|
221
|
+
}
|
|
222
|
+
return styles;
|
|
223
|
+
});
|
|
224
|
+
const updateScrollableSpace = () => {
|
|
225
|
+
const target = scrollTargetRef.value;
|
|
226
|
+
if (!target) return;
|
|
227
|
+
const { clientHeight, scrollHeight } = getScrollMetrics(target);
|
|
228
|
+
hasEnoughScrollableSpace.value = scrollHeight - clientHeight > scrollThreshold.value + fullHeight.value;
|
|
229
|
+
};
|
|
230
|
+
const handleScroll = () => {
|
|
231
|
+
const target = scrollTargetRef.value;
|
|
232
|
+
if (!target) return;
|
|
233
|
+
previousScroll = currentScroll.value;
|
|
234
|
+
currentScroll.value = resolveScrollTop(target);
|
|
235
|
+
const currentHeight = isWindowTarget(target) ? document.documentElement.scrollHeight : target.scrollHeight;
|
|
236
|
+
if (currentHeight > previousScrollHeight) updateScrollableSpace();
|
|
237
|
+
previousScrollHeight = currentHeight;
|
|
238
|
+
isScrollingUp.value = currentScroll.value < previousScroll;
|
|
239
|
+
const { clientHeight, scrollHeight } = getScrollMetrics(target);
|
|
240
|
+
const atBottom = currentScroll.value + clientHeight >= scrollHeight - 5;
|
|
241
|
+
if (!isScrollingUp.value && atBottom && currentScroll.value >= scrollThreshold.value && hasEnoughScrollableSpace.value) reachedBottomWhileScrollingDown.value = true;
|
|
242
|
+
const scrollJumped = Math.abs(currentScroll.value - previousScroll) > 100;
|
|
243
|
+
const atTop = currentScroll.value <= 5;
|
|
244
|
+
if (isScrollingUp.value && previousScroll - currentScroll.value > 1 && !atBottom || scrollJumped && currentScroll.value < scrollThreshold.value || atTop) reachedBottomWhileScrollingDown.value = false;
|
|
245
|
+
isAtBottom.value = atBottom;
|
|
246
|
+
if (!controlsVisibilityByScroll.value) return;
|
|
247
|
+
if (behavior.value.inverted) {
|
|
248
|
+
setVisible(currentScroll.value > scrollThreshold.value);
|
|
249
|
+
return;
|
|
250
|
+
}
|
|
251
|
+
if (!hasEnoughScrollableSpace.value) {
|
|
252
|
+
setVisible(true);
|
|
253
|
+
return;
|
|
254
|
+
}
|
|
255
|
+
if (reachedBottomWhileScrollingDown.value) {
|
|
256
|
+
setVisible(false);
|
|
257
|
+
return;
|
|
258
|
+
}
|
|
259
|
+
setVisible(isScrollingUp.value && !isAtBottom.value || currentScroll.value < scrollThreshold.value);
|
|
260
|
+
};
|
|
261
|
+
const bindScrollTarget = (target) => {
|
|
262
|
+
if (scrollTargetRef.value) off(scrollTargetRef.value, "scroll", handleScroll);
|
|
263
|
+
scrollTargetRef.value = target;
|
|
264
|
+
previousScroll = target ? resolveScrollTop(target) : 0;
|
|
265
|
+
currentScroll.value = previousScroll;
|
|
266
|
+
previousScrollHeight = target ? getScrollMetrics(target).scrollHeight : 0;
|
|
267
|
+
isScrollingUp.value = false;
|
|
268
|
+
isAtBottom.value = false;
|
|
269
|
+
reachedBottomWhileScrollingDown.value = false;
|
|
270
|
+
if (!scrollTargetRef.value) return;
|
|
271
|
+
on(scrollTargetRef.value, "scroll", handleScroll, { passive: true });
|
|
272
|
+
updateScrollableSpace();
|
|
273
|
+
handleScroll();
|
|
274
|
+
};
|
|
275
|
+
const syncScrollTarget = () => {
|
|
276
|
+
bindScrollTarget(resolveScrollTarget());
|
|
277
|
+
};
|
|
278
|
+
watch(() => props.scrollTarget, () => {
|
|
279
|
+
if (typeof window === "undefined") return;
|
|
280
|
+
if (!isMounted.value && props.scrollTarget) return;
|
|
281
|
+
syncScrollTarget();
|
|
282
|
+
}, { immediate: true });
|
|
283
|
+
watch(scrollThreshold, () => {
|
|
284
|
+
updateScrollableSpace();
|
|
285
|
+
handleScroll();
|
|
286
|
+
});
|
|
287
|
+
onMounted(() => {
|
|
288
|
+
if (typeof window === "undefined") return;
|
|
289
|
+
isMounted.value = true;
|
|
290
|
+
syncScrollTarget();
|
|
291
|
+
on(window, "resize", updateScrollableSpace, { passive: true });
|
|
292
|
+
updateScrollableSpace();
|
|
293
|
+
handleScroll();
|
|
294
|
+
nextTick(() => {
|
|
295
|
+
syncScrollTarget();
|
|
296
|
+
updateScrollableSpace();
|
|
297
|
+
handleScroll();
|
|
298
|
+
});
|
|
299
|
+
});
|
|
300
|
+
onBeforeUnmount(() => {
|
|
301
|
+
if (scrollTargetRef.value) off(scrollTargetRef.value, "scroll", handleScroll);
|
|
302
|
+
if (typeof window !== "undefined") off(window, "resize", updateScrollableSpace);
|
|
303
|
+
});
|
|
304
|
+
return (_ctx, _cache) => {
|
|
305
|
+
return openBlock(), createElementBlock("div", {
|
|
306
|
+
class: normalizeClass(wrapperClassNames.value),
|
|
307
|
+
style: normalizeStyle(wrapperStyles.value)
|
|
308
|
+
}, [createElementVNode("header", {
|
|
309
|
+
ref_key: "headerRef",
|
|
310
|
+
ref: headerRef,
|
|
311
|
+
class: normalizeClass(classNames.value),
|
|
312
|
+
style: normalizeStyle(headerStyles.value)
|
|
313
|
+
}, [
|
|
314
|
+
hasImage.value ? (openBlock(), createElementBlock("div", {
|
|
315
|
+
key: 0,
|
|
316
|
+
class: normalizeClass(`${unref(prefixCls)}-image`)
|
|
317
|
+
}, [renderSlot(_ctx.$slots, "image", {}, () => [__props.image ? (openBlock(), createElementBlock("img", {
|
|
318
|
+
key: 0,
|
|
319
|
+
class: normalizeClass(`${unref(prefixCls)}-image-inner`),
|
|
320
|
+
src: __props.image,
|
|
321
|
+
alt: ""
|
|
322
|
+
}, null, 10, _hoisted_1)) : createCommentVNode("", true)])], 2)) : createCommentVNode("", true),
|
|
323
|
+
createElementVNode("div", { class: normalizeClass(`${unref(prefixCls)}-bar`) }, [
|
|
324
|
+
_ctx.$slots.prepend ? (openBlock(), createElementBlock("div", {
|
|
325
|
+
key: 0,
|
|
326
|
+
class: normalizeClass(`${unref(prefixCls)}-prepend`)
|
|
327
|
+
}, [renderSlot(_ctx.$slots, "prepend")], 2)) : createCommentVNode("", true),
|
|
328
|
+
hasTitle.value ? (openBlock(), createElementBlock("div", {
|
|
329
|
+
key: 1,
|
|
330
|
+
class: normalizeClass(`${unref(prefixCls)}-title`)
|
|
331
|
+
}, [renderSlot(_ctx.$slots, "title", {}, () => [createTextVNode(toDisplayString(__props.title), 1)])], 2)) : createCommentVNode("", true),
|
|
332
|
+
_ctx.$slots.default ? (openBlock(), createElementBlock("div", {
|
|
333
|
+
key: 2,
|
|
334
|
+
class: normalizeClass(`${unref(prefixCls)}-content`)
|
|
335
|
+
}, [renderSlot(_ctx.$slots, "default")], 2)) : createCommentVNode("", true),
|
|
336
|
+
_ctx.$slots.append ? (openBlock(), createElementBlock("div", {
|
|
337
|
+
key: 3,
|
|
338
|
+
class: normalizeClass(`${unref(prefixCls)}-append`)
|
|
339
|
+
}, [renderSlot(_ctx.$slots, "append")], 2)) : createCommentVNode("", true)
|
|
340
|
+
], 2),
|
|
341
|
+
showExtension.value ? (openBlock(), createElementBlock("div", {
|
|
342
|
+
key: 1,
|
|
343
|
+
class: normalizeClass(`${unref(prefixCls)}-extension`)
|
|
344
|
+
}, [renderSlot(_ctx.$slots, "extension")], 2)) : createCommentVNode("", true)
|
|
345
|
+
], 6)], 6);
|
|
346
|
+
};
|
|
347
|
+
}
|
|
348
|
+
}));
|
|
349
|
+
//#endregion
|
|
350
|
+
export { header_vue_vue_type_script_setup_true_lang_default as default };
|