@flywheel-io/vision 2.7.0 → 2.7.2

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.
@@ -53,7 +53,7 @@ export declare class FwTooltipDirective implements OnInit, OnDestroy {
53
53
  ngOnInit(): void;
54
54
  private openDelayTimer;
55
55
  showTooltip(): void;
56
- positionChangeSub: Subscription;
56
+ positionChangeSub: Subscription | undefined;
57
57
  handlePositionChange: import("@angular/core").EffectRef;
58
58
  hideTooltip(): void;
59
59
  ngOnDestroy(): void;
@@ -125,8 +125,8 @@ export class FwTooltipDirective {
125
125
  pos.overlayY === newPosition.overlayY;
126
126
  });
127
127
  if (newPositionName) {
128
- this.tooltipRef().setInput('position', newPositionName);
129
- this.tooltipRef().changeDetectorRef.detectChanges();
128
+ this.tooltipRef()?.setInput('position', newPositionName);
129
+ this.tooltipRef()?.changeDetectorRef.detectChanges();
130
130
  }
131
131
  });
132
132
  });
@@ -157,11 +157,11 @@ export class FwTooltipDirective {
157
157
  hideTooltip() {
158
158
  window.clearTimeout(this.openDelayTimer);
159
159
  this.openDelayTimer = undefined;
160
- this.overlayRef().detach();
160
+ this.overlayRef()?.detach();
161
161
  this.tooltipRef.set(undefined);
162
162
  }
163
163
  ngOnDestroy() {
164
- this.positionChangeSub.unsubscribe();
164
+ this.positionChangeSub?.unsubscribe();
165
165
  this.hideTooltip();
166
166
  }
167
167
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
@@ -174,4 +174,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
174
174
  standalone: true,
175
175
  }]
