UNPKG

ngx-aside

Version:

Angular Aside Component. Simple Angular Sidebar Panel.

306 lines (278 loc) 24.3 kB
import { Component, Input, ViewContainerRef, Output, EventEmitter, HostListener, ComponentFactoryResolver, NgModule } from '@angular/core'; import { trigger, transition, style, animate } from '@angular/animations'; import { CommonModule } from '@angular/common'; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ class NgxOverlayComponent { constructor() { this.showStatus = true; } } NgxOverlayComponent.decorators = [ { type: Component, args: [{ selector: 'ngx-aside-overlay', template: ` <div class="overlay" [@show]="showStatus"></div>`, styles: [`.overlay { z-index: 1; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-color: currentColor; opacity: .6; }`], animations: [ trigger('show', [ transition('void => *', [ style([{ opacity: 0 }]), animate(100, style([{ opacity: .6 }])) ]) ]) ] },] }, ]; /** @nocollapse */ NgxOverlayComponent.ctorParameters = () => []; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ /** @type {?} */ const slideAnimations = trigger('slide', [ transition('void => left', [ style({ opacity: .6, transform: 'translate3d(-100%,0,0)' }), animate('.2s cubic-bezier(0.215, 0.610, 0.355, 1)', style({ opacity: 1, transform: 'translateZ(0)' })) ]), transition('void => right', [ style({ opacity: .6, transform: 'translate3d(100%,0,0)' }), animate('.2s cubic-bezier(0.215, 0.610, 0.355, 1)', style({ opacity: 1, transform: 'translateZ(0)' })) ]), transition('left => void', [ animate('.2s cubic-bezier(0.165, 0.84, 0.44, 1)', style({ opacity: 0, transform: 'translate3d(-50%,0,0)' })) ]), transition('right => void', [ animate('.2s cubic-bezier(0.165, 0.84, 0.44, 1)', style({ opacity: 0, transform: 'translate3d(50%,0,0)' })) ]) ]); /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ /* TODO: Configurable parameters width max-width TODO: @OutputEvents @OutputFunctions ? ---- */ class NgxAsideComponent { /** * @param {?} _resolver * @param {?} vcRef */ constructor(_resolver, vcRef) { this._resolver = _resolver; this.vcRef = vcRef; this.cancel = new EventEmitter(); this.submit = new EventEmitter(); this.position = 'right'; this.showOverlay = true; this.closeOnEscape = true; this.showDefaultFooter = true; this.showDefaultHeader = true; this.title = ''; this.cancelButtonTitle = 'Cancel'; this.submitButtonTitle = 'Submit'; this.visibleStatus = false; this.rootViewContainerRef = vcRef; } /** * @param {?} event * @return {?} */ hideAside(event) { if (this.cancel.observers.length > 0) { this.cancel.emit(event); } else { // If we don`t have any subscribers this.hide(); } } /** * @param {?} event * @return {?} */ submitAside(event) { if (this.cancel.observers.length > 0) { this.submit.emit(); } else { // If we don`t have any subscribers this.hide(); } } /** * @param {?} event * @return {?} */ handleEscape(event) { if (this.closeOnEscape) { event.preventDefault(); this.hideAside(event); } return false; } /** * @return {?} */ hide() { this.visibleStatus = false; if (!this.backdrop) { return; } this.backdrop.destroy(); this.backdrop = void 0; } /** * @return {?} */ show() { this.visibleStatus = true; this.addOverlay(); } /** * @return {?} */ addOverlay() { if (!this.backdrop && this.showOverlay) { /** @type {?} */ const OverlayComponentFactory = this._resolver.resolveComponentFactory(NgxOverlayComponent); this.backdrop = this.rootViewContainerRef.createComponent(OverlayComponentFactory, 0); } } } NgxAsideComponent.decorators = [ { type: Component, args: [{ selector: 'ngx-aside', template: `<aside [@slide]="position" *ngIf="visibleStatus" [className]="position"> <!-- Custom Header --> <ng-content *ngIf="!showDefaultHeader" class="aside-title-huj" select="header"> </ng-content> <!-- End Custom Header --> <!-- Default Header --> <header *ngIf="showDefaultHeader"> <div class="aside-title"> {{title}} </div> <div (click)="hideAside($event)" class="aside-button-close"> &times; </div> </header> <!-- End Custom Header --> <section> <div class="aside-container"> <ng-content></ng-content> </div> </section> <!-- Custom Footer --> <ng-content *ngIf="!showDefaultFooter" select="footer"></ng-content> <!-- End Custom Footer --> <!-- Default Footer --> <footer *ngIf="showDefaultFooter"> <button (click)="hideAside($event)" type="button" class="btn btn-secondary btn-cancel"> {{cancelButtonTitle}}</button> <button (click)="submitAside($event)" type="button" class="btn btn-primary btn-submit">{{submitButtonTitle}}</button> </footer> <!--End Default Footer --> </aside>`, styles: [`:host *{box-sizing:border-box}:host aside.right{right:0;top:0;bottom:0}:host aside.left{left:0;top:0;bottom:0}aside{will-change:opacity;display:flex;flex-direction:column;align-items:stretch;position:fixed;width:auto;max-width:50%;background-color:#fff;z-index:2;box-shadow:-6px 3px 11px 0 rgba(0,0,0,.23);padding:0 16px;height:100vh}section{overflow:auto;flex-grow:1}header{font-size:20px;display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%;height:64px;flex-shrink:0}header .aside-button-close{width:20px;text-align:center;opacity:.8}header .aside-button-close:hover{cursor:pointer;opacity:1}footer{flex-shrink:0;border-top:1px solid #e5e5e5;display:flex;align-items:flex-start;padding:16px 0}footer button{margin-right:6px}.left footer{justify-content:flex-end}.right footer{justify-content:flex-start}:host.left aside{box-shadow:6px -1px 11px 0 rgba(0,0,0,.23)}:host.left.footer{justify-content:flex-end}`], animations: [slideAnimations] },] }, ]; /** @nocollapse */ NgxAsideComponent.ctorParameters = () => [ { type: ComponentFactoryResolver }, { type: ViewContainerRef } ]; NgxAsideComponent.propDecorators = { cancel: [{ type: Output }], submit: [{ type: Output }], position: [{ type: Input }], showOverlay: [{ type: Input }], closeOnEscape: [{ type: Input }], showDefaultFooter: [{ type: Input }], showDefaultHeader: [{ type: Input }], title: [{ type: Input }], cancelButtonTitle: [{ type: Input }], submitButtonTitle: [{ type: Input }], handleEscape: [{ type: HostListener, args: ['document:keydown.esc', ['$event'],] }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ class NgxAsideModule { /** * @return {?} */ static forRoot() { return { ngModule: NgxAsideModule, providers: [] }; } } NgxAsideModule.decorators = [ { type: NgModule, args: [{ imports: [ CommonModule ], declarations: [ NgxAsideComponent, NgxOverlayComponent ], providers: [], entryComponents: [ NgxAsideComponent, NgxOverlayComponent ], exports: [ NgxAsideComponent, NgxOverlayComponent ] },] }, ]; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ export { NgxAsideModule, slideAnimations as ɵb, NgxAsideComponent as ɵa, NgxOverlayComponent as ɵc }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-aside.js.map","sources":["ng://ngx-aside/lib/overlay.component.ts","ng://ngx-aside/lib/aside.animations.ts","ng://ngx-aside/lib/aside.component.ts","ng://ngx-aside/lib/aside.module.ts"],"sourcesContent":["import {\r\n  Component\r\n} from '@angular/core';\r\n\r\nimport {\r\n  trigger,\r\n  transition,\r\n  style,\r\n  animate\r\n} from '@angular/animations';\r\n\r\n@Component({\r\n  selector: 'ngx-aside-overlay',\r\n  template: `\r\n        <div class=\"overlay\" [@show]=\"showStatus\"></div>`,\r\n  styles: [`.overlay {\r\n        z-index: 1;\r\n        position: absolute;\r\n        top: 0;\r\n        left: 0;\r\n        right: 0;\r\n        bottom: 0;\r\n        background-color: currentColor;\r\n        opacity: .6;\r\n    }`],\r\n  animations: [\r\n    trigger('show', [\r\n      transition('void => *', [\r\n        style([{ opacity: 0 }]),\r\n        animate(100,\r\n          style([{ opacity: .6 }])\r\n        )\r\n      ])\r\n    ])\r\n  ]\r\n})\r\n\r\nexport class NgxOverlayComponent {\r\n  public showStatus: boolean;\r\n\r\n  constructor() {\r\n    this.showStatus = true;\r\n  }\r\n}\r\n","import { transition, style, animate, trigger, AnimationTriggerMetadata } from '@angular/animations';\r\n\r\nexport const slideAnimations: AnimationTriggerMetadata = trigger('slide', [\r\n\r\n  transition('void => left', [\r\n    style({\r\n      opacity: .6,\r\n      transform: 'translate3d(-100%,0,0)'\r\n    }),\r\n    animate('.2s cubic-bezier(0.215, 0.610, 0.355, 1)',\r\n      style({\r\n        opacity: 1,\r\n        transform: 'translateZ(0)'\r\n      }))\r\n  ]),\r\n\r\n  transition('void => right', [\r\n    style({\r\n      opacity: .6,\r\n      transform: 'translate3d(100%,0,0)'\r\n    }),\r\n    animate('.2s cubic-bezier(0.215, 0.610, 0.355, 1)',\r\n      style({\r\n        opacity: 1,\r\n        transform: 'translateZ(0)'\r\n      }))\r\n  ]),\r\n\r\n  transition('left => void', [\r\n    animate('.2s cubic-bezier(0.165, 0.84, 0.44, 1)', style({\r\n      opacity: 0,\r\n      transform: 'translate3d(-50%,0,0)'\r\n    }\r\n    ))\r\n  ]),\r\n\r\n  transition('right => void', [\r\n    animate('.2s cubic-bezier(0.165, 0.84, 0.44, 1)', style({\r\n      opacity: 0,\r\n      transform: 'translate3d(50%,0,0)'\r\n    }\r\n    ))\r\n  ])\r\n]);\r\n","import {\r\n  Component,\r\n  Input,\r\n  ViewContainerRef,\r\n  Output,\r\n  EventEmitter,\r\n  ComponentRef,\r\n  HostBinding,\r\n  OnInit,\r\n  HostListener,\r\n  ComponentFactoryResolver\r\n} from '@angular/core';\r\n\r\nimport { NgxOverlayComponent } from './overlay.component';\r\nimport { slideAnimations } from './aside.animations';\r\n\r\n@Component({\r\n  selector: 'ngx-aside',\r\n  template: `<aside [@slide]=\"position\" *ngIf=\"visibleStatus\" [className]=\"position\">\r\n\r\n    <!-- Custom Header -->\r\n    <ng-content *ngIf=\"!showDefaultHeader\" class=\"aside-title-huj\" select=\"header\">\r\n\r\n\r\n    </ng-content>\r\n    <!-- End Custom Header -->\r\n\r\n\r\n    <!-- Default Header -->\r\n    <header *ngIf=\"showDefaultHeader\">\r\n        <div class=\"aside-title\">\r\n            {{title}}\r\n        </div>\r\n\r\n        <div (click)=\"hideAside($event)\" class=\"aside-button-close\">\r\n            &times;\r\n        </div>\r\n\r\n    </header>\r\n    <!-- End Custom Header -->\r\n\r\n\r\n    <section>\r\n        <div class=\"aside-container\">\r\n            <ng-content></ng-content>\r\n        </div>\r\n    </section>\r\n\r\n    <!-- Custom Footer -->\r\n    <ng-content *ngIf=\"!showDefaultFooter\" select=\"footer\"></ng-content>\r\n    <!-- End Custom Footer -->\r\n\r\n    <!-- Default Footer -->\r\n    <footer *ngIf=\"showDefaultFooter\">\r\n\r\n        <button (click)=\"hideAside($event)\" type=\"button\" class=\"btn btn-secondary btn-cancel\">\r\n         {{cancelButtonTitle}}</button>\r\n\r\n        <button (click)=\"submitAside($event)\" type=\"button\" class=\"btn btn-primary btn-submit\">{{submitButtonTitle}}</button>\r\n\r\n\r\n    </footer>\r\n    <!--End  Default Footer -->\r\n\r\n</aside>`,\r\n  styles: [`:host *{box-sizing:border-box}:host aside.right{right:0;top:0;bottom:0}:host aside.left{left:0;top:0;bottom:0}aside{will-change:opacity;display:flex;flex-direction:column;align-items:stretch;position:fixed;width:auto;max-width:50%;background-color:#fff;z-index:2;box-shadow:-6px 3px 11px 0 rgba(0,0,0,.23);padding:0 16px;height:100vh}section{overflow:auto;flex-grow:1}header{font-size:20px;display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%;height:64px;flex-shrink:0}header .aside-button-close{width:20px;text-align:center;opacity:.8}header .aside-button-close:hover{cursor:pointer;opacity:1}footer{flex-shrink:0;border-top:1px solid #e5e5e5;display:flex;align-items:flex-start;padding:16px 0}footer button{margin-right:6px}.left footer{justify-content:flex-end}.right footer{justify-content:flex-start}:host.left aside{box-shadow:6px -1px 11px 0 rgba(0,0,0,.23)}:host.left.footer{justify-content:flex-end}`],\r\n  animations: [slideAnimations]\r\n})\r\n\r\n/*\r\n\r\n TODO: Configurable parameters\r\n width\r\n max-width\r\n\r\n TODO: @OutputEvents\r\n @OutputFunctions ?\r\n\r\n ----\r\n\r\n */\r\n\r\nexport class NgxAsideComponent {\r\n\r\n  @Output() public cancel: EventEmitter<any> = new EventEmitter();\r\n  @Output() public submit: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Input() public position = 'right';\r\n  @Input() public showOverlay = true;\r\n  @Input() public closeOnEscape = true;\r\n\r\n  @Input() public showDefaultFooter = true;\r\n  @Input() public showDefaultHeader = true;\r\n\r\n  @Input() public title = '';\r\n  @Input() public cancelButtonTitle = 'Cancel';\r\n  @Input() public submitButtonTitle = 'Submit';\r\n\r\n  public visibleStatus: boolean = false;\r\n  private rootViewContainerRef: ViewContainerRef;\r\n  private backdrop: ComponentRef<{}>;\r\n\r\n  constructor(private _resolver: ComponentFactoryResolver, private vcRef: ViewContainerRef) {\r\n    this.rootViewContainerRef = vcRef;\r\n  }\r\n\r\n  public hideAside(event) {\r\n    if (this.cancel.observers.length > 0) {\r\n      this.cancel.emit(event);\r\n    } else { // If we don`t have any subscribers\r\n      this.hide();\r\n    }\r\n\r\n  }\r\n\r\n  public submitAside(event) {\r\n    if (this.cancel.observers.length > 0) {\r\n      this.submit.emit();\r\n    } else {  // If we don`t have any subscribers\r\n      this.hide();\r\n\r\n    }\r\n  }\r\n\r\n  @HostListener('document:keydown.esc', ['$event'])\r\n  public handleEscape(event) {\r\n\r\n    if (this.closeOnEscape) {\r\n      event.preventDefault();\r\n      this.hideAside(event);\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public hide() {\r\n\r\n    this.visibleStatus = false;\r\n\r\n    if (!this.backdrop) {\r\n      return;\r\n    }\r\n\r\n    this.backdrop.destroy();\r\n    this.backdrop = void 0;\r\n\r\n  }\r\n\r\n  public show() {\r\n    this.visibleStatus = true;\r\n    this.addOverlay();\r\n  }\r\n\r\n  private addOverlay() {\r\n    if (!this.backdrop && this.showOverlay) {\r\n      const OverlayComponentFactory = this._resolver.resolveComponentFactory(NgxOverlayComponent);\r\n      this.backdrop = this.rootViewContainerRef.createComponent(OverlayComponentFactory, 0);\r\n    }\r\n  }\r\n}\r\n","import { NgModule, ModuleWithProviders } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { NgxOverlayComponent } from './overlay.component';\r\nimport { NgxAsideComponent } from './aside.component';\r\n\r\n@NgModule({\r\n  imports: [\r\n    CommonModule\r\n  ],\r\n  declarations: [\r\n    NgxAsideComponent,\r\n    NgxOverlayComponent\r\n  ],\r\n  providers: [],\r\n  entryComponents: [\r\n    NgxAsideComponent,\r\n    NgxOverlayComponent\r\n  ],\r\n  exports: [\r\n    NgxAsideComponent,\r\n    NgxOverlayComponent\r\n  ]\r\n})\r\nexport class NgxAsideModule {\r\n  static forRoot(): ModuleWithProviders {\r\n    return {\r\n      ngModule: NgxAsideModule,\r\n      providers: []\r\n    };\r\n  }\r\n}\r\n"],"names":[],"mappings":"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"}