@angular-mdl/core
Version:
Angular components, directives and styles based on material design lite https://getmdl.io.
119 lines • 14.4 kB
JavaScript
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"]}