naive-ui
Version:
A Vue 3 Component Library. Fairly Complete, Theme Customizable, Uses TypeScript, Fast
53 lines (52 loc) • 2.02 kB
JavaScript
;
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;
}