- ✅ 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
75 lines
1.6 KiB
JavaScript
75 lines
1.6 KiB
JavaScript
/**
|
|
* @typedef Options
|
|
* Configuration for `stringify`.
|
|
* @property {boolean} [padLeft=true]
|
|
* Whether to pad a space before a token.
|
|
* @property {boolean} [padRight=false]
|
|
* Whether to pad a space after a token.
|
|
*/
|
|
|
|
/**
|
|
* @typedef {Options} StringifyOptions
|
|
* Please use `StringifyOptions` instead.
|
|
*/
|
|
|
|
/**
|
|
* Parse comma-separated tokens to an array.
|
|
*
|
|
* @param {string} value
|
|
* Comma-separated tokens.
|
|
* @returns {Array<string>}
|
|
* List of tokens.
|
|
*/
|
|
export function parse(value) {
|
|
/** @type {Array<string>} */
|
|
const tokens = []
|
|
const input = String(value || '')
|
|
let index = input.indexOf(',')
|
|
let start = 0
|
|
/** @type {boolean} */
|
|
let end = false
|
|
|
|
while (!end) {
|
|
if (index === -1) {
|
|
index = input.length
|
|
end = true
|
|
}
|
|
|
|
const token = input.slice(start, index).trim()
|
|
|
|
if (token || !end) {
|
|
tokens.push(token)
|
|
}
|
|
|
|
start = index + 1
|
|
index = input.indexOf(',', start)
|
|
}
|
|
|
|
return tokens
|
|
}
|
|
|
|
/**
|
|
* Serialize an array of strings or numbers to comma-separated tokens.
|
|
*
|
|
* @param {Array<string|number>} values
|
|
* List of tokens.
|
|
* @param {Options} [options]
|
|
* Configuration for `stringify` (optional).
|
|
* @returns {string}
|
|
* Comma-separated tokens.
|
|
*/
|
|
export function stringify(values, options) {
|
|
const settings = options || {}
|
|
|
|
// Ensure the last empty entry is seen.
|
|
const input = values[values.length - 1] === '' ? [...values, ''] : values
|
|
|
|
return input
|
|
.join(
|
|
(settings.padRight ? ' ' : '') +
|
|
',' +
|
|
(settings.padLeft === false ? '' : ' ')
|
|
)
|
|
.trim()
|
|
}
|