UNPKG

tp-window

Version:
195 lines (185 loc) 16.4 kB
import { Component, ViewChild, Input, ContentChildren, Output, EventEmitter, NgModule } from '@angular/core'; import { trigger, state, style, animate, transition } from '@angular/animations'; import { PortalModule } from '@angular/cdk/portal'; import 'rxjs'; import { CommonModule } from '@angular/common'; import { MatToolbarModule, MatTooltipModule } from '@angular/material'; import { MatIconModule } from '@angular/material/icon'; import { MatButtonModule } from '@angular/material/button'; import { MatProgressBarModule } from '@angular/material/progress-bar'; import { MatMenuModule } from '@angular/material/menu'; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ class WindowStateComponent { } WindowStateComponent.decorators = [ { type: Component, args: [{ selector: 'tp-window-state', template: ` <ng-template #templateRef> <ng-content></ng-content> </ng-template> `, inputs: ['name', 'icon', 'type'] },] }, ]; WindowStateComponent.propDecorators = { templateRef: [{ type: ViewChild, args: ['templateRef',] }], type: [{ type: Input }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ const /** @type {?} */ fadeOutAnimation = trigger('fadeOut', [ state('in', style({ opacity: 1 })), transition('* => void', [ animate(500, style({ opacity: 0 })) ]) ]); /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ class WindowComponent { constructor() { this.maxStateNumber = 5; this.stateChange = new EventEmitter(); this.isShowLoading = false; } /** * @param {?} loading * @return {?} */ set loading(loading) { if (loading) { this.isShowLoading = true; loading.subscribe(() => { this.isShowLoading = false; }); } } /** * @param {?} portal * @return {?} */ setPortal(portal) { this.optionPortal = portal; } /** * @return {?} */ ngAfterContentInit() { this.currentState = this.states.first; } /** * @param {?} state * @return {?} */ navigate(state$$1) { if (state$$1.type !== 'Button') { this.currentState = state$$1; } this.stateChange.emit(state$$1); } } WindowComponent.decorators = [ { type: Component, args: [{ selector: 'tp-window', template: `<div class="tp-window"> <mat-toolbar> <p class="mat-body-2 toolbar-title">{{name}}</p> <div class="toolbar-flex"></div> <ng-template [cdkPortalOutlet]="optionPortal"></ng-template> <ng-template [ngIf]="states.length <= maxStateNumber"> <ng-container *ngFor="let state of states"> <button *ngIf="state.type !== 'Content'" mat-icon-button (click)="navigate(state)" matTooltip="{{state.name}}"> <mat-icon>{{state.icon}}</mat-icon> </button> </ng-container> </ng-template> <ng-template [ngIf]="states.length > maxStateNumber"> <ng-container *ngFor="let state of states"> <button *ngIf="state.type === 'Button'" mat-icon-button (click)="navigate(state)" matTooltip="{{state.name}}"> <mat-icon>{{state.icon}}</mat-icon> </button> </ng-container> <button mat-icon-button [matMenuTriggerFor]="menu"> <mat-icon>more_horiz</mat-icon> </button> <mat-menu #menu="matMenu"> <ng-container *ngFor="let state of states"> <button *ngIf="state.type === 'State'" mat-menu-item (click)="navigate(state)"> <mat-icon>{{state.icon}}</mat-icon> <span>{{state.name}}</span> </button> </ng-container> </mat-menu> </ng-template> </mat-toolbar> <div class="loading"> <mat-progress-bar *ngIf="isShowLoading" [@fadeOut]="'in'" mode="indeterminate" color="primary"></mat-progress-bar> </div> <div class="content padding"> <div *ngTemplateOutlet="currentState.templateRef"></div> </div> <ng-content></ng-content> </div> `, 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: ViewChild, args: ['loadingPortal',] }], states: [{ type: ContentChildren, args: [WindowStateComponent,] }], loading: [{ type: Input }], maxStateNumber: [{ type: Input }], optionPortal: [{ type: Input }], stateChange: [{ type: Output }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ class WindowModule { } WindowModule.decorators = [ { type: NgModule, args: [{ imports: [ PortalModule, MatMenuModule, MatProgressBarModule, MatButtonModule, MatIconModule, MatTooltipModule, CommonModule, MatToolbarModule ], declarations: [WindowComponent, WindowStateComponent], exports: [WindowComponent, WindowStateComponent] },] }, ]; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ /** @enum {number} */ const 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 */ export { stateType, WindowComponent, WindowModule, fadeOutAnimation as ɵb, WindowStateComponent as ɵa }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tp-window.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":["state"],"mappings":";;;;;;;;;;;;;;;AAAA;;;YAGC,SAAS,SAAC;gBACT,QAAQ,EAAE,iBAAiB;gBAC3B,QAAQ,EAAE;;;;GAIT;gBACD,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;aACjC;;;0BAIE,SAAS,SAAC,aAAa;mBACvB,KAAK;;;;;;;AChBR,uBASa,gBAAgB,GAA4B,OAAO,CAAC,SAAS,EAAE;IAC1E,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC;IAChC,UAAU,CAAC,WAAW,EAAE;QACtB,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC;KAClC,CAAC;CACH,CAAC;;;;;;ACdF;;8BA6EoC,CAAC;2BAEyB,IAAI,YAAY,EAAwB;6BAG3E,KAAK;;;;;;IAd9B,IACI,OAAO,CAAC,OAAuB;QACjC,IAAG,OAAO,EAAE;YACV,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC1B,OAAO,CAAC,SAAS,CAAC;gBAChB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;aAC5B,CAAC,CAAC;SACJ;KACF;;;;;IAQD,SAAS,CAAC,MAAmB;QAC3B,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;KAC5B;;;;IAED,kBAAkB;QAChB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;KACvC;;;;;IAED,QAAQ,CAACA,QAA2B;QAClC,IAAGA,QAAK,CAAC,IAAI,KAAK,QAAQ,EAAE;YAC1B,IAAI,CAAC,YAAY,GAAGA,QAAK,CAAC;SAC3B;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAACA,QAAK,CAAC,CAAC;KAC9B;;;YAjFF,SAAS,SAAC;gBACT,QAAQ,EAAE,WAAW;gBACrB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyCX;gBACC,MAAM,EAAE,CAAC,wYAAwY,CAAC;gBAClZ,MAAM,EAAE,CAAC,MAAM,CAAC;gBAChB,QAAQ,EAAE,UAAU;gBACpB,UAAU,EAAE,CAAC,gBAAgB,CAAC;aAC/B;;;yBAEE,SAAS,SAAC,eAAe;qBACzB,eAAe,SAAC,oBAAoB;sBACpC,KAAK;6BASL,KAAK;2BACL,KAAK;0BACL,MAAM;;;;;;;AC/ET;;;YAWC,QAAQ,SAAC;gBACR,OAAO,EAAE;oBACP,YAAY;oBACZ,aAAa;oBACb,oBAAoB;oBACpB,eAAe;oBACf,aAAa;oBACb,gBAAgB;oBAChB,YAAY;oBACZ,gBAAgB;iBAAC;gBACnB,YAAY,EAAE,CAAC,eAAe,EAAE,oBAAoB,CAAC;gBACrD,OAAO,EAAE,CAAC,eAAe,EAAE,oBAAoB,CAAC;aACjD;;;;;;;ACvBD;;;;;;;;;;;;;;;;;"}