UNPKG

truly-ui

Version:

Web Components for Desktop Applications.

128 lines 14.4 kB
import { Component, ViewChild } from '@angular/core'; import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay'; import { OverlayAnimation } from '../../core/directives/overlay-animation'; import * as i0 from "@angular/core"; import * as i1 from "@angular/cdk/overlay"; import * as i2 from "../tooltip"; export class TlToolTipContainer { setOptions(options) { this.options = options; } setElement(element) { this.element = element; } ngAfterContentInit() { this.connectedOverlay.origin = new CdkOverlayOrigin(this.element); this.getPositionsByPlacement(); } getPositionsByPlacement() { const placements = { 'left-top': () => this.setLeftTop(), 'left-center': () => this.setLeftCenter(), 'left-bottom': () => this.setLeftBottom(), 'right-top': () => this.setRightTop(), 'right-center': () => this.setRightCenter(), 'right-bottom': () => this.setRightBottom(), 'top-center': () => this.setTopCenter(), 'bottom-center': () => this.setBottomCenter() }; if (placements[this.options.placement]) { placements[this.options.placement](); } } setBottomCenter() { this.connectedOverlay.positions = [{ originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top' }]; } setTopCenter() { this.connectedOverlay.positions = [{ originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom' }]; } setRightCenter() { this.connectedOverlay.positions = [{ originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' }]; } setRightTop() { this.connectedOverlay.positions = [{ originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top' }]; } setRightBottom() { this.connectedOverlay.positions = [{ originX: 'end', originY: 'bottom', overlayX: 'start', overlayY: 'bottom' }]; } setLeftBottom() { this.connectedOverlay.positions = [{ originX: 'start', originY: 'bottom', overlayX: 'end', overlayY: 'bottom' }]; } setLeftTop() { this.connectedOverlay.positions = [{ originX: 'start', originY: 'top', overlayX: 'end', overlayY: 'top' }]; } setLeftCenter() { this.connectedOverlay.positions = [{ originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' }]; } } /** @nocollapse */ TlToolTipContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TlToolTipContainer, deps: [], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ TlToolTipContainer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TlToolTipContainer, selector: "tl-tooltip-container", viewQueries: [{ propertyName: "tooltip", first: true, predicate: ["tooltip"], descendants: true, static: true }, { propertyName: "connectedOverlay", first: true, predicate: CdkConnectedOverlay, descendants: true, static: true }], ngImport: i0, template: ` <ng-template cdkConnectedOverlay [cdkConnectedOverlayHasBackdrop]="false" [cdkConnectedOverlayBackdropClass]="'cdk-overlay-transparent-backdrop'" [cdkConnectedOverlayOpen]="true"> <tl-tooltip @overlay [options]="options"></tl-tooltip> </ng-template> `, isInline: true, dependencies: [{ kind: "directive", type: i1.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "component", type: i2.TlToolTip, selector: "tl-tooltip", inputs: ["options"] }], animations: [OverlayAnimation] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TlToolTipContainer, decorators: [{ type: Component, args: [{ selector: 'tl-tooltip-container', template: ` <ng-template cdkConnectedOverlay [cdkConnectedOverlayHasBackdrop]="false" [cdkConnectedOverlayBackdropClass]="'cdk-overlay-transparent-backdrop'" [cdkConnectedOverlayOpen]="true"> <tl-tooltip @overlay [options]="options"></tl-tooltip> </ng-template> `, animations: [OverlayAnimation], }] }], propDecorators: { tooltip: [{ type: ViewChild, args: ['tooltip', { static: true }] }], connectedOverlay: [{ type: ViewChild, args: [CdkConnectedOverlay, { static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-container.js","sourceRoot":"","sources":["../../../../../projects/truly-ui/src/components/tooltip/parts/tooltip-container.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ViewChild } from '@angular/core';\nimport { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport { TooltipOptions } from '../tooltipOptions';\nimport { OverlayAnimation } from '../../core/directives/overlay-animation';\n\n@Component( {\n  selector: 'tl-tooltip-container',\n  template: `\n    <ng-template cdkConnectedOverlay\n                 [cdkConnectedOverlayHasBackdrop]=\"false\"\n                 [cdkConnectedOverlayBackdropClass]=\"'cdk-overlay-transparent-backdrop'\"\n                 [cdkConnectedOverlayOpen]=\"true\">\n      <tl-tooltip @overlay [options]=\"options\"></tl-tooltip>\n    </ng-template>\n  `,\n  animations: [OverlayAnimation],\n} )\nexport class TlToolTipContainer implements AfterContentInit {\n\n  @ViewChild( 'tooltip', {static: true} ) tooltip;\n\n  @ViewChild( CdkConnectedOverlay, {static: true} ) connectedOverlay: CdkConnectedOverlay;\n\n  public options: TooltipOptions;\n\n  private element;\n\n  setOptions( options: TooltipOptions ) {\n    this.options = options;\n  }\n\n  setElement( element ) {\n    this.element = element;\n  }\n\n  ngAfterContentInit() {\n    this.connectedOverlay.origin = new CdkOverlayOrigin( this.element );\n    this.getPositionsByPlacement();\n  }\n\n  getPositionsByPlacement() {\n    const placements = {\n      'left-top': () => this.setLeftTop(),\n      'left-center' : () => this.setLeftCenter(),\n      'left-bottom' : () => this.setLeftBottom(),\n      'right-top': () => this.setRightTop(),\n      'right-center': () => this.setRightCenter(),\n      'right-bottom': () => this.setRightBottom(),\n      'top-center': () => this.setTopCenter(),\n      'bottom-center': () => this.setBottomCenter()\n    };\n    if (placements[this.options.placement]) {\n      placements[this.options.placement]();\n    }\n  }\n\n  setBottomCenter() {\n    this.connectedOverlay.positions = [ {\n      originX: 'center',\n      originY: 'bottom',\n      overlayX: 'center',\n      overlayY: 'top'\n    } ];\n  }\n\n  setTopCenter() {\n    this.connectedOverlay.positions = [ {\n      originX: 'center',\n      originY: 'top',\n      overlayX: 'center',\n      overlayY: 'bottom'\n    } ];\n  }\n\n  setRightCenter() {\n    this.connectedOverlay.positions = [ {\n      originX: 'end',\n      originY: 'center',\n      overlayX: 'start',\n      overlayY: 'center'\n    } ];\n  }\n\n  setRightTop() {\n    this.connectedOverlay.positions = [ {\n      originX: 'end',\n      originY: 'top',\n      overlayX: 'start',\n      overlayY: 'top'\n    } ];\n  }\n\n  setRightBottom() {\n    this.connectedOverlay.positions = [ {\n      originX: 'end',\n      originY: 'bottom',\n      overlayX: 'start',\n      overlayY: 'bottom'\n    } ];\n  }\n\n  setLeftBottom() {\n    this.connectedOverlay.positions = [ {\n      originX: 'start',\n      originY: 'bottom',\n      overlayX: 'end',\n      overlayY: 'bottom'\n    } ];\n  }\n\n  setLeftTop() {\n    this.connectedOverlay.positions = [ {\n      originX: 'start',\n      originY: 'top',\n      overlayX: 'end',\n      overlayY: 'top'\n    } ];\n  }\n\n  setLeftCenter() {\n    this.connectedOverlay.positions = [ {\n      originX: 'start',\n      originY: 'center',\n      overlayX: 'end',\n      overlayY: 'center'\n    } ];\n  }\n\n}\n"]}