diff options
Diffstat (limited to 'vanilla/node_modules/cssstyle/lib/properties/display.js')
| -rw-r--r-- | vanilla/node_modules/cssstyle/lib/properties/display.js | 210 |
1 files changed, 210 insertions, 0 deletions
diff --git a/vanilla/node_modules/cssstyle/lib/properties/display.js b/vanilla/node_modules/cssstyle/lib/properties/display.js new file mode 100644 index 0000000..d331d54 --- /dev/null +++ b/vanilla/node_modules/cssstyle/lib/properties/display.js @@ -0,0 +1,210 @@ +"use strict"; + +const parsers = require("../parsers"); + +const property = "display"; + +/* keywords */ +const displayOutside = ["block", "inline", "run-in"]; +const displayFlow = ["flow", "flow-root"]; + +module.exports.parse = (v, opt = {}) => { + const { globalObject } = opt; + if (v === "") { + return v; + } + const { AST_TYPES } = parsers; + const value = parsers.parsePropertyValue(property, v, { + globalObject, + inArray: true + }); + if (Array.isArray(value) && value.length) { + switch (value.length) { + case 1: { + const [{ name, type }] = value; + switch (type) { + case AST_TYPES.GLOBAL_KEYWORD: { + return name; + } + case AST_TYPES.IDENTIFIER: { + if (name === "flow") { + return "block"; + } + return name; + } + default: + } + break; + } + case 2: { + const [part1, part2] = value; + const val1 = part1.type === AST_TYPES.IDENTIFIER && part1.name; + const val2 = part2.type === AST_TYPES.IDENTIFIER && part2.name; + if (val1 && val2) { + let outerValue = ""; + let innerValue = ""; + if (val1 === "list-item") { + outerValue = val2; + innerValue = val1; + } else if (val2 === "list-item") { + outerValue = val1; + innerValue = val2; + } else if (displayOutside.includes(val1)) { + outerValue = val1; + innerValue = val2; + } else if (displayOutside.includes(val2)) { + outerValue = val2; + innerValue = val1; + } + if (innerValue === "list-item") { + switch (outerValue) { + case "block": + case "flow": { + return innerValue; + } + case "flow-root": + case "inline": + case "run-in": { + return `${outerValue} ${innerValue}`; + } + default: + } + } else if (outerValue === "block") { + switch (innerValue) { + case "flow": { + return outerValue; + } + case "flow-root": + case "flex": + case "grid": + case "table": { + return innerValue; + } + case "ruby": { + return `${outerValue} ${innerValue}`; + } + default: + } + } else if (outerValue === "inline") { + switch (innerValue) { + case "flow": { + return outerValue; + } + case "flow-root": { + return `${outerValue}-block`; + } + case "flex": + case "grid": + case "table": { + return `${outerValue}-${innerValue}`; + } + case "ruby": { + return innerValue; + } + default: + } + } else if (outerValue === "run-in") { + switch (innerValue) { + case "flow": { + return outerValue; + } + case "flow-root": + case "flex": + case "grid": + case "table": + case "ruby": { + return `${outerValue} ${innerValue}`; + } + default: + } + } + } + break; + } + case 3: { + const [part1, part2, part3] = value; + const val1 = part1.type === AST_TYPES.IDENTIFIER && part1.name; + const val2 = part2.type === AST_TYPES.IDENTIFIER && part2.name; + const val3 = part3.type === AST_TYPES.IDENTIFIER && part3.name; + if (val1 && val2 && part3) { + let outerValue = ""; + let flowValue = ""; + let listItemValue = ""; + if (val1 === "list-item") { + listItemValue = val1; + if (displayFlow.includes(val2)) { + flowValue = val2; + outerValue = val3; + } else if (displayFlow.includes(val3)) { + flowValue = val3; + outerValue = val2; + } + } else if (val2 === "list-item") { + listItemValue = val2; + if (displayFlow.includes(val1)) { + flowValue = val1; + outerValue = val3; + } else if (displayFlow.includes(val3)) { + flowValue = val3; + outerValue = val1; + } + } else if (val3 === "list-item") { + listItemValue = val3; + if (displayFlow.includes(val1)) { + flowValue = val1; + outerValue = val2; + } else if (displayFlow.includes(val2)) { + flowValue = val2; + outerValue = val1; + } + } + if (outerValue && flowValue && listItemValue) { + switch (outerValue) { + case "block": { + if (flowValue === "flow") { + return listItemValue; + } + return `${flowValue} ${listItemValue}`; + } + case "inline": + case "run-in": { + if (flowValue === "flow") { + return `${outerValue} ${listItemValue}`; + } + return `${outerValue} ${flowValue} ${listItemValue}`; + } + } + } + } + break; + } + default: + } + } else if (typeof value === "string") { + return value; + } +}; + +module.exports.definition = { + set(v) { + v = parsers.prepareValue(v); + if (parsers.hasVarFunc(v)) { + this._setProperty(property, v); + } else { + const val = module.exports.parse(v, { + globalObject: this._global + }); + if (typeof val === "string") { + const priority = this._priorities.get(property) ?? ""; + this._setProperty(property, val, priority); + } + } + }, + get() { + return this.getPropertyValue(property); + }, + enumerable: true, + configurable: true +}; + +module.exports.property = property; |
