scrollbar2.js 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. var core = require('@vueuse/core');
  5. require('../../../utils/index.js');
  6. require('../../../tokens/index.js');
  7. require('../../../hooks/index.js');
  8. var util = require('./util.js');
  9. var bar = require('./bar2.js');
  10. var scrollbar = require('./scrollbar.js');
  11. var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
  12. var index = require('../../../hooks/use-namespace/index.js');
  13. var style = require('../../../utils/dom/style.js');
  14. var shared = require('@vue/shared');
  15. var error = require('../../../utils/error.js');
  16. var scrollbar$1 = require('../../../tokens/scrollbar.js');
  17. const COMPONENT_NAME = "ElScrollbar";
  18. const __default__ = vue.defineComponent({
  19. name: COMPONENT_NAME
  20. });
  21. const _sfc_main = /* @__PURE__ */ vue.defineComponent({
  22. ...__default__,
  23. props: scrollbar.scrollbarProps,
  24. emits: scrollbar.scrollbarEmits,
  25. setup(__props, { expose, emit }) {
  26. const props = __props;
  27. const ns = index.useNamespace("scrollbar");
  28. let stopResizeObserver = void 0;
  29. let stopResizeListener = void 0;
  30. const scrollbarRef = vue.ref();
  31. const wrapRef = vue.ref();
  32. const resizeRef = vue.ref();
  33. const sizeWidth = vue.ref("0");
  34. const sizeHeight = vue.ref("0");
  35. const barRef = vue.ref();
  36. const ratioY = vue.ref(1);
  37. const ratioX = vue.ref(1);
  38. const style$1 = vue.computed(() => {
  39. const style2 = {};
  40. if (props.height)
  41. style2.height = style.addUnit(props.height);
  42. if (props.maxHeight)
  43. style2.maxHeight = style.addUnit(props.maxHeight);
  44. return [props.wrapStyle, style2];
  45. });
  46. const wrapKls = vue.computed(() => {
  47. return [
  48. props.wrapClass,
  49. ns.e("wrap"),
  50. { [ns.em("wrap", "hidden-default")]: !props.native }
  51. ];
  52. });
  53. const resizeKls = vue.computed(() => {
  54. return [ns.e("view"), props.viewClass];
  55. });
  56. const handleScroll = () => {
  57. var _a;
  58. if (wrapRef.value) {
  59. (_a = barRef.value) == null ? void 0 : _a.handleScroll(wrapRef.value);
  60. emit("scroll", {
  61. scrollTop: wrapRef.value.scrollTop,
  62. scrollLeft: wrapRef.value.scrollLeft
  63. });
  64. }
  65. };
  66. function scrollTo(arg1, arg2) {
  67. if (shared.isObject(arg1)) {
  68. wrapRef.value.scrollTo(arg1);
  69. } else if (core.isNumber(arg1) && core.isNumber(arg2)) {
  70. wrapRef.value.scrollTo(arg1, arg2);
  71. }
  72. }
  73. const setScrollTop = (value) => {
  74. if (!core.isNumber(value)) {
  75. error.debugWarn(COMPONENT_NAME, "value must be a number");
  76. return;
  77. }
  78. wrapRef.value.scrollTop = value;
  79. };
  80. const setScrollLeft = (value) => {
  81. if (!core.isNumber(value)) {
  82. error.debugWarn(COMPONENT_NAME, "value must be a number");
  83. return;
  84. }
  85. wrapRef.value.scrollLeft = value;
  86. };
  87. const update = () => {
  88. if (!wrapRef.value)
  89. return;
  90. const offsetHeight = wrapRef.value.offsetHeight - util.GAP;
  91. const offsetWidth = wrapRef.value.offsetWidth - util.GAP;
  92. const originalHeight = offsetHeight ** 2 / wrapRef.value.scrollHeight;
  93. const originalWidth = offsetWidth ** 2 / wrapRef.value.scrollWidth;
  94. const height = Math.max(originalHeight, props.minSize);
  95. const width = Math.max(originalWidth, props.minSize);
  96. ratioY.value = originalHeight / (offsetHeight - originalHeight) / (height / (offsetHeight - height));
  97. ratioX.value = originalWidth / (offsetWidth - originalWidth) / (width / (offsetWidth - width));
  98. sizeHeight.value = height + util.GAP < offsetHeight ? `${height}px` : "";
  99. sizeWidth.value = width + util.GAP < offsetWidth ? `${width}px` : "";
  100. };
  101. vue.watch(() => props.noresize, (noresize) => {
  102. if (noresize) {
  103. stopResizeObserver == null ? void 0 : stopResizeObserver();
  104. stopResizeListener == null ? void 0 : stopResizeListener();
  105. } else {
  106. ;
  107. ({ stop: stopResizeObserver } = core.useResizeObserver(resizeRef, update));
  108. stopResizeListener = core.useEventListener("resize", update);
  109. }
  110. }, { immediate: true });
  111. vue.watch(() => [props.maxHeight, props.height], () => {
  112. if (!props.native)
  113. vue.nextTick(() => {
  114. var _a;
  115. update();
  116. if (wrapRef.value) {
  117. (_a = barRef.value) == null ? void 0 : _a.handleScroll(wrapRef.value);
  118. }
  119. });
  120. });
  121. vue.provide(scrollbar$1.scrollbarContextKey, vue.reactive({
  122. scrollbarElement: scrollbarRef,
  123. wrapElement: wrapRef
  124. }));
  125. vue.onMounted(() => {
  126. if (!props.native)
  127. vue.nextTick(() => {
  128. update();
  129. });
  130. });
  131. vue.onUpdated(() => update());
  132. expose({
  133. wrapRef,
  134. update,
  135. scrollTo,
  136. setScrollTop,
  137. setScrollLeft,
  138. handleScroll
  139. });
  140. return (_ctx, _cache) => {
  141. return vue.openBlock(), vue.createElementBlock("div", {
  142. ref_key: "scrollbarRef",
  143. ref: scrollbarRef,
  144. class: vue.normalizeClass(vue.unref(ns).b())
  145. }, [
  146. vue.createElementVNode("div", {
  147. ref_key: "wrapRef",
  148. ref: wrapRef,
  149. class: vue.normalizeClass(vue.unref(wrapKls)),
  150. style: vue.normalizeStyle(vue.unref(style$1)),
  151. onScroll: handleScroll
  152. }, [
  153. (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(_ctx.tag), {
  154. ref_key: "resizeRef",
  155. ref: resizeRef,
  156. class: vue.normalizeClass(vue.unref(resizeKls)),
  157. style: vue.normalizeStyle(_ctx.viewStyle)
  158. }, {
  159. default: vue.withCtx(() => [
  160. vue.renderSlot(_ctx.$slots, "default")
  161. ]),
  162. _: 3
  163. }, 8, ["class", "style"]))
  164. ], 38),
  165. !_ctx.native ? (vue.openBlock(), vue.createBlock(bar["default"], {
  166. key: 0,
  167. ref_key: "barRef",
  168. ref: barRef,
  169. height: sizeHeight.value,
  170. width: sizeWidth.value,
  171. always: _ctx.always,
  172. "ratio-x": ratioX.value,
  173. "ratio-y": ratioY.value
  174. }, null, 8, ["height", "width", "always", "ratio-x", "ratio-y"])) : vue.createCommentVNode("v-if", true)
  175. ], 2);
  176. };
  177. }
  178. });
  179. var Scrollbar = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/scrollbar/src/scrollbar.vue"]]);
  180. exports["default"] = Scrollbar;
  181. //# sourceMappingURL=scrollbar2.js.map