2019-05-26 01:54:41 +03:00
|
|
|
import {CSSParsedDeclaration} from '../css/index';
|
|
|
|
import {TextContainer} from './text-container';
|
|
|
|
import {Bounds, parseBounds} from '../css/layout/bounds';
|
|
|
|
import {isHTMLElementNode} from './node-parser';
|
2021-08-04 15:58:17 +03:00
|
|
|
import {Context} from '../core/context';
|
2019-05-26 01:54:41 +03:00
|
|
|
|
|
|
|
export const enum FLAGS {
|
|
|
|
CREATES_STACKING_CONTEXT = 1 << 1,
|
|
|
|
CREATES_REAL_STACKING_CONTEXT = 1 << 2,
|
|
|
|
IS_LIST_OWNER = 1 << 3
|
|
|
|
}
|
|
|
|
|
|
|
|
export class ElementContainer {
|
|
|
|
readonly styles: CSSParsedDeclaration;
|
|
|
|
readonly textNodes: TextContainer[];
|
|
|
|
readonly elements: ElementContainer[];
|
|
|
|
bounds: Bounds;
|
|
|
|
flags: number;
|
|
|
|
|
2021-08-04 15:58:17 +03:00
|
|
|
constructor(protected readonly context: Context, element: Element) {
|
|
|
|
this.styles = new CSSParsedDeclaration(context, window.getComputedStyle(element, null));
|
2019-05-26 01:54:41 +03:00
|
|
|
this.textNodes = [];
|
|
|
|
this.elements = [];
|
|
|
|
if (this.styles.transform !== null && isHTMLElementNode(element)) {
|
|
|
|
// getBoundingClientRect takes transforms into account
|
|
|
|
element.style.transform = 'none';
|
|
|
|
}
|
2021-08-04 15:58:17 +03:00
|
|
|
this.bounds = parseBounds(this.context, element);
|
2019-05-26 01:54:41 +03:00
|
|
|
this.flags = 0;
|
|
|
|
}
|
|
|
|
}
|