- ✅ 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
50 lines
1.1 KiB
JavaScript
50 lines
1.1 KiB
JavaScript
/**
|
|
* @import {ElementContent} from 'hast'
|
|
* @import {Reference, Nodes} from 'mdast'
|
|
* @import {State} from './state.js'
|
|
*/
|
|
|
|
/**
|
|
* Return the content of a reference without definition as plain text.
|
|
*
|
|
* @param {State} state
|
|
* Info passed around.
|
|
* @param {Extract<Nodes, Reference>} node
|
|
* Reference node (image, link).
|
|
* @returns {Array<ElementContent>}
|
|
* hast content.
|
|
*/
|
|
export function revert(state, node) {
|
|
const subtype = node.referenceType
|
|
let suffix = ']'
|
|
|
|
if (subtype === 'collapsed') {
|
|
suffix += '[]'
|
|
} else if (subtype === 'full') {
|
|
suffix += '[' + (node.label || node.identifier) + ']'
|
|
}
|
|
|
|
if (node.type === 'imageReference') {
|
|
return [{type: 'text', value: '![' + node.alt + suffix}]
|
|
}
|
|
|
|
const contents = state.all(node)
|
|
const head = contents[0]
|
|
|
|
if (head && head.type === 'text') {
|
|
head.value = '[' + head.value
|
|
} else {
|
|
contents.unshift({type: 'text', value: '['})
|
|
}
|
|
|
|
const tail = contents[contents.length - 1]
|
|
|
|
if (tail && tail.type === 'text') {
|
|
tail.value += suffix
|
|
} else {
|
|
contents.push({type: 'text', value: suffix})
|
|
}
|
|
|
|
return contents
|
|
}
|