UNPKG

@angular-mdl/core

Version:

Angular components, directives and styles based on material design lite https://getmdl.io.

157 lines 17.8 kB
import { Component, ComponentFactoryResolver, Injectable, ViewEncapsulation, } from "@angular/core"; import { MdlDialogOutletService } from "../dialog-outlet/mdl-dialog-outlet.service"; import { Subject } from "rxjs"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "../dialog-outlet/mdl-dialog-outlet.service"; const ANIMATION_TIME = 250; export class MdlSnackbarComponent { constructor() { this.showIt = false; } onClick() { this.onAction?.(); } isActive() { return this.showIt; } show() { const result = new Subject(); // wait unit the dom is in place - then showIt will change the css class setTimeout(() => { this.showIt = true; // fire after the view animation is done setTimeout(() => { result.next(); result.complete(); }, ANIMATION_TIME); }, ANIMATION_TIME); return result.asObservable(); } hide() { this.showIt = false; const result = new Subject(); // fire after the view animation is done setTimeout(() => { result.next(); result.complete(); }, ANIMATION_TIME); return result.asObservable(); } } MdlSnackbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSnackbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); MdlSnackbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: MdlSnackbarComponent, selector: "mdl-snackbar-component", ngImport: i0, template: ` <div id="demo-toast-example" class=" mdl-snackbar" [ngClass]="{ 'mdl-snackbar--active': showIt }" > <div class="mdl-snackbar__text">{{ message }}</div> <button *ngIf="onAction" class="mdl-snackbar__action" type="button" (click)="onClick()" > {{ actionText }} </button> </div> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSnackbarComponent, decorators: [{ type: Component, args: [{ selector: "mdl-snackbar-component", template: ` <div id="demo-toast-example" class=" mdl-snackbar" [ngClass]="{ 'mdl-snackbar--active': showIt }" > <div class="mdl-snackbar__text">{{ message }}</div> <button *ngIf="onAction" class="mdl-snackbar__action" type="button" (click)="onClick()" > {{ actionText }} </button> </div> `, encapsulation: ViewEncapsulation.None, }] }] }); export class MdlSnackbarService { constructor(componentFactoryResolver, dialogOutletService) { this.componentFactoryResolver = componentFactoryResolver; this.dialogOutletService = dialogOutletService; this.cFactory = this.componentFactoryResolver.resolveComponentFactory(MdlSnackbarComponent); } showToast(message, timeout) { return this.showSnackbar({ message, timeout, }); } showSnackbar(snackbarMessage) { const optTimeout = snackbarMessage.timeout || 2750; const closeAfterTimeout = !!snackbarMessage.closeAfterTimeout; const viewContainerRef = this.dialogOutletService.viewContainerRef; if (!viewContainerRef) { throw new Error("You did not provide a ViewContainerRef. " + "Please see https://github.com/mseemann/angular2-mdl/wiki/How-to-use-the-MdlDialogService"); } const cRef = viewContainerRef.createComponent(this.cFactory, viewContainerRef.length); const mdlSnackbarComponent = cRef.instance; mdlSnackbarComponent.message = snackbarMessage.message; if (this.previousSnack) { const previousSnack = this.previousSnack; const subscription = previousSnack.component.hide().subscribe(() => { previousSnack.cRef.destroy(); subscription.unsubscribe(); }); } this.previousSnack = { component: mdlSnackbarComponent, cRef, }; if (snackbarMessage.action) { if (closeAfterTimeout) { this.hideAndDestroySnack(mdlSnackbarComponent, cRef, optTimeout); } mdlSnackbarComponent.actionText = snackbarMessage.action.text; mdlSnackbarComponent.onAction = () => { mdlSnackbarComponent.hide().subscribe(() => { cRef.destroy(); snackbarMessage.action?.handler(); }); }; } else { this.hideAndDestroySnack(mdlSnackbarComponent, cRef, optTimeout); } const result = new Subject(); mdlSnackbarComponent.show().subscribe(() => { result.next(mdlSnackbarComponent); result.complete(); }); return result.asObservable(); } hideAndDestroySnack(component, componentRef, timeOut) { setTimeout(() => { component.hide().subscribe(() => { componentRef.destroy(); }); }, timeOut); } } MdlSnackbarService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSnackbarService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i2.MdlDialogOutletService }], target: i0.ɵɵFactoryTarget.Injectable }); MdlSnackbarService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSnackbarService, providedIn: "root" }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSnackbarService, decorators: [{ type: Injectable, args: [{ providedIn: "root", }] }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i2.MdlDialogOutletService }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdl-snackbar.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/snackbar/mdl-snackbar.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ComponentFactory,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Injectable,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { MdlDialogOutletService } from \"../dialog-outlet/mdl-dialog-outlet.service\";\nimport { Observable, Subject } from \"rxjs\";\n\nconst ANIMATION_TIME = 250;\n\n@Component({\n  selector: \"mdl-snackbar-component\",\n  template: `\n    <div\n      id=\"demo-toast-example\"\n      class=\" mdl-snackbar\"\n      [ngClass]=\"{ 'mdl-snackbar--active': showIt }\"\n    >\n      <div class=\"mdl-snackbar__text\">{{ message }}</div>\n      <button\n        *ngIf=\"onAction\"\n        class=\"mdl-snackbar__action\"\n        type=\"button\"\n        (click)=\"onClick()\"\n      >\n        {{ actionText }}\n      </button>\n    </div>\n  `,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MdlSnackbarComponent {\n  message: string | undefined;\n  actionText: string | undefined;\n  showIt = false;\n  onAction: (() => void) | undefined;\n\n  onClick(): void {\n    this.onAction?.();\n  }\n\n  isActive(): boolean {\n    return this.showIt;\n  }\n\n  show(): Observable<void> {\n    const result: Subject<void> = new Subject();\n    // wait unit the dom is in place - then showIt will change the css class\n    setTimeout(() => {\n      this.showIt = true;\n      // fire after the view animation is done\n      setTimeout(() => {\n        result.next();\n        result.complete();\n      }, ANIMATION_TIME);\n    }, ANIMATION_TIME);\n\n    return result.asObservable();\n  }\n\n  hide(): Observable<void> {\n    this.showIt = false;\n\n    const result: Subject<void> = new Subject();\n\n    // fire after the view animation is done\n    setTimeout(() => {\n      result.next();\n      result.complete();\n    }, ANIMATION_TIME);\n\n    return result.asObservable();\n  }\n}\n\nexport interface IMdlSnackbarMessage {\n  message: string;\n  timeout?: number;\n  closeAfterTimeout?: boolean;\n  action?: {\n    handler: () => void;\n    text: string;\n  };\n}\n\n@Injectable({\n  providedIn: \"root\",\n})\nexport class MdlSnackbarService {\n  private readonly cFactory: ComponentFactory<MdlSnackbarComponent>;\n  private previousSnack:\n    | {\n        component: MdlSnackbarComponent;\n        cRef: ComponentRef<MdlSnackbarComponent>;\n      }\n    | undefined;\n\n  constructor(\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private dialogOutletService: MdlDialogOutletService\n  ) {\n    this.cFactory =\n      this.componentFactoryResolver.resolveComponentFactory(\n        MdlSnackbarComponent\n      );\n  }\n\n  showToast(\n    message: string,\n    timeout?: number\n  ): Observable<MdlSnackbarComponent> {\n    return this.showSnackbar({\n      message,\n      timeout,\n    });\n  }\n\n  showSnackbar(\n    snackbarMessage: IMdlSnackbarMessage\n  ): Observable<MdlSnackbarComponent> {\n    const optTimeout = snackbarMessage.timeout || 2750;\n    const closeAfterTimeout = !!snackbarMessage.closeAfterTimeout;\n    const viewContainerRef = this.dialogOutletService.viewContainerRef;\n\n    if (!viewContainerRef) {\n      throw new Error(\n        \"You did not provide a ViewContainerRef. \" +\n          \"Please see https://github.com/mseemann/angular2-mdl/wiki/How-to-use-the-MdlDialogService\"\n      );\n    }\n\n    const cRef = viewContainerRef.createComponent(\n      this.cFactory,\n      viewContainerRef.length\n    );\n\n    const mdlSnackbarComponent = cRef.instance as MdlSnackbarComponent;\n    mdlSnackbarComponent.message = snackbarMessage.message;\n\n    if (this.previousSnack) {\n      const previousSnack = this.previousSnack;\n      const subscription = previousSnack.component.hide().subscribe(() => {\n        previousSnack.cRef.destroy();\n        subscription.unsubscribe();\n      });\n    }\n\n    this.previousSnack = {\n      component: mdlSnackbarComponent,\n      cRef,\n    };\n\n    if (snackbarMessage.action) {\n      if (closeAfterTimeout) {\n        this.hideAndDestroySnack(mdlSnackbarComponent, cRef, optTimeout);\n      }\n      mdlSnackbarComponent.actionText = snackbarMessage.action.text;\n      mdlSnackbarComponent.onAction = () => {\n        mdlSnackbarComponent.hide().subscribe(() => {\n          cRef.destroy();\n          snackbarMessage.action?.handler();\n        });\n      };\n    } else {\n      this.hideAndDestroySnack(mdlSnackbarComponent, cRef, optTimeout);\n    }\n\n    const result: Subject<MdlSnackbarComponent> =\n      new Subject<MdlSnackbarComponent>();\n\n    mdlSnackbarComponent.show().subscribe(() => {\n      result.next(mdlSnackbarComponent);\n      result.complete();\n    });\n\n    return result.asObservable();\n  }\n\n  private hideAndDestroySnack(\n    component: MdlSnackbarComponent,\n    componentRef: ComponentRef<MdlSnackbarComponent>,\n    timeOut: number\n  ) {\n    setTimeout(() => {\n      component.hide().subscribe(() => {\n        componentRef.destroy();\n      });\n    }, timeOut);\n  }\n}\n"]}