@ngneat/helipopper 7.1.1 → 8.0.1
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/esm2022/lib/tippy.directive.mjs +472 -0
- package/{esm2020 → esm2022}/lib/tippy.service.mjs +4 -4
- package/esm2022/lib/utils.mjs +125 -0
- package/{fesm2020 → fesm2022}/ngneat-helipopper.mjs +107 -42
- package/fesm2022/ngneat-helipopper.mjs.map +1 -0
- package/lib/defaults.d.ts +1 -1
- package/lib/tippy.directive.d.ts +12 -2
- package/lib/tippy.types.d.ts +5 -5
- package/lib/utils.d.ts +1 -0
- package/package.json +9 -15
- package/esm2020/lib/tippy.directive.mjs +0 -424
- package/esm2020/lib/utils.mjs +0 -108
- package/fesm2015/ngneat-helipopper.mjs +0 -635
- package/fesm2015/ngneat-helipopper.mjs.map +0 -1
- package/fesm2020/ngneat-helipopper.mjs.map +0 -1
- /package/{esm2020 → esm2022}/lib/defaults.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/tippy.types.mjs +0 -0
- /package/{esm2020 → esm2022}/ngneat-helipopper.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
package/esm2020/lib/utils.mjs
DELETED
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
import { Observable } from 'rxjs';
|
|
2
|
-
import { auditTime, map } from 'rxjs/operators';
|
|
3
|
-
import { ElementRef } from '@angular/core';
|
|
4
|
-
let supportsIntersectionObserver = false;
|
|
5
|
-
let supportsResizeObserver = false;
|
|
6
|
-
if (typeof window !== 'undefined') {
|
|
7
|
-
supportsIntersectionObserver = 'IntersectionObserver' in window;
|
|
8
|
-
supportsResizeObserver = 'ResizeObserver' in window;
|
|
9
|
-
}
|
|
10
|
-
export function inView(host, options = {
|
|
11
|
-
root: null,
|
|
12
|
-
threshold: 0.3
|
|
13
|
-
}) {
|
|
14
|
-
const element = coerceElement(host);
|
|
15
|
-
return new Observable(subscriber => {
|
|
16
|
-
if (!supportsIntersectionObserver) {
|
|
17
|
-
subscriber.next();
|
|
18
|
-
subscriber.complete();
|
|
19
|
-
return;
|
|
20
|
-
}
|
|
21
|
-
const observer = new IntersectionObserver(entries => {
|
|
22
|
-
// Several changes may occur in the same tick, we want to check the latest entry state.
|
|
23
|
-
const entry = entries[entries.length - 1];
|
|
24
|
-
if (entry.isIntersecting) {
|
|
25
|
-
subscriber.next();
|
|
26
|
-
subscriber.complete();
|
|
27
|
-
}
|
|
28
|
-
}, options);
|
|
29
|
-
observer.observe(element);
|
|
30
|
-
return () => observer.disconnect();
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
function isElementOverflow(host) {
|
|
34
|
-
// Don't access the `offsetWidth` multipe times since it triggers layout updates.
|
|
35
|
-
const hostOffsetWidth = host.offsetWidth;
|
|
36
|
-
return hostOffsetWidth > host.parentElement.offsetWidth || hostOffsetWidth < host.scrollWidth;
|
|
37
|
-
}
|
|
38
|
-
export function overflowChanges(host) {
|
|
39
|
-
const element = coerceElement(host);
|
|
40
|
-
return dimensionsChanges(element).pipe(auditTime(150), map(() => isElementOverflow(element)));
|
|
41
|
-
}
|
|
42
|
-
export function dimensionsChanges(target) {
|
|
43
|
-
return resizeObserverStrategy(target);
|
|
44
|
-
}
|
|
45
|
-
function resizeObserverStrategy(target) {
|
|
46
|
-
return new Observable(subscriber => {
|
|
47
|
-
if (!supportsResizeObserver) {
|
|
48
|
-
subscriber.next();
|
|
49
|
-
subscriber.complete();
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
const observer = new ResizeObserver(() => subscriber.next(true));
|
|
53
|
-
observer.observe(target);
|
|
54
|
-
return () => observer.disconnect();
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
export function onlyTippyProps(allProps) {
|
|
58
|
-
const tippyProps = {};
|
|
59
|
-
const ownProps = [
|
|
60
|
-
'useTextContent',
|
|
61
|
-
'variations',
|
|
62
|
-
'useHostWidth',
|
|
63
|
-
'defaultVariation',
|
|
64
|
-
'beforeRender',
|
|
65
|
-
'isLazy',
|
|
66
|
-
'variation',
|
|
67
|
-
'isEnabled',
|
|
68
|
-
'className',
|
|
69
|
-
'onlyTextOverflow',
|
|
70
|
-
'data',
|
|
71
|
-
'content',
|
|
72
|
-
'context',
|
|
73
|
-
'hideOnEscape',
|
|
74
|
-
'customHost',
|
|
75
|
-
'injector',
|
|
76
|
-
'preserveView',
|
|
77
|
-
'vcr',
|
|
78
|
-
'popperWidth',
|
|
79
|
-
'zIndexGetter'
|
|
80
|
-
];
|
|
81
|
-
const overriddenMethods = ['onShow', 'onHidden', 'onCreate'];
|
|
82
|
-
Object.keys(allProps).forEach(prop => {
|
|
83
|
-
if (!ownProps.includes(prop) && !overriddenMethods.includes(prop)) {
|
|
84
|
-
tippyProps[prop] = allProps[prop];
|
|
85
|
-
}
|
|
86
|
-
});
|
|
87
|
-
return tippyProps;
|
|
88
|
-
}
|
|
89
|
-
export function normalizeClassName(className) {
|
|
90
|
-
const classes = isString(className) ? className.split(' ') : className;
|
|
91
|
-
return classes.map(klass => klass?.trim()).filter(Boolean);
|
|
92
|
-
}
|
|
93
|
-
export function coerceCssPixelValue(value) {
|
|
94
|
-
if (isNil(value)) {
|
|
95
|
-
return '';
|
|
96
|
-
}
|
|
97
|
-
return typeof value === 'string' ? value : `${value}px`;
|
|
98
|
-
}
|
|
99
|
-
function isString(value) {
|
|
100
|
-
return typeof value === 'string';
|
|
101
|
-
}
|
|
102
|
-
function isNil(value) {
|
|
103
|
-
return value === undefined || value === null;
|
|
104
|
-
}
|
|
105
|
-
function coerceElement(element) {
|
|
106
|
-
return element instanceof ElementRef ? element.nativeElement : element;
|
|
107
|
-
}
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../projects/ngneat/helipopper/src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable } from 'rxjs';\nimport { auditTime, map } from 'rxjs/operators';\nimport { TippyElement } from './tippy.types';\nimport { ElementRef } from '@angular/core';\n\ndeclare const ResizeObserver: any;\n\nlet supportsIntersectionObserver = false;\nlet supportsResizeObserver = false;\n\nif (typeof window !== 'undefined') {\n  supportsIntersectionObserver = 'IntersectionObserver' in window;\n  supportsResizeObserver = 'ResizeObserver' in window;\n}\n\nexport function inView(\n  host: TippyElement,\n  options: IntersectionObserverInit = {\n    root: null,\n    threshold: 0.3\n  }\n) {\n  const element = coerceElement(host);\n\n  return new Observable(subscriber => {\n    if (!supportsIntersectionObserver) {\n      subscriber.next();\n      subscriber.complete();\n      return;\n    }\n\n    const observer = new IntersectionObserver(entries => {\n      // Several changes may occur in the same tick, we want to check the latest entry state.\n      const entry = entries[entries.length - 1];\n      if (entry.isIntersecting) {\n        subscriber.next();\n        subscriber.complete();\n      }\n    }, options);\n\n    observer.observe(element);\n\n    return () => observer.disconnect();\n  });\n}\n\nfunction isElementOverflow(host: HTMLElement): boolean {\n  // Don't access the `offsetWidth` multipe times since it triggers layout updates.\n  const hostOffsetWidth = host.offsetWidth;\n  return hostOffsetWidth > host.parentElement.offsetWidth || hostOffsetWidth < host.scrollWidth;\n}\n\nexport function overflowChanges(host: TippyElement) {\n  const element = coerceElement(host);\n\n  return dimensionsChanges(element).pipe(\n    auditTime(150),\n    map(() => isElementOverflow(element))\n  );\n}\n\nexport function dimensionsChanges(target: HTMLElement) {\n  return resizeObserverStrategy(target);\n}\n\nfunction resizeObserverStrategy(target: HTMLElement): Observable<boolean> {\n  return new Observable(subscriber => {\n    if (!supportsResizeObserver) {\n      subscriber.next();\n      subscriber.complete();\n      return;\n    }\n\n    const observer = new ResizeObserver(() => subscriber.next(true));\n    observer.observe(target);\n    return () => observer.disconnect();\n  });\n}\n\nexport function onlyTippyProps(allProps: any) {\n  const tippyProps = {};\n\n  const ownProps = [\n    'useTextContent',\n    'variations',\n    'useHostWidth',\n    'defaultVariation',\n    'beforeRender',\n    'isLazy',\n    'variation',\n    'isEnabled',\n    'className',\n    'onlyTextOverflow',\n    'data',\n    'content',\n    'context',\n    'hideOnEscape',\n    'customHost',\n    'injector',\n    'preserveView',\n    'vcr',\n    'popperWidth',\n    'zIndexGetter'\n  ];\n\n  const overriddenMethods = ['onShow', 'onHidden', 'onCreate'];\n\n  Object.keys(allProps).forEach(prop => {\n    if (!ownProps.includes(prop) && !overriddenMethods.includes(prop)) {\n      tippyProps[prop] = allProps[prop];\n    }\n  });\n\n  return tippyProps;\n}\n\nexport function normalizeClassName(className: string | string[]): string[] {\n  const classes = isString(className) ? className.split(' ') : className;\n\n  return classes.map(klass => klass?.trim()).filter(Boolean);\n}\n\nexport function coerceCssPixelValue<T>(value: T): string {\n  if (isNil(value)) {\n    return '';\n  }\n\n  return typeof value === 'string' ? value : `${value}px`;\n}\n\nfunction isString(value: unknown): value is string {\n  return typeof value === 'string';\n}\n\nfunction isNil(value: any): value is undefined | null {\n  return value === undefined || value === null;\n}\n\nfunction coerceElement(element: TippyElement) {\n  return element instanceof ElementRef ? element.nativeElement : element;\n}\n"]}
|