- ✅ 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
35 lines
1.2 KiB
JavaScript
35 lines
1.2 KiB
JavaScript
import NodeList from '../node/NodeList.js';
|
|
import * as PropertySymbol from '../../PropertySymbol.js';
|
|
/**
|
|
* Utility for finding labels associated with a form element.
|
|
*/
|
|
export default class HTMLLabelElementUtility {
|
|
/**
|
|
* Returns label elements for a form element.
|
|
*
|
|
* @param element Element to get labels for.
|
|
* @returns Label elements.
|
|
*/
|
|
static getAssociatedLabelElements(element) {
|
|
const id = element.id;
|
|
let labels;
|
|
if (id && element[PropertySymbol.isConnected]) {
|
|
const rootNode = element[PropertySymbol.rootNode] ||
|
|
element[PropertySymbol.ownerDocument];
|
|
labels = (rootNode.querySelectorAll(`label[for="${id}"]`)[PropertySymbol.items]);
|
|
}
|
|
else {
|
|
labels = [];
|
|
}
|
|
let parent = element[PropertySymbol.parentNode];
|
|
while (parent) {
|
|
if (parent['tagName'] === 'LABEL') {
|
|
labels.push(parent);
|
|
break;
|
|
}
|
|
parent = parent[PropertySymbol.parentNode];
|
|
}
|
|
return new NodeList(PropertySymbol.illegalConstructor, labels);
|
|
}
|
|
}
|
|
//# sourceMappingURL=HTMLLabelElementUtility.js.map
|