- ✅ 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
38 lines
1.1 KiB
JavaScript
38 lines
1.1 KiB
JavaScript
"use strict";
|
|
|
|
const { asciiLowercase } = require("./strings");
|
|
|
|
// Utility to translate from `border-width` to `borderWidth`.
|
|
// NOTE: For values prefixed with webkit, e.g. `-webkit-foo`, we need to provide
|
|
// both `webkitFoo` and `WebkitFoo`. Here we only return `webkitFoo`.
|
|
exports.dashedToCamelCase = function (dashed) {
|
|
if (dashed.startsWith("--")) {
|
|
return dashed;
|
|
}
|
|
let camel = "";
|
|
let nextCap = false;
|
|
// skip leading hyphen in vendor prefixed value, e.g. -webkit-foo
|
|
let i = /^-webkit-/.test(dashed) ? 1 : 0;
|
|
for (; i < dashed.length; i++) {
|
|
if (dashed[i] !== "-") {
|
|
camel += nextCap ? dashed[i].toUpperCase() : dashed[i];
|
|
nextCap = false;
|
|
} else {
|
|
nextCap = true;
|
|
}
|
|
}
|
|
return camel;
|
|
};
|
|
|
|
// Utility to translate from `borderWidth` to `border-width`.
|
|
exports.camelCaseToDashed = function (camelCase) {
|
|
if (camelCase.startsWith("--")) {
|
|
return camelCase;
|
|
}
|
|
const dashed = asciiLowercase(camelCase.replace(/(?<=[a-z])[A-Z]/g, "-$&"));
|
|
if (/^webkit-/.test(dashed)) {
|
|
return `-${dashed}`;
|
|
}
|
|
return dashed;
|
|
};
|