- ✅ 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
40 lines
1.3 KiB
JavaScript
40 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
var identity = require('./identity.js');
|
|
|
|
/**
|
|
* Recursively convert any node or its contents to native JavaScript
|
|
*
|
|
* @param value - The input value
|
|
* @param arg - If `value` defines a `toJSON()` method, use this
|
|
* as its first argument
|
|
* @param ctx - Conversion context, originally set in Document#toJS(). If
|
|
* `{ keep: true }` is not set, output should be suitable for JSON
|
|
* stringification.
|
|
*/
|
|
function toJS(value, arg, ctx) {
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
if (Array.isArray(value))
|
|
return value.map((v, i) => toJS(v, String(i), ctx));
|
|
if (value && typeof value.toJSON === 'function') {
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
if (!ctx || !identity.hasAnchor(value))
|
|
return value.toJSON(arg, ctx);
|
|
const data = { aliasCount: 0, count: 1, res: undefined };
|
|
ctx.anchors.set(value, data);
|
|
ctx.onCreate = res => {
|
|
data.res = res;
|
|
delete ctx.onCreate;
|
|
};
|
|
const res = value.toJSON(arg, ctx);
|
|
if (ctx.onCreate)
|
|
ctx.onCreate(res);
|
|
return res;
|
|
}
|
|
if (typeof value === 'bigint' && !ctx?.keep)
|
|
return Number(value);
|
|
return value;
|
|
}
|
|
|
|
exports.toJS = toJS;
|