@clr/angular
Version:
Angular components for Clarity
135 lines • 17.2 kB
JavaScript
/*
* Copyright (c) 2016-2025 Broadcom. All Rights Reserved.
* The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
* This software is released under MIT license.
* The full license information can be found in LICENSE in the root directory of this project.
*/
import { Component, HostListener, Inject, Input, Optional } from '@angular/core';
import { assertNever } from '../../utils/assert/assert.helpers';
import { uniqueIdFactory } from '../../utils/id-generator/id-generator.service';
import { AbstractPopover } from '../common/abstract-popover';
import { Point } from '../common/popover';
import { POPOVER_HOST_ANCHOR } from '../common/popover-host-anchor.token';
import * as i0 from "@angular/core";
import * as i1 from "./providers/tooltip-id.service";
import * as i2 from "./providers/tooltip-mouse.service";
const POSITIONS = ['bottom-left', 'bottom-right', 'top-left', 'top-right', 'right', 'left'];
const SIZES = ['xs', 'sm', 'md', 'lg'];
const defaultPosition = 'right';
const defaultSize = 'sm';
export class ClrTooltipContent extends AbstractPopover {
constructor(injector, parentHost, tooltipIdService, tooltipMouseService) {
super(injector, parentHost);
this.tooltipIdService = tooltipIdService;
this.tooltipMouseService = tooltipMouseService;
if (!parentHost) {
throw new Error('clr-tooltip-content should only be used inside of a clr-tooltip');
}
// Set the default id in case consumer does not supply a custom id.
this.id = uniqueIdFactory();
}
get id() {
return this._id;
}
set id(value) {
const id = value || '';
this._id = id;
this.tooltipIdService.updateId(id);
}
get position() {
return this._position;
}
set position(value) {
const oldPosition = this._position;
const newPosition = POSITIONS.includes(value) ? value : defaultPosition;
this._position = newPosition;
this.updateCssClass({ oldClass: `tooltip-${oldPosition}`, newClass: `tooltip-${newPosition}` });
// set the popover values based on direction
switch (newPosition) {
case 'top-right':
this.anchorPoint = Point.TOP_CENTER;
this.popoverPoint = Point.LEFT_BOTTOM;
break;
case 'top-left':
this.anchorPoint = Point.TOP_CENTER;
this.popoverPoint = Point.RIGHT_BOTTOM;
break;
case 'bottom-right':
this.anchorPoint = Point.BOTTOM_CENTER;
this.popoverPoint = Point.LEFT_TOP;
break;
case 'bottom-left':
this.anchorPoint = Point.BOTTOM_CENTER;
this.popoverPoint = Point.RIGHT_TOP;
break;
case 'right':
this.anchorPoint = Point.RIGHT_CENTER;
this.popoverPoint = Point.LEFT_TOP;
break;
case 'left':
this.anchorPoint = Point.LEFT_CENTER;
this.popoverPoint = Point.RIGHT_TOP;
break;
default:
assertNever(newPosition);
}
}
get size() {
return this._size;
}
set size(value) {
const oldSize = this._size;
const newSize = SIZES.includes(value) ? value : defaultSize;
this._size = newSize;
this.updateCssClass({ oldClass: `tooltip-${oldSize}`, newClass: `tooltip-${newSize}` });
}
ngOnInit() {
this.size = this.size || defaultSize;
this.position = this.position || defaultPosition;
}
onMouseEnter() {
this.tooltipMouseService.onMouseEnterContent();
}
onMouseLeave() {
this.tooltipMouseService.onMouseLeaveContent();
}
updateCssClass({ oldClass, newClass }) {
this.renderer.removeClass(this.el.nativeElement, oldClass);
this.renderer.addClass(this.el.nativeElement, newClass);
}
}
ClrTooltipContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrTooltipContent, deps: [{ token: i0.Injector }, { token: POPOVER_HOST_ANCHOR, optional: true }, { token: i1.TooltipIdService }, { token: i2.TooltipMouseService }], target: i0.ɵɵFactoryTarget.Component });
ClrTooltipContent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.2", type: ClrTooltipContent, selector: "clr-tooltip-content", inputs: { id: "id", position: ["clrPosition", "position"], size: ["clrSize", "size"] }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" }, properties: { "class.tooltip-content": "true", "style.opacity": "1", "attr.role": "\"tooltip\"", "id": "id" } }, usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrTooltipContent, decorators: [{
type: Component,
args: [{
selector: 'clr-tooltip-content',
template: `<ng-content></ng-content>`,
host: {
'[class.tooltip-content]': 'true',
'[style.opacity]': '1',
'[attr.role]': '"tooltip"',
'[id]': 'id',
},
}]
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i0.ElementRef, decorators: [{
type: Optional
}, {
type: Inject,
args: [POPOVER_HOST_ANCHOR]
}] }, { type: i1.TooltipIdService }, { type: i2.TooltipMouseService }]; }, propDecorators: { id: [{
type: Input
}], position: [{
type: Input,
args: ['clrPosition']
}], size: [{
type: Input,
args: ['clrSize']
}], onMouseEnter: [{
type: HostListener,
args: ['mouseenter']
}], onMouseLeave: [{
type: HostListener,
args: ['mouseleave']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-content.js","sourceRoot":"","sources":["../../../../../projects/angular/src/popover/tooltip/tooltip-content.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n * The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n * This software is released under MIT license.\n * The full license information can be found in LICENSE in the root directory of this project.\n */\n\nimport { Component, ElementRef, HostListener, Inject, Injector, Input, OnInit, Optional } from '@angular/core';\n\nimport { assertNever } from '../../utils/assert/assert.helpers';\nimport { uniqueIdFactory } from '../../utils/id-generator/id-generator.service';\nimport { AbstractPopover } from '../common/abstract-popover';\nimport { Point } from '../common/popover';\nimport { POPOVER_HOST_ANCHOR } from '../common/popover-host-anchor.token';\nimport { TooltipIdService } from './providers/tooltip-id.service';\nimport { TooltipMouseService } from './providers/tooltip-mouse.service';\n\nconst POSITIONS = ['bottom-left', 'bottom-right', 'top-left', 'top-right', 'right', 'left'] as const;\ntype Position = typeof POSITIONS[number];\n\nconst SIZES = ['xs', 'sm', 'md', 'lg'];\n\nconst defaultPosition = 'right';\nconst defaultSize = 'sm';\n\n@Component({\n  selector: 'clr-tooltip-content',\n  template: `<ng-content></ng-content>`,\n  host: {\n    '[class.tooltip-content]': 'true',\n    '[style.opacity]': '1',\n    '[attr.role]': '\"tooltip\"',\n    '[id]': 'id',\n  },\n})\nexport class ClrTooltipContent extends AbstractPopover implements OnInit {\n  private _id: string;\n  private _position: string;\n  private _size: string;\n\n  constructor(\n    injector: Injector,\n    @Optional()\n    @Inject(POPOVER_HOST_ANCHOR)\n    parentHost: ElementRef<HTMLElement>,\n    private tooltipIdService: TooltipIdService,\n    private tooltipMouseService: TooltipMouseService\n  ) {\n    super(injector, parentHost);\n\n    if (!parentHost) {\n      throw new Error('clr-tooltip-content should only be used inside of a clr-tooltip');\n    }\n\n    // Set the default id in case consumer does not supply a custom id.\n    this.id = uniqueIdFactory();\n  }\n\n  @Input()\n  get id(): string {\n    return this._id;\n  }\n  set id(value: string) {\n    const id = value || '';\n\n    this._id = id;\n    this.tooltipIdService.updateId(id);\n  }\n\n  @Input('clrPosition')\n  get position() {\n    return this._position;\n  }\n  set position(value: string) {\n    const oldPosition = this._position;\n    const newPosition = POSITIONS.includes(value as any) ? (value as Position) : defaultPosition;\n\n    this._position = newPosition;\n    this.updateCssClass({ oldClass: `tooltip-${oldPosition}`, newClass: `tooltip-${newPosition}` });\n\n    // set the popover values based on direction\n    switch (newPosition) {\n      case 'top-right':\n        this.anchorPoint = Point.TOP_CENTER;\n        this.popoverPoint = Point.LEFT_BOTTOM;\n        break;\n      case 'top-left':\n        this.anchorPoint = Point.TOP_CENTER;\n        this.popoverPoint = Point.RIGHT_BOTTOM;\n        break;\n      case 'bottom-right':\n        this.anchorPoint = Point.BOTTOM_CENTER;\n        this.popoverPoint = Point.LEFT_TOP;\n        break;\n      case 'bottom-left':\n        this.anchorPoint = Point.BOTTOM_CENTER;\n        this.popoverPoint = Point.RIGHT_TOP;\n        break;\n      case 'right':\n        this.anchorPoint = Point.RIGHT_CENTER;\n        this.popoverPoint = Point.LEFT_TOP;\n        break;\n      case 'left':\n        this.anchorPoint = Point.LEFT_CENTER;\n        this.popoverPoint = Point.RIGHT_TOP;\n        break;\n      default:\n        assertNever(newPosition);\n    }\n  }\n\n  @Input('clrSize')\n  get size() {\n    return this._size;\n  }\n  set size(value: string) {\n    const oldSize = this._size;\n    const newSize = SIZES.includes(value) ? value : defaultSize;\n\n    this._size = newSize;\n    this.updateCssClass({ oldClass: `tooltip-${oldSize}`, newClass: `tooltip-${newSize}` });\n  }\n\n  ngOnInit() {\n    this.size = this.size || defaultSize;\n    this.position = this.position || defaultPosition;\n  }\n\n  @HostListener('mouseenter')\n  private onMouseEnter() {\n    this.tooltipMouseService.onMouseEnterContent();\n  }\n\n  @HostListener('mouseleave')\n  private onMouseLeave() {\n    this.tooltipMouseService.onMouseLeaveContent();\n  }\n\n  private updateCssClass({ oldClass, newClass }: { oldClass: string; newClass: string }) {\n    this.renderer.removeClass(this.el.nativeElement, oldClass);\n    this.renderer.addClass(this.el.nativeElement, newClass);\n  }\n}\n"]}