- ✅ Ticket 1.1: Estructura Clean Architecture en backend - ✅ Ticket 1.2: Schemas Zod compartidos - ✅ Ticket 1.3: Refactorización drugs.ts (1362 → 8 archivos modulares) - ✅ Ticket 1.4: Refactorización procedures.ts (3583 → 6 archivos modulares) - ✅ Ticket 1.5: Eliminación de duplicidades (~50 líneas) Cambios principales: - Creada estructura Clean Architecture en backend/src/ - Schemas Zod compartidos en backend/src/shared/schemas/ - Refactorización modular de drugs y procedures - Utilidades genéricas en src/utils/ (filter, validation) - Eliminados scripts obsoletos y documentación antigua - Corregidos errores: QueryClient, import test-error-handling - Build verificado y funcionando correctamente
211 lines
6 KiB
JavaScript
211 lines
6 KiB
JavaScript
"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;
|