@angular-mdl/core
Version:
Angular components, directives and styles based on material design lite https://getmdl.io.
193 lines • 23.7 kB
JavaScript
import { Directive, ElementRef, Input, Renderer2, } from "@angular/core";
import { MaterialRipple } from "./ripple.vendor";
import * as i0 from "@angular/core";
const RIPPLE = "mdl-ripple";
// known bugs: https://github.com/google/material-design-lite/issues/4215
export class MdlRippleDirective {
constructor(elementRef, renderer, cssContainerClasses) {
this.elementRef = elementRef;
this.renderer = renderer;
this.cssContainerClasses = cssContainerClasses;
this.rippleActive = true;
this.el = elementRef.nativeElement;
}
ngOnChanges() {
// remove any existing ripple container
if (this.rippleContainer) {
this.el.removeChild(this.rippleContainer);
delete this.rippleContainer;
delete this.ripple;
}
// if used as mdl-ripple without property binding it is an empty string
// otherwise (e.g. [mdl-ripple] it is a boolean - may be with the default value true.
if (this.rippleActive === "" || this.rippleActive) {
this.rippleContainer = this.renderer.createElement("span");
this.cssContainerClasses.forEach((cssClass) => {
this.renderer.addClass(this.rippleContainer, cssClass);
});
const rippleElement = this.renderer.createElement("span");
this.renderer.addClass(rippleElement, RIPPLE);
this.rippleContainer?.appendChild(rippleElement);
if (this.rippleContainer) {
this.el.appendChild(this.rippleContainer);
}
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
this.ripple = new MaterialRipple(this.renderer, this.el);
}
}
}
MdlRippleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRippleDirective, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
MdlRippleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: MdlRippleDirective, usesOnChanges: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRippleDirective, decorators: [{
type: Directive
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: undefined }]; } });
export class MdlButtonRippleDirective extends MdlRippleDirective {
constructor(elementRef, renderer) {
super(elementRef, renderer, ["mdl-button__ripple-container"]);
// eslint-disable-next-line
this.rippleActive = true;
}
}
MdlButtonRippleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlButtonRippleDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
MdlButtonRippleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: MdlButtonRippleDirective, selector: "mdl-button[mdl-ripple], button[mdl-ripple]", inputs: { rippleActive: ["mdl-ripple", "rippleActive"] }, usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlButtonRippleDirective, decorators: [{
type: Directive,
args: [{
// eslint-disable-next-line
selector: "mdl-button[mdl-ripple], button[mdl-ripple]",
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { rippleActive: [{
type: Input,
args: ["mdl-ripple"]
}] } });
export class MdlCheckboxRippleDirective extends MdlRippleDirective {
constructor(elementRef, renderer) {
super(elementRef, renderer, [
"mdl-checkbox__ripple-container",
"mdl-ripple--center",
]);
// eslint-disable-next-line
this.rippleActive = true;
}
}
MdlCheckboxRippleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlCheckboxRippleDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
MdlCheckboxRippleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: MdlCheckboxRippleDirective, selector: "mdl-checkbox[mdl-ripple]", inputs: { rippleActive: ["mdl-ripple", "rippleActive"] }, usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlCheckboxRippleDirective, decorators: [{
type: Directive,
args: [{
// eslint-disable-next-line
selector: "mdl-checkbox[mdl-ripple]",
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { rippleActive: [{
type: Input,
args: ["mdl-ripple"]
}] } });
export class MdlRadioRippleDirective extends MdlRippleDirective {
constructor(elementRef, renderer) {
super(elementRef, renderer, [
"mdl-radio__ripple-container",
"mdl-ripple--center",
]);
// eslint-disable-next-line
this.rippleActive = true;
}
}
MdlRadioRippleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRadioRippleDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
MdlRadioRippleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: MdlRadioRippleDirective, selector: "mdl-radio[mdl-ripple]", inputs: { rippleActive: ["mdl-ripple", "rippleActive"] }, usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRadioRippleDirective, decorators: [{
type: Directive,
args: [{
// eslint-disable-next-line
selector: "mdl-radio[mdl-ripple]",
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { rippleActive: [{
type: Input,
args: ["mdl-ripple"]
}] } });
export class MdlIconToggleRippleDirective extends MdlRippleDirective {
constructor(elementRef, renderer) {
super(elementRef, renderer, [
"mdl-icon-toggle__ripple-container",
"mdl-ripple--center",
]);
// eslint-disable-next-line
this.rippleActive = true;
}
}
MdlIconToggleRippleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlIconToggleRippleDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
MdlIconToggleRippleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: MdlIconToggleRippleDirective, selector: "mdl-icon-toggle[mdl-ripple]", inputs: { rippleActive: ["mdl-ripple", "rippleActive"] }, usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlIconToggleRippleDirective, decorators: [{
type: Directive,
args: [{
// eslint-disable-next-line
selector: "mdl-icon-toggle[mdl-ripple]",
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { rippleActive: [{
type: Input,
args: ["mdl-ripple"]
}] } });
export class MdlSwitchRippleDirective extends MdlRippleDirective {
constructor(elementRef, renderer) {
super(elementRef, renderer, [
"mdl-switch__ripple-container",
"mdl-ripple--center",
]);
// eslint-disable-next-line
this.rippleActive = true;
}
}
MdlSwitchRippleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSwitchRippleDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
MdlSwitchRippleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: MdlSwitchRippleDirective, selector: "mdl-switch[mdl-ripple]", inputs: { rippleActive: ["mdl-ripple", "rippleActive"] }, usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSwitchRippleDirective, decorators: [{
type: Directive,
args: [{
// eslint-disable-next-line
selector: "mdl-switch[mdl-ripple]",
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { rippleActive: [{
type: Input,
args: ["mdl-ripple"]
}] } });
export class MdlMenuItemRippleDirective extends MdlRippleDirective {
constructor(elementRef, renderer) {
super(elementRef, renderer, ["mdl-menu__item--ripple-container"]);
// eslint-disable-next-line
this.rippleActive = true;
}
}
MdlMenuItemRippleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlMenuItemRippleDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
MdlMenuItemRippleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: MdlMenuItemRippleDirective, selector: "mdl-menu-item[mdl-ripple]", inputs: { rippleActive: ["mdl-ripple", "rippleActive"] }, usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlMenuItemRippleDirective, decorators: [{
type: Directive,
args: [{
// eslint-disable-next-line
selector: "mdl-menu-item[mdl-ripple]",
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { rippleActive: [{
type: Input,
args: ["mdl-ripple"]
}] } });
export class MdlAnchorRippleDirective extends MdlRippleDirective {
constructor(elementRef, renderer) {
super(elementRef, renderer, [
"mdl-tabs__ripple-container",
"mdl-layout__tab-ripple-container",
]);
// eslint-disable-next-line
this.rippleActive = true;
}
}
MdlAnchorRippleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlAnchorRippleDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
MdlAnchorRippleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: MdlAnchorRippleDirective, selector: "a[mdl-ripple],div[mdl-ripple]", inputs: { rippleActive: ["mdl-ripple", "rippleActive"] }, usesInheritance: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlAnchorRippleDirective, decorators: [{
type: Directive,
args: [{
// eslint-disable-next-line
selector: "a[mdl-ripple],div[mdl-ripple]",
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { rippleActive: [{
type: Input,
args: ["mdl-ripple"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdl-ripple.directive.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/ripple/mdl-ripple.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Input,\n  OnChanges,\n  Renderer2,\n} from \"@angular/core\";\nimport { MaterialRipple } from \"./ripple.vendor\";\n\nconst RIPPLE = \"mdl-ripple\";\n\n// known bugs: https://github.com/google/material-design-lite/issues/4215\n@Directive()\nexport class MdlRippleDirective implements OnChanges {\n  public el: HTMLElement;\n  rippleActive: boolean | string = true;\n\n  private rippleContainer: HTMLElement | undefined;\n  private ripple: (() => void) | undefined;\n\n  constructor(\n    private elementRef: ElementRef,\n    public renderer: Renderer2,\n    private cssContainerClasses: string[]\n  ) {\n    this.el = elementRef.nativeElement;\n  }\n\n  ngOnChanges(): void {\n    // remove any existing ripple container\n    if (this.rippleContainer) {\n      this.el.removeChild(this.rippleContainer);\n      delete this.rippleContainer;\n      delete this.ripple;\n    }\n\n    // if used as mdl-ripple without property binding it is an empty string\n    // otherwise (e.g. [mdl-ripple] it is a boolean - may be with the default value true.\n    if (this.rippleActive === \"\" || this.rippleActive) {\n      this.rippleContainer = this.renderer.createElement(\"span\");\n      this.cssContainerClasses.forEach((cssClass) => {\n        this.renderer.addClass(this.rippleContainer, cssClass);\n      });\n      const rippleElement = this.renderer.createElement(\"span\");\n      this.renderer.addClass(rippleElement, RIPPLE);\n      this.rippleContainer?.appendChild(rippleElement);\n      if (this.rippleContainer) {\n        this.el.appendChild(this.rippleContainer);\n      }\n      // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n      // @ts-ignore\n      this.ripple = new MaterialRipple(this.renderer, this.el);\n    }\n  }\n}\n\n@Directive({\n  // eslint-disable-next-line\n  selector: \"mdl-button[mdl-ripple], button[mdl-ripple]\",\n})\nexport class MdlButtonRippleDirective extends MdlRippleDirective {\n  // eslint-disable-next-line\n  @Input(\"mdl-ripple\") public override rippleActive: boolean | string = true;\n\n  constructor(elementRef: ElementRef, renderer: Renderer2) {\n    super(elementRef, renderer, [\"mdl-button__ripple-container\"]);\n  }\n}\n\n@Directive({\n  // eslint-disable-next-line\n  selector: \"mdl-checkbox[mdl-ripple]\",\n})\nexport class MdlCheckboxRippleDirective extends MdlRippleDirective {\n  // eslint-disable-next-line\n  @Input(\"mdl-ripple\") public override rippleActive: boolean | string = true;\n\n  constructor(elementRef: ElementRef, renderer: Renderer2) {\n    super(elementRef, renderer, [\n      \"mdl-checkbox__ripple-container\",\n      \"mdl-ripple--center\",\n    ]);\n  }\n}\n\n@Directive({\n  // eslint-disable-next-line\n  selector: \"mdl-radio[mdl-ripple]\",\n})\nexport class MdlRadioRippleDirective extends MdlRippleDirective {\n  // eslint-disable-next-line\n  @Input(\"mdl-ripple\") public override rippleActive: boolean | string = true;\n\n  constructor(elementRef: ElementRef, renderer: Renderer2) {\n    super(elementRef, renderer, [\n      \"mdl-radio__ripple-container\",\n      \"mdl-ripple--center\",\n    ]);\n  }\n}\n\n@Directive({\n  // eslint-disable-next-line\n  selector: \"mdl-icon-toggle[mdl-ripple]\",\n})\nexport class MdlIconToggleRippleDirective extends MdlRippleDirective {\n  // eslint-disable-next-line\n  @Input(\"mdl-ripple\") public override rippleActive: boolean | string = true;\n\n  constructor(elementRef: ElementRef, renderer: Renderer2) {\n    super(elementRef, renderer, [\n      \"mdl-icon-toggle__ripple-container\",\n      \"mdl-ripple--center\",\n    ]);\n  }\n}\n\n@Directive({\n  // eslint-disable-next-line\n  selector: \"mdl-switch[mdl-ripple]\",\n})\nexport class MdlSwitchRippleDirective extends MdlRippleDirective {\n  // eslint-disable-next-line\n  @Input(\"mdl-ripple\") public override rippleActive: boolean | string = true;\n\n  constructor(elementRef: ElementRef, renderer: Renderer2) {\n    super(elementRef, renderer, [\n      \"mdl-switch__ripple-container\",\n      \"mdl-ripple--center\",\n    ]);\n  }\n}\n\n@Directive({\n  // eslint-disable-next-line\n  selector: \"mdl-menu-item[mdl-ripple]\",\n})\nexport class MdlMenuItemRippleDirective extends MdlRippleDirective {\n  // eslint-disable-next-line\n  @Input(\"mdl-ripple\") public override rippleActive: boolean | string = true;\n\n  constructor(elementRef: ElementRef, renderer: Renderer2) {\n    super(elementRef, renderer, [\"mdl-menu__item--ripple-container\"]);\n  }\n}\n\n@Directive({\n  // eslint-disable-next-line\n  selector: \"a[mdl-ripple],div[mdl-ripple]\",\n})\nexport class MdlAnchorRippleDirective extends MdlRippleDirective {\n  // eslint-disable-next-line\n  @Input(\"mdl-ripple\") public override rippleActive: boolean | string = true;\n\n  constructor(elementRef: ElementRef, renderer: Renderer2) {\n    super(elementRef, renderer, [\n      \"mdl-tabs__ripple-container\",\n      \"mdl-layout__tab-ripple-container\",\n    ]);\n  }\n}\n"]}