@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
JavaScript
/**
* @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"]}