snipe/web/node_modules/cssstyle/lib/properties/borderBottomStyle.js
pyr0ball 7a704441a6 feat(snipe): Vue 3 frontend scaffold + Docker web service
- web/: Vue 3 + Vite + UnoCSS + Pinia, dark tactical theme (amber/#0d1117)
- AppNav, ListingCard, SearchView with filters/sort, composables
  (useSnipeMode, useKonamiCode, useMotion), Pinia search store
- Steal shimmer, auction countdown, Snipe Mode easter egg all native in Vue
- docker/web/: nginx + multi-stage Dockerfile (node build → nginx serve)
- compose.yml: api (8510) + web (8509) services
- Dockerfile CMD updated to uvicorn for upcoming FastAPI layer
- Clean build: 0 TS errors, 380 modules
2026-03-25 15:11:35 -07:00

58 lines
1.5 KiB
JavaScript

"use strict";
const parsers = require("../parsers");
const property = "border-bottom-style";
const lineShorthand = "border-style";
const positionShorthand = "border-bottom";
const shorthand = "border";
const descriptor = {
set(v) {
v = parsers.prepareValue(v);
if (parsers.hasVarFunc(v)) {
this._borderSetter(property, v, "");
} else {
const val = parse(v);
if (typeof val === "string") {
const shorthandPriority = this._priorities.get(shorthand);
const linePriority = this._priorities.get(lineShorthand);
const positionPriority = this._priorities.get(positionShorthand);
const priority =
!(shorthandPriority || linePriority || positionPriority) && this._priorities.has(property)
? this._priorities.get(property)
: "";
this._borderSetter(property, val, priority);
}
}
},
get() {
return this.getPropertyValue(property);
},
enumerable: true,
configurable: true
};
/**
* Parses the border-bottom-style 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 value = parsers.parsePropertyValue(property, v);
if (Array.isArray(value) && value.length === 1) {
return parsers.resolveKeywordValue(value);
} else if (typeof value === "string") {
return value;
}
}
module.exports = {
descriptor,
parse,
property
};