UNPKG

@angular-mdl/core

Version:

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

171 lines 28.5 kB
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":"AAAA,OAAO,EACL,SAAS,EAET,UAAU,EACV,UAAU,EACV,WAAW,EACX,MAAM,EACN,MAAM,EAEN,SAAS,EACT,SAAS,EACT,gBAAgB,EAChB,iBAAiB,GAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAKjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;;;;AAElD,MAAM,uBAAuB,GAAG,GAAG,CAAC;AACpC,MAAM,uBAAuB,GAAG,GAAG,CAAC;AAEpC,MAAM,0BAA0B,GAAG,gCAAgC,CAAC;AACpE,MAAM,0BAA0B,GAAG,gCAAgC,CAAC;AAEpE,MAAM,mBAAmB,GAAG,CAAC,IAAgB,EAAkB,EAAE,CAAC,CAAC;IACjE,MAAM,EAAE,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM;IAC9B,IAAI,EAAE,IAAI,CAAC,IAAI;IACf,GAAG,EAAE,IAAI,CAAC,GAAG;IACb,KAAK,EAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI;CAC9B,CAAC,CAAC;AAEH,MAAM,iBAAiB,GAAG,CAAC,IAAoB,EAAE,EAAE,CAAC,CAAC;IACnD,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IAC1C,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;CAC3C,CAAC,CAAC;AAEH,MAAM,aAAa,GAAG,CACpB,KAAmE,EACnD,EAAE;IAClB,IAAI,KAAK,YAAY,kBAAkB,EAAE;QACvC,MAAM,KAAK,GAAI,KAA4B,CAAC,UAAU,CAAC;QACvD,MAAM,IAAI,GAAe,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;QACrE,OAAO,mBAAmB,CAAC,IAAI,CAAC,CAAC;KAClC;SAAM,IAAI,KAAK,YAAY,UAAU,EAAE;QACtC,MAAM,GAAG,GAAe,KAAmB,CAAC;QAC5C,2EAA2E;QAC3E,mCAAmC;QACnC,2BAA2B;QAC3B,MAAM,WAAW,GAAG,CAAC,GAAG,CAAC,MAAM,IAAK,GAAW,CAAC,UAAU,CAAgB,CAAC;QAC3E,MAAM,IAAI,GAAe,WAAW,CAAC,qBAAqB,EAAE,CAAC;QAC7D,OAAO,mBAAmB,CAAC,IAAI,CAAC,CAAC;KAClC;IACD,OAAO,KAAuB,CAAC;AACjC,CAAC,CAAC;AAEF,gBAAgB;AA+BhB,MAAM,OAAO,sBAAsB;IA0BjC,YACU,MAAc,EACd,QAAmB,EACnB,UAAsB,EACtB,UAAsB,EAEtB,MAA+B,EAC/B,iBAA6C;QAN7C,WAAM,GAAN,MAAM,CAAQ;QACd,aAAQ,GAAR,QAAQ,CAAW;QACnB,eAAU,GAAV,UAAU,CAAY;QACtB,eAAU,GAAV,UAAU,CAAY;QAEtB,WAAM,GAAN,MAAM,CAAyB;QAC/B,sBAAiB,GAAjB,iBAAiB,CAA4B;QA5BvD,aAAQ,GAAG,IAAI,CAAC;QAGhB,YAAO,GAAG,KAAK,CAAC;QAGhB,WAAM,GAAW,kBAAkB,GAAG,CAAC,CAAC;QAEhC,4BAAuB,GAA8B;YAC3D,GAAG,EAAE,KAAK;YACV,OAAO,EAAE,GAAG;SACb,CAAC;QACM,cAAS,GAA8B;YAC7C,GAAG,EAAE,KAAK;YACV,OAAO,EAAE,GAAG;SACb,CAAC;QACM,0BAAqB,GAA8B;YACzD,GAAG,EAAE,KAAK;YACV,OAAO,EAAE,GAAG;SACb,CAAC;IAUC,CAAC;IAEJ,IAAI;QACF,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,2DAA2D;QAC3D,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC;QACnC,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE;YAC3B,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;gBAC/C,sFAAsF;gBACtF,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,+BAA+B,CAAC;gBAE9D,MAAM,gBAAgB,GACpB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;gBAExD,MAAM,YAAY,GAAG,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;gBAC1D,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO;oBACrC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;oBACpC,CAAC,CAAC,YAAY,CAAC;gBAEjB,MAAM,YAAY,GAAG,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;gBACzD,MAAM,UAAU,GAAG,iBAAiB,CAAC,YAAY,CAAC,CAAC;gBACnD,MAAM,QAAQ,GAAG,iBAAiB,CAAC,WAAW,CAAC,CAAC;gBAEhD,MAAM,eAAe,GAAG;oBACtB,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,GAAG,YAAY,CAAC,EAAE,CAAC;oBAC9C,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,GAAG,YAAY,CAAC,EAAE,CAAC;oBAC9C,MAAM,EACJ,IAAI,CAAC,KAAK,CACR,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,YAAY,CAAC,KAAK,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAClE,GAAG,GAAG;oBACT,MAAM,EACJ,IAAI,CAAC,KAAK,CACR,GAAG;wBACD,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,YAAY,CAAC,MAAM,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAChE,GAAG,GAAG;iBACV,CAAC;gBAEF,IAAI,CAAC,uBAAuB,GAAG;oBAC7B,GAAG,EAAE,GAAG,gBAAgB,CAAC,GAAG,IAAI;oBAChC,OAAO,EAAE,GAAG;oBACZ,SAAS,EAAE,aAAa,eAAe,CAAC,CAAC,OAAO,eAAe,CAAC,CAAC,aAAa,eAAe,CAAC,MAAM,KAAK,eAAe,CAAC,MAAM,GAAG;iBACnI,CAAC;gBAEF,MAAM,aAAa,GAAG;oBACpB,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,GAAG,YAAY,CAAC,EAAE,CAAC;oBAC5C,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,GAAG,YAAY,CAAC,EAAE,CAAC;oBAC5C,MAAM,EACJ,IAAI,CAAC,KAAK,CACR,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,WAAW,CAAC,KAAK,GAAG,gBAAgB,CAAC,KAAK,CAAC,CACjE,GAAG,GAAG;oBACT,MAAM,EACJ,IAAI,CAAC,KAAK,CACR,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,WAAW,CAAC,MAAM,GAAG,gBAAgB,CAAC,MAAM,CAAC,CACnE,GAAG,GAAG;iBACV,CAAC;gBAEF,IAAI,CAAC,qBAAqB,GAAG;oBAC3B,GAAG,EAAE,GAAG,gBAAgB,CAAC,GAAG,IAAI;oBAChC,OAAO,EAAE,GAAG;oBACZ,SAAS,EAAE,aAAa,aAAa,CAAC,CAAC,OAAO,aAAa,CAAC,CAAC,aAAa,aAAa,CAAC,MAAM,KAAK,aAAa,CAAC,MAAM,GAAG;iBAC3H,CAAC;aACH;YAED,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CACvC,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,CAAC,IAAI,CAAC,uBAAuB,EAAE,IAAI,CAAC,SAAS,CAAC,EAC9C,IAAI,CAAC,MAAM,CAAC,uBAAuB,IAAI,uBAAuB,EAC9D,IAAI,CAAC,MAAM,CAAC,0BAA0B,IAAI,0BAA0B,CACrE,CAAC;YAEF,SAAS,CAAC,IAAI,EAAE,CAAC;SAClB;IACH,CAAC;IAED,IAAI,CAAC,gBAAsD;QACzD,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE;YAC3B,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CACvC,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,qBAAqB,CAAC,EAC5C,IAAI,CAAC,MAAM,CAAC,uBAAuB,IAAI,uBAAuB,EAC9D,IAAI,CAAC,MAAM,CAAC,0BAA0B,IAAI,0BAA0B,CACrE,CAAC;YAEF,SAAS,CAAC,MAAM,CAAC,GAAG,EAAE;gBACpB,gBAAgB,CAAC,OAAO,EAAE,CAAC;YAC7B,CAAC,CAAC,CAAC;YAEH,SAAS,CAAC,IAAI,EAAE,CAAC;SAClB;aAAM;YACL,gBAAgB,CAAC,OAAO,EAAE,CAAC;SAC5B;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACpC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACpE,CAAC;IAEO,UAAU,CAAC,MAA2C;QAC5D,IAAI,MAAM,EAAE;YACV,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;gBACvC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,KAAK,EACL,MAAM,CAAC,KAAK,CAAC,CACd,CAAC;aACH;SACF;IACH,CAAC;IAEO,YAAY,CAAC,OAAe;QAClC,OAAO;aACJ,KAAK,CAAC,GAAG,CAAC;aACV,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;aAChC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YACpB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,gBAAgB;QACtB,mCAAmC;QACnC,IAAI,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,KAAK,WAAW,EAAE;YAC9C,OAAO,IAAI,CAAC;SACb;QACD,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;IAC7B,CAAC;;mHAlKU,sBAAsB,qHA+BvB,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;uGA/BlC,sBAAsB,sRACE,gBAAgB,2CA7BzC,4BAA4B;2FA4B3B,sBAAsB;kBA9BlC,SAAS;+BACE,2BAA2B,YAC3B,4BAA4B,iBA0BvB,iBAAiB,CAAC,IAAI;;0BAiClC,MAAM;2BAAC,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;qFA7B7C,YAAY;sBADX,SAAS;uBAAC,cAAc,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,EAAE;gBAInE,QAAQ;sBADP,WAAW;uBAAC,kBAAkB;gBAI/B,OAAO;sBADN,WAAW;uBAAC,YAAY;gBAIzB,MAAM;sBADL,WAAW;uBAAC,cAAc","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"]}