UNPKG

jsdom

Version:

A JavaScript implementation of many web standards

132 lines (125 loc) 3.46 kB
"use strict"; const parsers = require("../helpers/css-values"); // Constants const { AST_TYPES } = parsers; const property = "background-size"; const shorthand = "background"; const descriptor = { set(v) { v = v.trim(); if (parsers.hasVarFunc(v)) { this._setProperty(shorthand, ""); this._setProperty(property, v); } else { const val = parse(v); if (typeof val === "string") { const priority = !this._priorities.get(shorthand) && this._priorities.has(property) ? this._priorities.get(property) : ""; this._setProperty(property, val, priority); } } }, get() { return this.getPropertyValue(property); }, enumerable: true, configurable: true }; /** * Parses the background-size property value. * * @param {string} v - The value to parse. * @returns {string|undefined} The parsed value or undefined if invalid. */ function parse(v) { if (v === "") { return v; } const values = parsers.splitValue(v, { delimiter: "," }); const parsedValues = []; for (const val of values) { const value = parsers.parsePropertyValue(property, val); if (Array.isArray(value) && value.length) { if (value.length === 1) { const [{ isNumber, name, type, value: itemValue }] = value; switch (type) { case AST_TYPES.CALC: { if (isNumber) { return undefined; } parsedValues.push(`${name}(${itemValue})`); break; } case AST_TYPES.GLOBAL_KEYWORD: case AST_TYPES.IDENTIFIER: { parsedValues.push(name); break; } default: { const parsedValue = parsers.resolveNumericValue(value, { type: "length" }); if (!parsedValue) { return undefined; } parsedValues.push(parsedValue); } } } else { const [val1, val2] = value; const parts = []; if (val1.type === AST_TYPES.CALC && !val1.isNumber) { parts.push(`${val1.name}(${val1.value})`); } else if (val1.type === AST_TYPES.IDENTIFIER) { parts.push(val1.name); } else if (val1.type === AST_TYPES.DIMENSION) { parts.push(`${val1.value}${val1.unit}`); } else if (val1.type === AST_TYPES.PERCENTAGE) { parts.push(`${val1.value}%`); } else { return undefined; } switch (val2.type) { case AST_TYPES.CALC: { if (val2.isNumber) { return undefined; } parts.push(`${val2.name}(${val2.value})`); break; } case AST_TYPES.DIMENSION: { parts.push(`${val2.value}${val2.unit}`); break; } case AST_TYPES.IDENTIFIER: { if (val2.name !== "auto") { parts.push(val2.name); } break; } case AST_TYPES.PERCENTAGE: { parts.push(`${val2.value}%`); break; } default: { return undefined; } } parsedValues.push(parts.join(" ")); } } else if (typeof value === "string") { parsedValues.push(value); } } if (parsedValues.length) { return parsedValues.join(", "); } return undefined; } module.exports = { descriptor, parse, property };