happy-dom-without-node
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.
38 lines • 1.83 kB
JavaScript
import * as PropertySymbol from '../../PropertySymbol.js';
import HTMLElementNamedNodeMap from '../html-element/HTMLElementNamedNodeMap.js';
/**
* Named Node Map.
*
* @see https://developer.mozilla.org/en-US/docs/Web/API/NamedNodeMap
*/
export default class HTMLInputElementNamedNodeMap extends HTMLElementNamedNodeMap {
/**
* @override
*/
setNamedItem(item) {
const replacedItem = super.setNamedItem(item);
if ((item[PropertySymbol.name] === 'id' || item[PropertySymbol.name] === 'name') &&
this[PropertySymbol.ownerElement][PropertySymbol.formNode]) {
if (replacedItem && replacedItem[PropertySymbol.value]) {
this[PropertySymbol.ownerElement][PropertySymbol.formNode][PropertySymbol.removeFormControlItem](this[PropertySymbol.ownerElement], replacedItem[PropertySymbol.value]);
}
if (item[PropertySymbol.value]) {
this[PropertySymbol.ownerElement][PropertySymbol.formNode][PropertySymbol.appendFormControlItem](this[PropertySymbol.ownerElement], item[PropertySymbol.value]);
}
}
return replacedItem || null;
}
/**
* @override
*/
[(PropertySymbol.ownerElement, PropertySymbol.removeNamedItem)](name) {
const removedItem = super[PropertySymbol.removeNamedItem](name);
if (removedItem &&
(removedItem[PropertySymbol.name] === 'id' || removedItem[PropertySymbol.name] === 'name') &&
this[PropertySymbol.ownerElement][PropertySymbol.formNode]) {
this[PropertySymbol.ownerElement][PropertySymbol.formNode][PropertySymbol.removeFormControlItem](this[PropertySymbol.ownerElement], removedItem[PropertySymbol.value]);
}
return removedItem;
}
}
//# sourceMappingURL=HTMLInputElementNamedNodeMap.js.map