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 CHANGED
@@ -21,6 +21,7 @@
21
21
  - Table
22
22
  - Tag
23
23
  - Textarea
24
+ - Tooltip
24
25
  - Tree autocomplete
25
26
  - Tree select
26
27
 
@@ -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"]}
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsZ0VBQWdFLENBQUM7QUFDL0UsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsZ0VBQWdFLENBQUM7QUFDL0UsY0FBYywwQkFBMEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgY3BzLXVpLWtpdFxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWljb24vY3BzLWljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWlucHV0L2Nwcy1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtc2VsZWN0L2Nwcy1zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRyZWUtc2VsZWN0L2Nwcy10cmVlLXNlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYXV0b2NvbXBsZXRlL2Nwcy1hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRyZWUtYXV0b2NvbXBsZXRlL2Nwcy10cmVlLWF1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYnV0dG9uL2Nwcy1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoZWNrYm94L2Nwcy1jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8vY3BzLXJhZGlvLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9jcHMtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2Nwcy10YWJsZS1jb2x1bW4tc29ydGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhZy9jcHMtdGFnLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1jaGlwL2Nwcy1jaGlwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1sb2FkZXIvY3BzLWxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtZXhwYW5zaW9uLXBhbmVsL2Nwcy1leHBhbnNpb24tcGFuZWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXByb2dyZXNzLWNpcmN1bGFyL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcHJvZ3Jlc3MtbGluZWFyL2Nwcy1wcm9ncmVzcy1saW5lYXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWRhdGVwaWNrZXIvY3BzLWRhdGVwaWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRleHRhcmVhL2Nwcy10ZXh0YXJlYS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYnV0dG9uLXRvZ2dsZS9jcHMtYnV0dG9uLXRvZ2dsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvY29sb3JzLXV0aWxzJztcbiJdfQ==
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsZ0VBQWdFLENBQUM7QUFDL0UsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxnRUFBZ0UsQ0FBQztBQUMvRSxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBjcHMtdWkta2l0XG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtaWNvbi9jcHMtaWNvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtaW5wdXQvY3BzLWlucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1zZWxlY3QvY3BzLXNlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS1zZWxlY3QvY3BzLXRyZWUtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1hdXRvY29tcGxldGUvY3BzLWF1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS1hdXRvY29tcGxldGUvY3BzLXRyZWUtYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1idXR0b24vY3BzLWJ1dHRvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtY2hlY2tib3gvY3BzLWNoZWNrYm94LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1yYWRpby9jcHMtcmFkaW8uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2Nwcy10YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvY3BzLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFnL2Nwcy10YWcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWxvYWRlci9jcHMtbG9hZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1leHBhbnNpb24tcGFuZWwvY3BzLWV4cGFuc2lvbi1wYW5lbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcHJvZ3Jlc3MtY2lyY3VsYXIvY3BzLXByb2dyZXNzLWNpcmN1bGFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wcm9ncmVzcy1saW5lYXIvY3BzLXByb2dyZXNzLWxpbmVhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtZGF0ZXBpY2tlci9jcHMtZGF0ZXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGV4dGFyZWEvY3BzLXRleHRhcmVhLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2Nwcy10b29sdGlwLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1idXR0b24tdG9nZ2xlL2Nwcy1idXR0b24tdG9nZ2xlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9jb2xvcnMtdXRpbHMnO1xuIl19
@@ -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