tp-window
Version:
ThingsPro window component UI
175 lines (165 loc) • 19.3 kB
JavaScript
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('/core'), require('@angular/animations'), require('/common'), require('@angular/material'), require('/material/icon'), require('/material/button'), require('/material/progress-bar'), require('/material/menu'), require('/cdk/portal')) :
typeof define === 'function' && define.amd ? define('tp-window', ['exports', '/core', '@angular/animations', '/common', '@angular/material', '/material/icon', '/material/button', '/material/progress-bar', '/material/menu', '/cdk/portal'], factory) :
(factory((global['tp-window'] = {}),global.ng.core,global.ng.animations,global.ng.common,global.ng.material,global.ng.material.icon,global.ng.material.button,global.ng.material['progress-bar'],global.ng.material.menu,global.ng.cdk.portal));
}(this, (function (exports,core,animations,common,material,icon,button,progressBar,menu,portal) { 'use strict';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
var WindowStateComponent = (function () {
function WindowStateComponent() {
}
WindowStateComponent.decorators = [
{ type: core.Component, args: [{
selector: 'tp-window-state',
template: "\n <ng-template #templateRef>\n <ng-content></ng-content>\n </ng-template>\n ",
inputs: ['name', 'icon', 'type']
},] },
];
WindowStateComponent.propDecorators = {
templateRef: [{ type: core.ViewChild, args: ['templateRef',] }],
type: [{ type: core.Input }]
};
return WindowStateComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
var /** @type {?} */ fadeOutAnimation = animations.trigger('fadeOut', [
animations.state('in', animations.style({ opacity: 1 })),
animations.transition('* => void', [
animations.animate(500, animations.style({ opacity: 0 }))
])
]);
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
var WindowComponent = (function () {
function WindowComponent() {
this.maxStateNumber = 5;
this.stateChange = new core.EventEmitter();
this.isShowLoading = false;
}
Object.defineProperty(WindowComponent.prototype, "loading", {
set: /**
* @param {?} loading
* @return {?}
*/ function (loading) {
var _this = this;
if (loading) {
this.isShowLoading = true;
loading.subscribe(function () {
_this.isShowLoading = false;
});
}
},
enumerable: true,
configurable: true
});
/**
* @param {?} portal
* @return {?}
*/
WindowComponent.prototype.setPortal = /**
* @param {?} portal
* @return {?}
*/
function (portal$$1) {
this.optionPortal = portal$$1;
};
/**
* @return {?}
*/
WindowComponent.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
this.currentState = this.states.first;
};
/**
* @param {?} state
* @return {?}
*/
WindowComponent.prototype.navigate = /**
* @param {?} state
* @return {?}
*/
function (state) {
if (state.type !== 'Button') {
this.currentState = state;
}
this.stateChange.emit(state);
};
WindowComponent.decorators = [
{ type: core.Component, args: [{
selector: 'tp-window',
template: "<div class=\"tp-window\">\n <mat-toolbar>\n <p class=\"mat-body-2 toolbar-title\">{{name}}</p>\n <div class=\"toolbar-flex\"></div>\n <ng-template [cdkPortalOutlet]=\"optionPortal\"></ng-template>\n <ng-template [ngIf]=\"states.length <= maxStateNumber\">\n <ng-container *ngFor=\"let state of states\">\n <button *ngIf=\"state.type !== 'Content'\" mat-icon-button (click)=\"navigate(state)\" matTooltip=\"{{state.name}}\">\n <mat-icon>{{state.icon}}</mat-icon>\n </button>\n </ng-container>\n </ng-template>\n\n <ng-template [ngIf]=\"states.length > maxStateNumber\">\n <ng-container *ngFor=\"let state of states\">\n <button *ngIf=\"state.type === 'Button'\" mat-icon-button (click)=\"navigate(state)\" matTooltip=\"{{state.name}}\">\n <mat-icon>{{state.icon}}</mat-icon>\n </button>\n </ng-container>\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n <mat-icon>more_horiz</mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\">\n <ng-container *ngFor=\"let state of states\">\n <button *ngIf=\"state.type === 'State'\" mat-menu-item (click)=\"navigate(state)\">\n <mat-icon>{{state.icon}}</mat-icon>\n <span>{{state.name}}</span>\n </button>\n </ng-container>\n </mat-menu>\n </ng-template>\n\n </mat-toolbar>\n <div class=\"loading\">\n <mat-progress-bar *ngIf=\"isShowLoading\" [@fadeOut]=\"'in'\" mode=\"indeterminate\" color=\"primary\"></mat-progress-bar>\n </div>\n <div class=\"content padding\">\n <div *ngTemplateOutlet=\"currentState.templateRef\"></div>\n </div>\n <ng-content></ng-content>\n</div>\n",
styles: [".tp-window{box-shadow:0 1px 3px 0 rgba(0,0,0,.2),0 1px 1px 0 rgba(0,0,0,.14),0 2px 1px -1px rgba(0,0,0,.12)}.tp-window mat-toolbar .toolbar-title{color:#9e9e9e}.tp-window mat-toolbar .toolbar-flex{flex:1}.tp-window button{color:#9e9e9e;transition:background ease-out .2s}.tp-window button:hover{background-color:#e0e0e0}.tp-window .padding{padding:1em 1.5em}.tp-window .loading{height:10px}"],
inputs: ['name'],
exportAs: 'tpWindow',
animations: [fadeOutAnimation]
},] },
];
WindowComponent.propDecorators = {
loadingRef: [{ type: core.ViewChild, args: ['loadingPortal',] }],
states: [{ type: core.ContentChildren, args: [WindowStateComponent,] }],
loading: [{ type: core.Input }],
maxStateNumber: [{ type: core.Input }],
optionPortal: [{ type: core.Input }],
stateChange: [{ type: core.Output }]
};
return WindowComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
var WindowModule = (function () {
function WindowModule() {
}
WindowModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
portal.PortalModule,
menu.MatMenuModule,
progressBar.MatProgressBarModule,
button.MatButtonModule,
icon.MatIconModule,
material.MatTooltipModule,
common.CommonModule,
material.MatToolbarModule
],
declarations: [WindowComponent, WindowStateComponent],
exports: [WindowComponent, WindowStateComponent]
},] },
];
return WindowModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/** @enum {number} */
var stateType = {
Button: 0,
Content: 1,
State: 2,
};
stateType[stateType.Button] = "Button";
stateType[stateType.Content] = "Content";
stateType[stateType.State] = "State";
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
exports.stateType = stateType;
exports.WindowComponent = WindowComponent;
exports.WindowModule = WindowModule;
exports.ɵb = fadeOutAnimation;
exports.ɵa = WindowStateComponent;
Object.defineProperty(exports, '__esModule', { value: true });
})));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tp-window.umd.js.map","sources":["ng://tp-window/lib/tp-window.state.component.ts","ng://tp-window/lib/tp-window.animation.ts","ng://tp-window/lib/tp-window.component.ts","ng://tp-window/lib/tp-window.module.ts","ng://tp-window/public_api.ts"],"sourcesContent":["import { Component, TemplateRef, ViewChild, Input } from '@angular/core';\nexport type stateType = 'Button' | 'Content' | 'State';\n\n@Component({\n  selector: 'tp-window-state',\n  template: `\n    <ng-template #templateRef>\n      <ng-content></ng-content>\n    </ng-template>\n  `,\n  inputs: ['name', 'icon', 'type']\n})\n\nexport class WindowStateComponent {\n\n  @ViewChild('templateRef') templateRef: TemplateRef<any>;\n  @Input()\n  type: stateType;\n  name: string;\n  icon: string;\n}\n","import {\n  trigger,\n  state,\n  style,\n  animate,\n  transition,\n  AnimationTriggerMetadata\n} from '@angular/animations';\n\nexport const fadeOutAnimation:AnimationTriggerMetadata = trigger('fadeOut', [\n  state('in', style({opacity: 1})),\n  transition('* => void', [\n    animate(500, style({opacity: 0}))\n  ])\n])\n","import {\n  Component,\n  ContentChildren,\n  QueryList,\n  AfterContentInit,\n  TemplateRef,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild } from '@angular/core';\nimport { CdkPortalOutlet, Portal } from '@angular/cdk/portal';\nimport { WindowStateComponent,stateType } from './tp-window.state.component';\nimport { Observable } from 'rxjs';\nimport { fadeOutAnimation } from './tp-window.animation';\nexport { stateType } from './tp-window.state.component';\n\n@Component({\n  selector: 'tp-window',\n  template: `<div class=\"tp-window\">\n  <mat-toolbar>\n    <p class=\"mat-body-2 toolbar-title\">{{name}}</p>\n    <div class=\"toolbar-flex\"></div>\n      <ng-template [cdkPortalOutlet]=\"optionPortal\"></ng-template>\n      <ng-template [ngIf]=\"states.length <= maxStateNumber\">\n        <ng-container *ngFor=\"let state of states\">\n          <button *ngIf=\"state.type !== 'Content'\" mat-icon-button (click)=\"navigate(state)\" matTooltip=\"{{state.name}}\">\n            <mat-icon>{{state.icon}}</mat-icon>\n          </button>\n        </ng-container>\n      </ng-template>\n\n      <ng-template [ngIf]=\"states.length > maxStateNumber\">\n        <ng-container *ngFor=\"let state of states\">\n          <button *ngIf=\"state.type === 'Button'\" mat-icon-button (click)=\"navigate(state)\" matTooltip=\"{{state.name}}\">\n            <mat-icon>{{state.icon}}</mat-icon>\n          </button>\n        </ng-container>\n        <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n          <mat-icon>more_horiz</mat-icon>\n        </button>\n        <mat-menu #menu=\"matMenu\">\n          <ng-container *ngFor=\"let state of states\">\n            <button *ngIf=\"state.type === 'State'\" mat-menu-item (click)=\"navigate(state)\">\n              <mat-icon>{{state.icon}}</mat-icon>\n              <span>{{state.name}}</span>\n            </button>\n          </ng-container>\n        </mat-menu>\n      </ng-template>\n\n  </mat-toolbar>\n  <div class=\"loading\">\n    <mat-progress-bar *ngIf=\"isShowLoading\" [@fadeOut]=\"'in'\" mode=\"indeterminate\" color=\"primary\"></mat-progress-bar>\n  </div>\n  <div class=\"content padding\">\n    <div *ngTemplateOutlet=\"currentState.templateRef\"></div>\n  </div>\n  <ng-content></ng-content>\n</div>\n`,\n  styles: [`.tp-window{box-shadow:0 1px 3px 0 rgba(0,0,0,.2),0 1px 1px 0 rgba(0,0,0,.14),0 2px 1px -1px rgba(0,0,0,.12)}.tp-window mat-toolbar .toolbar-title{color:#9e9e9e}.tp-window mat-toolbar .toolbar-flex{flex:1}.tp-window button{color:#9e9e9e;transition:background ease-out .2s}.tp-window button:hover{background-color:#e0e0e0}.tp-window .padding{padding:1em 1.5em}.tp-window .loading{height:10px}`],\n  inputs: ['name'],\n  exportAs: 'tpWindow',\n  animations: [fadeOutAnimation]\n})\nexport class WindowComponent implements AfterContentInit {\n  @ViewChild('loadingPortal') loadingRef: TemplateRef<any>;\n  @ContentChildren(WindowStateComponent) states: QueryList<WindowStateComponent>;\n  @Input()\n  set loading(loading:Observable<any>) {\n    if(loading) {\n      this.isShowLoading = true;\n      loading.subscribe(() => {\n        this.isShowLoading = false;\n      });\n    }\n  }\n  @Input() maxStateNumber: number = 5;\n  @Input() optionPortal: Portal<any> | undefined;\n  @Output() stateChange: EventEmitter<WindowStateComponent> = new EventEmitter<WindowStateComponent>();\n  name: string;\n  currentState: WindowStateComponent;\n  isShowLoading: boolean = false;\n\n  setPortal(portal: Portal<any>) {\n    this.optionPortal = portal;\n  }\n\n  ngAfterContentInit() {\n    this.currentState = this.states.first;\n  }\n\n  navigate(state: WindowStateComponent) {\n    if(state.type !== 'Button') {\n      this.currentState = state;\n    }\n    this.stateChange.emit(state);\n  }\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { WindowComponent } from './tp-window.component';\nimport { WindowStateComponent } from './tp-window.state.component';\nimport { MatToolbarModule, MatTooltipModule } from '@angular/material';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { PortalModule } from '@angular/cdk/portal';\n\n@NgModule({\n  imports: [\n    PortalModule,\n    MatMenuModule,\n    MatProgressBarModule,\n    MatButtonModule,\n    MatIconModule,\n    MatTooltipModule,\n    CommonModule,\n    MatToolbarModule],\n  declarations: [WindowComponent, WindowStateComponent],\n  exports: [WindowComponent, WindowStateComponent]\n})\nexport class WindowModule { }\n","export * from './lib/tp-window.component';\nexport * from './lib/tp-window.module';\nexport enum stateType {\n  Button, Content, State\n}\n"],"names":["Component","ViewChild","Input","trigger","state","style","transition","animate","EventEmitter","portal","ContentChildren","Output","NgModule","PortalModule","MatMenuModule","MatProgressBarModule","MatButtonModule","MatIconModule","MatTooltipModule","CommonModule","MatToolbarModule"],"mappings":";;;;;;;;;;AAAA;;;;oBAGCA,cAAS,SAAC;wBACT,QAAQ,EAAE,iBAAiB;wBAC3B,QAAQ,EAAE,2FAIT;wBACD,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;qBACjC;;;kCAIEC,cAAS,SAAC,aAAa;2BACvBC,UAAK;;mCAhBR;;;;;;;ACAA,yBASa,gBAAgB,GAA4BC,kBAAO,CAAC,SAAS,EAAE;QAC1EC,gBAAK,CAAC,IAAI,EAAEC,gBAAK,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC;QAChCC,qBAAU,CAAC,WAAW,EAAE;YACtBC,kBAAO,CAAC,GAAG,EAAEF,gBAAK,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC;SAClC,CAAC;KACH,CAAC;;;;;;ACdF;;kCA6EoC,CAAC;+BAEyB,IAAIG,iBAAY,EAAwB;iCAG3E,KAAK;;QAd9B,sBACI,oCAAO;;;;gBADX,UACY,OAAuB;gBADnC,iBAQC;gBANC,IAAG,OAAO,EAAE;oBACV,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;oBAC1B,OAAO,CAAC,SAAS,CAAC;wBAChB,KAAI,CAAC,aAAa,GAAG,KAAK,CAAC;qBAC5B,CAAC,CAAC;iBACJ;aACF;;;WAAA;;;;;QAQD,mCAAS;;;;YAAT,UAAUC,SAAmB;gBAC3B,IAAI,CAAC,YAAY,GAAGA,SAAM,CAAC;aAC5B;;;;QAED,4CAAkB;;;YAAlB;gBACE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;aACvC;;;;;QAED,kCAAQ;;;;YAAR,UAAS,KAA2B;gBAClC,IAAG,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE;oBAC1B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;iBAC3B;gBACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAC9B;;oBAjFFT,cAAS,SAAC;wBACT,QAAQ,EAAE,WAAW;wBACrB,QAAQ,EAAE,2tDAyCX;wBACC,MAAM,EAAE,CAAC,wYAAwY,CAAC;wBAClZ,MAAM,EAAE,CAAC,MAAM,CAAC;wBAChB,QAAQ,EAAE,UAAU;wBACpB,UAAU,EAAE,CAAC,gBAAgB,CAAC;qBAC/B;;;iCAEEC,cAAS,SAAC,eAAe;6BACzBS,oBAAe,SAAC,oBAAoB;8BACpCR,UAAK;qCASLA,UAAK;mCACLA,UAAK;kCACLS,WAAM;;8BA/ET;;;;;;;ACAA;;;;oBAWCC,aAAQ,SAAC;wBACR,OAAO,EAAE;4BACPC,mBAAY;4BACZC,kBAAa;4BACbC,gCAAoB;4BACpBC,sBAAe;4BACfC,kBAAa;4BACbC,yBAAgB;4BAChBC,mBAAY;4BACZC,yBAAgB;yBAAC;wBACnB,YAAY,EAAE,CAAC,eAAe,EAAE,oBAAoB,CAAC;wBACrD,OAAO,EAAE,CAAC,eAAe,EAAE,oBAAoB,CAAC;qBACjD;;2BAvBD;;;;;;;ACAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}