@sdata/web-vue 1.13.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.
Files changed (241) hide show
  1. package/dist/sd.css +364 -1
  2. package/dist/sd.min.css +1 -1
  3. package/es/_components/picker/input-range.vue.d.ts +2 -2
  4. package/es/_components/picker/input.vue.d.ts +1 -1
  5. package/es/_components/resize-trigger.vue_vue_type_script_lang.js +1 -1
  6. package/es/_components/select-view/select-view.d.ts +2 -2
  7. package/es/_components/virtual-list/virtual-list.vue.d.ts +3 -3
  8. package/es/_hooks/use-config-provider-prop.d.ts +10 -0
  9. package/es/_hooks/use-config-provider-prop.js +19 -0
  10. package/es/_hooks/use-popup-manager.js +2 -4
  11. package/es/_utils/dom.d.ts +5 -2
  12. package/es/_utils/dom.js +1 -1
  13. package/es/anchor/anchor.vue.d.ts +2 -2
  14. package/es/anchor/index.d.ts +9 -9
  15. package/es/auto-complete/auto-complete.d.ts +3 -3
  16. package/es/auto-complete/index.d.ts +9 -9
  17. package/es/button/button.vue.d.ts +2 -2
  18. package/es/button/index.d.ts +6 -6
  19. package/es/calendar/calendar.d.ts +1 -1
  20. package/es/calendar/index.d.ts +3 -3
  21. package/es/card/card.d.ts +4 -4
  22. package/es/card/index.d.ts +9 -9
  23. package/es/carousel/carousel-arrow.vue.d.ts +1 -1
  24. package/es/carousel/carousel-indicator.vue.d.ts +1 -1
  25. package/es/carousel/carousel.d.ts +3 -3
  26. package/es/carousel/index.d.ts +9 -9
  27. package/es/cascader/base-cascader-panel.d.ts +1 -1
  28. package/es/cascader/cascader-search-panel.d.ts +1 -1
  29. package/es/cascader/cascader.vue.d.ts +14 -14
  30. package/es/checkbox/checkbox-group.d.ts +1 -1
  31. package/es/checkbox/index.d.ts +1 -1
  32. package/es/color-picker/color-picker.d.ts +5 -5
  33. package/es/color-picker/index.d.ts +15 -15
  34. package/es/color-picker/panel.d.ts +2 -2
  35. package/es/components.d.ts +1 -0
  36. package/es/config-provider/config-provider.vue.d.ts +26 -1
  37. package/es/config-provider/config-provider.vue_vue_type_script_lang.js +25 -1
  38. package/es/config-provider/context.d.ts +52 -1
  39. package/es/config-provider/index.d.ts +40 -3
  40. package/es/cropper/cropper.vue.d.ts +1 -1
  41. package/es/cropper/index.d.ts +3 -3
  42. package/es/date-picker/index.d.ts +107 -107
  43. package/es/date-picker/panels/date/index.vue.d.ts +15 -15
  44. package/es/date-picker/panels/footer.vue.d.ts +15 -15
  45. package/es/date-picker/panels/shortcuts.vue.d.ts +6 -6
  46. package/es/date-picker/panels/week/index.vue.d.ts +16 -16
  47. package/es/date-picker/picker-panel.vue.d.ts +54 -54
  48. package/es/date-picker/picker.vue.d.ts +94 -94
  49. package/es/date-picker/picker.vue_vue_type_script_lang.js +62 -11
  50. package/es/date-picker/pickers/date-picker.d.ts +1 -1
  51. package/es/date-picker/pickers/week-picker.d.ts +1 -1
  52. package/es/date-picker/range-picker-panel.vue.d.ts +55 -55
  53. package/es/date-picker/range-picker.vue.d.ts +182 -182
  54. package/es/date-picker/range-picker.vue_vue_type_script_lang.js +54 -10
  55. package/es/descriptions/descriptions.d.ts +1 -1
  56. package/es/descriptions/index.d.ts +3 -3
  57. package/es/drawer/drawer.js +9 -9
  58. package/es/drawer/drawer.vue.d.ts +21 -11
  59. package/es/drawer/drawer.vue_vue_type_script_lang.js +118 -9
  60. package/es/drawer/index.d.ts +57 -27
  61. package/es/dropdown/dropdown-button.vue.d.ts +24 -24
  62. package/es/dropdown/dropdown-submenu.vue.d.ts +17 -17
  63. package/es/dropdown/dropdown.vue.d.ts +16 -16
  64. package/es/dropdown/index.d.ts +74 -74
  65. package/es/ellipsis/ellipsis.vue.d.ts +43 -43
  66. package/es/ellipsis/index.d.ts +182 -182
  67. package/es/ellipsis/performant-ellipsis.vue.d.ts +44 -44
  68. package/es/form/form-item-label.vue.d.ts +36 -36
  69. package/es/form/form-item.vue.d.ts +40 -40
  70. package/es/form/index.d.ts +40 -40
  71. package/es/grid/grid-row.vue.d.ts +3 -3
  72. package/es/grid/index.d.ts +3 -3
  73. package/es/image/image.vue.d.ts +38 -38
  74. package/es/image/preview-action.d.ts +36 -36
  75. package/es/image/preview-group.vue.d.ts +41 -41
  76. package/es/image/preview-toolbar.vue.d.ts +36 -36
  77. package/es/image/preview.vue.d.ts +38 -38
  78. package/es/index.css +364 -1
  79. package/es/index.d.ts +5 -1
  80. package/es/index.js +17 -15
  81. package/es/index.scss +1 -0
  82. package/es/input/index.d.ts +9 -9
  83. package/es/input/input-password.vue.d.ts +2 -2
  84. package/es/input/input-search.d.ts +1 -1
  85. package/es/input/input.d.ts +2 -2
  86. package/es/input-number/index.d.ts +9 -9
  87. package/es/input-number/input-number.d.ts +3 -3
  88. package/es/input-tag/index.d.ts +6 -6
  89. package/es/input-tag/input-tag.d.ts +2 -2
  90. package/es/json-form/index.d.ts +112 -0
  91. package/es/json-form/index.js +11 -0
  92. package/es/json-form/json-form-component.js +5 -0
  93. package/es/json-form/json-form-component.vue.d.ts +24 -0
  94. package/es/json-form/json-form-component.vue_vue_type_script_setup_true_lang.js +89 -0
  95. package/es/json-form/json-form-item.js +5 -0
  96. package/es/json-form/json-form-item.vue.d.ts +32 -0
  97. package/es/json-form/json-form-item.vue_vue_type_script_setup_true_lang.js +213 -0
  98. package/es/json-form/json-form.js +5 -0
  99. package/es/json-form/json-form.vue.d.ts +42 -0
  100. package/es/json-form/json-form.vue_vue_type_script_setup_true_lang.js +142 -0
  101. package/es/json-form/style/css.js +2 -0
  102. package/es/json-form/style/index.css +31 -0
  103. package/es/json-form/style/index.d.ts +2 -0
  104. package/es/json-form/style/index.js +2 -0
  105. package/es/json-form/style/index.scss +25 -0
  106. package/es/json-form/style/token.scss +8 -0
  107. package/es/json-form/types.d.ts +291 -0
  108. package/es/json-form/types.js +43 -0
  109. package/es/json-form/utils.d.ts +11 -0
  110. package/es/json-form/utils.js +336 -0
  111. package/es/layout/header.js +2 -18
  112. package/es/layout/header.vue.d.ts +38 -3
  113. package/es/layout/header.vue_vue_type_script_setup_true_lang.js +350 -0
  114. package/es/layout/index.d.ts +1029 -49
  115. package/es/layout/interface.d.ts +40 -0
  116. package/es/layout/sider.js +38 -9
  117. package/es/layout/sider.vue.d.ts +950 -39
  118. package/es/layout/sider.vue_vue_type_script_lang.js +304 -31
  119. package/es/layout/style/index.css +155 -1
  120. package/es/layout/style/index.scss +198 -16
  121. package/es/layout/style/token.scss +13 -0
  122. package/es/link/index.d.ts +9 -9
  123. package/es/link/link.vue.d.ts +3 -3
  124. package/es/list/index.d.ts +3 -3
  125. package/es/list/list.d.ts +1 -1
  126. package/es/mention/index.d.ts +12 -12
  127. package/es/mention/mention.d.ts +4 -4
  128. package/es/menu/base-menu.vue.d.ts +24 -5
  129. package/es/menu/base-menu.vue_vue_type_script_lang.js +19 -1
  130. package/es/menu/context.d.ts +1 -1
  131. package/es/menu/index.d.ts +1 -1
  132. package/es/menu/interface.d.ts +8 -0
  133. package/es/menu/item-group.js +9 -2
  134. package/es/menu/item-group.vue.d.ts +2894 -0
  135. package/es/menu/item-group.vue_vue_type_script_lang.js +7 -2
  136. package/es/menu/item.d.ts +1 -1
  137. package/es/menu/item.js +10 -3
  138. package/es/menu/menu.d.ts +54 -5
  139. package/es/menu/menu.js +8 -0
  140. package/es/menu/style/css.js +1 -0
  141. package/es/menu/style/index.css +194 -0
  142. package/es/menu/style/index.d.ts +1 -0
  143. package/es/menu/style/index.js +1 -0
  144. package/es/menu/style/index.scss +48 -1
  145. package/es/menu/sub-menu-inline.js +24 -3
  146. package/es/menu/sub-menu-inline.vue.d.ts +2894 -0
  147. package/es/menu/sub-menu-inline.vue_vue_type_script_lang.js +4 -1
  148. package/es/menu/sub-menu-pop.js +29 -2
  149. package/es/menu/sub-menu-pop.vue.d.ts +2924 -22
  150. package/es/menu/sub-menu-pop.vue_vue_type_script_lang.js +3 -1
  151. package/es/menu/sub-menu.d.ts +1 -1
  152. package/es/message/message-list.d.ts +1 -1
  153. package/es/message/message.vue.d.ts +1 -1
  154. package/es/modal/index.d.ts +51 -27
  155. package/es/modal/modal.js +8 -8
  156. package/es/modal/modal.vue.d.ts +19 -11
  157. package/es/modal/modal.vue_vue_type_script_lang.js +134 -12
  158. package/es/notification/notification.vue.d.ts +1 -1
  159. package/es/overflow-list/index.d.ts +3 -3
  160. package/es/overflow-list/overflow-list.d.ts +1 -1
  161. package/es/pagination/page-jumper.vue.d.ts +9 -9
  162. package/es/pagination/page-options.vue.d.ts +66 -66
  163. package/es/popconfirm/index.d.ts +51 -51
  164. package/es/popconfirm/popconfirm.vue.d.ts +24 -24
  165. package/es/popover/index.d.ts +33 -33
  166. package/es/popover/popover.vue.d.ts +16 -16
  167. package/es/progress/circle.vue.d.ts +2 -2
  168. package/es/progress/index.d.ts +13 -13
  169. package/es/progress/line.vue.d.ts +1 -1
  170. package/es/progress/progress.vue.d.ts +6 -6
  171. package/es/progress/steps.vue.d.ts +2 -2
  172. package/es/radio/index.d.ts +4 -4
  173. package/es/radio/radio-group.d.ts +1 -1
  174. package/es/radio/radio.d.ts +1 -1
  175. package/es/sd-vue.js +17 -14
  176. package/es/select/index.d.ts +66 -66
  177. package/es/select/option.vue.d.ts +2 -2
  178. package/es/select/select-dropdown.vue.d.ts +4 -4
  179. package/es/select/select.d.ts +27 -27
  180. package/es/skeleton/index.d.ts +1 -1
  181. package/es/skeleton/shape.vue.d.ts +1 -1
  182. package/es/slider/index.d.ts +97 -97
  183. package/es/slider/slider-button.vue.d.ts +38 -38
  184. package/es/slider/slider-input.vue.d.ts +9 -9
  185. package/es/slider/slider.vue.d.ts +48 -48
  186. package/es/spin/index.d.ts +3 -3
  187. package/es/spin/spin.d.ts +1 -1
  188. package/es/statistic/index.d.ts +6 -6
  189. package/es/statistic/statistic.vue.d.ts +2 -2
  190. package/es/steps/index.d.ts +6 -6
  191. package/es/steps/steps.vue.d.ts +2 -2
  192. package/es/style/theme/z-index.d.ts +8 -0
  193. package/es/style/theme/z-index.js +7 -0
  194. package/es/switch/index.d.ts +21 -6
  195. package/es/switch/switch.vue.d.ts +11 -2
  196. package/es/switch/switch.vue_vue_type_script_lang.js +30 -5
  197. package/es/table/index.d.ts +15 -15
  198. package/es/table/table-operation-td.d.ts +5 -5
  199. package/es/table/table-th.js +1 -1
  200. package/es/table/table.d.ts +5 -5
  201. package/es/tabs/index.d.ts +9 -9
  202. package/es/tabs/tabs.d.ts +3 -3
  203. package/es/tag/index.d.ts +922 -922
  204. package/es/tag/tag.vue.d.ts +367 -367
  205. package/es/textarea/index.d.ts +6 -6
  206. package/es/textarea/textarea.vue.d.ts +2 -2
  207. package/es/time-picker/index.d.ts +104 -104
  208. package/es/time-picker/panel.vue.d.ts +14 -14
  209. package/es/time-picker/range-panel.d.ts +14 -14
  210. package/es/time-picker/time-picker.vue.d.ts +50 -50
  211. package/es/timeline/index.d.ts +9 -9
  212. package/es/timeline/timeline.d.ts +4 -4
  213. package/es/tooltip/index.d.ts +36 -36
  214. package/es/tooltip/tooltip.vue.d.ts +17 -17
  215. package/es/transfer/index.d.ts +37 -37
  216. package/es/transfer/transfer-list-item.d.ts +2 -2
  217. package/es/transfer/transfer-view.vue.d.ts +8 -8
  218. package/es/transfer/transfer-view.vue_vue_type_script_lang.js +1 -1
  219. package/es/transfer/transfer.vue.d.ts +17 -17
  220. package/es/tree/base-node.vue.d.ts +2 -2
  221. package/es/tree/base-node.vue_vue_type_script_lang.js +1 -1
  222. package/es/tree/node-switcher.vue_vue_type_script_lang.js +1 -1
  223. package/es/tree/transition-node-list.vue.d.ts +2 -2
  224. package/es/tree/tree.vue.d.ts +27 -27
  225. package/es/tree/tree.vue_vue_type_script_lang.js +3 -3
  226. package/es/tree-select/tree-select.vue.d.ts +30 -30
  227. package/es/tree-select/tree-select.vue_vue_type_script_lang.js +2 -2
  228. package/es/trigger/index.d.ts +15 -15
  229. package/es/trigger/trigger.d.ts +5 -5
  230. package/es/typography/base.d.ts +1 -1
  231. package/es/typography/edit-content.vue.d.ts +27 -27
  232. package/es/typography/operations.vue.d.ts +36 -36
  233. package/es/upload/index.d.ts +6 -6
  234. package/es/upload/upload-button.d.ts +1 -1
  235. package/es/upload/upload.d.ts +2 -2
  236. package/es/watermark/index.d.ts +3 -3
  237. package/es/watermark/watermark.d.ts +1 -1
  238. package/json/vetur-attributes.json +159 -7
  239. package/json/vetur-tags.json +48 -4
  240. package/json/web-types.json +344 -23
  241. 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 };