UNPKG

@asi-ngtools/lib

Version:

This project is a little components library, simple to use, which will help you to simplify your project.

191 lines (190 loc) 20.9 kB
/** * @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/common'; export class AsiDropdownContainer { /** * @param {?} document * @param {?} renderer * @param {?} elementRef */ constructor(document, renderer, elementRef) { this.document = document; this.renderer = renderer; this.elementRef = elementRef; this.calculWidth = true; this.subjectContainer = new Subject(); } /** * @param {?} event * @return {?} */ documentClick(event) { if (!this.drop.nativeElement.contains(event.target)) { this.asiDropDownService.canClose(this.index, this.canClose).subscribe(close => { if (close) { setTimeout(() => { this.close(); }); } }); } } /** * @return {?} */ close() { this.subjectContainer.next(this); this.subjectContainer.complete(); } /** * @return {?} */ onClose() { return this.subjectContainer.asObservable(); } /** * Move the container under htmlElement * @param {?} relativeTo The parent HTMLElement of the dropdown * @return {?} */ forElement(relativeTo) { this.referenceElement = relativeTo; /** @type {?} */ const rectRelativeTo = relativeTo.getBoundingClientRect(); /** @type {?} */ const bodyComputedStyle = getComputedStyle(this.document.body); /** @type {?} */ const bodyMarginTop = parseInt(bodyComputedStyle.marginTop.slice(0, -2), 10); /** @type {?} */ const parentComputedStyle = getComputedStyle(this.elementRef.nativeElement); /** @type {?} */ const parentMarginTop = parseInt(parentComputedStyle.marginTop.slice(0, -2), 10); /** @type {?} */ const parentMarginLeft = parseInt(parentComputedStyle.marginLeft.slice(0, -2), 10); /** @type {?} */ const rectElement = this.elementRef.nativeElement.getBoundingClientRect(); /** @type {?} */ const screenVerticalPosition = rectRelativeTo.top - bodyMarginTop; if (screenVerticalPosition > this.document.body.clientHeight / 2) { /** @type {?} */ const bodyVerticalPosition = rectElement.bottom - rectRelativeTo.top + parentMarginTop; this.drop.nativeElement.style.bottom = bodyVerticalPosition + 'px'; this.drop.nativeElement.style.marginBottom = '2px'; } else { /** @type {?} */ const bodyVerticalPosition = -rectElement.top + rectRelativeTo.top - parentMarginTop + relativeTo.offsetHeight; this.drop.nativeElement.style.top = bodyVerticalPosition + 'px'; this.drop.nativeElement.style.marginTop = '2px'; } this.drop.nativeElement.style.left = rectRelativeTo.left - rectElement.left - parentMarginLeft + 'px'; this.drop.nativeElement.style.width = relativeTo.offsetWidth + 'px'; } /** * @param {?} asiDrownDown The content to display in the container * @return {?} */ show(asiDrownDown) { setTimeout(() => { this.template = asiDrownDown.contentTemplate; /** @type {?} */ let visibility = this.drop.nativeElement.style.visibility; this.drop.nativeElement.style.visibility = 'hidden'; if (asiDrownDown.dropDownClass) { this.renderer.addClass(this.elementRef.nativeElement, asiDrownDown.dropDownClass); } setTimeout(() => { /** @type {?} */ const dropContainer = this.drop.nativeElement.getBoundingClientRect(); if (dropContainer.right > this.document.documentElement.clientWidth) { this.drop.nativeElement.style.left = (this.drop.nativeElement.offsetLeft - dropContainer.right + this.document.documentElement.clientWidth) + 'px'; } /** @type {?} */ let 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 {?} */ injectService(service) { this.asiDropDownService = service; } /** * @param {?} index * @return {?} */ setIndex(index) { this.index = index; this.elementRef.nativeElement.style.zIndex = AsiDropdownContainer.BASE_INDEX + index; } /** * @param {?} calculWidth * @return {?} */ setCalculWidth(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 = () => [ { 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'],] }] }; 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 {\r\n  TemplateRef,\r\n  Component,\r\n  ElementRef,\r\n  ViewChild,\r\n  HostListener,\r\n  Inject,\r\n  Input,\r\n  Renderer2,\r\n} from '@angular/core';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { AsiDropDown } from '../asi-dropdown.component';\r\nimport { DOCUMENT } from '@angular/common';\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: HTMLElement;\r\n\r\n  constructor(@Inject(DOCUMENT) private document: any, private renderer: Renderer2, private elementRef: ElementRef) {}\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 relativeTo The parent HTMLElement of the dropdown\r\n   */\r\n  forElement(relativeTo: any) {\r\n    this.referenceElement = relativeTo;\r\n\r\n    const rectRelativeTo = relativeTo.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    const bodyMarginTop = parseInt(bodyComputedStyle.marginTop.slice(0, -2), 10);\r\n\r\n    // Get the computed class margin (from both style + css class)\r\n    const parentComputedStyle = getComputedStyle(this.elementRef.nativeElement);\r\n\r\n    const parentMarginTop = parseInt(parentComputedStyle.marginTop.slice(0, -2), 10);\r\n    const parentMarginLeft = parseInt(parentComputedStyle.marginLeft.slice(0, -2), 10);\r\n\r\n    const rectElement = this.elementRef.nativeElement.getBoundingClientRect();\r\n\r\n    const screenVerticalPosition = rectRelativeTo.top - bodyMarginTop;\r\n    if (screenVerticalPosition > this.document.body.clientHeight / 2) {\r\n      // show over the element\r\n      const bodyVerticalPosition = rectElement.bottom - rectRelativeTo.top + parentMarginTop;\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      const bodyVerticalPosition = - rectElement.top + rectRelativeTo.top - parentMarginTop + relativeTo.offsetHeight;\r\n      this.drop.nativeElement.style.top = bodyVerticalPosition + 'px';\r\n      this.drop.nativeElement.style.marginTop = '2px';\r\n    }\r\n    this.drop.nativeElement.style.left = rectRelativeTo.left - rectElement.left - parentMarginLeft + 'px';\r\n\r\n    this.drop.nativeElement.style.width = relativeTo.offsetWidth + 'px';\r\n  }\r\n\r\n  /**\r\n   * @param asiDrownDown 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        const dropContainer = this.drop.nativeElement.getBoundingClientRect();\r\n        if (dropContainer.right > this.document.documentElement.clientWidth) {\r\n          this.drop.nativeElement.style.left =\r\n            (this.drop.nativeElement.offsetLeft - dropContainer.right + this.document.documentElement.clientWidth) + 'px';\r\n        }\r\n\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"]}