1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- import { isNumber, isStringNumber } from '../types.mjs';
- import { isClient } from '@vueuse/core';
- import { entriesOf, keysOf } from '../objects.mjs';
- import { debugWarn } from '../error.mjs';
- import { camelize, isObject, isString } from '@vue/shared';
- const SCOPE = "utils/dom/style";
- const classNameToArray = (cls = "") => cls.split(" ").filter((item) => !!item.trim());
- const hasClass = (el, cls) => {
- if (!el || !cls)
- return false;
- if (cls.includes(" "))
- throw new Error("className should not contain space.");
- return el.classList.contains(cls);
- };
- const addClass = (el, cls) => {
- if (!el || !cls.trim())
- return;
- el.classList.add(...classNameToArray(cls));
- };
- const removeClass = (el, cls) => {
- if (!el || !cls.trim())
- return;
- el.classList.remove(...classNameToArray(cls));
- };
- const getStyle = (element, styleName) => {
- var _a;
- if (!isClient || !element || !styleName)
- return "";
- let key = camelize(styleName);
- if (key === "float")
- key = "cssFloat";
- try {
- const style = element.style[key];
- if (style)
- return style;
- const computed = (_a = document.defaultView) == null ? void 0 : _a.getComputedStyle(element, "");
- return computed ? computed[key] : "";
- } catch (e) {
- return element.style[key];
- }
- };
- const setStyle = (element, styleName, value) => {
- if (!element || !styleName)
- return;
- if (isObject(styleName)) {
- entriesOf(styleName).forEach(([prop, value2]) => setStyle(element, prop, value2));
- } else {
- const key = camelize(styleName);
- element.style[key] = value;
- }
- };
- const removeStyle = (element, style) => {
- if (!element || !style)
- return;
- if (isObject(style)) {
- keysOf(style).forEach((prop) => removeStyle(element, prop));
- } else {
- setStyle(element, style, "");
- }
- };
- function addUnit(value, defaultUnit = "px") {
- if (!value)
- return "";
- if (isNumber(value) || isStringNumber(value)) {
- return `${value}${defaultUnit}`;
- } else if (isString(value)) {
- return value;
- }
- debugWarn(SCOPE, "binding value must be a string or number");
- }
- export { addClass, addUnit, classNameToArray, getStyle, hasClass, removeClass, removeStyle, setStyle };
|