@angular-mdl/core
Version:
Angular components, directives and styles based on material design lite https://getmdl.io.
127 lines • 14.2 kB
JavaScript
import { Component, ElementRef, HostBinding, HostListener, Input, ViewEncapsulation, } from "@angular/core";
import { MdlError } from "../common/mdl-error";
import { toBoolean } from "../common/boolean-property";
import { callNative } from "../common/native-support";
import * as i0 from "@angular/core";
export class MdlUnsupportedButtonTypeError extends MdlError {
constructor(type) {
/* istanbul ignore next */
super(`Button type "${type}" isn't supported (allowed: raised, fab, mini-fab, icon, '').`);
}
}
export class MdlUnsupportedColoredTypeError extends MdlError {
constructor(type) {
/* istanbul ignore next */
super(`Colored type "${type}" isn't supported (allowed: primary, accent, '').`);
}
}
const MDL_BUTTON_TYPES = ["raised", "fab", "mini-fab", "icon", ""];
const MDL_COLORED_TYPES = ["primary", "accent", ""];
export class MdlButtonComponent {
constructor(elementRef) {
this.elementRef = elementRef;
this.isButton = true;
// eslint-disable-next-line @angular-eslint/no-input-rename
this.mdlButtonType = "";
// eslint-disable-next-line @angular-eslint/no-input-rename
this.mdlColoredType = "";
this.disabledIntern = false;
this.element = elementRef.nativeElement;
}
get isDisable() {
return this.disabled ? "disabled" : null;
}
get raised() {
return this.mdlButtonType === "raised";
}
get fab() {
return this.mdlButtonType === "fab" || this.mdlButtonType === "mini-fab";
}
get miniFab() {
return this.mdlButtonType === "mini-fab";
}
get icon() {
return this.mdlButtonType === "icon";
}
get primary() {
return this.mdlColoredType === "primary";
}
get accent() {
return this.mdlColoredType === "accent";
}
get disabled() {
return this.disabledIntern;
}
set disabled(value) {
this.disabledIntern = toBoolean(value);
}
onMouseUp() {
this.blurIt();
}
onMouseLeave() {
this.blurIt();
}
ngOnChanges() {
if (this.mdlButtonType &&
MDL_BUTTON_TYPES.indexOf(this.mdlButtonType) === -1) {
throw new MdlUnsupportedButtonTypeError(this.mdlButtonType);
}
if (this.mdlColoredType &&
MDL_COLORED_TYPES.indexOf(this.mdlColoredType) === -1) {
throw new MdlUnsupportedColoredTypeError(this.mdlColoredType);
}
}
blurIt() {
callNative(this.element, "blur");
}
}
MdlButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlButtonComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
MdlButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: MdlButtonComponent, selector: "mdl-button, button[mdl-button], a[mdl-button]", inputs: { mdlButtonType: ["mdl-button-type", "mdlButtonType"], mdlColoredType: ["mdl-colored", "mdlColoredType"], disabled: "disabled" }, host: { listeners: { "mouseup": "onMouseUp()", "mouseleave": "onMouseLeave()" }, properties: { "class.mdl-button": "this.isButton", "attr.disabled": "this.isDisable", "class.mdl-button--raised": "this.raised", "class.mdl-button--fab": "this.fab", "class.mdl-button--mini-fab": "this.miniFab", "class.mdl-button--icon": "this.icon", "class.mdl-button--primary": "this.primary", "class.mdl-button--accent": "this.accent" } }, exportAs: ["mdlButton"], usesOnChanges: true, ngImport: i0, template: "<ng-content></ng-content>", isInline: true, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlButtonComponent, decorators: [{
type: Component,
args: [{
selector: "mdl-button, button[mdl-button], a[mdl-button]",
exportAs: "mdlButton",
template: "<ng-content></ng-content>",
encapsulation: ViewEncapsulation.None,
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { isButton: [{
type: HostBinding,
args: ["class.mdl-button"]
}], mdlButtonType: [{
type: Input,
args: ["mdl-button-type"]
}], mdlColoredType: [{
type: Input,
args: ["mdl-colored"]
}], isDisable: [{
type: HostBinding,
args: ["attr.disabled"]
}], raised: [{
type: HostBinding,
args: ["class.mdl-button--raised"]
}], fab: [{
type: HostBinding,
args: ["class.mdl-button--fab"]
}], miniFab: [{
type: HostBinding,
args: ["class.mdl-button--mini-fab"]
}], icon: [{
type: HostBinding,
args: ["class.mdl-button--icon"]
}], primary: [{
type: HostBinding,
args: ["class.mdl-button--primary"]
}], accent: [{
type: HostBinding,
args: ["class.mdl-button--accent"]
}], disabled: [{
type: Input
}], onMouseUp: [{
type: HostListener,
args: ["mouseup"]
}], onMouseLeave: [{
type: HostListener,
args: ["mouseleave"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdl-button.component.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/button/mdl-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnChanges,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { MdlError } from \"../common/mdl-error\";\nimport { toBoolean } from \"../common/boolean-property\";\nimport { callNative } from \"../common/native-support\";\n\nexport class MdlUnsupportedButtonTypeError extends MdlError {\n  constructor(type: string) {\n    /* istanbul ignore next */\n    super(\n      `Button type \"${type}\" isn't supported (allowed: raised, fab, mini-fab, icon, '').`\n    );\n  }\n}\n\nexport class MdlUnsupportedColoredTypeError extends MdlError {\n  constructor(type: string) {\n    /* istanbul ignore next */\n    super(\n      `Colored type \"${type}\" isn't supported (allowed: primary, accent, '').`\n    );\n  }\n}\n\nconst MDL_BUTTON_TYPES = [\"raised\", \"fab\", \"mini-fab\", \"icon\", \"\"];\n\nconst MDL_COLORED_TYPES = [\"primary\", \"accent\", \"\"];\n\nexport type MdlButtonType = \"raised\" | \"fab\" | \"mini-fab\" | \"icon\" | \"\";\nexport type MdlColorType = \"primary\" | \"accent\" | \"\";\n\n@Component({\n  selector: \"mdl-button, button[mdl-button], a[mdl-button]\",\n  exportAs: \"mdlButton\",\n  template: \"<ng-content></ng-content>\",\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MdlButtonComponent implements OnChanges {\n  @HostBinding(\"class.mdl-button\")\n  isButton = true;\n\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input(\"mdl-button-type\")\n  mdlButtonType: MdlButtonType = \"\";\n\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input(\"mdl-colored\")\n  mdlColoredType: MdlColorType = \"\";\n\n  readonly element: HTMLElement;\n  private disabledIntern = false;\n\n  constructor(public elementRef: ElementRef) {\n    this.element = elementRef.nativeElement;\n  }\n\n  @HostBinding(\"attr.disabled\") get isDisable(): string | null {\n    return this.disabled ? \"disabled\" : null;\n  }\n\n  @HostBinding(\"class.mdl-button--raised\") get raised(): boolean {\n    return this.mdlButtonType === \"raised\";\n  }\n\n  @HostBinding(\"class.mdl-button--fab\") get fab(): boolean {\n    return this.mdlButtonType === \"fab\" || this.mdlButtonType === \"mini-fab\";\n  }\n\n  @HostBinding(\"class.mdl-button--mini-fab\") get miniFab(): boolean {\n    return this.mdlButtonType === \"mini-fab\";\n  }\n\n  @HostBinding(\"class.mdl-button--icon\") get icon(): boolean {\n    return this.mdlButtonType === \"icon\";\n  }\n\n  @HostBinding(\"class.mdl-button--primary\") get primary(): boolean {\n    return this.mdlColoredType === \"primary\";\n  }\n\n  @HostBinding(\"class.mdl-button--accent\") get accent(): boolean {\n    return this.mdlColoredType === \"accent\";\n  }\n\n  @Input()\n  get disabled(): boolean {\n    return this.disabledIntern;\n  }\n\n  set disabled(value: boolean | string) {\n    this.disabledIntern = toBoolean(value);\n  }\n\n  @HostListener(\"mouseup\")\n  onMouseUp(): void {\n    this.blurIt();\n  }\n\n  @HostListener(\"mouseleave\")\n  onMouseLeave(): void {\n    this.blurIt();\n  }\n\n  ngOnChanges(): void {\n    if (\n      this.mdlButtonType &&\n      MDL_BUTTON_TYPES.indexOf(this.mdlButtonType) === -1\n    ) {\n      throw new MdlUnsupportedButtonTypeError(this.mdlButtonType);\n    }\n\n    if (\n      this.mdlColoredType &&\n      MDL_COLORED_TYPES.indexOf(this.mdlColoredType) === -1\n    ) {\n      throw new MdlUnsupportedColoredTypeError(this.mdlColoredType);\n    }\n  }\n\n  blurIt(): void {\n    callNative(this.element, \"blur\");\n  }\n}\n"]}