ngx-aside
Version:
Angular Aside Component. Simple Angular Sidebar Panel.
274 lines (264 loc) • 27.5 kB
JavaScript
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/animations'), require('@angular/common')) :
typeof define === 'function' && define.amd ? define('ngx-aside', ['exports', '@angular/core', '@angular/animations', '@angular/common'], factory) :
(factory((global['ngx-aside'] = {}),global.ng.core,global.ng.animations,global.ng.common));
}(this, (function (exports,core,animations,common) { 'use strict';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var NgxOverlayComponent = (function () {
function NgxOverlayComponent() {
this.showStatus = true;
}
NgxOverlayComponent.decorators = [
{ type: core.Component, args: [{
selector: 'ngx-aside-overlay',
template: "\n <div class=\"overlay\" [@show]=\"showStatus\"></div>",
styles: [".overlay {\n z-index: 1;\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: currentColor;\n opacity: .6;\n }"],
animations: [
animations.trigger('show', [
animations.transition('void => *', [
animations.style([{ opacity: 0 }]),
animations.animate(100, animations.style([{ opacity: .6 }]))
])
])
]
},] },
];
/** @nocollapse */
NgxOverlayComponent.ctorParameters = function () { return []; };
return NgxOverlayComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/** @type {?} */
var slideAnimations = animations.trigger('slide', [
animations.transition('void => left', [
animations.style({
opacity: .6,
transform: 'translate3d(-100%,0,0)'
}),
animations.animate('.2s cubic-bezier(0.215, 0.610, 0.355, 1)', animations.style({
opacity: 1,
transform: 'translateZ(0)'
}))
]),
animations.transition('void => right', [
animations.style({
opacity: .6,
transform: 'translate3d(100%,0,0)'
}),
animations.animate('.2s cubic-bezier(0.215, 0.610, 0.355, 1)', animations.style({
opacity: 1,
transform: 'translateZ(0)'
}))
]),
animations.transition('left => void', [
animations.animate('.2s cubic-bezier(0.165, 0.84, 0.44, 1)', animations.style({
opacity: 0,
transform: 'translate3d(-50%,0,0)'
}))
]),
animations.transition('right => void', [
animations.animate('.2s cubic-bezier(0.165, 0.84, 0.44, 1)', animations.style({
opacity: 0,
transform: 'translate3d(50%,0,0)'
}))
])
]);
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var NgxAsideComponent = (function () {
function NgxAsideComponent(_resolver, vcRef) {
this._resolver = _resolver;
this.vcRef = vcRef;
this.cancel = new core.EventEmitter();
this.submit = new core.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 {?}
*/
NgxAsideComponent.prototype.hideAside = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.cancel.observers.length > 0) {
this.cancel.emit(event);
}
else {
// If we don`t have any subscribers
this.hide();
}
};
/**
* @param {?} event
* @return {?}
*/
NgxAsideComponent.prototype.submitAside = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.cancel.observers.length > 0) {
this.submit.emit();
}
else {
// If we don`t have any subscribers
this.hide();
}
};
/**
* @param {?} event
* @return {?}
*/
NgxAsideComponent.prototype.handleEscape = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.closeOnEscape) {
event.preventDefault();
this.hideAside(event);
}
return false;
};
/**
* @return {?}
*/
NgxAsideComponent.prototype.hide = /**
* @return {?}
*/
function () {
this.visibleStatus = false;
if (!this.backdrop) {
return;
}
this.backdrop.destroy();
this.backdrop = void 0;
};
/**
* @return {?}
*/
NgxAsideComponent.prototype.show = /**
* @return {?}
*/
function () {
this.visibleStatus = true;
this.addOverlay();
};
/**
* @return {?}
*/
NgxAsideComponent.prototype.addOverlay = /**
* @return {?}
*/
function () {
if (!this.backdrop && this.showOverlay) {
/** @type {?} */
var OverlayComponentFactory = this._resolver.resolveComponentFactory(NgxOverlayComponent);
this.backdrop = this.rootViewContainerRef.createComponent(OverlayComponentFactory, 0);
}
};
NgxAsideComponent.decorators = [
{ type: core.Component, args: [{
selector: 'ngx-aside',
template: "<aside [@slide]=\"position\" *ngIf=\"visibleStatus\" [className]=\"position\">\n\n <!-- Custom Header -->\n <ng-content *ngIf=\"!showDefaultHeader\" class=\"aside-title-huj\" select=\"header\">\n\n\n </ng-content>\n <!-- End Custom Header -->\n\n\n <!-- Default Header -->\n <header *ngIf=\"showDefaultHeader\">\n <div class=\"aside-title\">\n {{title}}\n </div>\n\n <div (click)=\"hideAside($event)\" class=\"aside-button-close\">\n ×\n </div>\n\n </header>\n <!-- End Custom Header -->\n\n\n <section>\n <div class=\"aside-container\">\n <ng-content></ng-content>\n </div>\n </section>\n\n <!-- Custom Footer -->\n <ng-content *ngIf=\"!showDefaultFooter\" select=\"footer\"></ng-content>\n <!-- End Custom Footer -->\n\n <!-- Default Footer -->\n <footer *ngIf=\"showDefaultFooter\">\n\n <button (click)=\"hideAside($event)\" type=\"button\" class=\"btn btn-secondary btn-cancel\">\n {{cancelButtonTitle}}</button>\n\n <button (click)=\"submitAside($event)\" type=\"button\" class=\"btn btn-primary btn-submit\">{{submitButtonTitle}}</button>\n\n\n </footer>\n <!--End Default Footer -->\n\n</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 = function () {
return [
{ type: core.ComponentFactoryResolver },
{ type: core.ViewContainerRef }
];
};
NgxAsideComponent.propDecorators = {
cancel: [{ type: core.Output }],
submit: [{ type: core.Output }],
position: [{ type: core.Input }],
showOverlay: [{ type: core.Input }],
closeOnEscape: [{ type: core.Input }],
showDefaultFooter: [{ type: core.Input }],
showDefaultHeader: [{ type: core.Input }],
title: [{ type: core.Input }],
cancelButtonTitle: [{ type: core.Input }],
submitButtonTitle: [{ type: core.Input }],
handleEscape: [{ type: core.HostListener, args: ['document:keydown.esc', ['$event'],] }]
};
return NgxAsideComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var NgxAsideModule = (function () {
function NgxAsideModule() {
}
/**
* @return {?}
*/
NgxAsideModule.forRoot = /**
* @return {?}
*/
function () {
return {
ngModule: NgxAsideModule,
providers: []
};
};
NgxAsideModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
common.CommonModule
],
declarations: [
NgxAsideComponent,
NgxOverlayComponent
],
providers: [],
entryComponents: [
NgxAsideComponent,
NgxOverlayComponent
],
exports: [
NgxAsideComponent,
NgxOverlayComponent
]
},] },
];
return NgxAsideModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
exports.NgxAsideModule = NgxAsideModule;
exports.ɵb = slideAnimations;
exports.ɵa = NgxAsideComponent;
exports.ɵc = NgxOverlayComponent;
Object.defineProperty(exports, '__esModule', { value: true });
})));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-aside.umd.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":["Component","trigger","transition","style","animate","EventEmitter","ComponentFactoryResolver","ViewContainerRef","Output","Input","HostListener","NgModule","CommonModule"],"mappings":"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"}