@ngneat/helipopper 6.6.0 → 7.0.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/README.md +46 -42
- package/esm2020/lib/tippy.directive.mjs +67 -39
- package/fesm2015/ngneat-helipopper.mjs +66 -38
- package/fesm2015/ngneat-helipopper.mjs.map +1 -1
- package/fesm2020/ngneat-helipopper.mjs +66 -38
- package/fesm2020/ngneat-helipopper.mjs.map +1 -1
- package/lib/tippy.directive.d.ts +4 -5
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -73,7 +73,7 @@ You have the freedom to [customize](https://atomiks.github.io/tippyjs/v6/themes/
|
|
|
73
73
|
Import the standalone `TippyDirective` and use it in your templates:
|
|
74
74
|
|
|
75
75
|
```html
|
|
76
|
-
<button
|
|
76
|
+
<button tp="Helpful Message">
|
|
77
77
|
I have a tooltip
|
|
78
78
|
</button>
|
|
79
79
|
```
|
|
@@ -95,7 +95,7 @@ export const tooltipVariation = {
|
|
|
95
95
|
### Use `TemplateRef` as content
|
|
96
96
|
|
|
97
97
|
```html
|
|
98
|
-
<button [
|
|
98
|
+
<button [tp]="tpl" tpVariation="popper">
|
|
99
99
|
Click Me
|
|
100
100
|
</button>
|
|
101
101
|
|
|
@@ -117,7 +117,7 @@ class MyComponent {
|
|
|
117
117
|
```
|
|
118
118
|
|
|
119
119
|
```html
|
|
120
|
-
<button [
|
|
120
|
+
<button [tp]="MyComponent">
|
|
121
121
|
Click Me
|
|
122
122
|
</button>
|
|
123
123
|
```
|
|
@@ -128,7 +128,7 @@ You can pass the `onlyTextOverflow` input to show the tooltip only when the host
|
|
|
128
128
|
|
|
129
129
|
```html
|
|
130
130
|
<div style="max-width: 100px;" class="overflow-hidden flex">
|
|
131
|
-
<p class="ellipsis" [
|
|
131
|
+
<p class="ellipsis" [tp]="text" tpPlacement="right" [tpOnlyTextOverflow]="true">
|
|
132
132
|
{{ text }}
|
|
133
133
|
</p>
|
|
134
134
|
</div>
|
|
@@ -141,7 +141,7 @@ Note that it's using [`ResizeObserver`](https://caniuse.com/resizeobserver) api.
|
|
|
141
141
|
You can instruct tippy to use the element textContent as the tooltip content:
|
|
142
142
|
|
|
143
143
|
```html
|
|
144
|
-
<p
|
|
144
|
+
<p tp tpUseTextContent>
|
|
145
145
|
{{ text }}
|
|
146
146
|
</p>
|
|
147
147
|
```
|
|
@@ -149,12 +149,12 @@ You can instruct tippy to use the element textContent as the tooltip content:
|
|
|
149
149
|
|
|
150
150
|
### Lazy
|
|
151
151
|
|
|
152
|
-
You can pass the `
|
|
152
|
+
You can pass the `tpIsLazy` input when you want to defer the creation of tippy only when the element is in the view:
|
|
153
153
|
|
|
154
154
|
```html
|
|
155
155
|
<div *ngFor="let item of items"
|
|
156
|
-
[
|
|
157
|
-
[
|
|
156
|
+
[tp]="item.label"
|
|
157
|
+
[tpIsLazy]="true">{{ item.label }}
|
|
158
158
|
</div>
|
|
159
159
|
```
|
|
160
160
|
|
|
@@ -196,9 +196,9 @@ Now you can use it in your template:
|
|
|
196
196
|
|
|
197
197
|
<ul>
|
|
198
198
|
<li *ngFor="let item of list"
|
|
199
|
-
[
|
|
200
|
-
[
|
|
201
|
-
|
|
199
|
+
[tp]="contextMenu"
|
|
200
|
+
[tpData]="item"
|
|
201
|
+
tpVariation="contextMenu">
|
|
202
202
|
{{ item.label }}
|
|
203
203
|
</li>
|
|
204
204
|
</ul>
|
|
@@ -207,7 +207,7 @@ Now you can use it in your template:
|
|
|
207
207
|
### Manual Trigger
|
|
208
208
|
|
|
209
209
|
```html
|
|
210
|
-
<div
|
|
210
|
+
<div tp="Helpful Message" tpTrigger="manual" #tooltip="tippy">
|
|
211
211
|
Click Open to see me
|
|
212
212
|
</div>
|
|
213
213
|
|
|
@@ -215,12 +215,12 @@ Now you can use it in your template:
|
|
|
215
215
|
<button (click)="tooltip.hide()">Close</button>
|
|
216
216
|
```
|
|
217
217
|
|
|
218
|
-
###
|
|
218
|
+
### Declarative show/hide
|
|
219
219
|
|
|
220
220
|
Use isVisible to trigger show and hide. Set trigger to manual.
|
|
221
221
|
|
|
222
222
|
```html
|
|
223
|
-
<div
|
|
223
|
+
<div tp="Helpful Message" tpTrigger="manual" [tpIsVisible]="visibility">
|
|
224
224
|
Click Open to see me
|
|
225
225
|
</div>
|
|
226
226
|
|
|
@@ -235,38 +235,42 @@ live [here](https://ngneat.github.io/helipopper/).
|
|
|
235
235
|
### Inputs
|
|
236
236
|
|
|
237
237
|
```ts
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
238
|
+
tp: string | TemplateRef<any> | Type<any> | undefined | null;
|
|
239
|
+
tpAppendTo: TippyProps['appendTo'];
|
|
240
|
+
tpDelay: TippyProps['delay'];
|
|
241
|
+
tpDuration: TippyProps['duration'];
|
|
242
|
+
tpHideOnClick: TippyProps['hideOnClick'];
|
|
243
|
+
tpInteractive: TippyProps['interactive'];
|
|
244
|
+
tpInteractiveBorder: TippyProps['interactiveBorder'];
|
|
245
|
+
tpMaxWidth: TippyProps['maxWidth'];
|
|
246
|
+
tpOffset: TippyProps['offset'];
|
|
247
|
+
tpPlacement: TippyProps['placement'];
|
|
248
|
+
tpPopperOptions: TippyProps['popperOptions'];
|
|
249
|
+
tpShowOnCreate: TippyProps['showOnCreate'];
|
|
250
|
+
tpTrigger: TippyProps['trigger'];
|
|
251
|
+
tpTriggerTarget: TippyProps['triggerTarget'];
|
|
252
|
+
tpZIndex: TippyProps['zIndex'];
|
|
253
|
+
tpAnimation: TippyProps['animation'];
|
|
254
|
+
tpUseTextContent: boolean;
|
|
255
|
+
tpIsLazy: boolean;
|
|
256
|
+
tpVariation: string;
|
|
257
|
+
tpIsEnabled: boolean;
|
|
258
|
+
tpIsVisible: boolean;
|
|
259
|
+
tpClassName: string;
|
|
260
|
+
tpOnlyTextOverflow: boolean;
|
|
261
|
+
tpData: any;
|
|
262
|
+
tpUseHostWidth: boolean;
|
|
263
|
+
tpHideOnEscape: boolean;
|
|
264
|
+
tpDetectChangesComponent: boolean;
|
|
265
|
+
tpPopperWidth: number | string;
|
|
266
|
+
tpHost: HTMLElement;
|
|
267
|
+
tpIsVisible: boolean;
|
|
264
268
|
```
|
|
265
269
|
|
|
266
270
|
### Outputs
|
|
267
271
|
|
|
268
272
|
```ts
|
|
269
|
-
|
|
273
|
+
tpVisible = new EventEmitter<boolean>();
|
|
270
274
|
```
|
|
271
275
|
|
|
272
276
|
### Global Config
|
|
@@ -280,8 +284,8 @@ import { TippyService, TippyInstance } from '@ngneat/helipopper';
|
|
|
280
284
|
|
|
281
285
|
class Component {
|
|
282
286
|
@ViewChild('inputName') inputName: ElementRef;
|
|
287
|
+
tippy: TippyInstance;
|
|
283
288
|
private tippyService = inject(TippyService);
|
|
284
|
-
tippy:TippyInstance;
|
|
285
289
|
|
|
286
290
|
show() {
|
|
287
291
|
if(!this.tippy) {
|
|
@@ -21,8 +21,8 @@ export class TippyDirective {
|
|
|
21
21
|
this.useHostWidth = false;
|
|
22
22
|
this.hideOnEscape = false;
|
|
23
23
|
this.detectChangesComponent = true;
|
|
24
|
-
this.visible = new EventEmitter();
|
|
25
24
|
this.isVisible = false;
|
|
25
|
+
this.visible = new EventEmitter();
|
|
26
26
|
this.destroyed = new Subject();
|
|
27
27
|
this.enabled = true;
|
|
28
28
|
this.variationDefined = false;
|
|
@@ -77,7 +77,7 @@ export class TippyDirective {
|
|
|
77
77
|
if (isPlatformServer(this.platformId))
|
|
78
78
|
return;
|
|
79
79
|
this.zone.runOutsideAngular(() => {
|
|
80
|
-
if (this.
|
|
80
|
+
if (this.isLazy) {
|
|
81
81
|
if (this.onlyTextOverflow) {
|
|
82
82
|
inView(this.host)
|
|
83
83
|
.pipe(switchMap(() => overflowChanges(this.host)), takeUntil(this.destroyed))
|
|
@@ -308,12 +308,12 @@ export class TippyDirective {
|
|
|
308
308
|
}
|
|
309
309
|
}
|
|
310
310
|
TippyDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.1", ngImport: i0, type: TippyDirective, deps: [{ token: PLATFORM_ID }, { token: TIPPY_CONFIG }, { token: i0.Injector }, { token: i1.ViewService }, { token: i0.ViewContainerRef }, { token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
311
|
-
TippyDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.1", type: TippyDirective, isStandalone: true, selector: "[
|
|
311
|
+
TippyDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.1", type: TippyDirective, isStandalone: true, selector: "[tp]", inputs: { content: ["tp", "content"], appendTo: ["tpAppendTo", "appendTo"], delay: ["tpDelay", "delay"], duration: ["tpDuration", "duration"], hideOnClick: ["tpHideOnClick", "hideOnClick"], interactive: ["tpInteractive", "interactive"], interactiveBorder: ["tpInteractiveBorder", "interactiveBorder"], maxWidth: ["tpMaxWidth", "maxWidth"], offset: ["tpOffset", "offset"], placement: ["tpPlacement", "placement"], popperOptions: ["tpPopperOptions", "popperOptions"], showOnCreate: ["tpShowOnCreate", "showOnCreate"], trigger: ["tpTrigger", "trigger"], triggerTarget: ["tpTriggerTarget", "triggerTarget"], zIndex: ["tpZIndex", "zIndex"], animation: ["tpAnimation", "animation"], useTextContent: ["tpUseTextContent", "useTextContent"], isLazy: ["tpIsLazy", "isLazy"], variation: ["tpVariation", "variation"], isEnabled: ["tpIsEnabled", "isEnabled"], className: ["tpClassName", "className"], onlyTextOverflow: ["tpOnlyTextOverflow", "onlyTextOverflow"], data: ["tpData", "data"], useHostWidth: ["tpUseHostWidth", "useHostWidth"], hideOnEscape: ["tpHideOnEscape", "hideOnEscape"], detectChangesComponent: ["tpDetectChangesComponent", "detectChangesComponent"], popperWidth: ["tpPopperWidth", "popperWidth"], customHost: ["tpHost", "customHost"], isVisible: ["tpIsVisible", "isVisible"] }, outputs: { visible: "tpVisible" }, exportAs: ["tippy"], usesOnChanges: true, ngImport: i0 });
|
|
312
312
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.1", ngImport: i0, type: TippyDirective, decorators: [{
|
|
313
313
|
type: Directive,
|
|
314
314
|
args: [{
|
|
315
315
|
// eslint-disable-next-line @angular-eslint/directive-selector
|
|
316
|
-
selector: '[
|
|
316
|
+
selector: '[tp]',
|
|
317
317
|
exportAs: 'tippy',
|
|
318
318
|
standalone: true
|
|
319
319
|
}]
|
|
@@ -323,68 +323,96 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.1", ngImpor
|
|
|
323
323
|
}] }, { type: undefined, decorators: [{
|
|
324
324
|
type: Inject,
|
|
325
325
|
args: [TIPPY_CONFIG]
|
|
326
|
-
}] }, { type: i0.Injector }, { type: i1.ViewService }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i0.ElementRef }]; }, propDecorators: {
|
|
327
|
-
type: Input
|
|
326
|
+
}] }, { type: i0.Injector }, { type: i1.ViewService }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i0.ElementRef }]; }, propDecorators: { content: [{
|
|
327
|
+
type: Input,
|
|
328
|
+
args: ['tp']
|
|
329
|
+
}], appendTo: [{
|
|
330
|
+
type: Input,
|
|
331
|
+
args: ['tpAppendTo']
|
|
328
332
|
}], delay: [{
|
|
329
|
-
type: Input
|
|
333
|
+
type: Input,
|
|
334
|
+
args: ['tpDelay']
|
|
330
335
|
}], duration: [{
|
|
331
|
-
type: Input
|
|
336
|
+
type: Input,
|
|
337
|
+
args: ['tpDuration']
|
|
332
338
|
}], hideOnClick: [{
|
|
333
|
-
type: Input
|
|
339
|
+
type: Input,
|
|
340
|
+
args: ['tpHideOnClick']
|
|
334
341
|
}], interactive: [{
|
|
335
|
-
type: Input
|
|
342
|
+
type: Input,
|
|
343
|
+
args: ['tpInteractive']
|
|
336
344
|
}], interactiveBorder: [{
|
|
337
|
-
type: Input
|
|
345
|
+
type: Input,
|
|
346
|
+
args: ['tpInteractiveBorder']
|
|
338
347
|
}], maxWidth: [{
|
|
339
|
-
type: Input
|
|
348
|
+
type: Input,
|
|
349
|
+
args: ['tpMaxWidth']
|
|
340
350
|
}], offset: [{
|
|
341
|
-
type: Input
|
|
351
|
+
type: Input,
|
|
352
|
+
args: ['tpOffset']
|
|
342
353
|
}], placement: [{
|
|
343
|
-
type: Input
|
|
354
|
+
type: Input,
|
|
355
|
+
args: ['tpPlacement']
|
|
344
356
|
}], popperOptions: [{
|
|
345
|
-
type: Input
|
|
357
|
+
type: Input,
|
|
358
|
+
args: ['tpPopperOptions']
|
|
346
359
|
}], showOnCreate: [{
|
|
347
|
-
type: Input
|
|
360
|
+
type: Input,
|
|
361
|
+
args: ['tpShowOnCreate']
|
|
348
362
|
}], trigger: [{
|
|
349
|
-
type: Input
|
|
363
|
+
type: Input,
|
|
364
|
+
args: ['tpTrigger']
|
|
350
365
|
}], triggerTarget: [{
|
|
351
|
-
type: Input
|
|
366
|
+
type: Input,
|
|
367
|
+
args: ['tpTriggerTarget']
|
|
352
368
|
}], zIndex: [{
|
|
353
|
-
type: Input
|
|
369
|
+
type: Input,
|
|
370
|
+
args: ['tpZIndex']
|
|
354
371
|
}], animation: [{
|
|
355
|
-
type: Input
|
|
372
|
+
type: Input,
|
|
373
|
+
args: ['tpAnimation']
|
|
356
374
|
}], useTextContent: [{
|
|
357
|
-
type: Input
|
|
358
|
-
|
|
359
|
-
|
|
375
|
+
type: Input,
|
|
376
|
+
args: ['tpUseTextContent']
|
|
377
|
+
}], isLazy: [{
|
|
378
|
+
type: Input,
|
|
379
|
+
args: ['tpIsLazy']
|
|
360
380
|
}], variation: [{
|
|
361
|
-
type: Input
|
|
381
|
+
type: Input,
|
|
382
|
+
args: ['tpVariation']
|
|
362
383
|
}], isEnabled: [{
|
|
363
|
-
type: Input
|
|
384
|
+
type: Input,
|
|
385
|
+
args: ['tpIsEnabled']
|
|
364
386
|
}], className: [{
|
|
365
|
-
type: Input
|
|
387
|
+
type: Input,
|
|
388
|
+
args: ['tpClassName']
|
|
366
389
|
}], onlyTextOverflow: [{
|
|
367
|
-
type: Input
|
|
390
|
+
type: Input,
|
|
391
|
+
args: ['tpOnlyTextOverflow']
|
|
368
392
|
}], data: [{
|
|
369
|
-
type: Input
|
|
393
|
+
type: Input,
|
|
394
|
+
args: ['tpData']
|
|
370
395
|
}], useHostWidth: [{
|
|
371
|
-
type: Input
|
|
396
|
+
type: Input,
|
|
397
|
+
args: ['tpUseHostWidth']
|
|
372
398
|
}], hideOnEscape: [{
|
|
373
|
-
type: Input
|
|
399
|
+
type: Input,
|
|
400
|
+
args: ['tpHideOnEscape']
|
|
374
401
|
}], detectChangesComponent: [{
|
|
375
|
-
type: Input
|
|
402
|
+
type: Input,
|
|
403
|
+
args: ['tpDetectChangesComponent']
|
|
376
404
|
}], popperWidth: [{
|
|
377
|
-
type: Input
|
|
378
|
-
}], content: [{
|
|
379
405
|
type: Input,
|
|
380
|
-
args: ['
|
|
406
|
+
args: ['tpPopperWidth']
|
|
381
407
|
}], customHost: [{
|
|
382
408
|
type: Input,
|
|
383
|
-
args: ['
|
|
384
|
-
}], visible: [{
|
|
385
|
-
type: Output
|
|
409
|
+
args: ['tpHost']
|
|
386
410
|
}], isVisible: [{
|
|
387
|
-
type: Input
|
|
411
|
+
type: Input,
|
|
412
|
+
args: ['tpIsVisible']
|
|
413
|
+
}], visible: [{
|
|
414
|
+
type: Output,
|
|
415
|
+
args: ['tpVisible']
|
|
388
416
|
}] } });
|
|
389
417
|
function isChanged(key, changes) {
|
|
390
418
|
return key in changes;
|
|
@@ -392,4 +420,4 @@ function isChanged(key, changes) {
|
|
|
392
420
|
export function coerceBooleanInput(value) {
|
|
393
421
|
return value != null && `${value}` !== 'false';
|
|
394
422
|
}
|
|
395
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tippy.directive.js","sourceRoot":"","sources":["../../../../../projects/ngneat/helipopper/src/lib/tippy.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Injector,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  PLATFORM_ID,\n  ViewContainerRef\n} from '@angular/core';\nimport { isPlatformServer } from '@angular/common';\nimport tippy, { Instance } from 'tippy.js';\nimport { fromEvent, merge, Subject } from 'rxjs';\nimport { filter, switchMap, takeUntil } from 'rxjs/operators';\nimport { Content, isComponent, isString, isTemplateRef, ViewOptions, ViewRef, ViewService } from '@ngneat/overview';\n\nimport {\n  coerceCssPixelValue,\n  dimensionsChanges,\n  inView,\n  normalizeClassName,\n  onlyTippyProps,\n  overflowChanges\n} from './utils';\nimport { NgChanges, TIPPY_CONFIG, TIPPY_REF, TippyConfig, TippyInstance, TippyProps } from './tippy.types';\n\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: '[tippy]',\n  exportAs: 'tippy',\n  standalone: true\n})\nexport class TippyDirective implements OnChanges, AfterViewInit, OnDestroy, OnInit {\n  static ngAcceptInputType_useTextContent: boolean | '';\n\n  @Input() appendTo: TippyProps['appendTo'];\n  @Input() delay: TippyProps['delay'];\n  @Input() duration: TippyProps['duration'];\n  @Input() hideOnClick: TippyProps['hideOnClick'];\n  @Input() interactive: TippyProps['interactive'];\n  @Input() interactiveBorder: TippyProps['interactiveBorder'];\n  @Input() maxWidth: TippyProps['maxWidth'];\n  @Input() offset: TippyProps['offset'];\n  @Input() placement: TippyProps['placement'];\n  @Input() popperOptions: TippyProps['popperOptions'];\n  @Input() showOnCreate: TippyProps['showOnCreate'];\n  @Input() trigger: TippyProps['trigger'];\n  @Input() triggerTarget: TippyProps['triggerTarget'];\n  @Input() zIndex: TippyProps['zIndex'];\n  @Input() animation: TippyProps['animation'];\n\n  @Input() useTextContent: boolean;\n  @Input() lazy: boolean;\n  @Input() variation: string;\n  @Input() isEnabled: boolean;\n  @Input() className: string | string[];\n  @Input() onlyTextOverflow = false;\n  @Input() data: any;\n  @Input() useHostWidth = false;\n  @Input() hideOnEscape = false;\n  @Input() detectChangesComponent = true;\n  @Input() popperWidth: number | string;\n\n  @Input('tippy') content: Content | undefined | null;\n  @Input('tippyHost') customHost: HTMLElement;\n\n  @Output() visible = new EventEmitter<boolean>();\n  @Input() public isVisible = false;\n\n  protected instance: TippyInstance;\n  protected viewRef: ViewRef;\n  protected destroyed = new Subject<void>();\n  protected props: Partial<TippyConfig>;\n  protected enabled = true;\n  protected variationDefined = false;\n  protected viewOptions$: ViewOptions;\n\n  /**\n   * We had use `visible` event emitter previously as a `takeUntil` subscriber in multiple places\n   * within the directive.\n   * This is for internal use only; thus we don't have to deal with the `visible` event emitter\n   * and trigger change detections only when the `visible` event is being listened outside\n   * in the template (`<button [tippy]=\"...\" (visible)=\"...\"></button>`).\n   */\n  protected visibleInternal = new Subject<boolean>();\n\n  constructor(\n    @Inject(PLATFORM_ID) protected platformId: string,\n    @Inject(TIPPY_CONFIG) protected globalConfig: TippyConfig,\n    protected injector: Injector,\n    protected viewService: ViewService,\n    protected vcr: ViewContainerRef,\n    protected zone: NgZone,\n    protected hostRef: ElementRef\n  ) {}\n\n  ngOnChanges(changes: NgChanges<TippyDirective>) {\n    if (isPlatformServer(this.platformId)) return;\n\n    let props: Partial<TippyConfig> = Object.keys(changes).reduce((acc, change) => {\n      if (change === 'isVisible') return acc;\n\n      acc[change] = changes[change].currentValue;\n\n      return acc;\n    }, {});\n\n    let variation: string;\n\n    if (isChanged<NgChanges<TippyDirective>>('variation', changes)) {\n      variation = changes.variation.currentValue;\n      this.variationDefined = true;\n    } else if (!this.variationDefined) {\n      variation = this.globalConfig.defaultVariation;\n      this.variationDefined = true;\n    }\n\n    if (variation) {\n      props = {\n        ...this.globalConfig.variations[variation],\n        ...props\n      };\n    }\n\n    if (isChanged<NgChanges<TippyDirective>>('isEnabled', changes)) {\n      this.enabled = changes.isEnabled.currentValue;\n      this.setStatus();\n    }\n\n    if (isChanged<NgChanges<TippyDirective>>('isVisible', changes)) {\n      this.isVisible ? this.show() : this.hide();\n    }\n\n    this.setProps({ ...this.props, ...props });\n  }\n\n  ngOnInit() {\n    if (this.useHostWidth) {\n      this.props.maxWidth = this.hostWidth;\n    }\n  }\n\n  ngAfterViewInit() {\n    if (isPlatformServer(this.platformId)) return;\n\n    this.zone.runOutsideAngular(() => {\n      if (this.lazy) {\n        if (this.onlyTextOverflow) {\n          inView(this.host)\n            .pipe(\n              switchMap(() => overflowChanges(this.host)),\n              takeUntil(this.destroyed)\n            )\n            .subscribe(isElementOverflow => {\n              this.checkOverflow(isElementOverflow);\n            });\n        } else {\n          inView(this.host)\n            .pipe(takeUntil(this.destroyed))\n            .subscribe(() => {\n              this.createInstance();\n            });\n        }\n      } else if (this.onlyTextOverflow) {\n        overflowChanges(this.host)\n          .pipe(takeUntil(this.destroyed))\n          .subscribe(isElementOverflow => {\n            this.checkOverflow(isElementOverflow);\n          });\n      } else {\n        this.createInstance();\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this.destroyed.next();\n    this.instance?.destroy();\n    this.destroyView();\n  }\n\n  destroyView() {\n    this.viewOptions$ = null;\n    this.viewRef?.destroy();\n    this.viewRef = null;\n  }\n\n  show() {\n    this.instance?.show();\n  }\n\n  hide() {\n    this.instance?.hide();\n  }\n\n  enable() {\n    this.instance?.enable();\n  }\n\n  disable() {\n    this.instance?.disable();\n  }\n\n  protected setProps(props: Partial<TippyConfig>) {\n    this.props = props;\n    this.instance?.setProps(onlyTippyProps(props));\n  }\n\n  protected setStatus() {\n    this.enabled ? this.instance?.enable() : this.instance?.disable();\n  }\n\n  protected get host(): HTMLElement {\n    return this.customHost || this.hostRef.nativeElement;\n  }\n\n  protected get hostWidth(): number {\n    return this.host.getBoundingClientRect().width;\n  }\n\n  protected createInstance() {\n    if (!this.content && !coerceBooleanInput(this.useTextContent)) {\n      return;\n    }\n\n    this.zone.runOutsideAngular(() => {\n      this.instance = tippy(this.host, {\n        allowHTML: true,\n        appendTo: document.body,\n        ...onlyTippyProps(this.globalConfig),\n        ...onlyTippyProps(this.props),\n        onMount: instance => {\n          this.isVisible = true;\n          this.visibleInternal.next(this.isVisible);\n          if (this.visible.observed) {\n            this.zone.run(() => this.visible.next(this.isVisible));\n          }\n          this.useHostWidth && this.listenToHostResize();\n          this.globalConfig.onMount?.(instance);\n        },\n        onCreate: instance => {\n          instance.popper.classList.add(`tippy-variation-${this.variation || this.globalConfig.defaultVariation}`);\n          if (this.className) {\n            for (const klass of normalizeClassName(this.className)) {\n              instance.popper.classList.add(klass);\n            }\n          }\n          this.globalConfig.onCreate?.(instance);\n          if (this.isVisible === true) {\n            instance.show();\n          }\n        },\n        onShow: instance => {\n          instance.reference.setAttribute('data-tippy-open', '');\n          this.zone.run(() => {\n            const content = this.resolveContent(instance);\n            if (isString(content)) {\n              instance.setProps({ allowHTML: false });\n\n              if (!content?.trim()) {\n                this.disable();\n              } else {\n                this.enable();\n              }\n            }\n\n            instance.setContent(content);\n            this.hideOnEscape && this.handleEscapeButton();\n          });\n          if (this.useHostWidth) {\n            this.setInstanceWidth(instance, this.hostWidth);\n          } else if (this.popperWidth) {\n            this.setInstanceWidth(instance, this.popperWidth);\n          }\n          this.globalConfig.onShow?.(instance);\n        },\n        onHide(instance) {\n          instance.reference.removeAttribute('data-tippy-open');\n        },\n        onHidden: instance => {\n          this.destroyView();\n          this.isVisible = false;\n          this.visibleInternal.next(this.isVisible);\n          if (this.visible.observed) {\n            this.zone.run(() => this.visible.next(this.isVisible));\n          }\n          this.globalConfig.onHidden?.(instance);\n        }\n      });\n\n      this.setStatus();\n      this.setProps(this.props);\n\n      this.variation === 'contextMenu' && this.handleContextMenu();\n    });\n  }\n\n  protected resolveContent(instance: TippyInstance) {\n    if (!this.viewOptions$ && !isString(this.content)) {\n      if (isComponent(this.content)) {\n        this.instance.data = this.data;\n        this.viewOptions$ = {\n          injector: Injector.create({\n            providers: [\n              {\n                provide: TIPPY_REF,\n                useValue: this.instance\n              }\n            ],\n            parent: this.injector\n          })\n        };\n      } else if (isTemplateRef(this.content)) {\n        this.viewOptions$ = {\n          context: {\n            $implicit: this.hide.bind(this),\n            data: this.data\n          }\n        };\n      }\n    }\n\n    this.viewRef = this.viewService.createView(this.content, {\n      vcr: this.vcr,\n      ...this.viewOptions$\n    });\n\n    // We need to call detectChanges for onPush components to update the content\n    if (this.detectChangesComponent && isComponent(this.content)) {\n      this.viewRef.detectChanges();\n    }\n\n    let content = this.viewRef.getElement();\n\n    if (coerceBooleanInput(this.useTextContent)) {\n      content = instance.reference.textContent;\n    }\n\n    if (isString(content) && this.globalConfig.beforeRender) {\n      content = this.globalConfig.beforeRender(content);\n    }\n\n    return content;\n  }\n\n  protected handleContextMenu() {\n    fromEvent(this.host, 'contextmenu')\n      .pipe(takeUntil(this.destroyed))\n      .subscribe((event: MouseEvent) => {\n        event.preventDefault();\n\n        this.instance.setProps({\n          getReferenceClientRect: () =>\n            ({\n              width: 0,\n              height: 0,\n              top: event.clientY,\n              bottom: event.clientY,\n              left: event.clientX,\n              right: event.clientX\n            } as DOMRectReadOnly)\n        });\n\n        this.instance.show();\n      });\n  }\n\n  protected handleEscapeButton(): void {\n    this.zone.runOutsideAngular(() => {\n      fromEvent(document.body, 'keydown')\n        .pipe(\n          filter(({ code }: KeyboardEvent) => code === 'Escape'),\n          takeUntil(merge(this.destroyed, this.visibleInternal.pipe(filter(v => !v))))\n        )\n        .subscribe(() => this.hide());\n    });\n  }\n\n  protected checkOverflow(isElementOverflow: boolean) {\n    if (isElementOverflow) {\n      if (!this.instance) {\n        this.createInstance();\n      } else {\n        this.instance.enable();\n      }\n    } else {\n      this.instance?.disable();\n    }\n  }\n\n  protected listenToHostResize() {\n    dimensionsChanges(this.host)\n      .pipe(takeUntil(merge(this.destroyed, this.visibleInternal)))\n      .subscribe(() => {\n        this.setInstanceWidth(this.instance, this.hostWidth);\n      });\n  }\n\n  protected setInstanceWidth(instance: Instance, width: string | number) {\n    const inPixels = coerceCssPixelValue(width);\n    instance.popper.style.width = inPixels;\n    instance.popper.style.maxWidth = inPixels;\n    (instance.popper.firstElementChild as HTMLElement).style.maxWidth = inPixels;\n  }\n}\n\nfunction isChanged<T extends object>(key: keyof T, changes: T) {\n  return key in changes;\n}\n\nexport function coerceBooleanInput(value: any): boolean {\n  return value != null && `${value}` !== 'false';\n}\n"]}
|
|
423
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tippy.directive.js","sourceRoot":"","sources":["../../../../../projects/ngneat/helipopper/src/lib/tippy.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Injector,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  PLATFORM_ID,\n  ViewContainerRef\n} from '@angular/core';\nimport { isPlatformServer } from '@angular/common';\nimport tippy, { Instance } from 'tippy.js';\nimport { fromEvent, merge, Subject } from 'rxjs';\nimport { filter, switchMap, takeUntil } from 'rxjs/operators';\nimport { Content, isComponent, isString, isTemplateRef, ViewOptions, ViewRef, ViewService } from '@ngneat/overview';\n\nimport {\n  coerceCssPixelValue,\n  dimensionsChanges,\n  inView,\n  normalizeClassName,\n  onlyTippyProps,\n  overflowChanges\n} from './utils';\nimport { NgChanges, TIPPY_CONFIG, TIPPY_REF, TippyConfig, TippyInstance, TippyProps } from './tippy.types';\n\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: '[tp]',\n  exportAs: 'tippy',\n  standalone: true\n})\nexport class TippyDirective implements OnChanges, AfterViewInit, OnDestroy, OnInit {\n  @Input('tp') content: Content | undefined | null;\n  @Input('tpAppendTo') appendTo: TippyProps['appendTo'];\n  @Input('tpDelay') delay: TippyProps['delay'];\n  @Input('tpDuration') duration: TippyProps['duration'];\n  @Input('tpHideOnClick') hideOnClick: TippyProps['hideOnClick'];\n  @Input('tpInteractive') interactive: TippyProps['interactive'];\n  @Input('tpInteractiveBorder') interactiveBorder: TippyProps['interactiveBorder'];\n  @Input('tpMaxWidth') maxWidth: TippyProps['maxWidth'];\n  @Input('tpOffset') offset: TippyProps['offset'];\n  @Input('tpPlacement') placement: TippyProps['placement'];\n  @Input('tpPopperOptions') popperOptions: TippyProps['popperOptions'];\n  @Input('tpShowOnCreate') showOnCreate: TippyProps['showOnCreate'];\n  @Input('tpTrigger') trigger: TippyProps['trigger'];\n  @Input('tpTriggerTarget') triggerTarget: TippyProps['triggerTarget'];\n  @Input('tpZIndex') zIndex: TippyProps['zIndex'];\n  @Input('tpAnimation') animation: TippyProps['animation'];\n  @Input('tpUseTextContent') useTextContent: boolean;\n  @Input('tpIsLazy') isLazy: boolean;\n  @Input('tpVariation') variation: string;\n  @Input('tpIsEnabled') isEnabled: boolean;\n  @Input('tpClassName') className: string | string[];\n  @Input('tpOnlyTextOverflow') onlyTextOverflow = false;\n  @Input('tpData') data: any;\n  @Input('tpUseHostWidth') useHostWidth = false;\n  @Input('tpHideOnEscape') hideOnEscape = false;\n  @Input('tpDetectChangesComponent') detectChangesComponent = true;\n  @Input('tpPopperWidth') popperWidth: number | string;\n  @Input('tpHost') customHost: HTMLElement;\n  @Input('tpIsVisible') isVisible = false;\n\n  @Output('tpVisible') visible = new EventEmitter<boolean>();\n\n  protected instance: TippyInstance;\n  protected viewRef: ViewRef;\n  protected destroyed = new Subject<void>();\n  protected props: Partial<TippyConfig>;\n  protected enabled = true;\n  protected variationDefined = false;\n  protected viewOptions$: ViewOptions;\n\n  /**\n   * We had use `visible` event emitter previously as a `takeUntil` subscriber in multiple places\n   * within the directive.\n   * This is for internal use only; thus we don't have to deal with the `visible` event emitter\n   * and trigger change detections only when the `visible` event is being listened outside\n   * in the template (`<button [tippy]=\"...\" (visible)=\"...\"></button>`).\n   */\n  protected visibleInternal = new Subject<boolean>();\n\n  constructor(\n    @Inject(PLATFORM_ID) protected platformId: string,\n    @Inject(TIPPY_CONFIG) protected globalConfig: TippyConfig,\n    protected injector: Injector,\n    protected viewService: ViewService,\n    protected vcr: ViewContainerRef,\n    protected zone: NgZone,\n    protected hostRef: ElementRef\n  ) {}\n\n  ngOnChanges(changes: NgChanges<TippyDirective>) {\n    if (isPlatformServer(this.platformId)) return;\n\n    let props: Partial<TippyConfig> = Object.keys(changes).reduce((acc, change) => {\n      if (change === 'isVisible') return acc;\n\n      acc[change] = changes[change].currentValue;\n\n      return acc;\n    }, {});\n\n    let variation: string;\n\n    if (isChanged<NgChanges<TippyDirective>>('variation', changes)) {\n      variation = changes.variation.currentValue;\n      this.variationDefined = true;\n    } else if (!this.variationDefined) {\n      variation = this.globalConfig.defaultVariation;\n      this.variationDefined = true;\n    }\n\n    if (variation) {\n      props = {\n        ...this.globalConfig.variations[variation],\n        ...props\n      };\n    }\n\n    if (isChanged<NgChanges<TippyDirective>>('isEnabled', changes)) {\n      this.enabled = changes.isEnabled.currentValue;\n      this.setStatus();\n    }\n\n    if (isChanged<NgChanges<TippyDirective>>('isVisible', changes)) {\n      this.isVisible ? this.show() : this.hide();\n    }\n\n    this.setProps({ ...this.props, ...props });\n  }\n\n  ngOnInit() {\n    if (this.useHostWidth) {\n      this.props.maxWidth = this.hostWidth;\n    }\n  }\n\n  ngAfterViewInit() {\n    if (isPlatformServer(this.platformId)) return;\n\n    this.zone.runOutsideAngular(() => {\n      if (this.isLazy) {\n        if (this.onlyTextOverflow) {\n          inView(this.host)\n            .pipe(\n              switchMap(() => overflowChanges(this.host)),\n              takeUntil(this.destroyed)\n            )\n            .subscribe(isElementOverflow => {\n              this.checkOverflow(isElementOverflow);\n            });\n        } else {\n          inView(this.host)\n            .pipe(takeUntil(this.destroyed))\n            .subscribe(() => {\n              this.createInstance();\n            });\n        }\n      } else if (this.onlyTextOverflow) {\n        overflowChanges(this.host)\n          .pipe(takeUntil(this.destroyed))\n          .subscribe(isElementOverflow => {\n            this.checkOverflow(isElementOverflow);\n          });\n      } else {\n        this.createInstance();\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this.destroyed.next();\n    this.instance?.destroy();\n    this.destroyView();\n  }\n\n  destroyView() {\n    this.viewOptions$ = null;\n    this.viewRef?.destroy();\n    this.viewRef = null;\n  }\n\n  show() {\n    this.instance?.show();\n  }\n\n  hide() {\n    this.instance?.hide();\n  }\n\n  enable() {\n    this.instance?.enable();\n  }\n\n  disable() {\n    this.instance?.disable();\n  }\n\n  protected setProps(props: Partial<TippyConfig>) {\n    this.props = props;\n    this.instance?.setProps(onlyTippyProps(props));\n  }\n\n  protected setStatus() {\n    this.enabled ? this.instance?.enable() : this.instance?.disable();\n  }\n\n  protected get host(): HTMLElement {\n    return this.customHost || this.hostRef.nativeElement;\n  }\n\n  protected get hostWidth(): number {\n    return this.host.getBoundingClientRect().width;\n  }\n\n  protected createInstance() {\n    if (!this.content && !coerceBooleanInput(this.useTextContent)) {\n      return;\n    }\n\n    this.zone.runOutsideAngular(() => {\n      this.instance = tippy(this.host, {\n        allowHTML: true,\n        appendTo: document.body,\n        ...onlyTippyProps(this.globalConfig),\n        ...onlyTippyProps(this.props),\n        onMount: instance => {\n          this.isVisible = true;\n          this.visibleInternal.next(this.isVisible);\n          if (this.visible.observed) {\n            this.zone.run(() => this.visible.next(this.isVisible));\n          }\n          this.useHostWidth && this.listenToHostResize();\n          this.globalConfig.onMount?.(instance);\n        },\n        onCreate: instance => {\n          instance.popper.classList.add(`tippy-variation-${this.variation || this.globalConfig.defaultVariation}`);\n          if (this.className) {\n            for (const klass of normalizeClassName(this.className)) {\n              instance.popper.classList.add(klass);\n            }\n          }\n          this.globalConfig.onCreate?.(instance);\n          if (this.isVisible === true) {\n            instance.show();\n          }\n        },\n        onShow: instance => {\n          instance.reference.setAttribute('data-tippy-open', '');\n          this.zone.run(() => {\n            const content = this.resolveContent(instance);\n            if (isString(content)) {\n              instance.setProps({ allowHTML: false });\n\n              if (!content?.trim()) {\n                this.disable();\n              } else {\n                this.enable();\n              }\n            }\n\n            instance.setContent(content);\n            this.hideOnEscape && this.handleEscapeButton();\n          });\n          if (this.useHostWidth) {\n            this.setInstanceWidth(instance, this.hostWidth);\n          } else if (this.popperWidth) {\n            this.setInstanceWidth(instance, this.popperWidth);\n          }\n          this.globalConfig.onShow?.(instance);\n        },\n        onHide(instance) {\n          instance.reference.removeAttribute('data-tippy-open');\n        },\n        onHidden: instance => {\n          this.destroyView();\n          this.isVisible = false;\n          this.visibleInternal.next(this.isVisible);\n          if (this.visible.observed) {\n            this.zone.run(() => this.visible.next(this.isVisible));\n          }\n          this.globalConfig.onHidden?.(instance);\n        }\n      });\n\n      this.setStatus();\n      this.setProps(this.props);\n\n      this.variation === 'contextMenu' && this.handleContextMenu();\n    });\n  }\n\n  protected resolveContent(instance: TippyInstance) {\n    if (!this.viewOptions$ && !isString(this.content)) {\n      if (isComponent(this.content)) {\n        this.instance.data = this.data;\n        this.viewOptions$ = {\n          injector: Injector.create({\n            providers: [\n              {\n                provide: TIPPY_REF,\n                useValue: this.instance\n              }\n            ],\n            parent: this.injector\n          })\n        };\n      } else if (isTemplateRef(this.content)) {\n        this.viewOptions$ = {\n          context: {\n            $implicit: this.hide.bind(this),\n            data: this.data\n          }\n        };\n      }\n    }\n\n    this.viewRef = this.viewService.createView(this.content, {\n      vcr: this.vcr,\n      ...this.viewOptions$\n    });\n\n    // We need to call detectChanges for onPush components to update the content\n    if (this.detectChangesComponent && isComponent(this.content)) {\n      this.viewRef.detectChanges();\n    }\n\n    let content = this.viewRef.getElement();\n\n    if (coerceBooleanInput(this.useTextContent)) {\n      content = instance.reference.textContent;\n    }\n\n    if (isString(content) && this.globalConfig.beforeRender) {\n      content = this.globalConfig.beforeRender(content);\n    }\n\n    return content;\n  }\n\n  protected handleContextMenu() {\n    fromEvent(this.host, 'contextmenu')\n      .pipe(takeUntil(this.destroyed))\n      .subscribe((event: MouseEvent) => {\n        event.preventDefault();\n\n        this.instance.setProps({\n          getReferenceClientRect: () =>\n            ({\n              width: 0,\n              height: 0,\n              top: event.clientY,\n              bottom: event.clientY,\n              left: event.clientX,\n              right: event.clientX\n            } as DOMRectReadOnly)\n        });\n\n        this.instance.show();\n      });\n  }\n\n  protected handleEscapeButton(): void {\n    this.zone.runOutsideAngular(() => {\n      fromEvent(document.body, 'keydown')\n        .pipe(\n          filter(({ code }: KeyboardEvent) => code === 'Escape'),\n          takeUntil(merge(this.destroyed, this.visibleInternal.pipe(filter(v => !v))))\n        )\n        .subscribe(() => this.hide());\n    });\n  }\n\n  protected checkOverflow(isElementOverflow: boolean) {\n    if (isElementOverflow) {\n      if (!this.instance) {\n        this.createInstance();\n      } else {\n        this.instance.enable();\n      }\n    } else {\n      this.instance?.disable();\n    }\n  }\n\n  protected listenToHostResize() {\n    dimensionsChanges(this.host)\n      .pipe(takeUntil(merge(this.destroyed, this.visibleInternal)))\n      .subscribe(() => {\n        this.setInstanceWidth(this.instance, this.hostWidth);\n      });\n  }\n\n  protected setInstanceWidth(instance: Instance, width: string | number) {\n    const inPixels = coerceCssPixelValue(width);\n    instance.popper.style.width = inPixels;\n    instance.popper.style.maxWidth = inPixels;\n    (instance.popper.firstElementChild as HTMLElement).style.maxWidth = inPixels;\n  }\n}\n\nfunction isChanged<T extends object>(key: keyof T, changes: T) {\n  return key in changes;\n}\n\nexport function coerceBooleanInput(value: any): boolean {\n  return value != null && `${value}` !== 'false';\n}\n"]}
|