@circe/core
Version:
Circe Components for Angular :: Core Services and Tools
256 lines • 38.7 kB
JavaScript
import { Injectable } from '@angular/core';
import { npaElementFields, npaHashTypes } from '../_types/element.types';
export const boxModelTypeConstants = {
HORIZONTAL: 'horizontal',
VERTICAL: 'vertical'
};
export class BoxModelService {
constructor() {
this._defaultBoxModelType = boxModelTypeConstants.VERTICAL;
this._defaultElementHashType = npaHashTypes.class;
this._defaultComputedStylePropertyProcessed = false;
this._allowCssUnits = ['px', '%'];
this._additionHorizontalInsideClasses = ['padding-left', 'padding-right', 'border-left-width', 'border-right-width'];
this._additionHorizontalOutsideClasses = ['margin-left', 'margin-right'];
this._additionVerticalInsideClasses = ['padding-top', 'padding-bottom', 'border-top-width', 'border-bottom-width'];
this._additionVerticalOutsideClasses = ['margin-top', 'margin-bottom'];
this._fontSizeRule = { applyOnElements: ['i'], boxModelType: boxModelTypeConstants.HORIZONTAL };
}
/**
* _isElementHash
*
* @description
* Checks if element given param is ElementHash type.
*/
static _isElementHash(element) {
return !!(typeof element === 'object' &&
npaElementFields.type in element &&
npaElementFields.name in element &&
(Object.keys(element).length === 2 || Object.keys(element).length === 3));
}
/**
* _isElementQuery
*
* @description
* Checks if element given param is ElementQuery type.
*/
static _isElementQuery(element) {
return !!(typeof element === 'object' &&
npaElementFields.query in element &&
(Object.keys(element).length === 1 || Object.keys(element).length === 2));
}
/**
* _isNativeDomElement
*
* @description
* Checks if element given param is a native DOM element.
*/
static _isNativeDomElement(param) {
const _paramsToCheck = [
'getBoundingClientRect', 'getElementsByClassName', 'getElementsByTagName', 'querySelector'
];
return (!!param) ? (_paramsToCheck.map((e) => e in param)).every((el) => !!el) : false;
}
/**
* getSizeValues
*
* @description
* Get computed height and width from a SizeObject.
*/
static getSizeUnits(sizeObject) {
return {
height: sizeObject.height.value + sizeObject.height.unit,
width: sizeObject.width.value + sizeObject.height.unit
};
}
/**
* _convertToElementIdArray
*
* @description
* Transform elementId type to array of Dom elements.
*/
_convertToElementIdArray(elementId) {
const _auxArgument = [];
const _elementId = (Array.isArray(elementId)) ? elementId : [elementId];
for (const element of _elementId) {
_auxArgument.push(this.getElement(element));
}
return _auxArgument;
}
_getElementAdditions(element, boxModelType) {
const _type = boxModelType || this._defaultBoxModelType;
const _elementStyle = window.getComputedStyle(element);
const _output = {
boxModelAdditionInside: 0,
boxModelAdditionOutside: 0
};
const _auxOutputInside = [];
const _auxOutputOutside = [];
if (_type === boxModelTypeConstants.HORIZONTAL) {
this._additionHorizontalInsideClasses.forEach((e) => {
_auxOutputInside.push(_elementStyle.getPropertyValue(e));
});
this._additionHorizontalOutsideClasses.forEach((e) => {
_auxOutputOutside.push(_elementStyle.getPropertyValue(e));
});
}
else {
this._additionVerticalInsideClasses.forEach((e) => {
_auxOutputInside.push(_elementStyle.getPropertyValue(e));
});
this._additionVerticalOutsideClasses.forEach((e) => {
_auxOutputOutside.push(_elementStyle.getPropertyValue(e));
});
}
_auxOutputInside.forEach((el) => {
if (el !== '0px') {
_output.boxModelAdditionInside += this.readCssUnits(el).value;
}
});
_auxOutputOutside.forEach((el) => {
if (el !== '0px') {
_output.boxModelAdditionOutside += this.readCssUnits(el).value;
}
});
return _output;
}
getComputedStyleProperty(element, property, processed) {
const _processed = processed || this._defaultComputedStylePropertyProcessed;
const _elementComputedStyles = window.getComputedStyle(element);
const _output = _elementComputedStyles.getPropertyValue(property);
if (_output && _processed) {
return this.readCssUnits(_output);
}
return _output;
}
processElementForSpecialRules(element) {
if (this._fontSizeRule.applyOnElements.includes(element.tagName.toLowerCase())) {
const _elementBoxModel = this.getBoxModel(element, boxModelTypeConstants.HORIZONTAL);
const _elementFontSize = this.getComputedStyleProperty(element, 'font-size', true);
if (_elementBoxModel.boxModelExtractedInside !== _elementFontSize.value) {
element.style.width = `${_elementFontSize.value}px`;
return element;
}
}
return element;
}
readCssUnits(expression) {
const _output = { value: 0, unit: '' };
this._allowCssUnits.forEach((e) => {
if (expression.includes(e)) {
_output.unit = e;
const _aux = expression.split(e).filter((el) => !!el);
if (_aux.length === 1) {
_output.value = Number(_aux[0]);
}
return;
}
});
return (_output.value && _output.unit) ? _output : null;
}
processSizeString(sizeString) {
const _output = { width: null, height: null };
if (sizeString) {
const _auxSize = sizeString.split(' ');
if (_auxSize.length === 1) {
const _cssUnit = this.readCssUnits(_auxSize[0]);
_output.width = _cssUnit;
_output.height = _cssUnit;
}
else if (_auxSize.length === 2) {
_output.height = this.readCssUnits(_auxSize[0]);
_output.width = this.readCssUnits(_auxSize[1]);
}
}
return (_output.width && _output.height) ? _output : null;
}
/**
* getElement
*
* @description
* Returns an element DOM native object from different types of given params.
*/
getElement(element) {
let _output = element;
let _element = element;
let _shadowElement = document;
if (typeof element === 'string') {
_element = { type: this._defaultElementHashType, name: element };
}
else {
if (npaElementFields.shadowElement in _element) {
_shadowElement = this.getElement(_element.shadowElement);
}
}
if (!BoxModelService._isNativeDomElement(_element)) {
if (BoxModelService._isElementHash(_element)) {
switch (_element.type) {
case npaHashTypes.class:
_output = _shadowElement.getElementsByClassName(_element.name).item(0);
break;
case npaHashTypes.tag:
_output = _shadowElement.getElementsByTagName(_element.name).item(0);
break;
case npaHashTypes.id:
_output = document.getElementById(_element.name);
break;
}
}
else if (BoxModelService._isElementQuery(_element)) {
_output = _shadowElement.querySelector(_element.query);
}
}
if (!BoxModelService._isNativeDomElement(_output)) {
throw new Error('BoxModel.getElement: Unrecognizable element.');
}
return _output;
}
getDimensions(element) {
let _output;
const _element = this.getElement(element);
if (!!_element) {
const _elementRect = _element.getBoundingClientRect();
_output = {
height: { value: _elementRect.height, unit: 'px' },
width: { value: _elementRect.width, unit: 'px' }
};
}
return _output;
}
getBoxModel(elementId, boxModelType) {
const _output = {
type: boxModelType || this._defaultBoxModelType,
boxModel: 0,
boxModelAdditions: 0,
boxModelAggregated: 0,
boxModelExtracted: 0,
boxModelAdditionsInside: 0,
boxModelAdditionsOutside: 0,
boxModelAggregatedInside: 0,
boxModelAggregatedOutside: 0,
boxModelExtractedInside: 0,
boxModelExtractedOutside: 0
};
const _elementId = this._convertToElementIdArray(elementId);
_elementId.forEach((e) => {
const _elementRect = e.getBoundingClientRect();
const _additions = this._getElementAdditions(e, _output.type);
_output.boxModel += (_output.type === boxModelTypeConstants.HORIZONTAL) ? _elementRect.width : _elementRect.height;
_output.boxModelAdditions += _additions.boxModelAdditionInside + _additions.boxModelAdditionOutside;
_output.boxModelAdditionsInside += _additions.boxModelAdditionInside;
_output.boxModelAdditionsOutside += _additions.boxModelAdditionOutside;
});
_output.boxModelAggregated = _output.boxModel + _output.boxModelAdditions;
_output.boxModelExtracted = _output.boxModel - _output.boxModelAdditions;
_output.boxModelAggregatedInside = _output.boxModel + _output.boxModelAdditionsInside;
_output.boxModelAggregatedOutside = _output.boxModel + _output.boxModelAdditionsOutside;
_output.boxModelExtractedInside = _output.boxModel - _output.boxModelAdditionsInside;
_output.boxModelExtractedOutside = _output.boxModel - _output.boxModelAdditionsOutside;
return _output;
}
}
BoxModelService.decorators = [
{ type: Injectable }
];
BoxModelService.ctorParameters = () => [];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"box-model.service.js","sourceRoot":"","sources":["../../../../../projects/core/src/lib/box-model/box-model.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { NpaElement, npaElementFields, NpaElementHash, NpaElementQuery, NpaHashType, npaHashTypes} from '../_types/element.types';\n\nexport interface SizeObject {\n  width: ProcessedUnitObject;\n  height: ProcessedUnitObject;\n}\n\nexport interface SizeUnitsObject {\n  height: string;\n  width: string;\n}\n\nexport interface ProcessedUnitObject {\n  value: number;\n  unit: string;\n}\n\nexport type ElementId = NpaElement | Array<NpaElement>;\n\nexport type BoxModelType = 'horizontal' | 'vertical';\nexport interface BoxModelSwapObject {\n  type: BoxModelType;\n  boxModel: number;\n  boxModelAdditions: number;\n  boxModelAggregated: number;\n  boxModelExtracted: number;\n  boxModelAdditionsInside: number;\n  boxModelAdditionsOutside: number;\n  boxModelAggregatedInside: number;\n  boxModelAggregatedOutside: number;\n  boxModelExtractedInside: number;\n  boxModelExtractedOutside: number;\n}\n\nexport interface BoxModelAdditionObject {\n  boxModelAdditionInside: number;\n  boxModelAdditionOutside: number;\n}\n\nexport interface SpecialRuleObject {\n  applyOnElements: Array<string>;\n  boxModelType: BoxModelType;\n}\n\nexport const boxModelTypeConstants = {\n  HORIZONTAL: 'horizontal' as BoxModelType,\n  VERTICAL: 'vertical' as BoxModelType\n};\n\n@Injectable() export class BoxModelService {\n  private readonly _defaultBoxModelType: BoxModelType;\n\n  private readonly _defaultElementHashType: NpaHashType;\n\n  private readonly _defaultComputedStylePropertyProcessed: boolean;\n\n  private readonly _allowCssUnits: Array<string>;\n  private readonly _additionHorizontalInsideClasses: Array<string>;\n  private readonly _additionHorizontalOutsideClasses: Array<string>;\n  private readonly _additionVerticalInsideClasses: Array<string>;\n  private readonly _additionVerticalOutsideClasses: Array<string>;\n\n  private readonly _fontSizeRule: SpecialRuleObject;\n\n  constructor() {\n    this._defaultBoxModelType = boxModelTypeConstants.VERTICAL;\n\n    this._defaultElementHashType = npaHashTypes.class;\n\n    this._defaultComputedStylePropertyProcessed = false;\n\n    this._allowCssUnits = ['px', '%'];\n    this._additionHorizontalInsideClasses = ['padding-left', 'padding-right', 'border-left-width', 'border-right-width'];\n    this._additionHorizontalOutsideClasses = ['margin-left', 'margin-right'];\n    this._additionVerticalInsideClasses = ['padding-top', 'padding-bottom', 'border-top-width', 'border-bottom-width'];\n    this._additionVerticalOutsideClasses = ['margin-top', 'margin-bottom'];\n\n    this._fontSizeRule = { applyOnElements: ['i'], boxModelType: boxModelTypeConstants.HORIZONTAL };\n  }\n\n  /**\n   * _isElementHash\n   *\n   * @description\n   * Checks if element given param is ElementHash type.\n   */\n  public static _isElementHash(element: NpaElement): boolean {\n    return !!(\n      typeof element === 'object' &&\n      npaElementFields.type in element &&\n      npaElementFields.name in element &&\n      (Object.keys(element).length === 2 || Object.keys(element).length === 3)\n    );\n  }\n\n  /**\n   * _isElementQuery\n   *\n   * @description\n   * Checks if element given param is ElementQuery type.\n   */\n  public static _isElementQuery(element: NpaElement): boolean {\n    return !!(\n      typeof element === 'object' &&\n      npaElementFields.query in element &&\n      (Object.keys(element).length === 1 || Object.keys(element).length === 2)\n    );\n  }\n\n  /**\n   * _isNativeDomElement\n   *\n   * @description\n   * Checks if element given param is a native DOM element.\n   */\n  public static _isNativeDomElement(param: any): param is Element {\n    const _paramsToCheck: Array<string> = [\n      'getBoundingClientRect', 'getElementsByClassName', 'getElementsByTagName', 'querySelector'\n    ];\n    return (!!param) ? (_paramsToCheck.map((e: string) => e in param)).every((el) => !!el) : false;\n  }\n\n  /**\n   * getSizeValues\n   *\n   * @description\n   * Get computed height and width from a SizeObject.\n   */\n  public static getSizeUnits(sizeObject: SizeObject): SizeUnitsObject {\n    return {\n      height: sizeObject.height.value + sizeObject.height.unit,\n      width: sizeObject.width.value + sizeObject.height.unit\n    };\n  }\n\n  /**\n   * _convertToElementIdArray\n   *\n   * @description\n   * Transform elementId type to array of Dom elements.\n   */\n  private _convertToElementIdArray(elementId: ElementId): Array<Element> {\n    const _auxArgument: Array<Element> = [];\n    const _elementId: Array<NpaElement> = (Array.isArray(elementId)) ? elementId : [elementId];\n    for (const element of _elementId) {\n      _auxArgument.push(this.getElement(element));\n    }\n    return _auxArgument;\n  }\n\n  private _getElementAdditions(element: Element, boxModelType?: BoxModelType): BoxModelAdditionObject {\n    const _type: BoxModelType = boxModelType || this._defaultBoxModelType;\n    const _elementStyle: CSSStyleDeclaration = window.getComputedStyle(element);\n    const _output: BoxModelAdditionObject = {\n      boxModelAdditionInside: 0,\n      boxModelAdditionOutside: 0\n    };\n    const _auxOutputInside: Array<string> = [];\n    const _auxOutputOutside: Array<string> = [];\n    if (_type === boxModelTypeConstants.HORIZONTAL) {\n      this._additionHorizontalInsideClasses.forEach((e: string) => {\n        _auxOutputInside.push(_elementStyle.getPropertyValue(e));\n      });\n      this._additionHorizontalOutsideClasses.forEach((e: string) => {\n        _auxOutputOutside.push(_elementStyle.getPropertyValue(e));\n      });\n    } else {\n      this._additionVerticalInsideClasses.forEach((e: string) => {\n        _auxOutputInside.push(_elementStyle.getPropertyValue(e));\n      });\n      this._additionVerticalOutsideClasses.forEach((e: string) => {\n        _auxOutputOutside.push(_elementStyle.getPropertyValue(e));\n      });\n    }\n    _auxOutputInside.forEach((el: string) => {\n      if (el !== '0px') {\n        _output.boxModelAdditionInside += this.readCssUnits(el).value;\n      }\n    });\n    _auxOutputOutside.forEach((el: string) => {\n      if (el !== '0px') {\n        _output.boxModelAdditionOutside += this.readCssUnits(el).value;\n      }\n    });\n    return _output;\n  }\n\n  public getComputedStyleProperty(element: Element, property: string, processed?: boolean): string | ProcessedUnitObject {\n    const _processed: boolean = processed || this._defaultComputedStylePropertyProcessed;\n    const _elementComputedStyles: CSSStyleDeclaration = window.getComputedStyle(element);\n    const _output: string = _elementComputedStyles.getPropertyValue(property);\n    if (_output && _processed) {\n      return this.readCssUnits(_output);\n    }\n    return _output;\n  }\n\n  public processElementForSpecialRules(element: Element): Element {\n    if (this._fontSizeRule.applyOnElements.includes(element.tagName.toLowerCase())) {\n      const _elementBoxModel: BoxModelSwapObject = this.getBoxModel(element, boxModelTypeConstants.HORIZONTAL);\n      const _elementFontSize: ProcessedUnitObject = this.getComputedStyleProperty(element, 'font-size', true) as ProcessedUnitObject;\n      if (_elementBoxModel.boxModelExtractedInside !== _elementFontSize.value) {\n        (element as HTMLElement).style.width = `${_elementFontSize.value}px`;\n        return element as Element;\n      }\n    }\n    return element;\n  }\n\n  public readCssUnits(expression: string): ProcessedUnitObject {\n    const _output: ProcessedUnitObject = { value: 0, unit: '' };\n    this._allowCssUnits.forEach((e: string) => {\n      if (expression.includes(e)) {\n        _output.unit = e;\n        const _aux: Array<string> = expression.split(e).filter((el: string) => !!el);\n        if (_aux.length === 1) {\n          _output.value = Number(_aux[0]);\n        }\n        return;\n      }\n    });\n    return (_output.value && _output.unit) ? _output : null;\n  }\n\n  public processSizeString(sizeString: string): SizeObject {\n    const _output: SizeObject = { width: null, height: null };\n    if (sizeString) {\n      const _auxSize: Array<string> = sizeString.split(' ');\n      if (_auxSize.length === 1) {\n        const _cssUnit: ProcessedUnitObject = this.readCssUnits(_auxSize[0]);\n        _output.width = _cssUnit;\n        _output.height = _cssUnit;\n      } else if (_auxSize.length === 2) {\n        _output.height = this.readCssUnits(_auxSize[0]);\n        _output.width = this.readCssUnits(_auxSize[1]);\n      }\n    }\n    return (_output.width && _output.height) ? _output : null;\n  }\n\n  /**\n   * getElement\n   *\n   * @description\n   * Returns an element DOM native object from different types of given params.\n   */\n  public getElement(element: NpaElement): Element {\n    let _output: Element = element as Element;\n    let _element: NpaElement = element;\n    let _shadowElement: Element | Document = document;\n    if (typeof element === 'string') {\n      _element = { type: this._defaultElementHashType, name: element };\n    } else {\n      if (npaElementFields.shadowElement in (_element as NpaElementHash | NpaElementQuery)) {\n        _shadowElement = this.getElement((_element as NpaElementHash | NpaElementQuery).shadowElement);\n      }\n    }\n    if (!BoxModelService._isNativeDomElement(_element)) {\n      if (BoxModelService._isElementHash(_element)) {\n        switch ((_element as NpaElementHash).type) {\n          case npaHashTypes.class:\n            _output = _shadowElement.getElementsByClassName((_element as NpaElementHash).name).item(0);\n            break;\n          case npaHashTypes.tag:\n            _output = _shadowElement.getElementsByTagName((_element as NpaElementHash).name).item(0);\n            break;\n          case npaHashTypes.id:\n            _output = document.getElementById((_element as NpaElementHash).name);\n            break;\n        }\n      } else if (BoxModelService._isElementQuery(_element)) {\n        _output = _shadowElement.querySelector((_element as NpaElementQuery).query);\n      }\n    }\n    if (!BoxModelService._isNativeDomElement(_output)) {\n      throw new Error('BoxModel.getElement: Unrecognizable element.');\n    }\n    return _output;\n  }\n\n  public getDimensions(element: NpaElement): SizeObject {\n    let _output: SizeObject;\n    const _element: Element = this.getElement(element);\n    if (!!_element) {\n      const _elementRect: DOMRect = _element.getBoundingClientRect();\n      _output = {\n        height: { value: _elementRect.height, unit: 'px' },\n        width: { value: _elementRect.width, unit: 'px' }\n      };\n    }\n    return _output;\n  }\n\n  public getBoxModel(elementId: ElementId, boxModelType?: BoxModelType): BoxModelSwapObject {\n    const _output: BoxModelSwapObject = {\n      type: boxModelType || this._defaultBoxModelType,\n      boxModel: 0,\n      boxModelAdditions: 0,\n      boxModelAggregated: 0,\n      boxModelExtracted: 0,\n      boxModelAdditionsInside: 0,\n      boxModelAdditionsOutside: 0,\n      boxModelAggregatedInside: 0,\n      boxModelAggregatedOutside: 0,\n      boxModelExtractedInside: 0,\n      boxModelExtractedOutside: 0\n    };\n    const _elementId: Array<Element> = this._convertToElementIdArray(elementId);\n    _elementId.forEach((e: Element) => {\n      const _elementRect: DOMRect | ClientRect = e.getBoundingClientRect();\n      const _additions: BoxModelAdditionObject = this._getElementAdditions(e, _output.type);\n      _output.boxModel += (_output.type === boxModelTypeConstants.HORIZONTAL) ? _elementRect.width : _elementRect.height;\n      _output.boxModelAdditions += _additions.boxModelAdditionInside + _additions.boxModelAdditionOutside;\n      _output.boxModelAdditionsInside += _additions.boxModelAdditionInside;\n      _output.boxModelAdditionsOutside += _additions.boxModelAdditionOutside;\n    });\n    _output.boxModelAggregated = _output.boxModel + _output.boxModelAdditions;\n    _output.boxModelExtracted = _output.boxModel - _output.boxModelAdditions;\n    _output.boxModelAggregatedInside = _output.boxModel + _output.boxModelAdditionsInside;\n    _output.boxModelAggregatedOutside = _output.boxModel + _output.boxModelAdditionsOutside;\n    _output.boxModelExtractedInside = _output.boxModel - _output.boxModelAdditionsInside;\n    _output.boxModelExtractedOutside = _output.boxModel - _output.boxModelAdditionsOutside;\n    return _output;\n  }\n}\n"]}