@angular-mdl/core
Version:
Angular components, directives and styles based on material design lite https://getmdl.io.
157 lines • 17.8 kB
JavaScript
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"]}