@alauda/ui 6.5.8-beta → 6.5.8-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/tooltip/base-tooltip.mjs +52 -2
- package/esm2020/tooltip/tooltip.component.mjs +9 -5
- package/fesm2015/alauda-ui.mjs +59 -5
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +59 -5
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/package.json +1 -1
- package/tooltip/base-tooltip.d.ts +1 -0
- package/tooltip/tooltip.component.d.ts +2 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { OverlayConfig } from '@angular/cdk/overlay';
|
|
2
2
|
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
3
|
import { Directive, EventEmitter, } from '@angular/core';
|
|
4
|
-
import { ReplaySubject, merge, debounceTime, takeUntil, first, filter, Subject, } from 'rxjs';
|
|
4
|
+
import { ReplaySubject, merge, debounceTime, takeUntil, first, filter, Subject, delay, } from 'rxjs';
|
|
5
5
|
import { sleep } from '../utils';
|
|
6
6
|
import { TooltipComponent } from './tooltip.component';
|
|
7
7
|
import { TooltipTrigger } from './tooltip.types';
|
|
@@ -97,6 +97,53 @@ export class BaseTooltip {
|
|
|
97
97
|
get isCreated() {
|
|
98
98
|
return !!this.overlayRef;
|
|
99
99
|
}
|
|
100
|
+
_updateTransformOrigin() {
|
|
101
|
+
// @ts-ignore
|
|
102
|
+
const positionStrategy = this.overlayRef._positionStrategy;
|
|
103
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
104
|
+
const hasExactPosition = positionStrategy._hasExactPosition(); // 是不是应用了精确定位
|
|
105
|
+
if (!hasExactPosition) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
// 如果是精确定位,也就是预设位置空间不足以承载弹出元素,被重新指定新的弹出位置
|
|
109
|
+
// @ts-ignore
|
|
110
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
111
|
+
const paneRect = positionStrategy._pane.getBoundingClientRect(); // 弹出pane元素Rect
|
|
112
|
+
const triggerElReact = this.elRef.nativeElement.getBoundingClientRect(); // 触发点Rect
|
|
113
|
+
// @ts-ignore
|
|
114
|
+
const position = positionStrategy._lastPosition; // 当前策略位置(调整后的最佳的)
|
|
115
|
+
let xOrigin;
|
|
116
|
+
const yOrigin = position.overlayY;
|
|
117
|
+
if (position.overlayX === 'center') {
|
|
118
|
+
xOrigin = 'center';
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
xOrigin = position.overlayX === 'start' ? 'left' : 'right';
|
|
122
|
+
}
|
|
123
|
+
const origins = [xOrigin, yOrigin];
|
|
124
|
+
if (xOrigin === 'center' ||
|
|
125
|
+
(xOrigin === 'left' && paneRect.left !== triggerElReact.right) || // 位置没有被完全被颠倒的
|
|
126
|
+
(xOrigin === 'right' && paneRect.right !== triggerElReact.left) // 位置没有被完全被颠倒的
|
|
127
|
+
) {
|
|
128
|
+
const originLeft = triggerElReact.left - paneRect.left + triggerElReact.width / 2;
|
|
129
|
+
origins[0] = Math.min(originLeft, paneRect.width) + 'px';
|
|
130
|
+
}
|
|
131
|
+
if (yOrigin === 'center' ||
|
|
132
|
+
(yOrigin === 'top' && paneRect.top !== triggerElReact.bottom) || // 位置没有被完全被颠倒的
|
|
133
|
+
(yOrigin === 'bottom' && paneRect.bottom !== triggerElReact.top) // 位置没有被完全被颠倒的
|
|
134
|
+
) {
|
|
135
|
+
const originTop = triggerElReact.top - paneRect.top + triggerElReact.height / 2;
|
|
136
|
+
origins[1] = Math.min(originTop, paneRect.height) + 'px';
|
|
137
|
+
}
|
|
138
|
+
// @ts-ignore
|
|
139
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
140
|
+
const aniEls = positionStrategy._boundingBox.querySelectorAll(
|
|
141
|
+
// @ts-ignore
|
|
142
|
+
positionStrategy._transformOriginSelector);
|
|
143
|
+
[...aniEls].forEach(el => {
|
|
144
|
+
el.style.transformOrigin = origins.join(' ');
|
|
145
|
+
});
|
|
146
|
+
}
|
|
100
147
|
_createTooltip() {
|
|
101
148
|
if (this.disabled || this.isCreated) {
|
|
102
149
|
return;
|
|
@@ -116,6 +163,9 @@ export class BaseTooltip {
|
|
|
116
163
|
this.componentIns.hide$.pipe(takeUntil(this.destroy$)).subscribe(() => {
|
|
117
164
|
this._disposeTooltip();
|
|
118
165
|
});
|
|
166
|
+
merge(this.componentIns.beforeHide$, this.componentIns.beforeShow$.pipe(delay(0)))
|
|
167
|
+
.pipe(takeUntil(this.destroy$))
|
|
168
|
+
.subscribe(this._updateTransformOrigin.bind(this));
|
|
119
169
|
if (this.trigger === TooltipTrigger.Hover) {
|
|
120
170
|
this.componentIns.hover$
|
|
121
171
|
.pipe(takeUntil(this.componentIns.destroy$))
|
|
@@ -266,4 +316,4 @@ BaseTooltip.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "
|
|
|
266
316
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: BaseTooltip, decorators: [{
|
|
267
317
|
type: Directive
|
|
268
318
|
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }]; } });
|
|
269
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-tooltip.js","sourceRoot":"","sources":["../../../src/tooltip/base-tooltip.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  NgZone,\n  OnDestroy,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport {\n  ReplaySubject,\n  merge,\n  debounceTime,\n  takeUntil,\n  first,\n  filter,\n  Subject,\n} from 'rxjs';\n\nimport { sleep } from '../utils';\n\nimport { TooltipComponent } from './tooltip.component';\nimport { TooltipTrigger, TooltipType } from './tooltip.types';\nimport { getOriginPosition, getOverlayPosition } from './utils';\n\nexport interface TooltipInterface {\n  content: string | TemplateRef<any>;\n  context: any;\n  class: string;\n  type: TooltipType;\n  position: string;\n  trigger: TooltipTrigger;\n  disabled: boolean;\n  hideOnClick: boolean;\n  showed: EventEmitter<void>;\n  hided: EventEmitter<void>;\n}\n\nexport const DISPLAY_DELAY = 50;\nexport const HIDDEN_DELAY = 150;\n\n@Directive()\nexport class BaseTooltip<T = any>\n  implements TooltipInterface, AfterViewInit, OnDestroy\n{\n  set content(value: string | TemplateRef<any>) {\n    this._content = value;\n    this.inputContent$$.next(value);\n  }\n\n  get content() {\n    return this._content;\n  }\n\n  set context(value: T) {\n    this._context = value;\n    this.inputContext$$.next(value);\n  }\n\n  get context() {\n    return this._context;\n  }\n\n  set class(value: string) {\n    this.inputClass$$.next(value);\n  }\n\n  set type(value: TooltipType) {\n    if (!value) {\n      return;\n    }\n    this.inputType$$.next(value);\n  }\n\n  set position(value: string) {\n    if (!value || value === this._position) {\n      return;\n    }\n    this._position = value;\n    this.inputPosition$$.next(value);\n    this._disposeTooltip();\n  }\n\n  get position() {\n    return this._position;\n  }\n\n  set trigger(value) {\n    if (!value || value === this._trigger) {\n      return;\n    }\n    this._trigger = value;\n    this._disposeTooltip();\n    this.ngZone.run(this.updateListeners, this);\n  }\n\n  get trigger() {\n    return this._trigger;\n  }\n\n  set disabled(value) {\n    this._disabled = value;\n    if (value) {\n      this._disposeTooltip();\n    }\n  }\n\n  get disabled() {\n    return this._disabled;\n  }\n\n  hideOnClick = false;\n  disableAnimation = true;\n\n  showed = new EventEmitter<void>();\n  hided = new EventEmitter<void>();\n\n  overlayRef: OverlayRef;\n  protected componentClass: ComponentType<any> = TooltipComponent;\n  protected componentIns: TooltipComponent;\n  protected hostHovered = false;\n  protected tooltipHovered = false;\n  protected listeners: Array<() => void> = [];\n  protected unlistenBody: () => void;\n\n  protected inputContent$$ = new ReplaySubject<string | TemplateRef<any>>(1);\n  protected inputType$$ = new ReplaySubject<TooltipType>(1);\n  protected inputPosition$$ = new ReplaySubject<string>(1);\n  protected inputClass$$ = new ReplaySubject<string>(1);\n  protected inputContext$$ = new ReplaySubject<any>(1);\n\n  protected tooltipChanged$ = merge(\n    this.inputContent$$,\n    this.inputType$$,\n    this.inputPosition$$,\n    this.inputClass$$,\n    this.inputContext$$,\n  );\n\n  protected destroy$ = new Subject();\n\n  protected _position = 'top';\n  protected _trigger = TooltipTrigger.Hover;\n  protected _disabled = false;\n  protected _context: T;\n  protected _content: string | TemplateRef<unknown>;\n\n  get isCreated() {\n    return !!this.overlayRef;\n  }\n\n  constructor(\n    protected overlay: Overlay,\n    protected viewContainerRef: ViewContainerRef,\n    protected elRef: ElementRef<HTMLInputElement>,\n    protected renderer: Renderer2,\n    protected cdr: ChangeDetectorRef,\n    protected ngZone: NgZone,\n  ) {\n    this.tooltipChanged$.pipe(debounceTime(0)).subscribe(() => {\n      this.updatePosition();\n    });\n  }\n\n  _createTooltip() {\n    if (this.disabled || this.isCreated) {\n      return;\n    }\n    this._disposeTooltip();\n    this.overlayRef = this.createOverlay();\n    const portal = new ComponentPortal(\n      this.componentClass,\n      this.viewContainerRef,\n    );\n    this.componentIns = this.overlayRef.attach(portal).instance;\n    this.componentIns.setupInputs({\n      inputClass$: this.inputClass$$.asObservable(),\n      inputContent$: this.inputContent$$.asObservable(),\n      inputContext$: this.inputContext$$.asObservable(),\n      inputPosition$: this.inputPosition$$.asObservable(),\n      inputType$: this.inputType$$.asObservable(),\n      disableAnimation: this.disableAnimation,\n    });\n    this.componentIns.hide$.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this._disposeTooltip();\n    });\n\n    if (this.trigger === TooltipTrigger.Hover) {\n      this.componentIns.hover$\n        .pipe(takeUntil(this.componentIns.destroy$))\n        .subscribe(hovered => {\n          this.onTooltipHovered(hovered);\n        });\n    }\n    if (\n      this.trigger === TooltipTrigger.Hover ||\n      this.trigger === TooltipTrigger.Click\n    ) {\n      this.unlistenBody = this.renderer.listen(\n        'body',\n        'click',\n        this.onBodyClick.bind(this),\n      );\n    }\n\n    this.componentIns?.show();\n    this.cdr.markForCheck();\n\n    this.showed.emit();\n  }\n\n  _disposeTooltip() {\n    this.componentIns?.animating$$\n      .pipe(\n        filter(animating => !animating),\n        first(),\n      )\n      .subscribe(() => {\n        if (this.overlayRef) {\n          this.overlayRef.dispose();\n          this.overlayRef = null;\n          this.componentIns = null;\n          this.tooltipHovered = false;\n          if (this.unlistenBody) {\n            this.unlistenBody();\n            this.unlistenBody = null;\n          }\n          this.hided.emit();\n        }\n      });\n  }\n\n  toggleTooltip() {\n    if (this.isCreated) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  show() {\n    this._createTooltip();\n  }\n\n  hide() {\n    this.componentIns?.hide();\n  }\n\n  updatePosition() {\n    if (this.overlayRef) {\n      this.overlayRef.updatePosition();\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.trigger === TooltipTrigger.Hover) {\n      this.updateListeners();\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroy$.next(null);\n    this.destroy$.complete();\n    this._disposeTooltip();\n    this.clearListeners();\n  }\n\n  protected updateListeners() {\n    this.clearListeners();\n    switch (this.trigger) {\n      case TooltipTrigger.Click:\n        this.listeners.push(\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'click',\n            this.onClick.bind(this) as () => void,\n          ),\n        );\n        break;\n      case TooltipTrigger.Hover:\n        this.listeners.push(\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'mouseenter',\n            this.onMouseEnter.bind(this) as () => void,\n          ),\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'mouseleave',\n            this.onMouseLeave.bind(this) as () => void,\n          ),\n        );\n        break;\n      case TooltipTrigger.Focus:\n        this.listeners.push(\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'focus',\n            this.onFocus.bind(this),\n          ),\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'blur',\n            this.onBlur.bind(this),\n          ),\n        );\n        break;\n      case TooltipTrigger.Manual:\n        break;\n    }\n  }\n\n  protected clearListeners() {\n    this.listeners.forEach(unListen => {\n      unListen();\n    });\n    this.listeners = [];\n  }\n\n  protected createOverlay(): OverlayRef {\n    const originPosition = getOriginPosition(this.position);\n    const overlayPosition = getOverlayPosition(this.position);\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(this.elRef)\n      .withGrowAfterOpen(true)\n      .withTransformOriginOn('.aui-tooltip')\n      .withPositions([\n        { ...originPosition.main, ...overlayPosition.main },\n        { ...originPosition.fallback, ...overlayPosition.fallback },\n      ]);\n\n    const scrollStrategy = this.overlay.scrollStrategies.reposition();\n\n    const config = new OverlayConfig({\n      positionStrategy,\n      scrollStrategy,\n    });\n    return this.overlay.create(config);\n  }\n\n  protected async onMouseEnter() {\n    this.hostHovered = true;\n    if (!this.isCreated) {\n      await sleep(DISPLAY_DELAY);\n      if (this.hostHovered) {\n        this._createTooltip();\n      }\n    }\n  }\n\n  protected async onMouseLeave() {\n    this.hostHovered = false;\n    await sleep(HIDDEN_DELAY);\n    if (!this.tooltipHovered && !this.hostHovered) {\n      this.componentIns?.hide();\n    }\n  }\n\n  protected async onTooltipHovered(hovered: boolean) {\n    this.tooltipHovered = hovered;\n    if (!hovered) {\n      await sleep(HIDDEN_DELAY);\n      if (!this.tooltipHovered && !this.hostHovered) {\n        this.componentIns?.hide();\n      }\n    }\n  }\n\n  protected onClick() {\n    this.toggleTooltip();\n  }\n\n  protected onBodyClick(event: Event) {\n    if (\n      !this.elRef.nativeElement.contains(event.target as Node) &&\n      (this.hideOnClick ||\n        !this.componentIns.elRef.nativeElement.contains(event.target as Node))\n    ) {\n      this.componentIns?.hide();\n    }\n  }\n\n  protected onFocus() {\n    this._createTooltip();\n  }\n\n  protected onBlur() {\n    this.componentIns?.hide();\n  }\n}\n"]}
|
|
319
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-tooltip.js","sourceRoot":"","sources":["../../../src/tooltip/base-tooltip.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  NgZone,\n  OnDestroy,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport {\n  ReplaySubject,\n  merge,\n  debounceTime,\n  takeUntil,\n  first,\n  filter,\n  Subject,\n  delay,\n} from 'rxjs';\n\nimport { sleep } from '../utils';\n\nimport { TooltipComponent } from './tooltip.component';\nimport { TooltipTrigger, TooltipType } from './tooltip.types';\nimport { getOriginPosition, getOverlayPosition } from './utils';\n\nexport interface TooltipInterface {\n  content: string | TemplateRef<any>;\n  context: any;\n  class: string;\n  type: TooltipType;\n  position: string;\n  trigger: TooltipTrigger;\n  disabled: boolean;\n  hideOnClick: boolean;\n  showed: EventEmitter<void>;\n  hided: EventEmitter<void>;\n}\n\nexport const DISPLAY_DELAY = 50;\nexport const HIDDEN_DELAY = 150;\n\n@Directive()\nexport class BaseTooltip<T = any>\n  implements TooltipInterface, AfterViewInit, OnDestroy\n{\n  set content(value: string | TemplateRef<any>) {\n    this._content = value;\n    this.inputContent$$.next(value);\n  }\n\n  get content() {\n    return this._content;\n  }\n\n  set context(value: T) {\n    this._context = value;\n    this.inputContext$$.next(value);\n  }\n\n  get context() {\n    return this._context;\n  }\n\n  set class(value: string) {\n    this.inputClass$$.next(value);\n  }\n\n  set type(value: TooltipType) {\n    if (!value) {\n      return;\n    }\n    this.inputType$$.next(value);\n  }\n\n  set position(value: string) {\n    if (!value || value === this._position) {\n      return;\n    }\n    this._position = value;\n    this.inputPosition$$.next(value);\n    this._disposeTooltip();\n  }\n\n  get position() {\n    return this._position;\n  }\n\n  set trigger(value) {\n    if (!value || value === this._trigger) {\n      return;\n    }\n    this._trigger = value;\n    this._disposeTooltip();\n    this.ngZone.run(this.updateListeners, this);\n  }\n\n  get trigger() {\n    return this._trigger;\n  }\n\n  set disabled(value) {\n    this._disabled = value;\n    if (value) {\n      this._disposeTooltip();\n    }\n  }\n\n  get disabled() {\n    return this._disabled;\n  }\n\n  hideOnClick = false;\n  disableAnimation = true;\n\n  showed = new EventEmitter<void>();\n  hided = new EventEmitter<void>();\n\n  overlayRef: OverlayRef;\n  protected componentClass: ComponentType<any> = TooltipComponent;\n  protected componentIns: TooltipComponent;\n  protected hostHovered = false;\n  protected tooltipHovered = false;\n  protected listeners: Array<() => void> = [];\n  protected unlistenBody: () => void;\n\n  protected inputContent$$ = new ReplaySubject<string | TemplateRef<any>>(1);\n  protected inputType$$ = new ReplaySubject<TooltipType>(1);\n  protected inputPosition$$ = new ReplaySubject<string>(1);\n  protected inputClass$$ = new ReplaySubject<string>(1);\n  protected inputContext$$ = new ReplaySubject<any>(1);\n\n  protected tooltipChanged$ = merge(\n    this.inputContent$$,\n    this.inputType$$,\n    this.inputPosition$$,\n    this.inputClass$$,\n    this.inputContext$$,\n  );\n\n  protected destroy$ = new Subject();\n\n  protected _position = 'top';\n  protected _trigger = TooltipTrigger.Hover;\n  protected _disabled = false;\n  protected _context: T;\n  protected _content: string | TemplateRef<unknown>;\n\n  get isCreated() {\n    return !!this.overlayRef;\n  }\n\n  constructor(\n    protected overlay: Overlay,\n    protected viewContainerRef: ViewContainerRef,\n    protected elRef: ElementRef<HTMLInputElement>,\n    protected renderer: Renderer2,\n    protected cdr: ChangeDetectorRef,\n    protected ngZone: NgZone,\n  ) {\n    this.tooltipChanged$.pipe(debounceTime(0)).subscribe(() => {\n      this.updatePosition();\n    });\n  }\n\n  private _updateTransformOrigin() {\n    // @ts-ignore\n    const positionStrategy = this.overlayRef._positionStrategy;\n    // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n    const hasExactPosition = positionStrategy._hasExactPosition(); // 是不是应用了精确定位\n    if (!hasExactPosition) {\n      return;\n    }\n    // 如果是精确定位，也就是预设位置空间不足以承载弹出元素，被重新指定新的弹出位置\n    // @ts-ignore\n    // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n    const paneRect = positionStrategy._pane.getBoundingClientRect(); // 弹出pane元素Rect\n    const triggerElReact = this.elRef.nativeElement.getBoundingClientRect(); // 触发点Rect\n\n    // @ts-ignore\n    const position = positionStrategy._lastPosition; // 当前策略位置（调整后的最佳的）\n    let xOrigin: 'left' | 'right' | 'center';\n    const yOrigin: 'top' | 'bottom' | 'center' = position.overlayY;\n    if (position.overlayX === 'center') {\n      xOrigin = 'center';\n    } else {\n      xOrigin = position.overlayX === 'start' ? 'left' : 'right';\n    }\n\n    const origins: string[] = [xOrigin, yOrigin];\n    if (\n      xOrigin === 'center' ||\n      (xOrigin === 'left' && paneRect.left !== triggerElReact.right) || // 位置没有被完全被颠倒的\n      (xOrigin === 'right' && paneRect.right !== triggerElReact.left) // 位置没有被完全被颠倒的\n    ) {\n      const originLeft =\n        triggerElReact.left - paneRect.left + triggerElReact.width / 2;\n      origins[0] = Math.min(originLeft, paneRect.width) + 'px';\n    }\n    if (\n      yOrigin === 'center' ||\n      (yOrigin === 'top' && paneRect.top !== triggerElReact.bottom) || // 位置没有被完全被颠倒的\n      (yOrigin === 'bottom' && paneRect.bottom !== triggerElReact.top) // 位置没有被完全被颠倒的\n    ) {\n      const originTop =\n        triggerElReact.top - paneRect.top + triggerElReact.height / 2;\n      origins[1] = Math.min(originTop, paneRect.height) + 'px';\n    }\n    // @ts-ignore\n    // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n    const aniEls = positionStrategy._boundingBox!.querySelectorAll(\n      // @ts-ignore\n      positionStrategy._transformOriginSelector,\n    );\n    [...aniEls].forEach(el => {\n      el.style.transformOrigin = origins.join(' ');\n    });\n  }\n\n  _createTooltip() {\n    if (this.disabled || this.isCreated) {\n      return;\n    }\n    this._disposeTooltip();\n    this.overlayRef = this.createOverlay();\n    const portal = new ComponentPortal(\n      this.componentClass,\n      this.viewContainerRef,\n    );\n    this.componentIns = this.overlayRef.attach(portal).instance;\n    this.componentIns.setupInputs({\n      inputClass$: this.inputClass$$.asObservable(),\n      inputContent$: this.inputContent$$.asObservable(),\n      inputContext$: this.inputContext$$.asObservable(),\n      inputPosition$: this.inputPosition$$.asObservable(),\n      inputType$: this.inputType$$.asObservable(),\n      disableAnimation: this.disableAnimation,\n    });\n    this.componentIns.hide$.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this._disposeTooltip();\n    });\n    merge(\n      this.componentIns.beforeHide$,\n      this.componentIns.beforeShow$.pipe(delay(0)),\n    )\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(this._updateTransformOrigin.bind(this));\n\n    if (this.trigger === TooltipTrigger.Hover) {\n      this.componentIns.hover$\n        .pipe(takeUntil(this.componentIns.destroy$))\n        .subscribe(hovered => {\n          this.onTooltipHovered(hovered);\n        });\n    }\n    if (\n      this.trigger === TooltipTrigger.Hover ||\n      this.trigger === TooltipTrigger.Click\n    ) {\n      this.unlistenBody = this.renderer.listen(\n        'body',\n        'click',\n        this.onBodyClick.bind(this),\n      );\n    }\n\n    this.componentIns?.show();\n    this.cdr.markForCheck();\n\n    this.showed.emit();\n  }\n\n  _disposeTooltip() {\n    this.componentIns?.animating$$\n      .pipe(\n        filter(animating => !animating),\n        first(),\n      )\n      .subscribe(() => {\n        if (this.overlayRef) {\n          this.overlayRef.dispose();\n          this.overlayRef = null;\n          this.componentIns = null;\n          this.tooltipHovered = false;\n          if (this.unlistenBody) {\n            this.unlistenBody();\n            this.unlistenBody = null;\n          }\n          this.hided.emit();\n        }\n      });\n  }\n\n  toggleTooltip() {\n    if (this.isCreated) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  show() {\n    this._createTooltip();\n  }\n\n  hide() {\n    this.componentIns?.hide();\n  }\n\n  updatePosition() {\n    if (this.overlayRef) {\n      this.overlayRef.updatePosition();\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.trigger === TooltipTrigger.Hover) {\n      this.updateListeners();\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroy$.next(null);\n    this.destroy$.complete();\n    this._disposeTooltip();\n    this.clearListeners();\n  }\n\n  protected updateListeners() {\n    this.clearListeners();\n    switch (this.trigger) {\n      case TooltipTrigger.Click:\n        this.listeners.push(\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'click',\n            this.onClick.bind(this) as () => void,\n          ),\n        );\n        break;\n      case TooltipTrigger.Hover:\n        this.listeners.push(\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'mouseenter',\n            this.onMouseEnter.bind(this) as () => void,\n          ),\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'mouseleave',\n            this.onMouseLeave.bind(this) as () => void,\n          ),\n        );\n        break;\n      case TooltipTrigger.Focus:\n        this.listeners.push(\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'focus',\n            this.onFocus.bind(this),\n          ),\n          this.renderer.listen(\n            this.elRef.nativeElement,\n            'blur',\n            this.onBlur.bind(this),\n          ),\n        );\n        break;\n      case TooltipTrigger.Manual:\n        break;\n    }\n  }\n\n  protected clearListeners() {\n    this.listeners.forEach(unListen => {\n      unListen();\n    });\n    this.listeners = [];\n  }\n\n  protected createOverlay(): OverlayRef {\n    const originPosition = getOriginPosition(this.position);\n    const overlayPosition = getOverlayPosition(this.position);\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(this.elRef)\n      .withGrowAfterOpen(true)\n      .withTransformOriginOn('.aui-tooltip')\n      .withPositions([\n        { ...originPosition.main, ...overlayPosition.main },\n        { ...originPosition.fallback, ...overlayPosition.fallback },\n      ]);\n\n    const scrollStrategy = this.overlay.scrollStrategies.reposition();\n\n    const config = new OverlayConfig({\n      positionStrategy,\n      scrollStrategy,\n    });\n    return this.overlay.create(config);\n  }\n\n  protected async onMouseEnter() {\n    this.hostHovered = true;\n    if (!this.isCreated) {\n      await sleep(DISPLAY_DELAY);\n      if (this.hostHovered) {\n        this._createTooltip();\n      }\n    }\n  }\n\n  protected async onMouseLeave() {\n    this.hostHovered = false;\n    await sleep(HIDDEN_DELAY);\n    if (!this.tooltipHovered && !this.hostHovered) {\n      this.componentIns?.hide();\n    }\n  }\n\n  protected async onTooltipHovered(hovered: boolean) {\n    this.tooltipHovered = hovered;\n    if (!hovered) {\n      await sleep(HIDDEN_DELAY);\n      if (!this.tooltipHovered && !this.hostHovered) {\n        this.componentIns?.hide();\n      }\n    }\n  }\n\n  protected onClick() {\n    this.toggleTooltip();\n  }\n\n  protected onBodyClick(event: Event) {\n    if (\n      !this.elRef.nativeElement.contains(event.target as Node) &&\n      (this.hideOnClick ||\n        !this.componentIns.elRef.nativeElement.contains(event.target as Node))\n    ) {\n      this.componentIns?.hide();\n    }\n  }\n\n  protected onFocus() {\n    this._createTooltip();\n  }\n\n  protected onBlur() {\n    this.componentIns?.hide();\n  }\n}\n"]}
|
|
@@ -16,6 +16,8 @@ export class TooltipComponent {
|
|
|
16
16
|
this.destroy$ = new Subject();
|
|
17
17
|
this.animating$$ = new BehaviorSubject(false);
|
|
18
18
|
this.hide$ = new Subject();
|
|
19
|
+
this.beforeHide$ = new Subject();
|
|
20
|
+
this.beforeShow$ = new Subject();
|
|
19
21
|
}
|
|
20
22
|
ngOnDestroy() {
|
|
21
23
|
this.destroy$.next(null);
|
|
@@ -56,10 +58,12 @@ export class TooltipComponent {
|
|
|
56
58
|
}
|
|
57
59
|
}
|
|
58
60
|
show() {
|
|
61
|
+
this.beforeShow$.next(null);
|
|
59
62
|
this.showHide = 'show';
|
|
60
63
|
this.cdr.markForCheck();
|
|
61
64
|
}
|
|
62
65
|
hide() {
|
|
66
|
+
this.beforeHide$.next(null);
|
|
63
67
|
this.showHide = 'hide';
|
|
64
68
|
this.cdr.markForCheck();
|
|
65
69
|
}
|
|
@@ -75,9 +79,9 @@ TooltipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", versi
|
|
|
75
79
|
opacity: 0,
|
|
76
80
|
transform: 'scale(0)',
|
|
77
81
|
})),
|
|
78
|
-
transition('* => show', [animate('
|
|
82
|
+
transition('* => show', [animate('160ms cubic-bezier(0, 0, 0.2, 1)')]),
|
|
79
83
|
transition('* => hide', [
|
|
80
|
-
animate('
|
|
84
|
+
animate('160ms cubic-bezier(0.38, 0, 0.24, 1)'),
|
|
81
85
|
]),
|
|
82
86
|
]),
|
|
83
87
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
@@ -93,11 +97,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
93
97
|
opacity: 0,
|
|
94
98
|
transform: 'scale(0)',
|
|
95
99
|
})),
|
|
96
|
-
transition('* => show', [animate('
|
|
100
|
+
transition('* => show', [animate('160ms cubic-bezier(0, 0, 0.2, 1)')]),
|
|
97
101
|
transition('* => hide', [
|
|
98
|
-
animate('
|
|
102
|
+
animate('160ms cubic-bezier(0.38, 0, 0.24, 1)'),
|
|
99
103
|
]),
|
|
100
104
|
]),
|
|
101
105
|
], template: "<div\n *ngIf=\"inputContent$ | async\"\n [class]=\"class$ | async\"\n (mouseenter)=\"hover$.next(true)\"\n (mouseleave)=\"hover$.next(false)\"\n [@.disabled]=\"disableAnimation\"\n [@showHide]=\"showHide\"\n (@showHide.start)=\"onAnimation($event)\"\n (@showHide.done)=\"onAnimation($event)\"\n>\n {{ text$ | async }}\n <ng-container\n *ngIf=\"template$ | async\"\n [ngTemplateOutlet]=\"template$ | async\"\n [ngTemplateOutletContext]=\"context$ | async\"\n ></ng-container>\n</div>\n", styles: [".cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex;max-width:100%;max-height:100%}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:1}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:rgba(0,0,0,.32)}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:0;visibility:visible}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}.aui-tooltip{position:relative;padding:var(--aui-spacing-xl);border-radius:var(--aui-border-radius-m);font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);max-width:400px;word-wrap:break-word}:root .aui-tooltip{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-tooltip{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-tooltip{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-tooltip{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-tooltip--default{padding:var(--aui-spacing-m) var(--aui-spacing-xl)}:root .aui-tooltip--default{color:rgb(var(--aui-color-n-10));background-color:rgb(var(--aui-color-n-1))}html[aui-theme-mode=light] .aui-tooltip--default{color:rgb(var(--aui-color-n-10));background-color:rgb(var(--aui-color-n-1))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-tooltip--default{color:rgb(var(--aui-color-n-1));background-color:rgb(var(--aui-color-popper-bg))}}html[aui-theme-mode=dark] .aui-tooltip--default{color:rgb(var(--aui-color-n-1));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--primary{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--success{color:rgb(var(--aui-color-green));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--warning{color:rgb(var(--aui-color-yellow));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--error{color:rgb(var(--aui-color-red));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--info{color:rgb(var(--aui-color-n-1));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--top,.aui-tooltip--bottom{margin:var(--aui-spacing-s) 0}.aui-tooltip--start,.aui-tooltip--end{margin:0 var(--aui-spacing-s)}\n"] }]
|
|
102
106
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.component.js","sourceRoot":"","sources":["../../../src/tooltip/tooltip.component.ts","../../../src/tooltip/tooltip.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  style,\n  transition,\n  trigger,\n  AnimationEvent,\n  state,\n  animate,\n} from '@angular/animations';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  OnDestroy,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  map,\n  startWith,\n  BehaviorSubject,\n} from 'rxjs';\n\nimport { Bem, buildBem, publishRef } from '../utils';\n\nimport { TooltipType } from './tooltip.types';\n\n@Component({\n  templateUrl: './tooltip.component.html',\n  styleUrls: ['./tooltip.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  animations: [\n    trigger('showHide', [\n      state(\n        'show',\n        style({\n          opacity: 1,\n          transform: 'scale(1)',\n        }),\n      ),\n      state(\n        'hide,void',\n        style({\n          opacity: 0,\n          transform: 'scale(0)',\n        }),\n      ),\n      transition('* => show', [animate('240ms cubic-bezier(0, 0, 0.2, 1)')]),\n      transition('* => hide', [\n        animate('240ms cubic-bezier(0.38, 0, 0.24, 1)'),\n      ]),\n    ]),\n  ],\n})\nexport class TooltipComponent implements OnDestroy {\n  text: string;\n  template: TemplateRef<any>;\n  bem: Bem = buildBem('aui-tooltip');\n  showHide: 'show' | 'hide' = 'hide';\n  disableAnimation = true;\n\n  inputContent$: Observable<string | TemplateRef<any>>;\n  inputType$: Observable<TooltipType>;\n  inputPosition$: Observable<string>;\n  inputClass$: Observable<string>;\n  inputContext$: Observable<any>;\n\n  text$: Observable<string>;\n  template$: Observable<TemplateRef<any>>;\n  class$: Observable<string>;\n  context$: Observable<any>;\n\n  hover$ = new Subject<boolean>();\n  destroy$ = new Subject();\n  animating$$ = new BehaviorSubject(false);\n  hide$ = new Subject();\n\n  constructor(\n    public elRef: ElementRef<HTMLElement>,\n    public cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnDestroy() {\n    this.destroy$.next(null);\n    this.destroy$.complete();\n  }\n\n  setupInputs(inputs: {\n    inputContent$: Observable<string | TemplateRef<any>>;\n    inputType$: Observable<TooltipType>;\n    inputPosition$: Observable<string>;\n    inputClass$: Observable<string>;\n    inputContext$: Observable<any>;\n    disableAnimation?: boolean;\n  }) {\n    Object.assign(this, inputs);\n    this.text$ = this.inputContent$.pipe(\n      map(val => {\n        if (typeof val === 'string') {\n          return val;\n        }\n        return '';\n      }),\n      publishRef(),\n    );\n    this.template$ = this.inputContent$.pipe(\n      map(val => {\n        if (typeof val !== 'string') {\n          return val;\n        }\n        return null;\n      }),\n      publishRef(),\n    );\n    this.class$ = combineLatest([\n      this.inputPosition$.pipe(startWith('top')),\n      this.inputType$.pipe(startWith(TooltipType.Default)),\n      this.inputClass$.pipe(startWith('')),\n    ]).pipe(\n      map(([inputPosition, inputType, inputClass]) => {\n        const b = this.bem.block();\n        const dir = inputPosition.split(' ')[0];\n        return inputType === TooltipType.Plain\n          ? `${b}--${dir} ${inputClass}`\n          : `${b} ${b}--${inputType} ${b}--${dir} ${inputClass}`;\n      }),\n      publishRef(),\n    );\n    this.context$ = this.inputContext$.pipe(publishRef());\n  }\n\n  onAnimation(event: AnimationEvent) {\n    const { phaseName, toState } = event;\n    this.animating$$.next(phaseName === 'start');\n    if (toState === 'hide' && phaseName === 'done') {\n      this.hide$.next(true);\n    }\n  }\n\n  show() {\n    this.showHide = 'show';\n    this.cdr.markForCheck();\n  }\n\n  hide() {\n    this.showHide = 'hide';\n    this.cdr.markForCheck();\n  }\n}\n","<div\n  *ngIf=\"inputContent$ | async\"\n  [class]=\"class$ | async\"\n  (mouseenter)=\"hover$.next(true)\"\n  (mouseleave)=\"hover$.next(false)\"\n  [@.disabled]=\"disableAnimation\"\n  [@showHide]=\"showHide\"\n  (@showHide.start)=\"onAnimation($event)\"\n  (@showHide.done)=\"onAnimation($event)\"\n>\n  {{ text$ | async }}\n  <ng-container\n    *ngIf=\"template$ | async\"\n    [ngTemplateOutlet]=\"template$ | async\"\n    [ngTemplateOutletContext]=\"context$ | async\"\n  ></ng-container>\n</div>\n"]}
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.component.js","sourceRoot":"","sources":["../../../src/tooltip/tooltip.component.ts","../../../src/tooltip/tooltip.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  style,\n  transition,\n  trigger,\n  AnimationEvent,\n  state,\n  animate,\n} from '@angular/animations';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  OnDestroy,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  map,\n  startWith,\n  BehaviorSubject,\n} from 'rxjs';\n\nimport { Bem, buildBem, publishRef } from '../utils';\n\nimport { TooltipType } from './tooltip.types';\n\n@Component({\n  templateUrl: './tooltip.component.html',\n  styleUrls: ['./tooltip.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  animations: [\n    trigger('showHide', [\n      state(\n        'show',\n        style({\n          opacity: 1,\n          transform: 'scale(1)',\n        }),\n      ),\n      state(\n        'hide,void',\n        style({\n          opacity: 0,\n          transform: 'scale(0)',\n        }),\n      ),\n      transition('* => show', [animate('160ms cubic-bezier(0, 0, 0.2, 1)')]),\n      transition('* => hide', [\n        animate('160ms cubic-bezier(0.38, 0, 0.24, 1)'),\n      ]),\n    ]),\n  ],\n})\nexport class TooltipComponent implements OnDestroy {\n  text: string;\n  template: TemplateRef<any>;\n  bem: Bem = buildBem('aui-tooltip');\n  showHide: 'show' | 'hide' = 'hide';\n  disableAnimation = true;\n\n  inputContent$: Observable<string | TemplateRef<any>>;\n  inputType$: Observable<TooltipType>;\n  inputPosition$: Observable<string>;\n  inputClass$: Observable<string>;\n  inputContext$: Observable<any>;\n\n  text$: Observable<string>;\n  template$: Observable<TemplateRef<any>>;\n  class$: Observable<string>;\n  context$: Observable<any>;\n\n  hover$ = new Subject<boolean>();\n  destroy$ = new Subject();\n  animating$$ = new BehaviorSubject(false);\n  hide$ = new Subject();\n  beforeHide$ = new Subject();\n  beforeShow$ = new Subject();\n\n  constructor(\n    public elRef: ElementRef<HTMLElement>,\n    public cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnDestroy() {\n    this.destroy$.next(null);\n    this.destroy$.complete();\n  }\n\n  setupInputs(inputs: {\n    inputContent$: Observable<string | TemplateRef<any>>;\n    inputType$: Observable<TooltipType>;\n    inputPosition$: Observable<string>;\n    inputClass$: Observable<string>;\n    inputContext$: Observable<any>;\n    disableAnimation?: boolean;\n  }) {\n    Object.assign(this, inputs);\n    this.text$ = this.inputContent$.pipe(\n      map(val => {\n        if (typeof val === 'string') {\n          return val;\n        }\n        return '';\n      }),\n      publishRef(),\n    );\n    this.template$ = this.inputContent$.pipe(\n      map(val => {\n        if (typeof val !== 'string') {\n          return val;\n        }\n        return null;\n      }),\n      publishRef(),\n    );\n    this.class$ = combineLatest([\n      this.inputPosition$.pipe(startWith('top')),\n      this.inputType$.pipe(startWith(TooltipType.Default)),\n      this.inputClass$.pipe(startWith('')),\n    ]).pipe(\n      map(([inputPosition, inputType, inputClass]) => {\n        const b = this.bem.block();\n        const dir = inputPosition.split(' ')[0];\n        return inputType === TooltipType.Plain\n          ? `${b}--${dir} ${inputClass}`\n          : `${b} ${b}--${inputType} ${b}--${dir} ${inputClass}`;\n      }),\n      publishRef(),\n    );\n    this.context$ = this.inputContext$.pipe(publishRef());\n  }\n\n  onAnimation(event: AnimationEvent) {\n    const { phaseName, toState } = event;\n    this.animating$$.next(phaseName === 'start');\n    if (toState === 'hide' && phaseName === 'done') {\n      this.hide$.next(true);\n    }\n  }\n\n  show() {\n    this.beforeShow$.next(null);\n    this.showHide = 'show';\n    this.cdr.markForCheck();\n  }\n\n  hide() {\n    this.beforeHide$.next(null);\n    this.showHide = 'hide';\n    this.cdr.markForCheck();\n  }\n}\n","<div\n  *ngIf=\"inputContent$ | async\"\n  [class]=\"class$ | async\"\n  (mouseenter)=\"hover$.next(true)\"\n  (mouseleave)=\"hover$.next(false)\"\n  [@.disabled]=\"disableAnimation\"\n  [@showHide]=\"showHide\"\n  (@showHide.start)=\"onAnimation($event)\"\n  (@showHide.done)=\"onAnimation($event)\"\n>\n  {{ text$ | async }}\n  <ng-container\n    *ngIf=\"template$ | async\"\n    [ngTemplateOutlet]=\"template$ | async\"\n    [ngTemplateOutletContext]=\"context$ | async\"\n  ></ng-container>\n</div>\n"]}
|
package/fesm2015/alauda-ui.mjs
CHANGED
|
@@ -5,7 +5,7 @@ import * as i2 from '@angular/common';
|
|
|
5
5
|
import { DOCUMENT, CommonModule } from '@angular/common';
|
|
6
6
|
import * as i2$1 from '@angular/cdk/a11y';
|
|
7
7
|
import { FocusKeyManager, A11yModule } from '@angular/cdk/a11y';
|
|
8
|
-
import { Observable, ReplaySubject, share, startWith, map, distinctUntilChanged, Subject, takeUntil, filter, take, merge, fromEvent, combineLatest, debounceTime, switchMap, of, EMPTY, tap, BehaviorSubject, withLatestFrom, first, throttleTime, pluck, firstValueFrom, NEVER, observeOn, animationFrameScheduler, repeat, takeWhile, endWith, Subscription } from 'rxjs';
|
|
8
|
+
import { Observable, ReplaySubject, share, startWith, map, distinctUntilChanged, Subject, takeUntil, filter, take, merge, fromEvent, combineLatest, debounceTime, switchMap, of, EMPTY, tap, BehaviorSubject, withLatestFrom, first, delay, throttleTime, pluck, firstValueFrom, NEVER, observeOn, animationFrameScheduler, repeat, takeWhile, endWith, Subscription } from 'rxjs';
|
|
9
9
|
import * as i1 from '@angular/common/http';
|
|
10
10
|
import { HttpClient } from '@angular/common/http';
|
|
11
11
|
import { trigger, state, style, transition, animate, query } from '@angular/animations';
|
|
@@ -1288,6 +1288,8 @@ class TooltipComponent {
|
|
|
1288
1288
|
this.destroy$ = new Subject();
|
|
1289
1289
|
this.animating$$ = new BehaviorSubject(false);
|
|
1290
1290
|
this.hide$ = new Subject();
|
|
1291
|
+
this.beforeHide$ = new Subject();
|
|
1292
|
+
this.beforeShow$ = new Subject();
|
|
1291
1293
|
}
|
|
1292
1294
|
ngOnDestroy() {
|
|
1293
1295
|
this.destroy$.next(null);
|
|
@@ -1328,10 +1330,12 @@ class TooltipComponent {
|
|
|
1328
1330
|
}
|
|
1329
1331
|
}
|
|
1330
1332
|
show() {
|
|
1333
|
+
this.beforeShow$.next(null);
|
|
1331
1334
|
this.showHide = 'show';
|
|
1332
1335
|
this.cdr.markForCheck();
|
|
1333
1336
|
}
|
|
1334
1337
|
hide() {
|
|
1338
|
+
this.beforeHide$.next(null);
|
|
1335
1339
|
this.showHide = 'hide';
|
|
1336
1340
|
this.cdr.markForCheck();
|
|
1337
1341
|
}
|
|
@@ -1347,9 +1351,9 @@ TooltipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", versi
|
|
|
1347
1351
|
opacity: 0,
|
|
1348
1352
|
transform: 'scale(0)',
|
|
1349
1353
|
})),
|
|
1350
|
-
transition('* => show', [animate('
|
|
1354
|
+
transition('* => show', [animate('160ms cubic-bezier(0, 0, 0.2, 1)')]),
|
|
1351
1355
|
transition('* => hide', [
|
|
1352
|
-
animate('
|
|
1356
|
+
animate('160ms cubic-bezier(0.38, 0, 0.24, 1)'),
|
|
1353
1357
|
]),
|
|
1354
1358
|
]),
|
|
1355
1359
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
@@ -1365,9 +1369,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
1365
1369
|
opacity: 0,
|
|
1366
1370
|
transform: 'scale(0)',
|
|
1367
1371
|
})),
|
|
1368
|
-
transition('* => show', [animate('
|
|
1372
|
+
transition('* => show', [animate('160ms cubic-bezier(0, 0, 0.2, 1)')]),
|
|
1369
1373
|
transition('* => hide', [
|
|
1370
|
-
animate('
|
|
1374
|
+
animate('160ms cubic-bezier(0.38, 0, 0.24, 1)'),
|
|
1371
1375
|
]),
|
|
1372
1376
|
]),
|
|
1373
1377
|
], template: "<div\n *ngIf=\"inputContent$ | async\"\n [class]=\"class$ | async\"\n (mouseenter)=\"hover$.next(true)\"\n (mouseleave)=\"hover$.next(false)\"\n [@.disabled]=\"disableAnimation\"\n [@showHide]=\"showHide\"\n (@showHide.start)=\"onAnimation($event)\"\n (@showHide.done)=\"onAnimation($event)\"\n>\n {{ text$ | async }}\n <ng-container\n *ngIf=\"template$ | async\"\n [ngTemplateOutlet]=\"template$ | async\"\n [ngTemplateOutletContext]=\"context$ | async\"\n ></ng-container>\n</div>\n", styles: [".cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex;max-width:100%;max-height:100%}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:1}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:rgba(0,0,0,.32)}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:0;visibility:visible}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}.aui-tooltip{position:relative;padding:var(--aui-spacing-xl);border-radius:var(--aui-border-radius-m);font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);max-width:400px;word-wrap:break-word}:root .aui-tooltip{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-tooltip{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-tooltip{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-tooltip{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-tooltip--default{padding:var(--aui-spacing-m) var(--aui-spacing-xl)}:root .aui-tooltip--default{color:rgb(var(--aui-color-n-10));background-color:rgb(var(--aui-color-n-1))}html[aui-theme-mode=light] .aui-tooltip--default{color:rgb(var(--aui-color-n-10));background-color:rgb(var(--aui-color-n-1))}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-tooltip--default{color:rgb(var(--aui-color-n-1));background-color:rgb(var(--aui-color-popper-bg))}}html[aui-theme-mode=dark] .aui-tooltip--default{color:rgb(var(--aui-color-n-1));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--primary{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--success{color:rgb(var(--aui-color-green));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--warning{color:rgb(var(--aui-color-yellow));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--error{color:rgb(var(--aui-color-red));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--info{color:rgb(var(--aui-color-n-1));background-color:rgb(var(--aui-color-popper-bg))}.aui-tooltip--top,.aui-tooltip--bottom{margin:var(--aui-spacing-s) 0}.aui-tooltip--start,.aui-tooltip--end{margin:0 var(--aui-spacing-s)}\n"] }]
|
|
@@ -1520,6 +1524,53 @@ class BaseTooltip {
|
|
|
1520
1524
|
get isCreated() {
|
|
1521
1525
|
return !!this.overlayRef;
|
|
1522
1526
|
}
|
|
1527
|
+
_updateTransformOrigin() {
|
|
1528
|
+
// @ts-ignore
|
|
1529
|
+
const positionStrategy = this.overlayRef._positionStrategy;
|
|
1530
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
1531
|
+
const hasExactPosition = positionStrategy._hasExactPosition(); // 是不是应用了精确定位
|
|
1532
|
+
if (!hasExactPosition) {
|
|
1533
|
+
return;
|
|
1534
|
+
}
|
|
1535
|
+
// 如果是精确定位,也就是预设位置空间不足以承载弹出元素,被重新指定新的弹出位置
|
|
1536
|
+
// @ts-ignore
|
|
1537
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
1538
|
+
const paneRect = positionStrategy._pane.getBoundingClientRect(); // 弹出pane元素Rect
|
|
1539
|
+
const triggerElReact = this.elRef.nativeElement.getBoundingClientRect(); // 触发点Rect
|
|
1540
|
+
// @ts-ignore
|
|
1541
|
+
const position = positionStrategy._lastPosition; // 当前策略位置(调整后的最佳的)
|
|
1542
|
+
let xOrigin;
|
|
1543
|
+
const yOrigin = position.overlayY;
|
|
1544
|
+
if (position.overlayX === 'center') {
|
|
1545
|
+
xOrigin = 'center';
|
|
1546
|
+
}
|
|
1547
|
+
else {
|
|
1548
|
+
xOrigin = position.overlayX === 'start' ? 'left' : 'right';
|
|
1549
|
+
}
|
|
1550
|
+
const origins = [xOrigin, yOrigin];
|
|
1551
|
+
if (xOrigin === 'center' ||
|
|
1552
|
+
(xOrigin === 'left' && paneRect.left !== triggerElReact.right) || // 位置没有被完全被颠倒的
|
|
1553
|
+
(xOrigin === 'right' && paneRect.right !== triggerElReact.left) // 位置没有被完全被颠倒的
|
|
1554
|
+
) {
|
|
1555
|
+
const originLeft = triggerElReact.left - paneRect.left + triggerElReact.width / 2;
|
|
1556
|
+
origins[0] = Math.min(originLeft, paneRect.width) + 'px';
|
|
1557
|
+
}
|
|
1558
|
+
if (yOrigin === 'center' ||
|
|
1559
|
+
(yOrigin === 'top' && paneRect.top !== triggerElReact.bottom) || // 位置没有被完全被颠倒的
|
|
1560
|
+
(yOrigin === 'bottom' && paneRect.bottom !== triggerElReact.top) // 位置没有被完全被颠倒的
|
|
1561
|
+
) {
|
|
1562
|
+
const originTop = triggerElReact.top - paneRect.top + triggerElReact.height / 2;
|
|
1563
|
+
origins[1] = Math.min(originTop, paneRect.height) + 'px';
|
|
1564
|
+
}
|
|
1565
|
+
// @ts-ignore
|
|
1566
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call
|
|
1567
|
+
const aniEls = positionStrategy._boundingBox.querySelectorAll(
|
|
1568
|
+
// @ts-ignore
|
|
1569
|
+
positionStrategy._transformOriginSelector);
|
|
1570
|
+
[...aniEls].forEach(el => {
|
|
1571
|
+
el.style.transformOrigin = origins.join(' ');
|
|
1572
|
+
});
|
|
1573
|
+
}
|
|
1523
1574
|
_createTooltip() {
|
|
1524
1575
|
var _a;
|
|
1525
1576
|
if (this.disabled || this.isCreated) {
|
|
@@ -1540,6 +1591,9 @@ class BaseTooltip {
|
|
|
1540
1591
|
this.componentIns.hide$.pipe(takeUntil(this.destroy$)).subscribe(() => {
|
|
1541
1592
|
this._disposeTooltip();
|
|
1542
1593
|
});
|
|
1594
|
+
merge(this.componentIns.beforeHide$, this.componentIns.beforeShow$.pipe(delay(0)))
|
|
1595
|
+
.pipe(takeUntil(this.destroy$))
|
|
1596
|
+
.subscribe(this._updateTransformOrigin.bind(this));
|
|
1543
1597
|
if (this.trigger === TooltipTrigger.Hover) {
|
|
1544
1598
|
this.componentIns.hover$
|
|
1545
1599
|
.pipe(takeUntil(this.componentIns.destroy$))
|