aboutsummaryrefslogtreecommitdiffstats
path: root/vanilla/node_modules/cssstyle/lib/properties/borderStyle.js
diff options
context:
space:
mode:
authorAdam Mathes <adam@adammathes.com>2026-02-13 21:34:48 -0800
committerAdam Mathes <adam@adammathes.com>2026-02-13 21:34:48 -0800
commit76cb9c2a39d477a64824a985ade40507e3bbade1 (patch)
tree41e997aa9c6f538d3a136af61dae9424db2005a9 /vanilla/node_modules/cssstyle/lib/properties/borderStyle.js
parent819a39a21ac992b1393244a4c283bbb125208c69 (diff)
downloadneko-76cb9c2a39d477a64824a985ade40507e3bbade1.tar.gz
neko-76cb9c2a39d477a64824a985ade40507e3bbade1.tar.bz2
neko-76cb9c2a39d477a64824a985ade40507e3bbade1.zip
feat(vanilla): add testing infrastructure and tests (NK-wjnczv)
Diffstat (limited to 'vanilla/node_modules/cssstyle/lib/properties/borderStyle.js')
-rw-r--r--vanilla/node_modules/cssstyle/lib/properties/borderStyle.js110
1 files changed, 110 insertions, 0 deletions
diff --git a/vanilla/node_modules/cssstyle/lib/properties/borderStyle.js b/vanilla/node_modules/cssstyle/lib/properties/borderStyle.js
new file mode 100644
index 0000000..2cf8836
--- /dev/null
+++ b/vanilla/node_modules/cssstyle/lib/properties/borderStyle.js
@@ -0,0 +1,110 @@
+"use strict";
+
+const parsers = require("../parsers");
+const borderTopStyle = require("./borderTopStyle");
+const borderRightStyle = require("./borderRightStyle");
+const borderBottomStyle = require("./borderBottomStyle");
+const borderLeftStyle = require("./borderLeftStyle");
+
+const property = "border-style";
+const shorthand = "border";
+
+module.exports.shorthandFor = new Map([
+ [borderTopStyle.property, borderTopStyle],
+ [borderRightStyle.property, borderRightStyle],
+ [borderBottomStyle.property, borderBottomStyle],
+ [borderLeftStyle.property, borderLeftStyle]
+]);
+
+module.exports.parse = (v, opt = {}) => {
+ const { globalObject } = opt;
+ if (v === "") {
+ return v;
+ }
+ const values = parsers.parsePropertyValue(property, v, {
+ globalObject,
+ inArray: true
+ });
+ const parsedValues = [];
+ if (Array.isArray(values) && values.length) {
+ if (values.length > 4) {
+ return;
+ }
+ for (const value of values) {
+ const parsedValue = parsers.resolveKeywordValue([value], {
+ length: values.length
+ });
+ if (!parsedValue) {
+ return;
+ }
+ parsedValues.push(parsedValue);
+ }
+ } else if (typeof values === "string") {
+ parsedValues.push(values);
+ }
+ if (parsedValues.length) {
+ switch (parsedValues.length) {
+ case 1: {
+ return parsedValues;
+ }
+ case 2: {
+ const [val1, val2] = parsedValues;
+ if (val1 === val2) {
+ return [val1];
+ }
+ return parsedValues;
+ }
+ case 3: {
+ const [val1, val2, val3] = parsedValues;
+ if (val1 === val3) {
+ if (val1 === val2) {
+ return [val1];
+ }
+ return [val1, val2];
+ }
+ return parsedValues;
+ }
+ case 4: {
+ const [val1, val2, val3, val4] = parsedValues;
+ if (val2 === val4) {
+ if (val1 === val3) {
+ if (val1 === val2) {
+ return [val1];
+ }
+ return [val1, val2];
+ }
+ return [val1, val2, val3];
+ }
+ return parsedValues;
+ }
+ default:
+ }
+ }
+};
+
+module.exports.definition = {
+ set(v) {
+ v = parsers.prepareValue(v);
+ if (parsers.hasVarFunc(v)) {
+ this._borderSetter(property, v, "");
+ } else {
+ const val = module.exports.parse(v, {
+ globalObject: this._global
+ });
+ if (Array.isArray(val) || typeof val === "string") {
+ const priority =
+ !this._priorities.get(shorthand) && this._priorities.has(property)
+ ? this._priorities.get(property)
+ : "";
+ this._borderSetter(property, val, priority);
+ }
+ }
+ },
+ get() {
+ return this.getPropertyValue(property);
+ },
+ enumerable: true,
+ configurable: true
+};
+
+module.exports.property = property;