UNPKG

@angular-mdl/core

Version:

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

119 lines 14.4 kB
import { Component, ElementRef, HostBinding, Input, Renderer2, ViewEncapsulation, } from "@angular/core"; import { MdlTooltipPositionService } from "./mdl-tooltip-position.service"; import * as i0 from "@angular/core"; import * as i1 from "./mdl-tooltip-position.service"; const IS_ACTIVE = "is-active"; export class MdlSimpleTooltipComponent { constructor(elRef, renderer, mdlTooltipPositionService) { this.elRef = elRef; this.renderer = renderer; this.mdlTooltipPositionService = mdlTooltipPositionService; this.large = false; this.position = "top"; this.isTooltip = true; this.tooltipText = ""; this.active = false; this.element = elRef.nativeElement; } get isBottom() { return this.position === "bottom"; } get isRight() { return this.position === "right"; } get isLeft() { return this.position === "left"; } isTop() { return this.position === "top"; } mouseLeave() { if (this.delayTimeout) { clearTimeout(this.delayTimeout); } this.setActive(false); } mouseEnter(event) { if (this.delay) { this.delayTimeout = setTimeout(() => { this.show(event.target); }, this.delay); } else { this.show(event.target); } } isActive() { return this.active; } show(element) { const props = element.getBoundingClientRect(); const offsetWidth = this.element.offsetWidth; const offsetHeight = this.element.offsetHeight; const style = this.mdlTooltipPositionService.calcStyle(offsetWidth, offsetHeight, props, this.position); for (const key of Object.keys(style)) { this.renderer.setStyle(this.elRef.nativeElement, key, style[key]); } this.setActive(true); } setActive(active) { this.active = active; if (active) { this.renderer.addClass(this.elRef.nativeElement, IS_ACTIVE); } else { this.renderer.removeClass(this.elRef.nativeElement, IS_ACTIVE); } } } MdlSimpleTooltipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSimpleTooltipComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.MdlTooltipPositionService }], target: i0.ɵɵFactoryTarget.Component }); MdlSimpleTooltipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: MdlSimpleTooltipComponent, selector: "mdl-simple-tooltip", inputs: { position: "position", delay: "delay" }, host: { properties: { "class.mdl-tooltip--large": "this.large", "class.mdl-tooltip": "this.isTooltip", "class.mdl-tooltip--bottom": "this.isBottom", "class.mdl-tooltip--right": "this.isRight", "class.mdl-tooltip--left": "this.isLeft", "class.mdl-tooltip--top": "this.isTop" } }, providers: [MdlTooltipPositionService], ngImport: i0, template: "<div>{{tooltipText}}</div>", isInline: true, encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlSimpleTooltipComponent, decorators: [{ type: Component, args: [{ selector: "mdl-simple-tooltip", template: "<div>{{tooltipText}}</div>", providers: [MdlTooltipPositionService], encapsulation: ViewEncapsulation.None, }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.MdlTooltipPositionService }]; }, propDecorators: { large: [{ type: HostBinding, args: ["class.mdl-tooltip--large"] }], position: [{ type: Input }], delay: [{ type: Input }], isTooltip: [{ type: HostBinding, args: ["class.mdl-tooltip"] }], isBottom: [{ type: HostBinding, args: ["class.mdl-tooltip--bottom"] }], isRight: [{ type: HostBinding, args: ["class.mdl-tooltip--right"] }], isLeft: [{ type: HostBinding, args: ["class.mdl-tooltip--left"] }], isTop: [{ type: HostBinding, args: ["class.mdl-tooltip--top"] }] } }); export class MdlTooltipComponent extends MdlSimpleTooltipComponent { constructor(elRef, renderer, mdlTooltipPositionService) { super(elRef, renderer, mdlTooltipPositionService); } } MdlTooltipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlTooltipComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.MdlTooltipPositionService }], target: i0.ɵɵFactoryTarget.Component }); MdlTooltipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: MdlTooltipComponent, selector: "mdl-tooltip", providers: [MdlTooltipPositionService], exportAs: ["mdlTooltip"], usesInheritance: true, ngImport: i0, template: "<div><ng-content></ng-content></div>", isInline: true, encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlTooltipComponent, decorators: [{ type: Component, args: [{ selector: "mdl-tooltip", template: "<div><ng-content></ng-content></div>", exportAs: "mdlTooltip", providers: [MdlTooltipPositionService], encapsulation: ViewEncapsulation.None, }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.MdlTooltipPositionService }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdl-tooltip.component.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/tooltip/mdl-tooltip.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  Renderer2,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { MdlTooltipPositionService } from \"./mdl-tooltip-position.service\";\n\nconst IS_ACTIVE = \"is-active\";\n\n@Component({\n  selector: \"mdl-simple-tooltip\",\n  template: \"<div>{{tooltipText}}</div>\",\n  providers: [MdlTooltipPositionService],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MdlSimpleTooltipComponent {\n  @HostBinding(\"class.mdl-tooltip--large\")\n  large = false;\n\n  @Input()\n  position: \"left\" | \"right\" | \"top\" | \"bottom\" = \"top\";\n\n  @Input()\n  delay: number | undefined;\n\n  @HostBinding(\"class.mdl-tooltip\")\n  isTooltip = true;\n\n  tooltipText: string | undefined = \"\";\n  element: HTMLElement;\n\n  active = false;\n  delayTimeout: unknown;\n\n  constructor(\n    private elRef: ElementRef,\n    private renderer: Renderer2,\n    private mdlTooltipPositionService: MdlTooltipPositionService\n  ) {\n    this.element = elRef.nativeElement;\n  }\n\n  @HostBinding(\"class.mdl-tooltip--bottom\") get isBottom(): boolean {\n    return this.position === \"bottom\";\n  }\n\n  @HostBinding(\"class.mdl-tooltip--right\") get isRight(): boolean {\n    return this.position === \"right\";\n  }\n\n  @HostBinding(\"class.mdl-tooltip--left\") get isLeft(): boolean {\n    return this.position === \"left\";\n  }\n\n  @HostBinding(\"class.mdl-tooltip--top\") isTop(): boolean {\n    return this.position === \"top\";\n  }\n\n  mouseLeave(): void {\n    if (this.delayTimeout) {\n      clearTimeout(this.delayTimeout as number);\n    }\n    this.setActive(false);\n  }\n\n  mouseEnter(event: Event): void {\n    if (this.delay) {\n      this.delayTimeout = setTimeout(() => {\n        this.show(event.target as HTMLElement);\n      }, this.delay);\n    } else {\n      this.show(event.target as HTMLElement);\n    }\n  }\n\n  isActive(): boolean {\n    return this.active;\n  }\n\n  private show(element: HTMLElement) {\n    const props = element.getBoundingClientRect();\n    const offsetWidth = this.element.offsetWidth;\n    const offsetHeight = this.element.offsetHeight;\n\n    const style = this.mdlTooltipPositionService.calcStyle(\n      offsetWidth,\n      offsetHeight,\n      props,\n      this.position\n    );\n\n    for (const key of Object.keys(style)) {\n      this.renderer.setStyle(this.elRef.nativeElement, key, style[key]);\n    }\n\n    this.setActive(true);\n  }\n\n  private setActive(active: boolean) {\n    this.active = active;\n    if (active) {\n      this.renderer.addClass(this.elRef.nativeElement, IS_ACTIVE);\n    } else {\n      this.renderer.removeClass(this.elRef.nativeElement, IS_ACTIVE);\n    }\n  }\n}\n\n@Component({\n  selector: \"mdl-tooltip\",\n  template: \"<div><ng-content></ng-content></div>\",\n  exportAs: \"mdlTooltip\",\n  providers: [MdlTooltipPositionService],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MdlTooltipComponent extends MdlSimpleTooltipComponent {\n  constructor(\n    elRef: ElementRef,\n    renderer: Renderer2,\n    mdlTooltipPositionService: MdlTooltipPositionService\n  ) {\n    super(elRef, renderer, mdlTooltipPositionService);\n  }\n}\n"]}