import QuerySelector from '../../query-selector/QuerySelector.js';
import HTMLElement from '../html-element/HTMLElement.js';
import * as PropertySymbol from '../../PropertySymbol.js';
import DOMTokenList from '../../dom/DOMTokenList.js';
/**
* HTMLTableCellElement
*
* @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLTableCellElement
*/
export default class HTMLTableCellElement extends HTMLElement {
[PropertySymbol.headers] = null;
/**
* Returns abbr.
*
* @returns Abbr.
*/
get abbr() {
return this.getAttribute('abbr') || '';
}
/**
* Sets abbr.
*
* @param value Abbr.
*/
set abbr(value) {
this.setAttribute('abbr', value);
}
/**
* A number representing the cell's position in the cells collection of the
the cell is contained within. If the cell doesn't belong to a
, it returns -1.
*
* @returns Cell index.
*/
get cellIndex() {
let parent = this.parentNode;
while (parent) {
if (parent[PropertySymbol.tagName] === 'TR') {
const cells = QuerySelector.querySelectorAll(parent, 'td,th')[PropertySymbol.items];
return cells.indexOf(this);
}
parent = parent.parentNode;
}
return -1;
}
/**
* Returns colspan.
*
* @returns Colspan.
*/
get colSpan() {
const value = Number(this.getAttribute('colspan'));
return isNaN(value) || value < 1 ? 1 : value;
}
/**
* Sets colspan.
*
* @param value Colspan.
*/
set colSpan(value) {
const parsedValue = Number(value);
this.setAttribute('colspan', isNaN(parsedValue) || parsedValue < 1 ? '1' : String(parsedValue));
}
/**
* A DOMTokenList describing a list of id of elements that represent headers associated with the cell. It reflects the headers attribute.
*
* @returns Headers.
*/
get headers() {
if (!this[PropertySymbol.headers]) {
this[PropertySymbol.headers] = new DOMTokenList(PropertySymbol.illegalConstructor, this, 'headers');
}
return this[PropertySymbol.headers];
}
/**
* Returns rowspan.
*
* @returns Rowspan.
*/
get rowSpan() {
const value = Number(this.getAttribute('rowspan'));
return isNaN(value) || value < 1 ? 1 : value;
}
/**
* Sets rowspan.
*
* @param value Rowspan.
*/
set rowSpan(value) {
const parsedValue = Number(value);
this.setAttribute('rowspan', isNaN(parsedValue) || parsedValue < 1 ? '1' : String(parsedValue));
}
/**
* Returns scope.
*
* @returns Scope.
*/
get scope() {
return this.getAttribute('scope') || '';
}
/**
* Sets scope.
*
* @param value Scope.
*/
set scope(value) {
this.setAttribute('scope', value);
}
}
//# sourceMappingURL=HTMLTableCellElement.js.map |