176
176
  }] });
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../src/components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, computed, Directive, effect, ElementRef, inject, input, model, OnDestroy, OnInit, signal, ViewContainerRef } from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { FwTooltipPanelComponent, SimplePosition } from './tooltip-panel/tooltip-panel.component';\n\ntype DelayLength = 'none' | 'short' | 'long';\ntype DelayMap = { [K in DelayLength]: number };\n\nconst delayMap: DelayMap = {\n  'none': 0,\n  'short': 400,\n  'long': 700,\n}\n\nconst delayNameToMs = (name: DelayLength): number => {\n  return delayMap[name];\n}\n\n\nconst positionMap: { [key: string]: ConnectedPosition } = {\n  'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n  'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },\n  'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },\n  'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },\n  'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n};\n\n\n/**\n * Directive for displaying extra context on hover\n * @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-tooltip--docs)\n */\n@Directive({\n  selector: '[fwTooltip]',\n  standalone: true,\n})\nexport class FwTooltipDirective implements OnInit, OnDestroy {\n\n  /***** External Context *****/\n\n  private elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private viewContainerRef = inject(ViewContainerRef);\n  private overlayService = inject(Overlay);\n\n  /***** Internal Refs *****/\n\n  private overlayRef = signal<OverlayRef>(undefined);\n  private tooltipRef = signal<ComponentRef<FwTooltipPanelComponent>>(undefined);\n  private tooltipPortal: ComponentPortal<FwTooltipPanelComponent>;\n\n  /***** Inputs *****/\n\n  // a lot of these ideally wouldn't be models,\n  // but it makes it easier to interact with this from derivative directives\n\n  // VS Code pulls the input that shares a name with the directive for giving context\n  // so putting the top level comment on this input\n\n  /**\n   * Directive for displaying extra context on hover\n   * @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-tooltip--docs)\n   */\n  title = model<string>('Placeholder', {\n    alias: 'fwTooltip',\n  })\n\n  /**\n   * direction relative to the parent component that the tooltip will attempt to position itself to\n   */\n  position = model<SimplePosition>('above', {\n    alias: 'fwTooltipPosition',\n  });\n\n  /**\n   * maximum width of the tooltip in pixels\n   */\n  maxWidth = model<number>(200, {\n    alias: 'fwTooltipMaxWidthPx',\n  })\n\n  /**\n   * amount of delay before the tooltip displays\n   *\n   * none (0ms),\n   * short (400ms),\n   * long (700ms)\n   */\n  delayMs = input(400, {\n    transform: delayNameToMs,\n    alias: 'fwTooltipDelay',\n  });\n\n  /**\n   * whether or not the tooltip should have a caret\n   */\n  displayCaret = input(true, {\n    alias: 'fwTooltipCaret',\n  });\n\n\n  enabled = model(true, {\n    alias: 'fwTooltipEnabled',\n  });\n\n  /***** Derived State *****/\n\n  connectedPositions = computed<ConnectedPosition[]>(() => {\n    // falback positions for if it doesn't fit in the specified position\n    // tend towards closer first i.e. 'above' will try 'left' and 'right' before resorting to 'below\n    const positionPreferenceOrderMap = {\n      'above': ['above', 'right', 'left', 'below'],\n      'right': ['right', 'below', 'above', 'left'],\n      'below': ['below', 'left', 'right', 'above'],\n      'left': ['left', 'above', 'below', 'right'],\n    }\n\n    const fallbackNamedPositions = positionPreferenceOrderMap[this.position()];\n    const connectedPositions = fallbackNamedPositions.map(name => positionMap[name]);\n\n    return connectedPositions;\n  });\n\n  positionStrategy = computed(() => {\n    const positionBuilder = this.overlayService.position();\n    const withOrigin = positionBuilder.flexibleConnectedTo(this.elementRef);\n    const completedStrategy = withOrigin.withPositions(this.connectedPositions());\n    return completedStrategy;\n  });\n\n  overlayConfig = computed<OverlayConfig>(() => ({\n    positionStrategy: this.positionStrategy(),\n    maxWidth: Number(this.maxWidth()),\n    ScrollStrategyOptions: this.overlayService.scrollStrategies.close(),\n    disposeOnNavigation: true,\n  }));\n\n  /***** Effects and Methods *****/\n\n  addMouseEventListeners = effect(() => {\n\n    const nativeElement = this.elementRef.nativeElement;\n\n    nativeElement.addEventListener('mouseenter', () => {\n      this.showTooltip();\n    });\n\n    nativeElement.addEventListener('mouseleave', () => {\n      this.hideTooltip();\n    });\n  })\n\n  ngOnInit(): void {\n    this.tooltipPortal = new ComponentPortal(FwTooltipPanelComponent, this.viewContainerRef);\n\n    this.overlayRef.set(this.overlayService.create());\n  }\n\n\n  private openDelayTimer: number;\n\n  showTooltip(): void {\n    if (!this.enabled() || !this.title()) {\n      return;\n    }\n\n        const overlayRef = this.overlayRef();\n    overlayRef.updatePositionStrategy(this.positionStrategy());\n\n    if (this.openDelayTimer) {\n      return;\n    }\n\n    this.openDelayTimer = window.setTimeout(() => {\n      const tooltipRef = overlayRef.attach(this.tooltipPortal);\n      this.tooltipRef.set(tooltipRef);\n\n      tooltipRef.setInput('title', this.title());\n      tooltipRef.setInput('position', this.position());\n      tooltipRef.setInput('maxWidth', this.maxWidth());\n      tooltipRef.setInput('displayCaret', this.displayCaret());\n      tooltipRef.changeDetectorRef.detectChanges();\n    }, this.delayMs());\n  }\n\n  positionChangeSub: Subscription;\n\n  // updates the tooltip panel's caret position if a fallback position is used\n  handlePositionChange = effect(() => {\n\n    this.positionChangeSub?.unsubscribe();\n    this.positionChangeSub = this.positionStrategy().positionChanges.subscribe(positionChange => {\n\n      const newPosition = positionChange.connectionPair;\n\n      const positionNames = Object.keys(positionMap);\n      const newPositionName = positionNames.find(name => {\n        const pos = positionMap[name];\n\n        return pos.originX === newPosition.originX &&\n        pos.originY === newPosition.originY &&\n        pos.overlayX === newPosition.overlayX &&\n        pos.overlayY === newPosition.overlayY;\n      })\n\n      if (newPositionName) {\n        this.tooltipRef().setInput('position', newPositionName);\n        this.tooltipRef().changeDetectorRef.detectChanges();\n      }\n    })\n  })\n\n  hideTooltip(): void {\n    window.clearTimeout(this.openDelayTimer);\n    this.openDelayTimer = undefined;\n    this.overlayRef().detach();\n    this.tooltipRef.set(undefined);\n  }\n\n  ngOnDestroy(): void {\n    this.positionChangeSub.unsubscribe();\n    this.hideTooltip();\n  }\n}\n"]}
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../src/components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, computed, Directive, effect, ElementRef, inject, input, model, OnDestroy, OnInit, signal, ViewContainerRef } from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { FwTooltipPanelComponent, SimplePosition } from './tooltip-panel/tooltip-panel.component';\n\ntype DelayLength = 'none' | 'short' | 'long';\ntype DelayMap = { [K in DelayLength]: number };\n\nconst delayMap: DelayMap = {\n  'none': 0,\n  'short': 400,\n  'long': 700,\n}\n\nconst delayNameToMs = (name: DelayLength): number => {\n  return delayMap[name];\n}\n\n\nconst positionMap: { [key: string]: ConnectedPosition } = {\n  'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n  'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },\n  'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },\n  'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },\n  'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n};\n\n\n/**\n * Directive for displaying extra context on hover\n * @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-tooltip--docs)\n */\n@Directive({\n  selector: '[fwTooltip]',\n  standalone: true,\n})\nexport class FwTooltipDirective implements OnInit, OnDestroy {\n\n  /***** External Context *****/\n\n  private elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private viewContainerRef = inject(ViewContainerRef);\n  private overlayService = inject(Overlay);\n\n  /***** Internal Refs *****/\n\n  private overlayRef = signal<OverlayRef | undefined>(undefined);\n  private tooltipRef = signal<ComponentRef<FwTooltipPanelComponent> | undefined>(undefined);\n  private tooltipPortal: ComponentPortal<FwTooltipPanelComponent>;\n\n  /***** Inputs *****/\n\n  // a lot of these ideally wouldn't be models,\n  // but it makes it easier to interact with this from derivative directives\n\n  // VS Code pulls the input that shares a name with the directive for giving context\n  // so putting the top level comment on this input\n\n  /**\n   * Directive for displaying extra context on hover\n   * @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-tooltip--docs)\n   */\n  title = model<string>('Placeholder', {\n    alias: 'fwTooltip',\n  })\n\n  /**\n   * direction relative to the parent component that the tooltip will attempt to position itself to\n   */\n  position = model<SimplePosition>('above', {\n    alias: 'fwTooltipPosition',\n  });\n\n  /**\n   * maximum width of the tooltip in pixels\n   */\n  maxWidth = model<number>(200, {\n    alias: 'fwTooltipMaxWidthPx',\n  })\n\n  /**\n   * amount of delay before the tooltip displays\n   *\n   * none (0ms),\n   * short (400ms),\n   * long (700ms)\n   */\n  delayMs = input(400, {\n    transform: delayNameToMs,\n    alias: 'fwTooltipDelay',\n  });\n\n  /**\n   * whether or not the tooltip should have a caret\n   */\n  displayCaret = input(true, {\n    alias: 'fwTooltipCaret',\n  });\n\n\n  enabled = model(true, {\n    alias: 'fwTooltipEnabled',\n  });\n\n  /***** Derived State *****/\n\n  connectedPositions = computed<ConnectedPosition[]>(() => {\n    // falback positions for if it doesn't fit in the specified position\n    // tend towards closer first i.e. 'above' will try 'left' and 'right' before resorting to 'below\n    const positionPreferenceOrderMap = {\n      'above': ['above', 'right', 'left', 'below'],\n      'right': ['right', 'below', 'above', 'left'],\n      'below': ['below', 'left', 'right', 'above'],\n      'left': ['left', 'above', 'below', 'right'],\n    }\n\n    const fallbackNamedPositions = positionPreferenceOrderMap[this.position()];\n    const connectedPositions = fallbackNamedPositions.map(name => positionMap[name]);\n\n    return connectedPositions;\n  });\n\n  positionStrategy = computed(() => {\n    const positionBuilder = this.overlayService.position();\n    const withOrigin = positionBuilder.flexibleConnectedTo(this.elementRef);\n    const completedStrategy = withOrigin.withPositions(this.connectedPositions());\n    return completedStrategy;\n  });\n\n  overlayConfig = computed<OverlayConfig>(() => ({\n    positionStrategy: this.positionStrategy(),\n    maxWidth: Number(this.maxWidth()),\n    ScrollStrategyOptions: this.overlayService.scrollStrategies.close(),\n    disposeOnNavigation: true,\n  }));\n\n  /***** Effects and Methods *****/\n\n  addMouseEventListeners = effect(() => {\n\n    const nativeElement = this.elementRef.nativeElement;\n\n    nativeElement.addEventListener('mouseenter', () => {\n      this.showTooltip();\n    });\n\n    nativeElement.addEventListener('mouseleave', () => {\n      this.hideTooltip();\n    });\n  })\n\n  ngOnInit(): void {\n    this.tooltipPortal = new ComponentPortal(FwTooltipPanelComponent, this.viewContainerRef);\n\n    this.overlayRef.set(this.overlayService.create());\n  }\n\n\n  private openDelayTimer: number;\n\n  showTooltip(): void {\n    if (!this.enabled() || !this.title()) {\n      return;\n    }\n\n        const overlayRef = this.overlayRef();\n    overlayRef.updatePositionStrategy(this.positionStrategy());\n\n    if (this.openDelayTimer) {\n      return;\n    }\n\n    this.openDelayTimer = window.setTimeout(() => {\n      const tooltipRef = overlayRef.attach(this.tooltipPortal);\n      this.tooltipRef.set(tooltipRef);\n\n      tooltipRef.setInput('title', this.title());\n      tooltipRef.setInput('position', this.position());\n      tooltipRef.setInput('maxWidth', this.maxWidth());\n      tooltipRef.setInput('displayCaret', this.displayCaret());\n      tooltipRef.changeDetectorRef.detectChanges();\n    }, this.delayMs());\n  }\n\n  positionChangeSub: Subscription | undefined;\n\n  // updates the tooltip panel's caret position if a fallback position is used\n  handlePositionChange = effect(() => {\n\n    this.positionChangeSub?.unsubscribe();\n    this.positionChangeSub = this.positionStrategy().positionChanges.subscribe(positionChange => {\n\n      const newPosition = positionChange.connectionPair;\n\n      const positionNames = Object.keys(positionMap);\n      const newPositionName = positionNames.find(name => {\n        const pos = positionMap[name];\n\n        return pos.originX === newPosition.originX &&\n        pos.originY === newPosition.originY &&\n        pos.overlayX === newPosition.overlayX &&\n        pos.overlayY === newPosition.overlayY;\n      })\n\n      if (newPositionName) {\n        this.tooltipRef()?.setInput('position', newPositionName);\n        this.tooltipRef()?.changeDetectorRef.detectChanges();\n      }\n    })\n  })\n\n  hideTooltip(): void {\n    window.clearTimeout(this.openDelayTimer);\n    this.openDelayTimer = undefined;\n    this.overlayRef()?.detach();\n    this.tooltipRef.set(undefined);\n  }\n\n  ngOnDestroy(): void {\n    this.positionChangeSub?.unsubscribe();\n    this.hideTooltip();\n  }\n}\n"]}
@@ -1112,8 +1112,8 @@ class FwTooltipDirective {
1112
1112
  pos.overlayY === newPosition.overlayY;
1113
1113
  });
1114
1114
  if (newPositionName) {
1115
- this.tooltipRef().setInput('position', newPositionName);
1116
- this.tooltipRef().changeDetectorRef.detectChanges();
1115
+ this.tooltipRef()?.setInput('position', newPositionName);
1116
+ this.tooltipRef()?.changeDetectorRef.detectChanges();
1117
1117
  }
1118
1118
  });
1119
1119
  });
@@ -1144,11 +1144,11 @@ class FwTooltipDirective {
1144
1144
  hideTooltip() {
1145
1145
  window.clearTimeout(this.openDelayTimer);
1146
1146
  this.openDelayTimer = undefined;
1147
- this.overlayRef().detach();
1147
+ this.overlayRef()?.detach();
1148
1148
  this.tooltipRef.set(undefined);
1149
1149
  }
1150
1150
  ngOnDestroy() {
1151
- this.positionChangeSub.unsubscribe();
1151
+ this.positionChangeSub?.unsubscribe();
1152
1152
  this.hideTooltip();
1153
1153
  }
1154
1154
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }