UNPKG

@hxui/angular

Version:

An Angular library based on the [HXUI design system](https://hxui.io).

135 lines 14.6 kB
import { ChangeDetectorRef, Component, Input, TemplateRef } from '@angular/core'; import { Subject } from 'rxjs'; import { Context, Visibility } from '../enums'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class TooltipContentComponent { constructor(_changeDetectionRef) { this._changeDetectionRef = _changeDetectionRef; this.placement = 'bottom'; this.context = Context.None; this.maxWidth = 200; /** Enums to be used in the template **/ this.contextEnum = Context; this.visibilityEnum = Visibility; this.visibility = Visibility.Hidden; /** Subject for notifying that the tooltip has been hidden from the view */ this._onHide = new Subject(); } /** * Shows the tooltip * @param delay Amount of milliseconds to the delay showing the tooltip. */ show(delay) { // Cancel the delayed hide if it is scheduled if (this._hideTimeoutId) { clearTimeout(this._hideTimeoutId); } this._showTimeoutId = window.setTimeout(() => { // Schedule for change detection incase the tooltip is used within a // component with OnPush change detection this._changeDetectionRef.markForCheck(); this.visibility = Visibility.Visible; }, delay); } /** * Hide the tooltip after the provided delay in ms. * @param delay Amount of milliseconds to delay hiding the tooltip. */ hide(delay) { // Cancel the delayed show if it is scheduled if (this._showTimeoutId) { clearTimeout(this._showTimeoutId); } this._hideTimeoutId = window.setTimeout(() => { this.visibility = Visibility.Hidden; this._onHide.next(true); }, delay); } /** Returns an observable that notifies when the tooltip has been hidden from view. */ afterHidden() { return this._onHide.asObservable(); } isVisible() { return this.visibility === Visibility.Visible; } } TooltipContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TooltipContentComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); TooltipContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: TooltipContentComponent, selector: "hx-tooltip-content, hxa-tooltip-content", inputs: { content: "content", placement: "placement", context: "context", maxWidth: "maxWidth", dynamicContent: "dynamicContent" }, ngImport: i0, template: ` <div class="hxui-reset"> <div class="hx-tooltip is-{{ placement }}" [class.is-active]="visibility === visibilityEnum.Visible" [class.is-success]="context === contextEnum.Success" [class.is-warning]="context === contextEnum.Warning" [class.is-danger]="context === contextEnum.Danger" [class.is-white]="context === contextEnum.White" role="tooltip" > <div *ngIf="!dynamicContent" class="hx-tooltip-content" [innerHtml]="content" [style.max-width.px]="maxWidth" ></div> <div *ngIf="dynamicContent" class="hx-tooltip-content" [style.max-width.px]="maxWidth" > <ng-container [ngTemplateOutlet]="dynamicContent"></ng-container> </div> </div> </div> `, isInline: true, styles: [".hxa-tooltip-panel{display:flex;position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;max-width:100%;max-height:100%}\n", ".hx-tooltip.is-left,.hx-tooltip.is-left:before{margin-right:.5rem}\n", ".hx-tooltip.is-right,.hx-tooltip.is-right:before{margin-left:.5rem}\n", ".hx-tooltip.is-bottom,.hx-tooltip.is-bottom:before{margin-top:.5rem}\n", ".hx-tooltip.is-top,.hx-tooltip.is-top:before{margin-bottom:.5rem}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TooltipContentComponent, decorators: [{ type: Component, args: [{ selector: 'hx-tooltip-content, hxa-tooltip-content', template: ` <div class="hxui-reset"> <div class="hx-tooltip is-{{ placement }}" [class.is-active]="visibility === visibilityEnum.Visible" [class.is-success]="context === contextEnum.Success" [class.is-warning]="context === contextEnum.Warning" [class.is-danger]="context === contextEnum.Danger" [class.is-white]="context === contextEnum.White" role="tooltip" > <div *ngIf="!dynamicContent" class="hx-tooltip-content" [innerHtml]="content" [style.max-width.px]="maxWidth" ></div> <div *ngIf="dynamicContent" class="hx-tooltip-content" [style.max-width.px]="maxWidth" > <ng-container [ngTemplateOutlet]="dynamicContent"></ng-container> </div> </div> </div> `, styles: [ '.hxa-tooltip-panel { display:flex; position: absolute; pointer-events: auto; box-sizing: border-box; z-index: 1000; max-width: 100%; max-height: 100%;}', '.hx-tooltip.is-left, .hx-tooltip.is-left:before{ margin-right:.5rem; }', '.hx-tooltip.is-right, .hx-tooltip.is-right:before{ margin-left:.5rem; }', '.hx-tooltip.is-bottom, .hx-tooltip.is-bottom:before{ margin-top:.5rem; }', '.hx-tooltip.is-top, .hx-tooltip.is-top:before{ margin-bottom:.5rem; }' ] }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { content: [{ type: Input }], placement: [{ type: Input }], context: [{ type: Input }], maxWidth: [{ type: Input }], dynamicContent: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-content.component.js","sourceRoot":"","sources":["../../../../../projects/hx-ui/src/lib/tooltip/tooltip-content.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,KAAK,EACL,WAAW,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;;;AAwC/C,MAAM,OAAO,uBAAuB;IA+BlC,YAAoB,mBAAsC;QAAtC,wBAAmB,GAAnB,mBAAmB,CAAmB;QA1B1D,cAAS,GAAwC,QAAQ,CAAC;QAG1D,YAAO,GAAY,OAAO,CAAC,IAAI,CAAC;QAGhC,aAAQ,GAAG,GAAG,CAAC;QAKf,wCAAwC;QACxC,gBAAW,GAAG,OAAO,CAAC;QACtB,mBAAc,GAAG,UAAU,CAAC;QAE5B,eAAU,GAAe,UAAU,CAAC,MAAM,CAAC;QAE3C,2EAA2E;QAC1D,YAAO,GAAiB,IAAI,OAAO,EAAE,CAAC;IAQM,CAAC;IAE9D;;;OAGG;IACH,IAAI,CAAC,KAAa;QAChB,6CAA6C;QAC7C,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YAC3C,oEAAoE;YACpE,yCAAyC;YACzC,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC;QACvC,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAED;;;OAGG;IACH,IAAI,CAAC,KAAa;QAChB,6CAA6C;QAC7C,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACnC;QAED,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YAC3C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC;YACpC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAED,sFAAsF;IACtF,WAAW;QACT,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,UAAU,KAAK,UAAU,CAAC,OAAO,CAAC;IAChD,CAAC;;qHAzEU,uBAAuB;yGAAvB,uBAAuB,mNAnCxB;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BT;4FASU,uBAAuB;kBArCnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,yCAAyC;oBACnD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BT;oBACD,MAAM,EAAE;wBACN,yJAAyJ;wBACzJ,wEAAwE;wBACxE,yEAAyE;wBACzE,0EAA0E;wBAC1E,uEAAuE;qBACxE;iBACF;wGAGC,OAAO;sBADN,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIN,QAAQ;sBADP,KAAK;gBAIN,cAAc;sBADb,KAAK","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Input,\r\n  TemplateRef\r\n} from '@angular/core';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { Context, Visibility } from '../enums';\r\nimport { TooltipDynamicContentDirective } from './tooltip-dynamic-content.directive';\r\n\r\n@Component({\r\n  selector: 'hx-tooltip-content, hxa-tooltip-content',\r\n  template: `\r\n    <div class=\"hxui-reset\">\r\n      <div\r\n        class=\"hx-tooltip is-{{ placement }}\"\r\n        [class.is-active]=\"visibility === visibilityEnum.Visible\"\r\n        [class.is-success]=\"context === contextEnum.Success\"\r\n        [class.is-warning]=\"context === contextEnum.Warning\"\r\n        [class.is-danger]=\"context === contextEnum.Danger\"\r\n        [class.is-white]=\"context === contextEnum.White\"\r\n        role=\"tooltip\"\r\n      >\r\n        <div\r\n          *ngIf=\"!dynamicContent\"\r\n          class=\"hx-tooltip-content\"\r\n          [innerHtml]=\"content\"\r\n          [style.max-width.px]=\"maxWidth\"\r\n        ></div>\r\n        <div\r\n          *ngIf=\"dynamicContent\"\r\n          class=\"hx-tooltip-content\"\r\n          [style.max-width.px]=\"maxWidth\"\r\n        >\r\n          <ng-container [ngTemplateOutlet]=\"dynamicContent\"></ng-container>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  styles: [\r\n    '.hxa-tooltip-panel { display:flex; position: absolute; pointer-events: auto; box-sizing: border-box; z-index: 1000; max-width: 100%; max-height: 100%;}',\r\n    '.hx-tooltip.is-left, .hx-tooltip.is-left:before{ margin-right:.5rem; }',\r\n    '.hx-tooltip.is-right, .hx-tooltip.is-right:before{ margin-left:.5rem; }',\r\n    '.hx-tooltip.is-bottom, .hx-tooltip.is-bottom:before{ margin-top:.5rem; }',\r\n    '.hx-tooltip.is-top, .hx-tooltip.is-top:before{ margin-bottom:.5rem; }'\r\n  ]\r\n})\r\nexport class TooltipContentComponent {\r\n  @Input()\r\n  content: string;\r\n\r\n  @Input()\r\n  placement: 'top' | 'bottom' | 'left' | 'right' = 'bottom';\r\n\r\n  @Input()\r\n  context: Context = Context.None;\r\n\r\n  @Input()\r\n  maxWidth = 200;\r\n\r\n  @Input()\r\n  dynamicContent: TemplateRef<TooltipDynamicContentDirective>;\r\n\r\n  /** Enums to be used in the template **/\r\n  contextEnum = Context;\r\n  visibilityEnum = Visibility;\r\n\r\n  visibility: Visibility = Visibility.Hidden;\r\n\r\n  /** Subject for notifying that the tooltip has been hidden from the view */\r\n  private readonly _onHide: Subject<any> = new Subject();\r\n\r\n  /** The timeout ID of any current timer set to show the tooltip */\r\n  private _showTimeoutId: number;\r\n\r\n  /** The timeout ID of any current timer set to hide the tooltip */\r\n  private _hideTimeoutId: number;\r\n\r\n  constructor(private _changeDetectionRef: ChangeDetectorRef) {}\r\n\r\n  /**\r\n   * Shows the tooltip\r\n   * @param delay Amount of milliseconds to the delay showing the tooltip.\r\n   */\r\n  show(delay: number): void {\r\n    // Cancel the delayed hide if it is scheduled\r\n    if (this._hideTimeoutId) {\r\n      clearTimeout(this._hideTimeoutId);\r\n    }\r\n    this._showTimeoutId = window.setTimeout(() => {\r\n      // Schedule for change detection incase the tooltip is used within a\r\n      // component with OnPush change detection\r\n      this._changeDetectionRef.markForCheck();\r\n      this.visibility = Visibility.Visible;\r\n    }, delay);\r\n  }\r\n\r\n  /**\r\n   * Hide the tooltip after the provided delay in ms.\r\n   * @param delay Amount of milliseconds to delay hiding the tooltip.\r\n   */\r\n  hide(delay: number): void {\r\n    // Cancel the delayed show if it is scheduled\r\n    if (this._showTimeoutId) {\r\n      clearTimeout(this._showTimeoutId);\r\n    }\r\n\r\n    this._hideTimeoutId = window.setTimeout(() => {\r\n      this.visibility = Visibility.Hidden;\r\n      this._onHide.next(true);\r\n    }, delay);\r\n  }\r\n\r\n  /** Returns an observable that notifies when the tooltip has been hidden from view. */\r\n  afterHidden(): Observable<void> {\r\n    return this._onHide.asObservable();\r\n  }\r\n\r\n  isVisible(): boolean {\r\n    return this.visibility === Visibility.Visible;\r\n  }\r\n}\r\n"]}