cps-ui-kit 0.27.0 → 0.28.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 +1 -0
- package/esm2020/lib/directives/cps-tooltip.directive.mjs +201 -0
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/cps-ui-kit.mjs +201 -1
- package/fesm2015/cps-ui-kit.mjs.map +1 -1
- package/fesm2020/cps-ui-kit.mjs +199 -1
- package/fesm2020/cps-ui-kit.mjs.map +1 -1
- package/lib/directives/cps-tooltip.directive.d.ts +35 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/styles/cps-tooltip-style.scss +13 -0
- package/styles/styles.scss +2 -1
- /package/styles/{_variables.scss → variables.scss} +0 -0
package/README.md
CHANGED
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
import { Directive, HostListener, Input } from '@angular/core';
|
|
2
|
+
import { convertSize } from '../utils/size-utils';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class CpsTooltipDirective {
|
|
5
|
+
// eslint-disable-next-line no-useless-constructor
|
|
6
|
+
constructor(_elementRef) {
|
|
7
|
+
this._elementRef = _elementRef;
|
|
8
|
+
this.tooltipOpenDelay = 300;
|
|
9
|
+
this.tooltipCloseDelay = 300;
|
|
10
|
+
this.tooltipOpenOn = 'hover';
|
|
11
|
+
this.tooltipPosition = 'top';
|
|
12
|
+
this.tooltipPersistent = false;
|
|
13
|
+
this.tooltipDisabled = false;
|
|
14
|
+
this.tooltipMaxWidth = '100%';
|
|
15
|
+
this.tooltipContentClass = 'cps-tooltip-content';
|
|
16
|
+
this._createTooltip = () => {
|
|
17
|
+
if (this._popup)
|
|
18
|
+
this._destroyTooltip();
|
|
19
|
+
if (this.tooltipDisabled)
|
|
20
|
+
return;
|
|
21
|
+
this._popup = document.createElement('div');
|
|
22
|
+
this._constructElement(this._popup);
|
|
23
|
+
if (this.tooltipPersistent)
|
|
24
|
+
this._popup.addEventListener('click', this._destroyTooltip);
|
|
25
|
+
window.addEventListener('scroll', this._destroyTooltip, true);
|
|
26
|
+
};
|
|
27
|
+
this._destroyTooltip = () => {
|
|
28
|
+
window.removeEventListener('scroll', this._destroyTooltip, true);
|
|
29
|
+
this._popup?.removeEventListener('click', this._destroyTooltip);
|
|
30
|
+
this._popup?.remove();
|
|
31
|
+
this._popup = undefined;
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
ngOnDestroy() {
|
|
35
|
+
this._destroyTooltip();
|
|
36
|
+
}
|
|
37
|
+
_constructElement(popup) {
|
|
38
|
+
const popupContent = document.createElement('div');
|
|
39
|
+
popupContent.innerHTML = this.tooltip || 'Add your text to this tooltip';
|
|
40
|
+
popupContent.classList.add(this.tooltipContentClass);
|
|
41
|
+
popup.appendChild(popupContent);
|
|
42
|
+
popup.classList.add('cps-tooltip');
|
|
43
|
+
popup.style.maxWidth = convertSize(this.tooltipMaxWidth);
|
|
44
|
+
document.body.appendChild(popup);
|
|
45
|
+
const coords = this._getCoords();
|
|
46
|
+
if (!coords) {
|
|
47
|
+
this._destroyTooltip();
|
|
48
|
+
throw new Error('Not enough space on the screen for the tooltip!');
|
|
49
|
+
}
|
|
50
|
+
popup.style.left = coords.left.toString() + 'px';
|
|
51
|
+
popup.style.top = coords.top.toString() + 'px';
|
|
52
|
+
}
|
|
53
|
+
_getCoords() {
|
|
54
|
+
function isInsideScreen(coords) {
|
|
55
|
+
return (coords.top >= 0 &&
|
|
56
|
+
coords.left >= 0 &&
|
|
57
|
+
coords.left + popupRect.width <= window.innerWidth &&
|
|
58
|
+
coords.top + popupRect.height <= window.innerHeight);
|
|
59
|
+
}
|
|
60
|
+
let positions = ['top', 'bottom', 'left', 'right'];
|
|
61
|
+
positions = positions.filter((item) => item !== this.tooltipPosition);
|
|
62
|
+
positions.unshift(this.tooltipPosition);
|
|
63
|
+
const targetEl = this._elementRef.nativeElement;
|
|
64
|
+
const targetElRect = targetEl.getBoundingClientRect();
|
|
65
|
+
const popupRect = this._popup.getBoundingClientRect();
|
|
66
|
+
for (const pos of positions) {
|
|
67
|
+
const coords = this._getCoordsForPosition(pos, targetEl, targetElRect, popupRect);
|
|
68
|
+
if (isInsideScreen(coords)) {
|
|
69
|
+
return coords;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return undefined;
|
|
73
|
+
}
|
|
74
|
+
_getCoordsForPosition(position, targetEl, targetElRect, popupRect) {
|
|
75
|
+
switch (position) {
|
|
76
|
+
case 'bottom':
|
|
77
|
+
return {
|
|
78
|
+
left: targetElRect.left +
|
|
79
|
+
window.scrollX +
|
|
80
|
+
(targetEl.offsetWidth - popupRect.width) / 2,
|
|
81
|
+
top: targetElRect.bottom + window.scrollY + 8
|
|
82
|
+
};
|
|
83
|
+
case 'left':
|
|
84
|
+
return {
|
|
85
|
+
left: targetElRect.left - window.scrollX - popupRect.width - 8,
|
|
86
|
+
top: targetElRect.top +
|
|
87
|
+
window.scrollY +
|
|
88
|
+
(targetEl.offsetHeight - popupRect.height) / 2
|
|
89
|
+
};
|
|
90
|
+
case 'right':
|
|
91
|
+
return {
|
|
92
|
+
left: targetElRect.right + window.scrollX + 8,
|
|
93
|
+
top: targetElRect.top +
|
|
94
|
+
window.scrollY +
|
|
95
|
+
(targetEl.offsetHeight - popupRect.height) / 2
|
|
96
|
+
};
|
|
97
|
+
default:
|
|
98
|
+
return {
|
|
99
|
+
left: targetElRect.left +
|
|
100
|
+
window.scrollX +
|
|
101
|
+
(targetEl.offsetWidth - popupRect.width) / 2,
|
|
102
|
+
top: targetElRect.top + window.scrollY - popupRect.height - 8
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
onMouseEnter() {
|
|
107
|
+
if (this.tooltipOpenOn === 'hover') {
|
|
108
|
+
clearTimeout(this._hideTimeout);
|
|
109
|
+
this._showTimeout = setTimeout(this._createTooltip, this.tooltipOpenDelay);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
onMouseLeave() {
|
|
113
|
+
clearTimeout(this._showTimeout);
|
|
114
|
+
if (!this.tooltipPersistent) {
|
|
115
|
+
this._hideTimeout = setTimeout(this._destroyTooltip, this.tooltipCloseDelay);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
onFocus() {
|
|
119
|
+
if (this.tooltipOpenOn === 'focus') {
|
|
120
|
+
clearTimeout(this._hideTimeout);
|
|
121
|
+
this._showTimeout = setTimeout(this._createTooltip, this.tooltipOpenDelay);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
onBlur() {
|
|
125
|
+
clearTimeout(this._showTimeout);
|
|
126
|
+
if (!this.tooltipPersistent && this.tooltipOpenOn === 'focus') {
|
|
127
|
+
this._hideTimeout = setTimeout(this._destroyTooltip, this.tooltipCloseDelay);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
onClick() {
|
|
131
|
+
if (this.tooltipOpenOn === 'click') {
|
|
132
|
+
clearTimeout(this._hideTimeout);
|
|
133
|
+
this._showTimeout = setTimeout(this._createTooltip, 0);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
onPageResize() {
|
|
137
|
+
if (this._popup)
|
|
138
|
+
this._destroyTooltip();
|
|
139
|
+
}
|
|
140
|
+
onDocumentClick(target) {
|
|
141
|
+
if (this.tooltipPersistent && this._popup) {
|
|
142
|
+
if (!target?.isConnected) {
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
const clickedInside = this._elementRef?.nativeElement?.contains(target);
|
|
146
|
+
if (!clickedInside) {
|
|
147
|
+
this._destroyTooltip();
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
CpsTooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTooltipDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
153
|
+
CpsTooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: CpsTooltipDirective, isStandalone: true, selector: "[cpsTooltip]", inputs: { tooltip: ["cpsTooltip", "tooltip"], tooltipOpenDelay: "tooltipOpenDelay", tooltipCloseDelay: "tooltipCloseDelay", tooltipOpenOn: "tooltipOpenOn", tooltipPosition: "tooltipPosition", tooltipPersistent: "tooltipPersistent", tooltipDisabled: "tooltipDisabled", tooltipMaxWidth: "tooltipMaxWidth", tooltipContentClass: "tooltipContentClass" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "focus": "onFocus()", "blur": "onBlur()", "click": "onClick()", "window:resize": "onPageResize()", "document:click": "onDocumentClick($event.target)" } }, ngImport: i0 });
|
|
154
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTooltipDirective, decorators: [{
|
|
155
|
+
type: Directive,
|
|
156
|
+
args: [{
|
|
157
|
+
selector: '[cpsTooltip]',
|
|
158
|
+
standalone: true
|
|
159
|
+
}]
|
|
160
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { tooltip: [{
|
|
161
|
+
type: Input,
|
|
162
|
+
args: ['cpsTooltip']
|
|
163
|
+
}], tooltipOpenDelay: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], tooltipCloseDelay: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], tooltipOpenOn: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], tooltipPosition: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], tooltipPersistent: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], tooltipDisabled: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], tooltipMaxWidth: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], tooltipContentClass: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], onMouseEnter: [{
|
|
180
|
+
type: HostListener,
|
|
181
|
+
args: ['mouseenter']
|
|
182
|
+
}], onMouseLeave: [{
|
|
183
|
+
type: HostListener,
|
|
184
|
+
args: ['mouseleave']
|
|
185
|
+
}], onFocus: [{
|
|
186
|
+
type: HostListener,
|
|
187
|
+
args: ['focus']
|
|
188
|
+
}], onBlur: [{
|
|
189
|
+
type: HostListener,
|
|
190
|
+
args: ['blur']
|
|
191
|
+
}], onClick: [{
|
|
192
|
+
type: HostListener,
|
|
193
|
+
args: ['click']
|
|
194
|
+
}], onPageResize: [{
|
|
195
|
+
type: HostListener,
|
|
196
|
+
args: ['window:resize']
|
|
197
|
+
}], onDocumentClick: [{
|
|
198
|
+
type: HostListener,
|
|
199
|
+
args: ['document:click', ['$event.target']]
|
|
200
|
+
}] } });
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-tooltip.directive.js","sourceRoot":"","sources":["../../../../../projects/cps-ui-kit/src/lib/directives/cps-tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnDestroy\n} from '@angular/core';\nimport { convertSize } from '../utils/size-utils';\n\nexport type TooltipPosition = 'top' | 'bottom' | 'left' | 'right';\nexport type TooltipOpenOn = 'hover' | 'click' | 'focus';\n\n@Directive({\n  selector: '[cpsTooltip]',\n  standalone: true\n})\nexport class CpsTooltipDirective implements OnDestroy {\n  @Input('cpsTooltip') tooltip!: string;\n\n  @Input() tooltipOpenDelay: string | number = 300;\n  @Input() tooltipCloseDelay: string | number = 300;\n  @Input() tooltipOpenOn: TooltipOpenOn = 'hover';\n  @Input() tooltipPosition: TooltipPosition = 'top';\n  @Input() tooltipPersistent = false;\n  @Input() tooltipDisabled = false;\n  @Input() tooltipMaxWidth: number | string = '100%';\n  @Input() tooltipContentClass = 'cps-tooltip-content';\n\n  private _popup?: HTMLDivElement;\n  private _showTimeout?: any;\n  private _hideTimeout?: any;\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private _elementRef: ElementRef<HTMLElement>) {}\n\n  ngOnDestroy(): void {\n    this._destroyTooltip();\n  }\n\n  private _createTooltip = () => {\n    if (this._popup) this._destroyTooltip();\n\n    if (this.tooltipDisabled) return;\n\n    this._popup = document.createElement('div');\n    this._constructElement(this._popup);\n\n    if (this.tooltipPersistent)\n      this._popup.addEventListener('click', this._destroyTooltip);\n\n    window.addEventListener('scroll', this._destroyTooltip, true);\n  };\n\n  private _destroyTooltip = () => {\n    window.removeEventListener('scroll', this._destroyTooltip, true);\n    this._popup?.removeEventListener('click', this._destroyTooltip);\n    this._popup?.remove();\n    this._popup = undefined;\n  };\n\n  private _constructElement(popup: HTMLDivElement) {\n    const popupContent = document.createElement('div');\n    popupContent.innerHTML = this.tooltip || 'Add your text to this tooltip';\n    popupContent.classList.add(this.tooltipContentClass);\n    popup.appendChild(popupContent);\n\n    popup.classList.add('cps-tooltip');\n    popup.style.maxWidth = convertSize(this.tooltipMaxWidth);\n\n    document.body.appendChild(popup);\n\n    const coords = this._getCoords();\n    if (!coords) {\n      this._destroyTooltip();\n      throw new Error('Not enough space on the screen for the tooltip!');\n    }\n\n    popup.style.left = coords.left.toString() + 'px';\n    popup.style.top = coords.top.toString() + 'px';\n  }\n\n  private _getCoords(): { left: number; top: number } | undefined {\n    function isInsideScreen(coords: { left: number; top: number }): boolean {\n      return (\n        coords.top >= 0 &&\n        coords.left >= 0 &&\n        coords.left + popupRect.width <= window.innerWidth &&\n        coords.top + popupRect.height <= window.innerHeight\n      );\n    }\n\n    let positions = ['top', 'bottom', 'left', 'right'] as TooltipPosition[];\n    positions = positions.filter((item) => item !== this.tooltipPosition);\n    positions.unshift(this.tooltipPosition);\n\n    const targetEl = this._elementRef.nativeElement;\n    const targetElRect = targetEl.getBoundingClientRect();\n    const popupRect = (this._popup as HTMLDivElement).getBoundingClientRect();\n\n    for (const pos of positions) {\n      const coords = this._getCoordsForPosition(\n        pos as TooltipPosition,\n        targetEl,\n        targetElRect,\n        popupRect\n      );\n\n      if (isInsideScreen(coords)) {\n        return coords;\n      }\n    }\n\n    return undefined;\n  }\n\n  private _getCoordsForPosition(\n    position: TooltipPosition,\n    targetEl: HTMLElement,\n    targetElRect: DOMRect,\n    popupRect: DOMRect\n  ): {\n    left: number;\n    top: number;\n  } {\n    switch (position) {\n      case 'bottom':\n        return {\n          left:\n            targetElRect.left +\n            window.scrollX +\n            (targetEl.offsetWidth - popupRect.width) / 2,\n          top: targetElRect.bottom + window.scrollY + 8\n        };\n      case 'left':\n        return {\n          left: targetElRect.left - window.scrollX - popupRect.width - 8,\n          top:\n            targetElRect.top +\n            window.scrollY +\n            (targetEl.offsetHeight - popupRect.height) / 2\n        };\n      case 'right':\n        return {\n          left: targetElRect.right + window.scrollX + 8,\n          top:\n            targetElRect.top +\n            window.scrollY +\n            (targetEl.offsetHeight - popupRect.height) / 2\n        };\n      default:\n        return {\n          left:\n            targetElRect.left +\n            window.scrollX +\n            (targetEl.offsetWidth - popupRect.width) / 2,\n          top: targetElRect.top + window.scrollY - popupRect.height - 8\n        };\n    }\n  }\n\n  @HostListener('mouseenter') onMouseEnter() {\n    if (this.tooltipOpenOn === 'hover') {\n      clearTimeout(this._hideTimeout);\n\n      this._showTimeout = setTimeout(\n        this._createTooltip,\n        this.tooltipOpenDelay as number\n      );\n    }\n  }\n\n  @HostListener('mouseleave') onMouseLeave() {\n    clearTimeout(this._showTimeout);\n\n    if (!this.tooltipPersistent) {\n      this._hideTimeout = setTimeout(\n        this._destroyTooltip,\n        this.tooltipCloseDelay as number\n      );\n    }\n  }\n\n  @HostListener('focus') onFocus() {\n    if (this.tooltipOpenOn === 'focus') {\n      clearTimeout(this._hideTimeout);\n\n      this._showTimeout = setTimeout(\n        this._createTooltip,\n        this.tooltipOpenDelay as number\n      );\n    }\n  }\n\n  @HostListener('blur') onBlur() {\n    clearTimeout(this._showTimeout);\n    if (!this.tooltipPersistent && this.tooltipOpenOn === 'focus') {\n      this._hideTimeout = setTimeout(\n        this._destroyTooltip,\n        this.tooltipCloseDelay as number\n      );\n    }\n  }\n\n  @HostListener('click') onClick() {\n    if (this.tooltipOpenOn === 'click') {\n      clearTimeout(this._hideTimeout);\n\n      this._showTimeout = setTimeout(this._createTooltip, 0);\n    }\n  }\n\n  @HostListener('window:resize') onPageResize() {\n    if (this._popup) this._destroyTooltip();\n  }\n\n  @HostListener('document:click', ['$event.target'])\n  public onDocumentClick(target: any) {\n    if (this.tooltipPersistent && this._popup) {\n      if (!target?.isConnected) {\n        return;\n      }\n      const clickedInside = this._elementRef?.nativeElement?.contains(target);\n      if (!clickedInside) {\n        this._destroyTooltip();\n      }\n    }\n  }\n}\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -20,6 +20,7 @@ export * from './lib/components/cps-progress-circular/cps-progress-circular.comp
|
|
|
20
20
|
export * from './lib/components/cps-progress-linear/cps-progress-linear.component';
|
|
21
21
|
export * from './lib/components/cps-datepicker/cps-datepicker.component';
|
|
22
22
|
export * from './lib/components/cps-textarea/cps-textarea.component';
|
|
23
|
+
export * from './lib/directives/cps-tooltip.directive';
|
|
23
24
|
export * from './lib/components/cps-button-toggle/cps-button-toggle.component';
|
|
24
25
|
export * from './lib/utils/colors-utils';
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsZ0VBQWdFLENBQUM7QUFDL0UsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxnRUFBZ0UsQ0FBQztBQUMvRSxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBjcHMtdWkta2l0XG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtaWNvbi9jcHMtaWNvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtaW5wdXQvY3BzLWlucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1zZWxlY3QvY3BzLXNlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS1zZWxlY3QvY3BzLXRyZWUtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1hdXRvY29tcGxldGUvY3BzLWF1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS1hdXRvY29tcGxldGUvY3BzLXRyZWUtYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1idXR0b24vY3BzLWJ1dHRvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtY2hlY2tib3gvY3BzLWNoZWNrYm94LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1yYWRpby9jcHMtcmFkaW8uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2Nwcy10YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvY3BzLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFnL2Nwcy10YWcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWxvYWRlci9jcHMtbG9hZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1leHBhbnNpb24tcGFuZWwvY3BzLWV4cGFuc2lvbi1wYW5lbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcHJvZ3Jlc3MtY2lyY3VsYXIvY3BzLXByb2dyZXNzLWNpcmN1bGFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wcm9ncmVzcy1saW5lYXIvY3BzLXByb2dyZXNzLWxpbmVhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtZGF0ZXBpY2tlci9jcHMtZGF0ZXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGV4dGFyZWEvY3BzLXRleHRhcmVhLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2Nwcy10b29sdGlwLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1idXR0b24tdG9nZ2xlL2Nwcy1idXR0b24tdG9nZ2xlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9jb2xvcnMtdXRpbHMnO1xuIl19
|
package/fesm2015/cps-ui-kit.mjs
CHANGED
|
@@ -3434,6 +3434,206 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
3434
3434
|
type: Output
|
|
3435
3435
|
}] } });
|
|
3436
3436
|
|
|
3437
|
+
class CpsTooltipDirective {
|
|
3438
|
+
// eslint-disable-next-line no-useless-constructor
|
|
3439
|
+
constructor(_elementRef) {
|
|
3440
|
+
this._elementRef = _elementRef;
|
|
3441
|
+
this.tooltipOpenDelay = 300;
|
|
3442
|
+
this.tooltipCloseDelay = 300;
|
|
3443
|
+
this.tooltipOpenOn = 'hover';
|
|
3444
|
+
this.tooltipPosition = 'top';
|
|
3445
|
+
this.tooltipPersistent = false;
|
|
3446
|
+
this.tooltipDisabled = false;
|
|
3447
|
+
this.tooltipMaxWidth = '100%';
|
|
3448
|
+
this.tooltipContentClass = 'cps-tooltip-content';
|
|
3449
|
+
this._createTooltip = () => {
|
|
3450
|
+
if (this._popup)
|
|
3451
|
+
this._destroyTooltip();
|
|
3452
|
+
if (this.tooltipDisabled)
|
|
3453
|
+
return;
|
|
3454
|
+
this._popup = document.createElement('div');
|
|
3455
|
+
this._constructElement(this._popup);
|
|
3456
|
+
if (this.tooltipPersistent)
|
|
3457
|
+
this._popup.addEventListener('click', this._destroyTooltip);
|
|
3458
|
+
window.addEventListener('scroll', this._destroyTooltip, true);
|
|
3459
|
+
};
|
|
3460
|
+
this._destroyTooltip = () => {
|
|
3461
|
+
var _a, _b;
|
|
3462
|
+
window.removeEventListener('scroll', this._destroyTooltip, true);
|
|
3463
|
+
(_a = this._popup) === null || _a === void 0 ? void 0 : _a.removeEventListener('click', this._destroyTooltip);
|
|
3464
|
+
(_b = this._popup) === null || _b === void 0 ? void 0 : _b.remove();
|
|
3465
|
+
this._popup = undefined;
|
|
3466
|
+
};
|
|
3467
|
+
}
|
|
3468
|
+
ngOnDestroy() {
|
|
3469
|
+
this._destroyTooltip();
|
|
3470
|
+
}
|
|
3471
|
+
_constructElement(popup) {
|
|
3472
|
+
const popupContent = document.createElement('div');
|
|
3473
|
+
popupContent.innerHTML = this.tooltip || 'Add your text to this tooltip';
|
|
3474
|
+
popupContent.classList.add(this.tooltipContentClass);
|
|
3475
|
+
popup.appendChild(popupContent);
|
|
3476
|
+
popup.classList.add('cps-tooltip');
|
|
3477
|
+
popup.style.maxWidth = convertSize(this.tooltipMaxWidth);
|
|
3478
|
+
document.body.appendChild(popup);
|
|
3479
|
+
const coords = this._getCoords();
|
|
3480
|
+
if (!coords) {
|
|
3481
|
+
this._destroyTooltip();
|
|
3482
|
+
throw new Error('Not enough space on the screen for the tooltip!');
|
|
3483
|
+
}
|
|
3484
|
+
popup.style.left = coords.left.toString() + 'px';
|
|
3485
|
+
popup.style.top = coords.top.toString() + 'px';
|
|
3486
|
+
}
|
|
3487
|
+
_getCoords() {
|
|
3488
|
+
function isInsideScreen(coords) {
|
|
3489
|
+
return (coords.top >= 0 &&
|
|
3490
|
+
coords.left >= 0 &&
|
|
3491
|
+
coords.left + popupRect.width <= window.innerWidth &&
|
|
3492
|
+
coords.top + popupRect.height <= window.innerHeight);
|
|
3493
|
+
}
|
|
3494
|
+
let positions = ['top', 'bottom', 'left', 'right'];
|
|
3495
|
+
positions = positions.filter((item) => item !== this.tooltipPosition);
|
|
3496
|
+
positions.unshift(this.tooltipPosition);
|
|
3497
|
+
const targetEl = this._elementRef.nativeElement;
|
|
3498
|
+
const targetElRect = targetEl.getBoundingClientRect();
|
|
3499
|
+
const popupRect = this._popup.getBoundingClientRect();
|
|
3500
|
+
for (const pos of positions) {
|
|
3501
|
+
const coords = this._getCoordsForPosition(pos, targetEl, targetElRect, popupRect);
|
|
3502
|
+
if (isInsideScreen(coords)) {
|
|
3503
|
+
return coords;
|
|
3504
|
+
}
|
|
3505
|
+
}
|
|
3506
|
+
return undefined;
|
|
3507
|
+
}
|
|
3508
|
+
_getCoordsForPosition(position, targetEl, targetElRect, popupRect) {
|
|
3509
|
+
switch (position) {
|
|
3510
|
+
case 'bottom':
|
|
3511
|
+
return {
|
|
3512
|
+
left: targetElRect.left +
|
|
3513
|
+
window.scrollX +
|
|
3514
|
+
(targetEl.offsetWidth - popupRect.width) / 2,
|
|
3515
|
+
top: targetElRect.bottom + window.scrollY + 8
|
|
3516
|
+
};
|
|
3517
|
+
case 'left':
|
|
3518
|
+
return {
|
|
3519
|
+
left: targetElRect.left - window.scrollX - popupRect.width - 8,
|
|
3520
|
+
top: targetElRect.top +
|
|
3521
|
+
window.scrollY +
|
|
3522
|
+
(targetEl.offsetHeight - popupRect.height) / 2
|
|
3523
|
+
};
|
|
3524
|
+
case 'right':
|
|
3525
|
+
return {
|
|
3526
|
+
left: targetElRect.right + window.scrollX + 8,
|
|
3527
|
+
top: targetElRect.top +
|
|
3528
|
+
window.scrollY +
|
|
3529
|
+
(targetEl.offsetHeight - popupRect.height) / 2
|
|
3530
|
+
};
|
|
3531
|
+
default:
|
|
3532
|
+
return {
|
|
3533
|
+
left: targetElRect.left +
|
|
3534
|
+
window.scrollX +
|
|
3535
|
+
(targetEl.offsetWidth - popupRect.width) / 2,
|
|
3536
|
+
top: targetElRect.top + window.scrollY - popupRect.height - 8
|
|
3537
|
+
};
|
|
3538
|
+
}
|
|
3539
|
+
}
|
|
3540
|
+
onMouseEnter() {
|
|
3541
|
+
if (this.tooltipOpenOn === 'hover') {
|
|
3542
|
+
clearTimeout(this._hideTimeout);
|
|
3543
|
+
this._showTimeout = setTimeout(this._createTooltip, this.tooltipOpenDelay);
|
|
3544
|
+
}
|
|
3545
|
+
}
|
|
3546
|
+
onMouseLeave() {
|
|
3547
|
+
clearTimeout(this._showTimeout);
|
|
3548
|
+
if (!this.tooltipPersistent) {
|
|
3549
|
+
this._hideTimeout = setTimeout(this._destroyTooltip, this.tooltipCloseDelay);
|
|
3550
|
+
}
|
|
3551
|
+
}
|
|
3552
|
+
onFocus() {
|
|
3553
|
+
if (this.tooltipOpenOn === 'focus') {
|
|
3554
|
+
clearTimeout(this._hideTimeout);
|
|
3555
|
+
this._showTimeout = setTimeout(this._createTooltip, this.tooltipOpenDelay);
|
|
3556
|
+
}
|
|
3557
|
+
}
|
|
3558
|
+
onBlur() {
|
|
3559
|
+
clearTimeout(this._showTimeout);
|
|
3560
|
+
if (!this.tooltipPersistent && this.tooltipOpenOn === 'focus') {
|
|
3561
|
+
this._hideTimeout = setTimeout(this._destroyTooltip, this.tooltipCloseDelay);
|
|
3562
|
+
}
|
|
3563
|
+
}
|
|
3564
|
+
onClick() {
|
|
3565
|
+
if (this.tooltipOpenOn === 'click') {
|
|
3566
|
+
clearTimeout(this._hideTimeout);
|
|
3567
|
+
this._showTimeout = setTimeout(this._createTooltip, 0);
|
|
3568
|
+
}
|
|
3569
|
+
}
|
|
3570
|
+
onPageResize() {
|
|
3571
|
+
if (this._popup)
|
|
3572
|
+
this._destroyTooltip();
|
|
3573
|
+
}
|
|
3574
|
+
onDocumentClick(target) {
|
|
3575
|
+
var _a, _b;
|
|
3576
|
+
if (this.tooltipPersistent && this._popup) {
|
|
3577
|
+
if (!(target === null || target === void 0 ? void 0 : target.isConnected)) {
|
|
3578
|
+
return;
|
|
3579
|
+
}
|
|
3580
|
+
const clickedInside = (_b = (_a = this._elementRef) === null || _a === void 0 ? void 0 : _a.nativeElement) === null || _b === void 0 ? void 0 : _b.contains(target);
|
|
3581
|
+
if (!clickedInside) {
|
|
3582
|
+
this._destroyTooltip();
|
|
3583
|
+
}
|
|
3584
|
+
}
|
|
3585
|
+
}
|
|
3586
|
+
}
|
|
3587
|
+
CpsTooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTooltipDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
3588
|
+
CpsTooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: CpsTooltipDirective, isStandalone: true, selector: "[cpsTooltip]", inputs: { tooltip: ["cpsTooltip", "tooltip"], tooltipOpenDelay: "tooltipOpenDelay", tooltipCloseDelay: "tooltipCloseDelay", tooltipOpenOn: "tooltipOpenOn", tooltipPosition: "tooltipPosition", tooltipPersistent: "tooltipPersistent", tooltipDisabled: "tooltipDisabled", tooltipMaxWidth: "tooltipMaxWidth", tooltipContentClass: "tooltipContentClass" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "focus": "onFocus()", "blur": "onBlur()", "click": "onClick()", "window:resize": "onPageResize()", "document:click": "onDocumentClick($event.target)" } }, ngImport: i0 });
|
|
3589
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTooltipDirective, decorators: [{
|
|
3590
|
+
type: Directive,
|
|
3591
|
+
args: [{
|
|
3592
|
+
selector: '[cpsTooltip]',
|
|
3593
|
+
standalone: true
|
|
3594
|
+
}]
|
|
3595
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { tooltip: [{
|
|
3596
|
+
type: Input,
|
|
3597
|
+
args: ['cpsTooltip']
|
|
3598
|
+
}], tooltipOpenDelay: [{
|
|
3599
|
+
type: Input
|
|
3600
|
+
}], tooltipCloseDelay: [{
|
|
3601
|
+
type: Input
|
|
3602
|
+
}], tooltipOpenOn: [{
|
|
3603
|
+
type: Input
|
|
3604
|
+
}], tooltipPosition: [{
|
|
3605
|
+
type: Input
|
|
3606
|
+
}], tooltipPersistent: [{
|
|
3607
|
+
type: Input
|
|
3608
|
+
}], tooltipDisabled: [{
|
|
3609
|
+
type: Input
|
|
3610
|
+
}], tooltipMaxWidth: [{
|
|
3611
|
+
type: Input
|
|
3612
|
+
}], tooltipContentClass: [{
|
|
3613
|
+
type: Input
|
|
3614
|
+
}], onMouseEnter: [{
|
|
3615
|
+
type: HostListener,
|
|
3616
|
+
args: ['mouseenter']
|
|
3617
|
+
}], onMouseLeave: [{
|
|
3618
|
+
type: HostListener,
|
|
3619
|
+
args: ['mouseleave']
|
|
3620
|
+
}], onFocus: [{
|
|
3621
|
+
type: HostListener,
|
|
3622
|
+
args: ['focus']
|
|
3623
|
+
}], onBlur: [{
|
|
3624
|
+
type: HostListener,
|
|
3625
|
+
args: ['blur']
|
|
3626
|
+
}], onClick: [{
|
|
3627
|
+
type: HostListener,
|
|
3628
|
+
args: ['click']
|
|
3629
|
+
}], onPageResize: [{
|
|
3630
|
+
type: HostListener,
|
|
3631
|
+
args: ['window:resize']
|
|
3632
|
+
}], onDocumentClick: [{
|
|
3633
|
+
type: HostListener,
|
|
3634
|
+
args: ['document:click', ['$event.target']]
|
|
3635
|
+
}] } });
|
|
3636
|
+
|
|
3437
3637
|
class CpsButtonToggleComponent {
|
|
3438
3638
|
set value(value) {
|
|
3439
3639
|
this._value = value;
|
|
@@ -3551,5 +3751,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
3551
3751
|
* Generated bundle index. Do not edit.
|
|
3552
3752
|
*/
|
|
3553
3753
|
|
|
3554
|
-
export { CpsAutocompleteComponent, CpsButtonComponent, CpsButtonToggleComponent, CpsCheckboxComponent, CpsChipComponent, CpsDatepickerComponent, CpsExpansionPanelComponent, CpsIconComponent, CpsInputComponent, CpsLoaderComponent, CpsProgressCircularComponent, CpsProgressLinearComponent, CpsRadioComponent, CpsSelectComponent, CpsTableColumnSortableDirective, CpsTableComponent, CpsTagComponent, CpsTextareaComponent, CpsTreeAutocompleteComponent, CpsTreeSelectComponent, getCSSColor, getCpsColors, getTextColor, iconNames, tableFactory };
|
|
3754
|
+
export { CpsAutocompleteComponent, CpsButtonComponent, CpsButtonToggleComponent, CpsCheckboxComponent, CpsChipComponent, CpsDatepickerComponent, CpsExpansionPanelComponent, CpsIconComponent, CpsInputComponent, CpsLoaderComponent, CpsProgressCircularComponent, CpsProgressLinearComponent, CpsRadioComponent, CpsSelectComponent, CpsTableColumnSortableDirective, CpsTableComponent, CpsTagComponent, CpsTextareaComponent, CpsTooltipDirective, CpsTreeAutocompleteComponent, CpsTreeSelectComponent, getCSSColor, getCpsColors, getTextColor, iconNames, tableFactory };
|
|
3555
3755
|
//# sourceMappingURL=cps-ui-kit.mjs.map
|