@angular-mdl/core
Version:
Angular components, directives and styles based on material design lite https://getmdl.io.
171 lines • 28.5 kB
JavaScript
import { Component, ElementRef, forwardRef, HostBinding, Inject, NgZone, Renderer2, ViewChild, ViewContainerRef, ViewEncapsulation, } from "@angular/core";
import { MDL_CONFIGUARTION, MIN_DIALOG_Z_INDEX } from "./config";
import { MdlButtonComponent } from "../button/mdl-button.component";
import { InternalMdlDialogReference } from "./internal-dialog-reference";
import { Animations } from "../common/animations";
import * as i0 from "@angular/core";
import * as i1 from "../common/animations";
import * as i2 from "./internal-dialog-reference";
const enterTransitionDuration = 300;
const leaveTransitionDuration = 250;
const enterTransitionEasingCurve = "cubic-bezier(0.0, 0.0, 0.2, 1)";
const leaveTransitionEasingCurve = "cubic-bezier(0.0, 0.0, 0.2, 1)";
const createOpenCloseRect = (rect) => ({
height: rect.top - rect.bottom,
left: rect.left,
top: rect.top,
width: rect.right - rect.left,
});
const getCenterInScreen = (rect) => ({
cx: Math.round(rect.left + rect.width / 2),
cy: Math.round(rect.top + rect.height / 2),
});
const getClientRect = (input) => {
if (input instanceof MdlButtonComponent) {
const elRef = input.elementRef;
const rect = elRef.nativeElement.getBoundingClientRect();
return createOpenCloseRect(rect);
}
else if (input instanceof MouseEvent) {
const evt = input;
// just to make it possible to test this code with a fake event - target is
// readonly and con not be mutated.
// eslint-disable-next-line
const htmlElement = (evt.target || evt.testtarget);
const rect = htmlElement.getBoundingClientRect();
return createOpenCloseRect(rect);
}
return input;
};
// @experimental
export class MdlDialogHostComponent {
constructor(ngZone, renderer, animations, elementRef, config, internalDialogRef) {
this.ngZone = ngZone;
this.renderer = renderer;
this.animations = animations;
this.elementRef = elementRef;
this.config = config;
this.internalDialogRef = internalDialogRef;
this.isDialog = true;
this.visible = false;
this.zIndex = MIN_DIALOG_Z_INDEX + 1;
this.showAnimationStartStyle = {
top: "38%",
opacity: "0",
};
this.showStyle = {
top: "50%",
opacity: "1",
};
this.hideAnimationEndStyle = {
top: "63%",
opacity: "0",
};
}
show() {
this.visible = true;
// give the dialogs time to draw so that a focus can be set
setTimeout(() => {
this.internalDialogRef.visible();
});
if (this.isAnimateEnabled()) {
if (this.config.openFrom || this.config.closeTo) {
// transform is modified during anmiation and must be part of each animation keyframe.
this.showStyle["transform"] = "translate(0, -50%) scale(1.0)";
const targetClientRect = this.elementRef.nativeElement.getBoundingClientRect();
const openFromRect = getClientRect(this.config?.openFrom);
const closeToRect = this.config.closeTo
? getClientRect(this.config.closeTo)
: openFromRect;
const centerTarget = getCenterInScreen(targetClientRect);
const centerFrom = getCenterInScreen(openFromRect);
const centerTo = getCenterInScreen(closeToRect);
const translationFrom = {
x: Math.round(centerFrom.cx - centerTarget.cx),
y: Math.round(centerFrom.cy - centerTarget.cy),
scaleX: Math.round(100 * Math.min(0.25, openFromRect.width / targetClientRect.width)) / 100,
scaleY: Math.round(100 *
Math.min(0.25, openFromRect.height / targetClientRect.height)) / 100,
};
this.showAnimationStartStyle = {
top: `${targetClientRect.top}px`,
opacity: "0",
transform: `translate(${translationFrom.x}px, ${translationFrom.y}px) scale(${translationFrom.scaleX}, ${translationFrom.scaleY})`,
};
const translationTo = {
x: Math.round(centerTo.cx - centerTarget.cx),
y: Math.round(centerTo.cy - centerTarget.cy),
scaleX: Math.round(100 * Math.min(0.25, closeToRect.width / targetClientRect.width)) / 100,
scaleY: Math.round(100 * Math.min(0.25, closeToRect.height / targetClientRect.height)) / 100,
};
this.hideAnimationEndStyle = {
top: `${targetClientRect.top}px`,
opacity: "0",
transform: `translate(${translationTo.x}px, ${translationTo.y}px) scale(${translationTo.scaleX}, ${translationTo.scaleY})`,
};
}
const animation = this.animations.animate(this.elementRef.nativeElement, [this.showAnimationStartStyle, this.showStyle], this.config.enterTransitionDuration || enterTransitionDuration, this.config.enterTransitionEasingCurve || enterTransitionEasingCurve);
animation.play();
}
}
hide(selfComponentRef) {
if (this.isAnimateEnabled()) {
const animation = this.animations.animate(this.elementRef.nativeElement, [this.showStyle, this.hideAnimationEndStyle], this.config.leaveTransitionDuration || leaveTransitionDuration, this.config.leaveTransitionEasingCurve || leaveTransitionEasingCurve);
animation.onDone(() => {
selfComponentRef.destroy();
});
animation.play();
}
else {
selfComponentRef.destroy();
}
}
ngOnInit() {
this.applyStyle(this.config.styles);
this.applyClasses(this.config.classes ? this.config.classes : "");
}
applyStyle(styles) {
if (styles) {
for (const style of Object.keys(styles)) {
this.renderer.setStyle(this.elementRef.nativeElement, style, styles[style]);
}
}
}
applyClasses(classes) {
classes
.split(" ")
.filter((cssClass) => !!cssClass)
.forEach((cssClass) => {
this.renderer.addClass(this.elementRef.nativeElement, cssClass);
});
}
isAnimateEnabled() {
// not present? assume it is true.
if (typeof this.config.animate === "undefined") {
return true;
}
return this.config.animate;
}
}
MdlDialogHostComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlDialogHostComponent, deps: [{ token: i0.NgZone }, { token: i0.Renderer2 }, { token: i1.Animations }, { token: i0.ElementRef }, { token: forwardRef(() => MDL_CONFIGUARTION) }, { token: i2.InternalMdlDialogReference }], target: i0.ɵɵFactoryTarget.Component });
MdlDialogHostComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: MdlDialogHostComponent, selector: "mdl-dialog-host-component", host: { properties: { "class.mdl-dialog": "this.isDialog", "class.open": "this.visible", "style.zIndex": "this.zIndex" } }, viewQueries: [{ propertyName: "dialogTarget", first: true, predicate: ["dialogTarget"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: ` <div #dialogTarget></div>`, isInline: true, styles: ["mdl-dialog-host-component{width:-moz-fit-content;width:fit-content;height:-moz-fit-content;height:fit-content;padding:1em;background:white;color:#000;opacity:1;visibility:hidden;display:block;position:fixed;margin:auto;left:0;right:0;transition:all;top:50%;transform:translateY(-50%)}mdl-dialog-host-component.open{visibility:visible}\n"], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlDialogHostComponent, decorators: [{
type: Component,
args: [{ selector: "mdl-dialog-host-component", template: ` <div #dialogTarget></div>`, encapsulation: ViewEncapsulation.None, styles: ["mdl-dialog-host-component{width:-moz-fit-content;width:fit-content;height:-moz-fit-content;height:fit-content;padding:1em;background:white;color:#000;opacity:1;visibility:hidden;display:block;position:fixed;margin:auto;left:0;right:0;transition:all;top:50%;transform:translateY(-50%)}mdl-dialog-host-component.open{visibility:visible}\n"] }]
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.Renderer2 }, { type: i1.Animations }, { type: i0.ElementRef }, { type: undefined, decorators: [{
type: Inject,
args: [forwardRef(() => MDL_CONFIGUARTION)]
}] }, { type: i2.InternalMdlDialogReference }]; }, propDecorators: { dialogTarget: [{
type: ViewChild,
args: ["dialogTarget", { read: ViewContainerRef, static: true }]
}], isDialog: [{
type: HostBinding,
args: ["class.mdl-dialog"]
}], visible: [{
type: HostBinding,
args: ["class.open"]
}], zIndex: [{
type: HostBinding,
args: ["style.zIndex"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdl-dialog-host.component.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/dialog/mdl-dialog-host.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ComponentRef,\n  ElementRef,\n  forwardRef,\n  HostBinding,\n  Inject,\n  NgZone,\n  OnInit,\n  Renderer2,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from \"@angular/core\";\n\nimport { MDL_CONFIGUARTION, MIN_DIALOG_Z_INDEX } from \"./config\";\nimport {\n  IMdlDialogConfiguration,\n  IOpenCloseRect,\n} from \"./mdl-dialog-configuration\";\nimport { MdlButtonComponent } from \"../button/mdl-button.component\";\nimport { InternalMdlDialogReference } from \"./internal-dialog-reference\";\nimport { Animations } from \"../common/animations\";\n\nconst enterTransitionDuration = 300;\nconst leaveTransitionDuration = 250;\n\nconst enterTransitionEasingCurve = \"cubic-bezier(0.0, 0.0, 0.2, 1)\";\nconst leaveTransitionEasingCurve = \"cubic-bezier(0.0, 0.0, 0.2, 1)\";\n\nconst createOpenCloseRect = (rect: ClientRect): IOpenCloseRect => ({\n  height: rect.top - rect.bottom,\n  left: rect.left,\n  top: rect.top,\n  width: rect.right - rect.left,\n});\n\nconst getCenterInScreen = (rect: IOpenCloseRect) => ({\n  cx: Math.round(rect.left + rect.width / 2),\n  cy: Math.round(rect.top + rect.height / 2),\n});\n\nconst getClientRect = (\n  input: MdlButtonComponent | MouseEvent | IOpenCloseRect | undefined\n): IOpenCloseRect => {\n  if (input instanceof MdlButtonComponent) {\n    const elRef = (input as MdlButtonComponent).elementRef;\n    const rect: ClientRect = elRef.nativeElement.getBoundingClientRect();\n    return createOpenCloseRect(rect);\n  } else if (input instanceof MouseEvent) {\n    const evt: MouseEvent = input as MouseEvent;\n    // just to make it possible to test this code with a fake event - target is\n    // readonly and con not be mutated.\n    // eslint-disable-next-line\n    const htmlElement = (evt.target || (evt as any).testtarget) as HTMLElement;\n    const rect: ClientRect = htmlElement.getBoundingClientRect();\n    return createOpenCloseRect(rect);\n  }\n  return input as IOpenCloseRect;\n};\n\n// @experimental\n@Component({\n  selector: \"mdl-dialog-host-component\",\n  template: ` <div #dialogTarget></div>`,\n  styles: [\n    `\n      mdl-dialog-host-component {\n        width: fit-content;\n        height: fit-content;\n        padding: 1em;\n        background: white;\n        color: black;\n        opacity: 1;\n        visibility: hidden;\n        display: block;\n        position: fixed;\n        margin: auto;\n        left: 0;\n        right: 0;\n        transition: all;\n        top: 50%;\n        transform: translate(0, -50%);\n      }\n\n      mdl-dialog-host-component.open {\n        visibility: visible;\n      }\n    `,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MdlDialogHostComponent implements OnInit {\n  @ViewChild(\"dialogTarget\", { read: ViewContainerRef, static: true })\n  dialogTarget: ViewContainerRef | undefined;\n\n  @HostBinding(\"class.mdl-dialog\")\n  isDialog = true;\n\n  @HostBinding(\"class.open\")\n  visible = false;\n\n  @HostBinding(\"style.zIndex\")\n  zIndex: number = MIN_DIALOG_Z_INDEX + 1;\n\n  private showAnimationStartStyle: { [key: string]: string } = {\n    top: \"38%\",\n    opacity: \"0\",\n  };\n  private showStyle: { [key: string]: string } = {\n    top: \"50%\",\n    opacity: \"1\",\n  };\n  private hideAnimationEndStyle: { [key: string]: string } = {\n    top: \"63%\",\n    opacity: \"0\",\n  };\n\n  constructor(\n    private ngZone: NgZone,\n    private renderer: Renderer2,\n    private animations: Animations,\n    private elementRef: ElementRef,\n    @Inject(forwardRef(() => MDL_CONFIGUARTION))\n    private config: IMdlDialogConfiguration,\n    private internalDialogRef: InternalMdlDialogReference\n  ) {}\n\n  show(): void {\n    this.visible = true;\n    // give the dialogs time to draw so that a focus can be set\n    setTimeout(() => {\n      this.internalDialogRef.visible();\n    });\n\n    if (this.isAnimateEnabled()) {\n      if (this.config.openFrom || this.config.closeTo) {\n        // transform is modified during anmiation and must be part of each animation keyframe.\n        this.showStyle[\"transform\"] = \"translate(0, -50%) scale(1.0)\";\n\n        const targetClientRect =\n          this.elementRef.nativeElement.getBoundingClientRect();\n\n        const openFromRect = getClientRect(this.config?.openFrom);\n        const closeToRect = this.config.closeTo\n          ? getClientRect(this.config.closeTo)\n          : openFromRect;\n\n        const centerTarget = getCenterInScreen(targetClientRect);\n        const centerFrom = getCenterInScreen(openFromRect);\n        const centerTo = getCenterInScreen(closeToRect);\n\n        const translationFrom = {\n          x: Math.round(centerFrom.cx - centerTarget.cx),\n          y: Math.round(centerFrom.cy - centerTarget.cy),\n          scaleX:\n            Math.round(\n              100 * Math.min(0.25, openFromRect.width / targetClientRect.width)\n            ) / 100,\n          scaleY:\n            Math.round(\n              100 *\n                Math.min(0.25, openFromRect.height / targetClientRect.height)\n            ) / 100,\n        };\n\n        this.showAnimationStartStyle = {\n          top: `${targetClientRect.top}px`,\n          opacity: \"0\",\n          transform: `translate(${translationFrom.x}px, ${translationFrom.y}px) scale(${translationFrom.scaleX}, ${translationFrom.scaleY})`,\n        };\n\n        const translationTo = {\n          x: Math.round(centerTo.cx - centerTarget.cx),\n          y: Math.round(centerTo.cy - centerTarget.cy),\n          scaleX:\n            Math.round(\n              100 * Math.min(0.25, closeToRect.width / targetClientRect.width)\n            ) / 100,\n          scaleY:\n            Math.round(\n              100 * Math.min(0.25, closeToRect.height / targetClientRect.height)\n            ) / 100,\n        };\n\n        this.hideAnimationEndStyle = {\n          top: `${targetClientRect.top}px`,\n          opacity: \"0\",\n          transform: `translate(${translationTo.x}px, ${translationTo.y}px) scale(${translationTo.scaleX}, ${translationTo.scaleY})`,\n        };\n      }\n\n      const animation = this.animations.animate(\n        this.elementRef.nativeElement,\n        [this.showAnimationStartStyle, this.showStyle],\n        this.config.enterTransitionDuration || enterTransitionDuration,\n        this.config.enterTransitionEasingCurve || enterTransitionEasingCurve\n      );\n\n      animation.play();\n    }\n  }\n\n  hide(selfComponentRef: ComponentRef<MdlDialogHostComponent>): void {\n    if (this.isAnimateEnabled()) {\n      const animation = this.animations.animate(\n        this.elementRef.nativeElement,\n        [this.showStyle, this.hideAnimationEndStyle],\n        this.config.leaveTransitionDuration || leaveTransitionDuration,\n        this.config.leaveTransitionEasingCurve || leaveTransitionEasingCurve\n      );\n\n      animation.onDone(() => {\n        selfComponentRef.destroy();\n      });\n\n      animation.play();\n    } else {\n      selfComponentRef.destroy();\n    }\n  }\n\n  ngOnInit(): void {\n    this.applyStyle(this.config.styles);\n    this.applyClasses(this.config.classes ? this.config.classes : \"\");\n  }\n\n  private applyStyle(styles: { [p: string]: string } | undefined) {\n    if (styles) {\n      for (const style of Object.keys(styles)) {\n        this.renderer.setStyle(\n          this.elementRef.nativeElement,\n          style,\n          styles[style]\n        );\n      }\n    }\n  }\n\n  private applyClasses(classes: string) {\n    classes\n      .split(\" \")\n      .filter((cssClass) => !!cssClass)\n      .forEach((cssClass) => {\n        this.renderer.addClass(this.elementRef.nativeElement, cssClass);\n      });\n  }\n\n  private isAnimateEnabled() {\n    // not present?  assume it is true.\n    if (typeof this.config.animate === \"undefined\") {\n      return true;\n    }\n    return this.config.animate;\n  }\n}\n"]}