@asi-ngtools/lib
Version:
This project is a little components library, simple to use, which will help you to simplify your project.
249 lines (248 loc) • 23.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { Component, ElementRef, ViewChild, HostListener, Inject, Input, Renderer2 } from '@angular/core';
import { Subject } from 'rxjs';
import { DOCUMENT } from '@angular/platform-browser';
var AsiDropdownContainer = /** @class */ (function () {
function AsiDropdownContainer(document, renderer, elementRef) {
this.document = document;
this.renderer = renderer;
this.elementRef = elementRef;
this.calculWidth = true;
this.subjectContainer = new Subject();
}
/**
* @param {?} event
* @return {?}
*/
AsiDropdownContainer.prototype.documentClick = /**
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
if (!this.drop.nativeElement.contains(event.target)) {
this.asiDropDownService.canClose(this.index, this.canClose).subscribe(function (close) {
if (close) {
setTimeout(function () {
_this.close();
});
}
});
}
};
/**
* @return {?}
*/
AsiDropdownContainer.prototype.close = /**
* @return {?}
*/
function () {
this.subjectContainer.next(this);
this.subjectContainer.complete();
};
// Close event when click outside
/**
* @return {?}
*/
AsiDropdownContainer.prototype.onClose = /**
* @return {?}
*/
function () {
return this.subjectContainer.asObservable();
};
/**
* Move the container under htmlElement
* @param htmlElement The parent HTMLElement of the dropdown
*/
/**
* Move the container under htmlElement
* @param {?} elementRef
* @return {?}
*/
AsiDropdownContainer.prototype.forElement = /**
* Move the container under htmlElement
* @param {?} elementRef
* @return {?}
*/
function (elementRef) {
this.referenceElement = elementRef;
/** @type {?} */
var rectPos = elementRef.getBoundingClientRect();
/** @type {?} */
var bodyComputedStyle = getComputedStyle(this.document.body);
/** @type {?} */
var bodyMarginTop = parseInt(bodyComputedStyle.marginTop.slice(0, -2), 10);
/** @type {?} */
var bodyMarginLeft = parseInt(bodyComputedStyle.marginLeft.slice(0, -2), 10);
/** @type {?} */
var topVerticalPosition = rectPos.top + this.getScrollTopValue() - bodyMarginTop;
if (topVerticalPosition > this.document.body.clientHeight / 2) {
// show over the element
this.drop.nativeElement.style.bottom = (this.document.body.clientHeight - topVerticalPosition) + 'px';
this.drop.nativeElement.style.marginBottom = '5px';
}
else {
// show under the element
this.drop.nativeElement.style.top = (topVerticalPosition + elementRef.offsetHeight) + 'px';
this.drop.nativeElement.style.marginTop = '5px';
}
/** @type {?} */
var screenVerticalPosition = rectPos.top - bodyMarginTop;
/** @type {?} */
var bodyVerticalPosition;
if (screenVerticalPosition > this.document.body.clientHeight / 2) {
// show over the element
bodyVerticalPosition = this.document.body.clientHeight - (this.getScrollTopValue() + screenVerticalPosition);
this.drop.nativeElement.style.bottom = bodyVerticalPosition + 'px';
this.drop.nativeElement.style.marginBottom = '2px';
}
else {
// show under the element
bodyVerticalPosition = this.getScrollTopValue() + screenVerticalPosition + elementRef.offsetHeight;
this.drop.nativeElement.style.top = bodyVerticalPosition + 'px';
this.drop.nativeElement.style.marginTop = '2px';
}
this.drop.nativeElement.style.left = rectPos.left + this.getScrollLeftValue() - bodyMarginLeft + 'px';
this.drop.nativeElement.style.width = elementRef.offsetWidth + 'px';
};
/**
* @return {?}
*/
AsiDropdownContainer.prototype.getScrollTopValue = /**
* @return {?}
*/
function () {
return this.document.body.scrollTop + this.document.documentElement.scrollTop;
};
/**
* @return {?}
*/
AsiDropdownContainer.prototype.getScrollLeftValue = /**
* @return {?}
*/
function () {
return this.document.body.scrollLeft + this.document.documentElement.scrollLeft;
};
/**
* @param element The content to display in the container
*/
/**
* @param {?} asiDrownDown
* @return {?}
*/
AsiDropdownContainer.prototype.show = /**
* @param {?} asiDrownDown
* @return {?}
*/
function (asiDrownDown) {
var _this = this;
setTimeout(function () {
_this.template = asiDrownDown.contentTemplate;
/** @type {?} */
var visibility = _this.drop.nativeElement.style.visibility;
_this.drop.nativeElement.style.visibility = 'hidden';
if (asiDrownDown.dropDownClass) {
_this.renderer.addClass(_this.elementRef.nativeElement, asiDrownDown.dropDownClass);
}
setTimeout(function () {
/** @type {?} */
var dropRight = _this.drop.nativeElement.offsetLeft + _this.drop.nativeElement.offsetWidth;
if (dropRight > _this.document.documentElement.clientWidth) {
_this.drop.nativeElement.style.left = _this.drop.nativeElement.offsetLeft
+ _this.document.documentElement.scrollLeft - (dropRight - _this.document.documentElement.clientWidth) + 'px';
}
_this.drop.nativeElement.style.visibility = visibility;
});
});
};
/**
* @param {?} service
* @return {?}
*/
AsiDropdownContainer.prototype.injectService = /**
* @param {?} service
* @return {?}
*/
function (service) {
this.asiDropDownService = service;
};
/**
* @param {?} index
* @return {?}
*/
AsiDropdownContainer.prototype.setIndex = /**
* @param {?} index
* @return {?}
*/
function (index) {
this.index = index;
this.elementRef.nativeElement.style.zIndex = AsiDropdownContainer.BASE_INDEX + index;
};
/**
* @param {?} calculWidth
* @return {?}
*/
AsiDropdownContainer.prototype.setCalculWidth = /**
* @param {?} calculWidth
* @return {?}
*/
function (calculWidth) {
if (calculWidth) {
this.drop.nativeElement.style.width = this.referenceElement.offsetWidth + 'px';
}
else {
this.drop.nativeElement.style.width = '';
}
};
AsiDropdownContainer.BASE_INDEX = 125;
AsiDropdownContainer.decorators = [
{ type: Component, args: [{
selector: 'asi-dropdown-container',
host: { 'class': 'asi-component asi-dropdown-container' },
template: "<div #drop class=\"dropdown-container\">\r\n <ng-template [ngTemplateOutlet]=\"template\"></ng-template>\r\n</div>"
}] }
];
/** @nocollapse */
AsiDropdownContainer.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Renderer2 },
{ type: ElementRef }
]; };
AsiDropdownContainer.propDecorators = {
calculWidth: [{ type: Input }],
drop: [{ type: ViewChild, args: ['drop', { read: ElementRef },] }],
documentClick: [{ type: HostListener, args: ['document:mouseup', ['$event'],] }]
};
return AsiDropdownContainer;
}());
export { AsiDropdownContainer };
if (false) {
/** @type {?} */
AsiDropdownContainer.BASE_INDEX;
/** @type {?} */
AsiDropdownContainer.prototype.index;
/** @type {?} */
AsiDropdownContainer.prototype.canClose;
/** @type {?} */
AsiDropdownContainer.prototype.calculWidth;
/** @type {?} */
AsiDropdownContainer.prototype.drop;
/** @type {?} */
AsiDropdownContainer.prototype.subjectContainer;
/** @type {?} */
AsiDropdownContainer.prototype.asiDropDownService;
/** @type {?} */
AsiDropdownContainer.prototype.template;
/** @type {?} */
AsiDropdownContainer.prototype.referenceElement;
/** @type {?} */
AsiDropdownContainer.prototype.document;
/** @type {?} */
AsiDropdownContainer.prototype.renderer;
/** @type {?} */
AsiDropdownContainer.prototype.elementRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-dropdown-container.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-dropdown/container/asi-dropdown-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsiDropdownService } from './../asi-dropdown.service';\r\nimport { TemplateRef, Component, ElementRef, ViewChild, HostListener, Inject, Input, Renderer2 } from '@angular/core';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { AsiDropDown } from './../asi-dropdown.component';\r\nimport { DOCUMENT } from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: 'asi-dropdown-container',\r\n  host: { 'class': 'asi-component asi-dropdown-container' },\r\n  templateUrl: 'asi-dropdown-container.component.html'\r\n})\r\nexport class AsiDropdownContainer {\r\n\r\n  private static BASE_INDEX = 125;\r\n\r\n  index: number;\r\n  canClose: Function;\r\n\r\n  @Input() calculWidth = true;\r\n\r\n  @ViewChild('drop', { read: ElementRef }) drop: ElementRef;\r\n\r\n  private subjectContainer: Subject<AsiDropdownContainer> = new Subject();\r\n\r\n  private asiDropDownService: AsiDropdownService;\r\n\r\n  public template: TemplateRef<any>;\r\n  private referenceElement: any;\r\n\r\n  constructor(@Inject(DOCUMENT) private document: any, private renderer: Renderer2, private elementRef: ElementRef) {\r\n  }\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  documentClick(event: MouseEvent) {\r\n    if (!this.drop.nativeElement.contains(event.target)) {\r\n      this.asiDropDownService.canClose(this.index, this.canClose).subscribe(close => {\r\n        if (close) {\r\n          setTimeout(() => {\r\n            this.close();\r\n          });\r\n        }\r\n      })\r\n    }\r\n  }\r\n\r\n  close() {\r\n    this.subjectContainer.next(this);\r\n    this.subjectContainer.complete();\r\n  }\r\n\r\n  // Close event when click outside\r\n  onClose(): Observable<AsiDropdownContainer> {\r\n    return this.subjectContainer.asObservable();\r\n  }\r\n\r\n  /**\r\n   * Move the container under htmlElement\r\n   * @param htmlElement The parent HTMLElement of the dropdown\r\n   */\r\n  forElement(elementRef: any) {\r\n    this.referenceElement = elementRef;\r\n\r\n    const rectPos = elementRef.getBoundingClientRect();\r\n\r\n    // Get the computed class margin (from both style + css class)\r\n    const bodyComputedStyle = getComputedStyle(this.document.body);\r\n\r\n    const bodyMarginTop = parseInt(bodyComputedStyle.marginTop.slice(0, -2), 10);\r\n    const bodyMarginLeft = parseInt(bodyComputedStyle.marginLeft.slice(0, -2), 10);\r\n\r\n    const topVerticalPosition = rectPos.top + this.getScrollTopValue() - bodyMarginTop;\r\n\r\n    if (topVerticalPosition > this.document.body.clientHeight / 2) {\r\n      // show over the element\r\n      this.drop.nativeElement.style.bottom = (this.document.body.clientHeight - topVerticalPosition) + 'px';\r\n      this.drop.nativeElement.style.marginBottom = '5px';\r\n    } else {\r\n      // show under the element\r\n      this.drop.nativeElement.style.top = (topVerticalPosition + elementRef.offsetHeight) + 'px';\r\n      this.drop.nativeElement.style.marginTop = '5px';\r\n    }\r\n\r\n    const screenVerticalPosition = rectPos.top - bodyMarginTop;\r\n    let bodyVerticalPosition;\r\n    if (screenVerticalPosition > this.document.body.clientHeight / 2) {\r\n      // show over the element\r\n      bodyVerticalPosition = this.document.body.clientHeight - (this.getScrollTopValue() + screenVerticalPosition);\r\n      this.drop.nativeElement.style.bottom = bodyVerticalPosition + 'px';\r\n      this.drop.nativeElement.style.marginBottom = '2px';\r\n    } else {\r\n      // show under the element\r\n      bodyVerticalPosition = this.getScrollTopValue() + screenVerticalPosition + elementRef.offsetHeight;\r\n      this.drop.nativeElement.style.top = bodyVerticalPosition + 'px';\r\n      this.drop.nativeElement.style.marginTop = '2px';\r\n    }\r\n\r\n\r\n\r\n\r\n    this.drop.nativeElement.style.left = rectPos.left + this.getScrollLeftValue() - bodyMarginLeft + 'px';\r\n\r\n    this.drop.nativeElement.style.width = elementRef.offsetWidth + 'px';\r\n  }\r\n\r\n  private getScrollTopValue() {\r\n    return this.document.body.scrollTop + this.document.documentElement.scrollTop;\r\n  }\r\n\r\n  private getScrollLeftValue() {\r\n    return this.document.body.scrollLeft + this.document.documentElement.scrollLeft;\r\n  }\r\n\r\n  /**\r\n   * @param element The content to display in the container\r\n   */\r\n  show(asiDrownDown: AsiDropDown) {\r\n    setTimeout(() => {\r\n      this.template = asiDrownDown.contentTemplate;\r\n      let visibility = this.drop.nativeElement.style.visibility;\r\n      this.drop.nativeElement.style.visibility = 'hidden';\r\n      if (asiDrownDown.dropDownClass) {\r\n        this.renderer.addClass(this.elementRef.nativeElement, asiDrownDown.dropDownClass);\r\n      }\r\n      setTimeout(() => {\r\n        let dropRight = this.drop.nativeElement.offsetLeft + this.drop.nativeElement.offsetWidth;\r\n        if (dropRight > this.document.documentElement.clientWidth) {\r\n          this.drop.nativeElement.style.left = this.drop.nativeElement.offsetLeft\r\n            + this.document.documentElement.scrollLeft - (dropRight - this.document.documentElement.clientWidth) + 'px';\r\n        }\r\n        this.drop.nativeElement.style.visibility = visibility;\r\n      });\r\n    });\r\n  }\r\n\r\n  public injectService(service: AsiDropdownService) {\r\n    this.asiDropDownService = service;\r\n  }\r\n\r\n  public setIndex(index: number) {\r\n    this.index = index;\r\n    this.elementRef.nativeElement.style.zIndex = AsiDropdownContainer.BASE_INDEX + index;\r\n  }\r\n\r\n  public setCalculWidth(calculWidth: boolean) {\r\n    if (calculWidth) {\r\n      this.drop.nativeElement.style.width = this.referenceElement.offsetWidth + 'px';\r\n    } else {\r\n      this.drop.nativeElement.style.width = '';\r\n    }\r\n  }\r\n}\r\n"]}