UNPKG

naive-ui

Version:

A Vue 3 Component Library. Fairly Complete, Theme Customizable, Uses TypeScript, Fast

53 lines (52 loc) 2.02 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __exportStar = (this && this.__exportStar) || function(m, exports) { for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.calculateSize = calculateSize; exports.clampValue = clampValue; exports.resolveSpeed = resolveSpeed; __exportStar(require("./duplicatedLogic"), exports); __exportStar(require("./event"), exports); function calculateSize(element, innerOnly) { let { offsetWidth: width, offsetHeight: height } = element; if (innerOnly) { const style = getComputedStyle(element); width = width - Number.parseFloat(style.getPropertyValue('padding-left')) - Number.parseFloat(style.getPropertyValue('padding-right')); height = height - Number.parseFloat(style.getPropertyValue('padding-top')) - Number.parseFloat(style.getPropertyValue('padding-bottom')); } return { width, height }; } function clampValue(value, min, max) { return value < min ? min : value > max ? max : value; } function resolveSpeed(value) { if (value === undefined) return 0; if (typeof value === 'number') return value; const timeRE = /^((\d+)?\.?\d+?)(ms|s)?$/; const match = value.match(timeRE); if (match) { const [, number, , unit = 'ms'] = match; return Number(number) * (unit === 'ms' ? 1 : 1000); } return 0; }