index.mjs 1018 B

123456789101112131415161718192021222324252627282930313233343536
  1. import normalizeWheel from "normalize-wheel-es";
  2. //#region ../../packages/directives/mousewheel/index.ts
  3. const SCOPE = "_Mousewheel";
  4. const mousewheel = function(element, callback) {
  5. if (element && element.addEventListener) {
  6. removeWheelHandler(element);
  7. const fn = function(event) {
  8. const normalized = normalizeWheel(event);
  9. callback && Reflect.apply(callback, this, [event, normalized]);
  10. };
  11. element[SCOPE] = { wheelHandler: fn };
  12. element.addEventListener("wheel", fn, { passive: true });
  13. }
  14. };
  15. const removeWheelHandler = (element) => {
  16. if (element[SCOPE]?.wheelHandler) {
  17. element.removeEventListener("wheel", element[SCOPE].wheelHandler);
  18. element[SCOPE] = null;
  19. }
  20. };
  21. const Mousewheel = {
  22. beforeMount(el, binding) {
  23. mousewheel(el, binding.value);
  24. },
  25. unmounted(el) {
  26. removeWheelHandler(el);
  27. },
  28. updated(el, binding) {
  29. if (binding.value !== binding.oldValue) mousewheel(el, binding.value);
  30. }
  31. };
  32. //#endregion
  33. export { SCOPE, Mousewheel as default };
  34. //# sourceMappingURL=index.mjs.map