style.js 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
  2. const require_runtime = require('../../_virtual/_rolldown/runtime.js');
  3. const require_aria = require('./aria.js');
  4. const require_types = require('../types.js');
  5. const require_objects = require('../objects.js');
  6. const require_error = require('../error.js');
  7. let _vueuse_core = require("@vueuse/core");
  8. let _vue_shared = require("@vue/shared");
  9. //#region ../../packages/utils/dom/style.ts
  10. const SCOPE = "utils/dom/style";
  11. const classNameToArray = (cls = "") => cls.split(" ").filter((item) => !!item.trim());
  12. const hasClass = (el, cls) => {
  13. if (!el || !cls) return false;
  14. if (cls.includes(" ")) throw new Error("className should not contain space.");
  15. return el.classList.contains(cls);
  16. };
  17. const addClass = (el, cls) => {
  18. if (!el || !cls.trim()) return;
  19. el.classList.add(...classNameToArray(cls));
  20. };
  21. const removeClass = (el, cls) => {
  22. if (!el || !cls.trim()) return;
  23. el.classList.remove(...classNameToArray(cls));
  24. };
  25. const getStyle = (element, styleName) => {
  26. if (!_vueuse_core.isClient || !element || !styleName || require_aria.isShadowRoot(element)) return "";
  27. let key = (0, _vue_shared.camelize)(styleName);
  28. if (key === "float") key = "cssFloat";
  29. try {
  30. const style = element.style[key];
  31. if (style) return style;
  32. const computed = document.defaultView?.getComputedStyle(element, "");
  33. return computed ? computed[key] : "";
  34. } catch {
  35. return element.style[key];
  36. }
  37. };
  38. const setStyle = (element, styleName, value) => {
  39. if (!element || !styleName) return;
  40. if ((0, _vue_shared.isObject)(styleName)) require_objects.entriesOf(styleName).forEach(([prop, value]) => setStyle(element, prop, value));
  41. else {
  42. const key = (0, _vue_shared.camelize)(styleName);
  43. element.style[key] = value;
  44. }
  45. };
  46. const removeStyle = (element, style) => {
  47. if (!element || !style) return;
  48. if ((0, _vue_shared.isObject)(style)) require_objects.keysOf(style).forEach((prop) => removeStyle(element, prop));
  49. else setStyle(element, style, "");
  50. };
  51. function addUnit(value, defaultUnit = "px") {
  52. if (!value && value !== 0) return "";
  53. if (require_types.isNumber(value) || require_types.isStringNumber(value)) return `${value}${defaultUnit}`;
  54. else if ((0, _vue_shared.isString)(value)) return value;
  55. require_error.debugWarn(SCOPE, "binding value must be a string or number");
  56. }
  57. //#endregion
  58. exports.addClass = addClass;
  59. exports.addUnit = addUnit;
  60. exports.classNameToArray = classNameToArray;
  61. exports.getStyle = getStyle;
  62. exports.hasClass = hasClass;
  63. exports.removeClass = removeClass;
  64. exports.removeStyle = removeStyle;
  65. exports.setStyle = setStyle;
  66. //# sourceMappingURL=style.js.map