UNPKG

happy-dom

Version:

Happy DOM is a JavaScript implementation of a web browser without its graphical user interface. It includes many web standards from WHATWG DOM and HTML.

127 lines (116 loc) 3.62 kB
import * as PropertySymbol from '../../PropertySymbol.js'; import HTMLInputElement from '../html-input-element/HTMLInputElement.js'; import HTMLTextAreaElement from '../html-text-area-element/HTMLTextAreaElement.js'; import HTMLSelectElement from '../html-select-element/HTMLSelectElement.js'; import RadioNodeList from './RadioNodeList.js'; import HTMLButtonElement from '../html-button-element/HTMLButtonElement.js'; /** * HTMLFormControlsCollection. * * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLFormControlsCollection */ export default class HTMLFormControlsCollection extends Array<HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLButtonElement> implements HTMLFormControlsCollection { public [PropertySymbol.namedItems]: { [k: string]: RadioNodeList } = {}; /** * Returns item by index. * * @param index Index. */ public item( index: number ): HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLButtonElement | null { return index >= 0 && this[index] ? this[index] : null; } /** * Returns named item. * * @param name Name. * @returns Node. */ public namedItem( name: string ): | HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLButtonElement | RadioNodeList | null { if (this[PropertySymbol.namedItems][name] && this[PropertySymbol.namedItems][name].length) { if (this[PropertySymbol.namedItems][name].length === 1) { return this[PropertySymbol.namedItems][name][0]; } return this[PropertySymbol.namedItems][name]; } return null; } /** * Appends named item. * * @param node Node. * @param name Name. */ public [PropertySymbol.appendNamedItem]( node: HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLButtonElement, name: string ): void { if (name) { this[PropertySymbol.namedItems][name] = this[PropertySymbol.namedItems][name] || new RadioNodeList(); if (!this[PropertySymbol.namedItems][name].includes(node)) { this[PropertySymbol.namedItems][name].push(node); } if (this[PropertySymbol.isValidPropertyName](name)) { this[name] = this[PropertySymbol.namedItems][name].length > 1 ? this[PropertySymbol.namedItems][name] : this[PropertySymbol.namedItems][name][0]; } } } /** * Appends named item. * * @param node Node. * @param name Name. */ public [PropertySymbol.removeNamedItem]( node: HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLButtonElement, name: string ): void { if (name && this[PropertySymbol.namedItems][name]) { const index = this[PropertySymbol.namedItems][name].indexOf(node); if (index > -1) { this[PropertySymbol.namedItems][name].splice(index, 1); if (this[PropertySymbol.namedItems][name].length === 0) { delete this[PropertySymbol.namedItems][name]; if (this.hasOwnProperty(name) && this[PropertySymbol.isValidPropertyName](name)) { delete this[name]; } } else if (this[PropertySymbol.isValidPropertyName](name)) { this[name] = this[PropertySymbol.namedItems][name].length > 1 ? this[PropertySymbol.namedItems][name] : this[PropertySymbol.namedItems][name][0]; } } } } /** * Returns "true" if the property name is valid. * * @param name Name. * @returns True if the property name is valid. */ protected [PropertySymbol.isValidPropertyName](name: string): boolean { return ( !!name && !this.constructor.prototype.hasOwnProperty(name) && !Array.prototype.hasOwnProperty(name) && (isNaN(Number(name)) || name.includes('.')) ); } }