UNPKG

@lucasferreiralsf/angular-frontend-library

Version:

This is a set of custom angular components to easy the development of any Subway frontend project.

174 lines 14.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Output, EventEmitter, ViewChild, ViewContainerRef } from '@angular/core'; import { trigger, transition, useAnimation } from '@angular/animations'; import { flipInX, flipOutX } from 'ng-animate'; import { Overlay, CdkOverlayOrigin, OverlayConfig } from '@angular/cdk/overlay'; import { TemplatePortalDirective } from '@angular/cdk/portal'; export class FilterTableComponent { /** * @param {?} overlay * @param {?} viewContainerRef */ constructor(overlay, viewContainerRef) { this.overlay = overlay; this.viewContainerRef = viewContainerRef; this.limpar = new EventEmitter(); this.pesquisa = new EventEmitter(); this.positions = [{ originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top' }]; } /** * @return {?} */ ngOnInit() { this.dropDownDialogOpen = 'out'; this.btnLimparOutsideShow = 'out'; } /** * @return {?} */ ngAfterViewInit() { this.strategy = this.overlay.position() .flexibleConnectedTo(this._overlayOrigin.elementRef) .withPositions(this.positions).withTransformOriginOn('#filter-table-button'); this.config = new OverlayConfig({ positionStrategy: this.strategy, hasBackdrop: true, backdropClass: 'cdk-overlay-transparent-backdrop' }); this.overlayRef = this.overlay.create(this.config); } /** * @return {?} */ openFilterTableContentOverlay() { this.overlayRef.backdropClick().subscribe((/** * @return {?} */ () => { this.overlayRef.detach(); })); this.overlayRef.attach(this.overlayDropDownContentTemplate); } /** * closeDropdown * @return {?} */ closeDropdown() { if (this.overlayRef.hasAttached) { this.overlayRef.detach(); } } /* clickedInside($event: Event) { $event.preventDefault(); $event.stopPropagation(); // <- that will stop propagation on lower layers } */ /* @HostListener("document:click", ['$event']) clickedOutside($event) { this.dropDownDialogOpen = 'out' } */ /** * @return {?} */ toggleFilter() { this.dropDownDialogOpen = this.dropDownDialogOpen === 'out' ? 'in' : 'out'; } /** * @return {?} */ pesquisar() { this.pesquisa.emit(); this.btnLimparOutsideShow = 'in'; this.closeDropdown(); } /** * @return {?} */ limparFiltro() { this.limpar.emit(); this.btnLimparOutsideShow = 'out'; this.closeDropdown(); } } FilterTableComponent.decorators = [ { type: Component, args: [{ selector: 'sb-filter-table', template: "<div fxLayout=\"row\" fxLayoutAlign=\"flex-end center\">\r\n\t<button @flipInOut *ngIf=\"btnLimparOutsideShow == 'in'\" id=\"btn-filter-limpar-outside\" mat-button class=\"btn-filter\"\r\n\t\t(click)=\"limparFiltro();\">Limpar Filtro</button>\r\n\t<button mat-icon-button (click)=\"openFilterTableContentOverlay()\" cdk-overlay-origin id=\"filter-table-button\">\r\n\t\t<mat-icon>filter_list</mat-icon>\r\n\t</button>\r\n\t<ng-template cdk-portal #overlayDropDownContentTemplate=\"cdkPortal\">\r\n\t\t<mat-card @flipInOut style=\"z-index: 1;\" class=\"mat-elevation-z4\">\r\n\t\t\t<div fxLayout=\"row wrap\" fxLayoutGap=\"20px grid\" fxLayoutAlign=\"center\">\r\n\t\t\t\t<ng-content></ng-content>\r\n\t\t\t</div>\r\n\t\t\t<sb-filter-table-actions (limpar)=\"limparFiltro()\" (pesquisa)=\"pesquisar()\"></sb-filter-table-actions>\r\n\t\t</mat-card>\r\n\t</ng-template>\r\n</div>\r\n", animations: [ trigger('flipInOut', [ transition('void => *', useAnimation(flipInX, { params: { timing: 0.4, delay: 0 } })), transition('* => void', useAnimation(flipOutX, { params: { timing: 0.5, delay: 0 } })) ]) ], styles: [""] }] } ]; /** @nocollapse */ FilterTableComponent.ctorParameters = () => [ { type: Overlay }, { type: ViewContainerRef } ]; FilterTableComponent.propDecorators = { limpar: [{ type: Output }], pesquisa: [{ type: Output }], _overlayOrigin: [{ type: ViewChild, args: [CdkOverlayOrigin,] }], overlayDropDownContentTemplate: [{ type: ViewChild, args: ['overlayDropDownContentTemplate',] }] }; if (false) { /** * @type {?} * @private */ FilterTableComponent.prototype.strategy; /** * @type {?} * @private */ FilterTableComponent.prototype.config; /** * @type {?} * @private */ FilterTableComponent.prototype.overlayRef; /** @type {?} */ FilterTableComponent.prototype.dropDownDialogOpen; /** @type {?} */ FilterTableComponent.prototype.btnLimparOutsideShow; /** @type {?} */ FilterTableComponent.prototype.limpar; /** @type {?} */ FilterTableComponent.prototype.pesquisa; /** * @type {?} * @private */ FilterTableComponent.prototype._overlayOrigin; /** * @type {?} * @private */ FilterTableComponent.prototype.overlayDropDownContentTemplate; /** * @type {?} * @private */ FilterTableComponent.prototype.positions; /** * @type {?} * @private */ FilterTableComponent.prototype.overlay; /** @type {?} */ FilterTableComponent.prototype.viewContainerRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-table.component.js","sourceRoot":"ng://@lucasferreiralsf/angular-frontend-library/","sources":["lib/data-table/filter-table/filter-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Output, EventEmitter, ViewChild, ViewContainerRef, AfterViewInit } from '@angular/core';\r\nimport { trigger, transition, useAnimation } from '@angular/animations';\r\nimport { flipInX, flipOutX } from 'ng-animate';\r\nimport {\r\n  Overlay,\r\n  CdkOverlayOrigin,\r\n  OverlayConfig,\r\n  ConnectedPosition,\r\n  OverlayRef\r\n} from '@angular/cdk/overlay';\r\nimport { TemplatePortalDirective } from '@angular/cdk/portal';\r\n\r\n@Component({\r\n  selector: 'sb-filter-table',\r\n  templateUrl: './filter-table.component.html',\r\n  styleUrls: ['./filter-table.component.scss'],\r\n  animations: [\r\n    trigger('flipInOut', [\r\n      transition('void => *', useAnimation(flipInX, {\r\n        params: { timing: 0.4, delay: 0 }})),\r\n      transition('* => void', useAnimation(flipOutX, {\r\n        params: { timing: 0.5, delay: 0 }}))\r\n    ])\r\n  ],\r\n})\r\nexport class FilterTableComponent implements OnInit, AfterViewInit {\r\n\r\n  private strategy: any;\r\n  private config: OverlayConfig;\r\n  private overlayRef: OverlayRef;\r\n  dropDownDialogOpen: string;\r\n  btnLimparOutsideShow: string;\r\n  @Output() limpar: EventEmitter<void> = new EventEmitter();\r\n  @Output() pesquisa: EventEmitter<any> = new EventEmitter();\r\n  @ViewChild(CdkOverlayOrigin) private _overlayOrigin: CdkOverlayOrigin;\r\n  @ViewChild('overlayDropDownContentTemplate') private overlayDropDownContentTemplate: TemplatePortalDirective;\r\n\r\n  private positions: ConnectedPosition[] = [{\r\n    originX: 'end',\r\n    originY: 'bottom',\r\n    overlayX: 'end',\r\n    overlayY: 'top'\r\n  }];\r\n\r\n  constructor(\r\n    private overlay: Overlay,\r\n    public viewContainerRef: ViewContainerRef\r\n    ) { }\r\n\r\n  ngOnInit() {\r\n    this.dropDownDialogOpen = 'out';\r\n    this.btnLimparOutsideShow = 'out';\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.strategy = this.overlay.position()\r\n      .flexibleConnectedTo(\r\n        this._overlayOrigin.elementRef)\r\n      .withPositions(this.positions).withTransformOriginOn('#filter-table-button');\r\n\r\n    this.config = new OverlayConfig({\r\n      positionStrategy: this.strategy,\r\n      hasBackdrop: true,\r\n      backdropClass: 'cdk-overlay-transparent-backdrop'\r\n    });\r\n    this.overlayRef = this.overlay.create(this.config);\r\n\r\n\r\n  }\r\n\r\n  openFilterTableContentOverlay() {\r\n\r\n    this.overlayRef.backdropClick().subscribe(() => {\r\n      this.overlayRef.detach();\r\n    });\r\n\r\n    this.overlayRef.attach(this.overlayDropDownContentTemplate);\r\n  }\r\n\r\n\r\n  /**\r\n   * closeDropdown\r\n   */\r\n  public closeDropdown() {\r\n    if (this.overlayRef.hasAttached) {\r\n      this.overlayRef.detach();\r\n    }\r\n  }\r\n\r\n  /* clickedInside($event: Event) {\r\n    $event.preventDefault();\r\n    $event.stopPropagation();  // <- that will stop propagation on lower layers\r\n  } */\r\n\r\n\r\n  /* @HostListener(\"document:click\", ['$event']) clickedOutside($event) {\r\n      this.dropDownDialogOpen = 'out'\r\n  } */\r\n\r\n  toggleFilter(): void {\r\n    this.dropDownDialogOpen = this.dropDownDialogOpen === 'out' ? 'in' : 'out';\r\n  }\r\n\r\n  pesquisar() {\r\n    this.pesquisa.emit();\r\n    this.btnLimparOutsideShow = 'in';\r\n    this.closeDropdown();\r\n  }\r\n\r\n  limparFiltro() {\r\n    this.limpar.emit();\r\n    this.btnLimparOutsideShow = 'out';\r\n    this.closeDropdown();\r\n  }\r\n\r\n  /* pesquisar() {\r\n    this.pesquisa.emit()\r\n    this.btnLimparOutsideShow = 'in'\r\n    this.toggleFilter()\r\n  } */\r\n\r\n  /* limparFiltro() {\r\n    this.limpar.emit()\r\n    this.btnLimparOutsideShow = 'out'\r\n    this.dropDownDialogOpen = 'out'\r\n  } */\r\n\r\n}\r\n"]}