@sarasanalytics-com/design-system 0.0.136 → 0.0.138
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/interfaces/button-interface.mjs +1 -1
- package/esm2022/interfaces/chip-interface.mjs +1 -1
- package/esm2022/interfaces/form-layout.interface.mjs +2 -0
- package/esm2022/interfaces/grid-interface.mjs +1 -1
- package/esm2022/lib/avatar/avatar.component.mjs +3 -3
- package/esm2022/lib/categories-nav/categories-nav.component.mjs +27 -0
- package/esm2022/lib/chips/chips.component.mjs +3 -3
- package/esm2022/lib/data-grid/data-grid.component.mjs +135 -0
- package/esm2022/lib/dialog/dialog.component.mjs +43 -3
- package/esm2022/lib/filter/filter.component.mjs +232 -0
- package/esm2022/lib/form-input/form-input.component.mjs +71 -7
- package/esm2022/lib/form-select/form-select.component.mjs +187 -5
- package/esm2022/lib/grid-cell/grid-cell.component.mjs +173 -25
- package/esm2022/lib/menu/menu-list/menu-item.component.mjs +3 -3
- package/esm2022/lib/menu/menu.component.mjs +3 -3
- package/esm2022/lib/message-banner-v2/message-banner-v2.component.mjs +256 -7
- package/esm2022/lib/query-builder/query-builder-demo.component.mjs +134 -0
- package/esm2022/lib/query-builder/query-builder.component.mjs +275 -0
- package/esm2022/lib/query-builder/query-builder.service.mjs +107 -0
- package/esm2022/lib/query-builder-textarea/query-builder-textarea-demo.component.mjs +130 -0
- package/esm2022/lib/query-builder-textarea/query-builder-textarea.component.mjs +805 -0
- package/esm2022/lib/tool-tip/tool-tip.component.mjs +8 -3
- package/esm2022/public-api.mjs +10 -1
- package/fesm2022/sarasanalytics-com-design-system.mjs +3042 -587
- package/fesm2022/sarasanalytics-com-design-system.mjs.map +1 -1
- package/interfaces/button-interface.d.ts +1 -0
- package/interfaces/form-layout.interface.d.ts +59 -0
- package/interfaces/grid-interface.d.ts +11 -4
- package/lib/categories-nav/categories-nav.component.d.ts +15 -0
- package/lib/data-grid/data-grid.component.d.ts +33 -0
- package/lib/dialog/dialog.component.d.ts +13 -0
- package/lib/filter/filter.component.d.ts +83 -0
- package/lib/form-input/form-input.component.d.ts +11 -1
- package/lib/form-select/form-select.component.d.ts +8 -0
- package/lib/grid-cell/grid-cell.component.d.ts +51 -10
- package/lib/message-banner-v2/message-banner-v2.component.d.ts +34 -2
- package/lib/query-builder/query-builder-demo.component.d.ts +14 -0
- package/lib/query-builder/query-builder.component.d.ts +90 -0
- package/lib/query-builder/query-builder.service.d.ts +39 -0
- package/lib/query-builder-textarea/query-builder-textarea-demo.component.d.ts +9 -0
- package/lib/query-builder-textarea/query-builder-textarea.component.d.ts +143 -0
- package/lib/tool-tip/tool-tip.component.d.ts +2 -1
- package/package.json +1 -1
- package/public-api.d.ts +9 -0
|
@@ -1,25 +1,116 @@
|
|
|
1
|
-
import { Component, EventEmitter } from '@angular/core';
|
|
2
|
-
import { Output } from '@angular/core';
|
|
3
|
-
import { AvatarComponent } from '../avatar/avatar.component';
|
|
1
|
+
import { Component, Output, EventEmitter, ViewChild, HostListener } from '@angular/core';
|
|
4
2
|
import { ChipsComponent } from '../chips/chips.component';
|
|
5
3
|
import { ButtonComponent } from '../button/button.component';
|
|
6
|
-
import {
|
|
4
|
+
import { AvatarComponent } from '../avatar/avatar.component';
|
|
5
|
+
import { ToolTipComponent } from '../tool-tip/tool-tip.component';
|
|
6
|
+
import { CommonModule, NgFor, NgIf } from '@angular/common';
|
|
7
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/cdk/overlay";
|
|
8
10
|
export class GridCellComponent {
|
|
9
|
-
constructor() {
|
|
11
|
+
constructor(cdr, overlay, viewContainerRef) {
|
|
12
|
+
this.cdr = cdr;
|
|
13
|
+
this.overlay = overlay;
|
|
14
|
+
this.viewContainerRef = viewContainerRef;
|
|
15
|
+
this.showDropdown = false;
|
|
16
|
+
this.MAX_VISIBLE_CHIPS = 1;
|
|
17
|
+
this.displayedChips = [];
|
|
18
|
+
this.remainingChipsCount = 0;
|
|
19
|
+
this.rowNum = 0;
|
|
10
20
|
this.onClickButtonEvent = new EventEmitter();
|
|
11
21
|
this.onClickChipEvent = new EventEmitter();
|
|
12
22
|
this.onClickLinkEvent = new EventEmitter();
|
|
13
23
|
this.onClickAvatarEvent = new EventEmitter();
|
|
24
|
+
this.hoveredChip = null;
|
|
25
|
+
this.tooltipComponentRef = null;
|
|
26
|
+
}
|
|
27
|
+
agInit(params) {
|
|
28
|
+
this.rowNum = params.rowIndex;
|
|
29
|
+
// Check for direct field value first, then fallback to _cellParams
|
|
30
|
+
let cellData = params.value;
|
|
31
|
+
if (!cellData && params.data && params.colDef?.field) {
|
|
32
|
+
const cellParamsKey = `${params.colDef.field}_cellParams`;
|
|
33
|
+
cellData = params.data[cellParamsKey];
|
|
34
|
+
}
|
|
35
|
+
this.params = {
|
|
36
|
+
...params,
|
|
37
|
+
...(cellData ?? {})
|
|
38
|
+
};
|
|
39
|
+
if (this.params.chipConfig && Array.isArray(this.params.chipConfig)) {
|
|
40
|
+
this.displayedChips = this.params.chipConfig.slice(0, this.MAX_VISIBLE_CHIPS);
|
|
41
|
+
this.remainingChipsCount = Math.max(0, this.params.chipConfig.length - this.MAX_VISIBLE_CHIPS);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
this.displayedChips = this.params.chipConfig;
|
|
45
|
+
this.remainingChipsCount = 0;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
refresh(params) {
|
|
49
|
+
this.agInit(params);
|
|
50
|
+
return true;
|
|
14
51
|
}
|
|
15
|
-
|
|
52
|
+
typeOf(value) {
|
|
53
|
+
return typeof value;
|
|
54
|
+
}
|
|
55
|
+
buttonClicked(event) {
|
|
56
|
+
if (this.params.buttonConfig?.onClick) {
|
|
57
|
+
this.params.buttonConfig.onClick(event);
|
|
58
|
+
}
|
|
16
59
|
this.params.buttonClicked && this.params.buttonClicked({
|
|
17
|
-
...
|
|
60
|
+
...event,
|
|
18
61
|
rowId: this.rowNum
|
|
19
62
|
});
|
|
20
|
-
this.onClickButtonEvent.emit({ ...
|
|
63
|
+
this.onClickButtonEvent.emit({ ...event, rowId: this.rowNum });
|
|
64
|
+
}
|
|
65
|
+
toggleDropdown(element) {
|
|
66
|
+
if (this.overlayRef) {
|
|
67
|
+
this.overlayRef.dispose();
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
const positionStrategy = this.overlay.position()
|
|
71
|
+
.flexibleConnectedTo(element)
|
|
72
|
+
.withPush(true)
|
|
73
|
+
.withFlexibleDimensions(true)
|
|
74
|
+
.withViewportMargin(8)
|
|
75
|
+
.withPositions([
|
|
76
|
+
{
|
|
77
|
+
originX: 'end',
|
|
78
|
+
originY: 'bottom',
|
|
79
|
+
overlayX: 'end',
|
|
80
|
+
overlayY: 'top',
|
|
81
|
+
offsetY: 4,
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
originX: 'start',
|
|
85
|
+
originY: 'bottom',
|
|
86
|
+
overlayX: 'start',
|
|
87
|
+
overlayY: 'top',
|
|
88
|
+
offsetY: 4,
|
|
89
|
+
}
|
|
90
|
+
]);
|
|
91
|
+
this.overlayRef = this.overlay.create({
|
|
92
|
+
positionStrategy,
|
|
93
|
+
hasBackdrop: true,
|
|
94
|
+
backdropClass: 'cdk-overlay-transparent-backdrop',
|
|
95
|
+
panelClass: 'actions-dropdown-panel',
|
|
96
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition()
|
|
97
|
+
});
|
|
98
|
+
const portal = new TemplatePortal(this.dropdownTemplate, this.viewContainerRef);
|
|
99
|
+
this.overlayRef.attach(portal);
|
|
100
|
+
this.overlayRef.backdropClick().subscribe(() => this.overlayRef.dispose());
|
|
101
|
+
}
|
|
102
|
+
handleActionClick(action, event) {
|
|
103
|
+
event.stopPropagation();
|
|
104
|
+
this.showDropdown = false;
|
|
105
|
+
if (action.onClick) {
|
|
106
|
+
action.onClick();
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
onDocumentClick(event) {
|
|
110
|
+
if (this.actionsContainer && !this.actionsContainer.nativeElement.contains(event.target)) {
|
|
111
|
+
this.showDropdown = false;
|
|
112
|
+
}
|
|
21
113
|
}
|
|
22
|
-
// above function behavior is same for all functions in this class
|
|
23
114
|
chipClicked(evt) {
|
|
24
115
|
this.params.chipClicked && this.params.chipClicked({
|
|
25
116
|
...evt,
|
|
@@ -48,31 +139,85 @@ export class GridCellComponent {
|
|
|
48
139
|
...evt,
|
|
49
140
|
rowId: this.rowNum
|
|
50
141
|
});
|
|
51
|
-
this.
|
|
142
|
+
this.onClickAvatarEvent.emit({ ...evt, rowId: this.rowNum });
|
|
52
143
|
}
|
|
53
|
-
|
|
54
|
-
this.
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
144
|
+
showTooltip(config, event) {
|
|
145
|
+
this.hoveredChip = config;
|
|
146
|
+
if (event && event.currentTarget) {
|
|
147
|
+
const chipContainer = event.currentTarget;
|
|
148
|
+
const chipElement = chipContainer.querySelector('sa-chip');
|
|
149
|
+
if (chipElement) {
|
|
150
|
+
const rect = chipElement.getBoundingClientRect();
|
|
151
|
+
const topPosition = rect.bottom + 8;
|
|
152
|
+
const leftPosition = rect.left + rect.width / 2;
|
|
153
|
+
this.createTooltipComponent(topPosition, leftPosition);
|
|
154
|
+
}
|
|
58
155
|
}
|
|
59
|
-
// console.log(this.params);
|
|
60
156
|
}
|
|
61
|
-
|
|
62
|
-
|
|
157
|
+
hideTooltip() {
|
|
158
|
+
this.hoveredChip = null;
|
|
159
|
+
this.destroyTooltipComponent();
|
|
160
|
+
}
|
|
161
|
+
createTooltipComponent(top, left) {
|
|
162
|
+
this.destroyTooltipComponent();
|
|
163
|
+
this.tooltipComponentRef = this.viewContainerRef.createComponent(ToolTipComponent);
|
|
164
|
+
this.tooltipComponentRef.instance.messages = this.getTooltipText();
|
|
165
|
+
this.tooltipComponentRef.instance.simpleMode = true;
|
|
166
|
+
this.tooltipComponentRef.instance.pointerPosition = 'top';
|
|
167
|
+
const tooltipElement = this.tooltipComponentRef.location.nativeElement;
|
|
168
|
+
tooltipElement.style.cssText = `
|
|
169
|
+
position: fixed;
|
|
170
|
+
top: ${top}px;
|
|
171
|
+
left: ${left}px;
|
|
172
|
+
z-index: 99999;
|
|
173
|
+
transform: translateX(-50%);
|
|
174
|
+
pointer-events: none;
|
|
175
|
+
`;
|
|
176
|
+
document.body.appendChild(tooltipElement);
|
|
177
|
+
this.tooltipComponentRef.changeDetectorRef.detectChanges();
|
|
178
|
+
}
|
|
179
|
+
destroyTooltipComponent() {
|
|
180
|
+
if (this.tooltipComponentRef) {
|
|
181
|
+
const tooltipElement = this.tooltipComponentRef.location.nativeElement;
|
|
182
|
+
if (tooltipElement.parentNode) {
|
|
183
|
+
tooltipElement.parentNode.removeChild(tooltipElement);
|
|
184
|
+
}
|
|
185
|
+
this.tooltipComponentRef.destroy();
|
|
186
|
+
this.tooltipComponentRef = null;
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
getTooltipText() {
|
|
190
|
+
if (!this.params?.chipConfig)
|
|
191
|
+
return [];
|
|
192
|
+
return this.params.chipConfig.map(chip => chip.text);
|
|
193
|
+
}
|
|
194
|
+
ngOnDestroy() {
|
|
195
|
+
this.hideTooltip();
|
|
196
|
+
if (this.overlayRef) {
|
|
197
|
+
this.overlayRef.dispose();
|
|
198
|
+
}
|
|
63
199
|
}
|
|
64
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: GridCellComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: GridCellComponent, isStandalone: true, selector: "
|
|
200
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: GridCellComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
201
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: GridCellComponent, isStandalone: true, selector: "sa-grid-cell", outputs: { onClickButtonEvent: "onClickButtonEvent", onClickChipEvent: "onClickChipEvent", onClickLinkEvent: "onClickLinkEvent", onClickAvatarEvent: "onClickAvatarEvent" }, host: { listeners: { "document:click": "onDocumentClick($event)" } }, viewQueries: [{ propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true }, { propertyName: "actionsContainer", first: true, predicate: ["actionsContainer"], descendants: true }], ngImport: i0, template: "<div class=\"grid-cell {{params.cellType}}\">\r\n\r\n <img class=\"icons\" src={{params.iconPath}} [style.display]=\"(params.viewLeadingIcon) ? 'block' : 'none'\" alt=\"\">\r\n\r\n <sa-avatar [id]=\"params.avatarConfig?.id\" [altText]=\"params.avatarConfig?.altText\"\r\n [imagePath]=\"params.avatarConfig?.imagePath\" [size]=\"params.avatarConfig?.size\"\r\n [style.display]=\"(params.viewAvatar) ? 'block' : 'none'\" (onClickEvent)=\"avatarClicked($event)\">\r\n </sa-avatar>\r\n\r\n <div class=\"grid-text\" [style.display]=\"(params.viewText) ? 'block' : 'none'\">\r\n <div [style.display]=\"(params.text) ? 'block' : 'none'\" (click)=\"linkClicked()\" class=\"main-text\">{{params.text}}\r\n </div>\r\n\r\n <div [style.display]=\"(params.subText) ? 'block' : 'none'\" class=\"sub-text\">{{params.subText}}</div>\r\n </div>\r\n\r\n <img class=\"icons\" src={{params.iconPath}} [style.display]=\"(params.viewTrailingIcon) ? 'block' : 'none'\" alt=\"\">\r\n <div class=\"chips-container\" [style.display]=\"(params.viewChip) ? 'flex' : 'none'\">\r\n\r\n <div *ngFor=\"let config of displayedChips\">\r\n <sa-chip [id]=\"config.id\" [filling]=\"config.filling\" id=\"chip_{{rowNum}}_{{config.id}}\" [iconPath]=\"config.iconPath\"\r\n [iconPosition]=\"config.iconPosition\" [largeStateIcon]=\"config.largeStateIcon\" [state]=\"config.state\"\r\n [type]=\"config.type\" [text]=\"config.text\" [class.small]=\"config.type === 'small'\"\r\n [class.neutral]=\"config.state === 'neutral'\" (onClickEvent)=\"chipClicked($event)\"></sa-chip>\r\n </div>\r\n <div class=\"chip-tooltip-container\" *ngIf=\"remainingChipsCount > 0\" style=\"position: relative;\"\r\n (mouseenter)=\"showTooltip(remainingChipsCount, $event)\" (mouseleave)=\"hideTooltip()\">\r\n <sa-chip [id]=\"'chip_' + rowNum + '_more'\" [text]=\"'+' + remainingChipsCount\" [filling]=\"displayedChips[0]?.filling\"\r\n [type]=\"displayedChips[0]?.type\" [state]=\"displayedChips[0]?.state\" (onClickEvent)=\"chipClicked($event)\"></sa-chip>\r\n</div>\r\n\r\n <sa-button [iconPosition]=\"params.buttonConfig?.iconPosition\" [ImagePath]=\"params.buttonConfig?.imagePath\"\r\n [id]=\"params.buttonConfig?.id\" [size]=\"params.buttonConfig?.size\" [state]=\"params.buttonConfig?.state\"\r\n [type]=\"params.buttonConfig?.type\" [text]=\"params.buttonConfig?.text\" [href]=\"params.buttonConfig?.href\"\r\n [hrefTarget]=\"params.buttonConfig?.hrefTarget\" [style.display]=\"(params.viewButton) ? 'block' : 'none'\"\r\n (onClickEvent)=\"buttonClicked($event)\"></sa-button>\r\n\r\n</div>\r\n\r\n <div *ngIf=\"params.cellType === 'actions'\" class=\"actions-container\">\r\n <img [src]=\"params.buttonConfig?.imagePath\" alt=\"actions\" class=\"actions-icon\" (click)=\"toggleDropdown(actionsButton)\"\r\n #actionsButton />\r\n \r\n <ng-template #dropdownTemplate>\r\n <div class=\"actions-dropdown\">\r\n <div *ngFor=\"let action of params.actions\" class=\"action-item\" (click)=\"handleActionClick(action, $event)\">\r\n <img *ngIf=\"action.icon\" [src]=\"action.icon\" class=\"action-icon\" />\r\n <span class=\"action-label\">{{action.label}}</span>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </div>\r\n</div>\r\n", styles: [".header{--bg: var(--primary-50);--color: var(--text-highemphasis);--border: none;--flex-direction: left}.header:hover{cursor:pointer}.row{--color: var(--text-highemphasis);--cursor: default;--border: var(--grey-50);--flex-direction: left}.numeric{--color: var(--text-highemphasis);--cursor: default;--border: var(--grey-50);--flex-direction: right}.interactive{--color: var(--primary-500);--cursor: pointer;--border: var(--grey-50);--flex-direction: left}.grid-cell{display:flex;height:48px;padding:var(--small-12px);justify-content:var(--flex-direction);align-items:center;gap:var(--small-8px);flex-shrink:0;font-family:var(--font);box-sizing:border-box;border-bottom:1px solid var(--border);width:calc(100% - 20px);background-color:var(--bg)}.grid-text{display:flex;flex-direction:column}.main-text{color:var(--color);font-size:14px;font-weight:400;height:20px;line-height:20px}.main-text:hover{cursor:var(--cursor)}.sub-text{font-size:11px;font-weight:400;height:16px;line-height:16px;color:var(--text-mediumemphasis)}.icons{width:var(--medium-20px);height:var(--medium-20px)}.grid-chip{display:flex;height:24px;padding:var(--Small-4px, 4px) var(--Small-8px, 8px);justify-content:center;align-items:center;gap:var(--Small-4px, 4px);border-radius:4px;background:var(--Grey-100, #EAECF0);color:var(--Text-Medium-Emphasis, #6D6979);font-family:var(--font-family, Roboto);font-size:11px;font-style:normal;font-weight:500;line-height:16px;letter-spacing:.5px}.grid-cell,.chips-container{overflow:visible!important;position:relative}.chip-tooltip-container{position:relative;display:inline-flex;overflow:visible!important}.chip-tooltip-container sa-tool-tip{display:none}.chips-container{display:flex;gap:var(--Small-4px, 4px);align-items:center}.actions-container{position:relative;display:flex;width:32px;height:32px;justify-content:center;align-items:center;cursor:pointer}.actions-icon{width:20px;height:20px;cursor:pointer!important}.actions-dropdown{position:absolute;right:0;min-width:150px;z-index:1000;border-radius:4px;border:1px solid var(--Grey-100, #EAECF0);background:var(--Structural-White, #FFF);box-shadow:0 1px 2px #0000004d}.action-item{display:flex;height:40px;padding:12px;align-items:center;gap:8px;align-self:stretch;cursor:pointer;transition:background-color .2s}.action-item:hover{background-color:#f5f5f5}.action-label{color:var(--text-highemphasis, #1C1B20);font-family:var(--font-roboto, Roboto);font-size:14px;font-style:normal;font-weight:400;line-height:20px;letter-spacing:.25px}.actions-container.clicked{border-radius:64px;background:var(--Primary-50, #F4EBFF);padding:8px}.chips-container{overflow:visible!important;position:relative}.chip-tooltip-container{position:relative;display:inline-flex;overflow:visible}\n"], dependencies: [{ kind: "component", type: AvatarComponent, selector: "sa-avatar", inputs: ["id", "imagePath", "altText", "size"], outputs: ["onClickEvent", "onMouseInEvent", "onMouseOutEvent"] }, { kind: "component", type: ChipsComponent, selector: "sa-chip", inputs: ["id", "iconPath", "text", "type", "state", "filling", "iconPosition", "largeStateIcon", "largeStateText", "tooltip", "className"], outputs: ["onClickEvent"] }, { kind: "component", type: ButtonComponent, selector: "sa-button", inputs: ["id", "type", "state", "size", "text", "ImagePath", "icon", "iconPosition", "href", "hrefTarget", "width", "isSubmit", "buttonIconSize", "showSpinner"], outputs: ["onClickEvent", "onMouseInEvent", "onMouseOutEvent"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: CommonModule }] }); }
|
|
66
202
|
}
|
|
67
203
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: GridCellComponent, decorators: [{
|
|
68
204
|
type: Component,
|
|
69
|
-
args: [{ selector: '
|
|
205
|
+
args: [{ selector: 'sa-grid-cell', standalone: true, imports: [
|
|
70
206
|
AvatarComponent,
|
|
71
207
|
ChipsComponent,
|
|
72
208
|
ButtonComponent,
|
|
73
|
-
NgFor
|
|
74
|
-
|
|
75
|
-
|
|
209
|
+
NgFor,
|
|
210
|
+
NgIf,
|
|
211
|
+
ToolTipComponent,
|
|
212
|
+
CommonModule
|
|
213
|
+
], template: "<div class=\"grid-cell {{params.cellType}}\">\r\n\r\n <img class=\"icons\" src={{params.iconPath}} [style.display]=\"(params.viewLeadingIcon) ? 'block' : 'none'\" alt=\"\">\r\n\r\n <sa-avatar [id]=\"params.avatarConfig?.id\" [altText]=\"params.avatarConfig?.altText\"\r\n [imagePath]=\"params.avatarConfig?.imagePath\" [size]=\"params.avatarConfig?.size\"\r\n [style.display]=\"(params.viewAvatar) ? 'block' : 'none'\" (onClickEvent)=\"avatarClicked($event)\">\r\n </sa-avatar>\r\n\r\n <div class=\"grid-text\" [style.display]=\"(params.viewText) ? 'block' : 'none'\">\r\n <div [style.display]=\"(params.text) ? 'block' : 'none'\" (click)=\"linkClicked()\" class=\"main-text\">{{params.text}}\r\n </div>\r\n\r\n <div [style.display]=\"(params.subText) ? 'block' : 'none'\" class=\"sub-text\">{{params.subText}}</div>\r\n </div>\r\n\r\n <img class=\"icons\" src={{params.iconPath}} [style.display]=\"(params.viewTrailingIcon) ? 'block' : 'none'\" alt=\"\">\r\n <div class=\"chips-container\" [style.display]=\"(params.viewChip) ? 'flex' : 'none'\">\r\n\r\n <div *ngFor=\"let config of displayedChips\">\r\n <sa-chip [id]=\"config.id\" [filling]=\"config.filling\" id=\"chip_{{rowNum}}_{{config.id}}\" [iconPath]=\"config.iconPath\"\r\n [iconPosition]=\"config.iconPosition\" [largeStateIcon]=\"config.largeStateIcon\" [state]=\"config.state\"\r\n [type]=\"config.type\" [text]=\"config.text\" [class.small]=\"config.type === 'small'\"\r\n [class.neutral]=\"config.state === 'neutral'\" (onClickEvent)=\"chipClicked($event)\"></sa-chip>\r\n </div>\r\n <div class=\"chip-tooltip-container\" *ngIf=\"remainingChipsCount > 0\" style=\"position: relative;\"\r\n (mouseenter)=\"showTooltip(remainingChipsCount, $event)\" (mouseleave)=\"hideTooltip()\">\r\n <sa-chip [id]=\"'chip_' + rowNum + '_more'\" [text]=\"'+' + remainingChipsCount\" [filling]=\"displayedChips[0]?.filling\"\r\n [type]=\"displayedChips[0]?.type\" [state]=\"displayedChips[0]?.state\" (onClickEvent)=\"chipClicked($event)\"></sa-chip>\r\n</div>\r\n\r\n <sa-button [iconPosition]=\"params.buttonConfig?.iconPosition\" [ImagePath]=\"params.buttonConfig?.imagePath\"\r\n [id]=\"params.buttonConfig?.id\" [size]=\"params.buttonConfig?.size\" [state]=\"params.buttonConfig?.state\"\r\n [type]=\"params.buttonConfig?.type\" [text]=\"params.buttonConfig?.text\" [href]=\"params.buttonConfig?.href\"\r\n [hrefTarget]=\"params.buttonConfig?.hrefTarget\" [style.display]=\"(params.viewButton) ? 'block' : 'none'\"\r\n (onClickEvent)=\"buttonClicked($event)\"></sa-button>\r\n\r\n</div>\r\n\r\n <div *ngIf=\"params.cellType === 'actions'\" class=\"actions-container\">\r\n <img [src]=\"params.buttonConfig?.imagePath\" alt=\"actions\" class=\"actions-icon\" (click)=\"toggleDropdown(actionsButton)\"\r\n #actionsButton />\r\n \r\n <ng-template #dropdownTemplate>\r\n <div class=\"actions-dropdown\">\r\n <div *ngFor=\"let action of params.actions\" class=\"action-item\" (click)=\"handleActionClick(action, $event)\">\r\n <img *ngIf=\"action.icon\" [src]=\"action.icon\" class=\"action-icon\" />\r\n <span class=\"action-label\">{{action.label}}</span>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </div>\r\n</div>\r\n", styles: [".header{--bg: var(--primary-50);--color: var(--text-highemphasis);--border: none;--flex-direction: left}.header:hover{cursor:pointer}.row{--color: var(--text-highemphasis);--cursor: default;--border: var(--grey-50);--flex-direction: left}.numeric{--color: var(--text-highemphasis);--cursor: default;--border: var(--grey-50);--flex-direction: right}.interactive{--color: var(--primary-500);--cursor: pointer;--border: var(--grey-50);--flex-direction: left}.grid-cell{display:flex;height:48px;padding:var(--small-12px);justify-content:var(--flex-direction);align-items:center;gap:var(--small-8px);flex-shrink:0;font-family:var(--font);box-sizing:border-box;border-bottom:1px solid var(--border);width:calc(100% - 20px);background-color:var(--bg)}.grid-text{display:flex;flex-direction:column}.main-text{color:var(--color);font-size:14px;font-weight:400;height:20px;line-height:20px}.main-text:hover{cursor:var(--cursor)}.sub-text{font-size:11px;font-weight:400;height:16px;line-height:16px;color:var(--text-mediumemphasis)}.icons{width:var(--medium-20px);height:var(--medium-20px)}.grid-chip{display:flex;height:24px;padding:var(--Small-4px, 4px) var(--Small-8px, 8px);justify-content:center;align-items:center;gap:var(--Small-4px, 4px);border-radius:4px;background:var(--Grey-100, #EAECF0);color:var(--Text-Medium-Emphasis, #6D6979);font-family:var(--font-family, Roboto);font-size:11px;font-style:normal;font-weight:500;line-height:16px;letter-spacing:.5px}.grid-cell,.chips-container{overflow:visible!important;position:relative}.chip-tooltip-container{position:relative;display:inline-flex;overflow:visible!important}.chip-tooltip-container sa-tool-tip{display:none}.chips-container{display:flex;gap:var(--Small-4px, 4px);align-items:center}.actions-container{position:relative;display:flex;width:32px;height:32px;justify-content:center;align-items:center;cursor:pointer}.actions-icon{width:20px;height:20px;cursor:pointer!important}.actions-dropdown{position:absolute;right:0;min-width:150px;z-index:1000;border-radius:4px;border:1px solid var(--Grey-100, #EAECF0);background:var(--Structural-White, #FFF);box-shadow:0 1px 2px #0000004d}.action-item{display:flex;height:40px;padding:12px;align-items:center;gap:8px;align-self:stretch;cursor:pointer;transition:background-color .2s}.action-item:hover{background-color:#f5f5f5}.action-label{color:var(--text-highemphasis, #1C1B20);font-family:var(--font-roboto, Roboto);font-size:14px;font-style:normal;font-weight:400;line-height:20px;letter-spacing:.25px}.actions-container.clicked{border-radius:64px;background:var(--Primary-50, #F4EBFF);padding:8px}.chips-container{overflow:visible!important;position:relative}.chip-tooltip-container{position:relative;display:inline-flex;overflow:visible}\n"] }]
|
|
214
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.Overlay }, { type: i0.ViewContainerRef }], propDecorators: { dropdownTemplate: [{
|
|
215
|
+
type: ViewChild,
|
|
216
|
+
args: ['dropdownTemplate']
|
|
217
|
+
}], actionsContainer: [{
|
|
218
|
+
type: ViewChild,
|
|
219
|
+
args: ['actionsContainer']
|
|
220
|
+
}], onClickButtonEvent: [{
|
|
76
221
|
type: Output
|
|
77
222
|
}], onClickChipEvent: [{
|
|
78
223
|
type: Output
|
|
@@ -80,5 +225,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
80
225
|
type: Output
|
|
81
226
|
}], onClickAvatarEvent: [{
|
|
82
227
|
type: Output
|
|
228
|
+
}], onDocumentClick: [{
|
|
229
|
+
type: HostListener,
|
|
230
|
+
args: ['document:click', ['$event']]
|
|
83
231
|
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-cell.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/grid-cell/grid-cell.component.ts","../../../../../projects/component-library/src/lib/grid-cell/grid-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter } from '@angular/core';\r\nimport { Output } from '@angular/core';\r\nimport { AvatarComponent } from '../avatar/avatar.component';\r\nimport { ChipsComponent } from '../chips/chips.component';\r\nimport { ButtonComponent } from '../button/button.component';\r\nimport { NgFor } from '@angular/common';\r\nimport { ICellRendererAngularComp, IHeaderAngularComp } from 'ag-grid-angular';\r\nimport { GridInterface } from '../../interfaces/grid-interface';\r\n\r\n@Component({\r\n  selector: 'lib-grid-cell',\r\n  standalone: true,\r\n  imports: [\r\n    AvatarComponent,\r\n    ChipsComponent,\r\n    ButtonComponent,\r\n    NgFor\r\n  ],\r\n  templateUrl: './grid-cell.component.html',\r\n  styleUrl: './grid-cell.component.css'\r\n})\r\nexport class GridCellComponent implements ICellRendererAngularComp, IHeaderAngularComp {\r\n  params: GridInterface;\r\n  rowNum: number;\r\n\r\n  @Output() onClickButtonEvent = new EventEmitter();\r\n  @Output() onClickChipEvent = new EventEmitter();\r\n  @Output() onClickLinkEvent = new EventEmitter();\r\n  @Output() onClickAvatarEvent = new EventEmitter();\r\n\r\n  buttonClicked(evt: Event) {\r\n    this.params.buttonClicked && this.params.buttonClicked({            // calls the function passed via params in gridInterface.\r\n      ...evt,\r\n      rowId: this.rowNum\r\n    });\r\n    this.onClickButtonEvent.emit({ ...evt, rowId: this.rowNum });      // this event isn't caught by anything. \r\n  }\r\n\r\n  // above function behavior is same for all functions in this class\r\n\r\n  chipClicked(evt: Event) {\r\n    this.params.chipClicked && this.params.chipClicked({\r\n      ...evt,\r\n      rowId: this.rowNum\r\n    });\r\n    this.onClickChipEvent.emit({ ...evt, rowId: this.rowNum });\r\n  }\r\n\r\n  linkClicked() {\r\n    if (this.params.cellType != \"interactive\") return;\r\n\r\n    this.params.linkClicked && this.params.linkClicked({         //calling function passed in params with rowId object in arguments\r\n      rowId: this.rowNum\r\n    });\r\n\r\n    if (this.params.interactiveLink != \"\") {\r\n      if (this.params.interactiveLinkTarget == \"blank\") {\r\n        window.open(this.params.interactiveLink)!;\r\n      }\r\n      else if (this.params.interactiveLinkTarget == \"self\") {\r\n        location.href = this.params.interactiveLink!;\r\n      }\r\n    }\r\n    this.onClickLinkEvent.emit({ rowId: this.rowNum });\r\n  }\r\n\r\n  avatarClicked(evt: Event) {\r\n    this.params.avatarClicked && this.params.avatarClicked({\r\n      ...evt,\r\n      rowId: this.rowNum\r\n    });\r\n    this.onClickChipEvent.emit({ ...evt, rowId: this.rowNum });\r\n  }\r\n\r\n  agInit(inParams: any): void {          // must exist when class implements ICellRendererAngularComp / IHeaderAngularComp\r\n\r\n    this.rowNum = inParams.rowIndex;\r\n    this.params = inParams.value;       // inParams.value exists when gridCell is rendered as cell, `cellRenderer: GridCellComponent`\r\n    if (inParams.value == undefined) {    // inParams.value is undefined when gridCell is rendered as header, `headerComponent: GridCellComponent`, \r\n      this.params = inParams\r\n    }\r\n    // console.log(this.params);\r\n  }\r\n\r\n  refresh(params: any) {     // must exist when class implements ICellRendererAngularComp / IHeaderAngularComp\r\n    return false;           // not sure what this return value does.\r\n  }\r\n\r\n}\r\n","<div class=\"grid-cell {{params.cellType}}\">\r\n\r\n  <img class=\"icons\" src={{params.iconPath}} [style.display]=\"(params.viewLeadingIcon) ? 'block' : 'none'\" alt=\"\">\r\n\r\n  <sa-avatar [id]=\"params.avatarConfig?.id\" [altText]=\"params.avatarConfig?.altText\"\r\n    [imagePath]=\"params.avatarConfig?.imagePath\" [size]=\"params.avatarConfig?.size\"\r\n    [style.display]=\"(params.viewAvatar) ? 'block' : 'none'\" (onClickEvent)=\"avatarClicked($event)\">\r\n  </sa-avatar>\r\n\r\n  <div class=\"grid-text\" [style.display]=\"(params.viewText) ? 'block' : 'none'\">\r\n    <div [style.display]=\"(params.text) ? 'block' : 'none'\" (click)=\"linkClicked()\" class=\"main-text\">{{params.text}}\r\n    </div>\r\n\r\n    <div [style.display]=\"(params.subText) ? 'block' : 'none'\" class=\"sub-text\">{{params.subText}}</div>\r\n  </div>\r\n\r\n  <img class=\"icons\" src={{params.iconPath}} [style.display]=\"(params.viewTrailingIcon) ? 'block' : 'none'\" alt=\"\">\r\n\r\n\r\n  <sa-chip *ngFor=\"let config of params.chipConfig, let i = index\" [id]=\"config.id\" [filling]=\"config.filling\"\r\n    id=\"chip_{{rowNum}}_{{config.id}}\" [iconPath]=\"config.iconPath\" [iconPosition]=\"config.iconPosition\"\r\n    [largeStateIcon]=\"config.largeStateIcon\" [state]=\"config.state\" [type]=\"config.type\" [text]=\"config.text\"\r\n    [style.display]=\"(params.viewChip) ? 'block' : 'none'\" (onClickEvent)=\"chipClicked($event)\"></sa-chip>\r\n\r\n  <sa-button [iconPosition]=\"params.buttonConfig?.iconPosition\" [ImagePath]=\"params.buttonConfig?.imagePath\"\r\n    [id]=\"params.buttonConfig?.id\" [size]=\"params.buttonConfig?.size\" [state]=\"params.buttonConfig?.state\"\r\n    [type]=\"params.buttonConfig?.type\" [text]=\"params.buttonConfig?.text\" [href]=\"params.buttonConfig?.href\"\r\n    [hrefTarget]=\"params.buttonConfig?.hrefTarget\" [style.display]=\"(params.viewButton) ? 'block' : 'none'\"\r\n    (onClickEvent)=\"buttonClicked($event)\"></sa-button>\r\n\r\n</div>\r\n"]}
|
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-cell.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/grid-cell/grid-cell.component.ts","../../../../../projects/component-library/src/lib/grid-cell/grid-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, ChangeDetectorRef, ElementRef, ViewChild, HostListener, OnDestroy } from '@angular/core';\r\nimport { ChipsComponent } from '../chips/chips.component';\r\nimport { ButtonComponent } from '../button/button.component';\r\nimport { ICellRendererAngularComp, IHeaderAngularComp } from 'ag-grid-angular';\r\nimport { GridInterface } from '../../interfaces/grid-interface';\r\nimport { AvatarComponent } from '../avatar/avatar.component';\r\nimport { ToolTipComponent } from '../tool-tip/tool-tip.component';\r\nimport { ChipInterface } from '../../interfaces/chip-interface';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { CommonModule, NgFor, NgIf } from '@angular/common';\r\nimport { ComponentRef } from '@angular/core';\r\nimport { TemplateRef, ViewContainerRef } from '@angular/core';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { ICellRendererParams } from 'ag-grid-community';\r\n\r\ninterface CellParams extends ICellRendererParams {\r\n  rowIndex: number;\r\n  value: any;\r\n  data: { you?: boolean };\r\n}\r\n\r\n@Component({\r\n  selector: 'sa-grid-cell',\r\n  standalone: true,\r\n  imports: [\r\n    AvatarComponent,\r\n    ChipsComponent,\r\n    ButtonComponent,\r\n    NgFor,\r\n    NgIf,\r\n    ToolTipComponent,\r\n    CommonModule\r\n  ],\r\n  templateUrl: './grid-cell.component.html',\r\n  styleUrl: './grid-cell.component.css'\r\n})\r\nexport class GridCellComponent implements ICellRendererAngularComp, OnDestroy {\r\n  @ViewChild('dropdownTemplate') dropdownTemplate!: TemplateRef<any>;\r\n  overlayRef!: OverlayRef;\r\n  @ViewChild('actionsContainer') actionsContainer!: ElementRef;\r\n  showDropdown = false;\r\n  readonly MAX_VISIBLE_CHIPS = 1; \r\n  displayedChips: ChipInterface[] = [];\r\n  remainingChipsCount = 0;\r\n  params!: GridInterface;\r\n  rowNum = 0;\r\n\r\n  @Output() onClickButtonEvent = new EventEmitter<{ rowId: number }>();\r\n  @Output() onClickChipEvent = new EventEmitter<{ rowId: number }>();\r\n  @Output() onClickLinkEvent = new EventEmitter();\r\n  @Output() onClickAvatarEvent = new EventEmitter<{ rowId: number }>();\r\n\r\n  constructor(private cdr: ChangeDetectorRef, private overlay: Overlay, private viewContainerRef: ViewContainerRef) {}\r\n\r\n  hoveredChip: any = null;\r\n  private tooltipComponentRef: ComponentRef<ToolTipComponent> | null = null;\r\n\r\n  agInit(params: CellParams): void {\r\n    this.rowNum = params.rowIndex;\r\n    \r\n    // Check for direct field value first, then fallback to _cellParams\r\n    let cellData = params.value;\r\n    if (!cellData && params.data && params.colDef?.field) {\r\n      const cellParamsKey = `${params.colDef.field}_cellParams`;\r\n      cellData = params.data[cellParamsKey];\r\n    }\r\n    \r\n    this.params = {\r\n      ...params,\r\n      ...(cellData ?? {})\r\n    };\r\n    \r\n    if (this.params.chipConfig && Array.isArray(this.params.chipConfig)) {\r\n      this.displayedChips = this.params.chipConfig.slice(0, this.MAX_VISIBLE_CHIPS);\r\n      this.remainingChipsCount = Math.max(0, this.params.chipConfig.length - this.MAX_VISIBLE_CHIPS);\r\n    }\r\n    else {\r\n       this.displayedChips = this.params.chipConfig;\r\n       this.remainingChipsCount = 0;\r\n    }\r\n  }\r\n\r\n  refresh(params: CellParams): boolean {\r\n    this.agInit(params);\r\n    return true;\r\n  }\r\n\r\n  typeOf(value: unknown): string {\r\n    return typeof value;\r\n  }\r\n  \r\n  buttonClicked(event: any) {\r\n    if (this.params.buttonConfig?.onClick) {\r\n      this.params.buttonConfig.onClick(event);\r\n    }\r\n    this.params.buttonClicked && this.params.buttonClicked({            \r\n      ...event,\r\n      rowId: this.rowNum\r\n    });\r\n    this.onClickButtonEvent.emit({ ...event, rowId: this.rowNum });      \r\n  }\r\n\r\n  toggleDropdown(element: HTMLElement) {\r\n    if (this.overlayRef) {\r\n      this.overlayRef.dispose();\r\n      return;\r\n    }\r\n\r\n    const positionStrategy = this.overlay.position()\r\n      .flexibleConnectedTo(element)\r\n      .withPush(true) \r\n      .withFlexibleDimensions(true) \r\n      .withViewportMargin(8) \r\n      .withPositions([\r\n        {\r\n          originX: 'end',\r\n          originY: 'bottom',\r\n          overlayX: 'end',\r\n          overlayY: 'top',\r\n          offsetY: 4,\r\n        },\r\n        {\r\n          originX: 'start',\r\n          originY: 'bottom',\r\n          overlayX: 'start',\r\n          overlayY: 'top',\r\n          offsetY: 4,\r\n        }\r\n      ]);\r\n\r\n    this.overlayRef = this.overlay.create({\r\n      positionStrategy,\r\n      hasBackdrop: true,\r\n      backdropClass: 'cdk-overlay-transparent-backdrop',\r\n      panelClass: 'actions-dropdown-panel',\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition() \r\n    });\r\n\r\n    const portal = new TemplatePortal(this.dropdownTemplate, this.viewContainerRef);\r\n    this.overlayRef.attach(portal);\r\n\r\n    this.overlayRef.backdropClick().subscribe(() => this.overlayRef.dispose());\r\n  }\r\n\r\n  handleActionClick(action: any, event: Event) {\r\n    event.stopPropagation();\r\n    this.showDropdown = false;\r\n    if (action.onClick) {\r\n      action.onClick();\r\n    }\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onDocumentClick(event: Event) {\r\n    if (this.actionsContainer && !this.actionsContainer.nativeElement.contains(event.target)) {\r\n      this.showDropdown = false;\r\n    }\r\n  }\r\n\r\n  chipClicked(evt: Event) {\r\n    this.params.chipClicked && this.params.chipClicked({\r\n      ...evt,\r\n      rowId: this.rowNum\r\n    });\r\n    this.onClickChipEvent.emit({ ...evt, rowId: this.rowNum });\r\n  }\r\n\r\n  linkClicked() {\r\n    if (this.params.cellType != \"interactive\") return;\r\n\r\n    this.params.linkClicked && this.params.linkClicked({         \r\n      rowId: this.rowNum\r\n    });\r\n\r\n    if (this.params.interactiveLink != \"\") {\r\n      if (this.params.interactiveLinkTarget == \"blank\") {\r\n        window.open(this.params.interactiveLink)!;\r\n      }\r\n      else if (this.params.interactiveLinkTarget == \"self\") {\r\n        location.href = this.params.interactiveLink!;\r\n      }\r\n    }\r\n    this.onClickLinkEvent.emit({ rowId: this.rowNum });\r\n  }\r\n\r\n  avatarClicked(evt: Event) {\r\n    this.params.avatarClicked && this.params.avatarClicked({\r\n      ...evt,\r\n      rowId: this.rowNum\r\n    });\r\n    this.onClickAvatarEvent.emit({ ...evt, rowId: this.rowNum });\r\n  }\r\n\r\n  showTooltip(config: any, event?: MouseEvent) {\r\n    this.hoveredChip = config; \r\n    if (event && event.currentTarget) {\r\n      const chipContainer = event.currentTarget as HTMLElement;\r\n      const chipElement = chipContainer.querySelector('sa-chip') as HTMLElement;\r\n      if (chipElement) {\r\n        const rect = chipElement.getBoundingClientRect();\r\n        const topPosition = rect.bottom + 8;\r\n        const leftPosition = rect.left + rect.width / 2;\r\n        this.createTooltipComponent(topPosition, leftPosition);\r\n      }\r\n    }\r\n  }\r\n\r\n  hideTooltip() {\r\n    this.hoveredChip = null;\r\n    this.destroyTooltipComponent();\r\n  }\r\n\r\n  createTooltipComponent(top: number, left: number) {\r\n    this.destroyTooltipComponent();\r\n    this.tooltipComponentRef = this.viewContainerRef.createComponent(ToolTipComponent);    \r\n    this.tooltipComponentRef.instance.messages = this.getTooltipText(); \r\n    this.tooltipComponentRef.instance.simpleMode = true;\r\n    this.tooltipComponentRef.instance.pointerPosition = 'top';\r\n    \r\n    const tooltipElement = this.tooltipComponentRef.location.nativeElement;\r\n    tooltipElement.style.cssText = `\r\n      position: fixed;\r\n      top: ${top}px;\r\n      left: ${left}px;\r\n      z-index: 99999;\r\n      transform: translateX(-50%);\r\n      pointer-events: none;\r\n    `;\r\n    document.body.appendChild(tooltipElement);\r\n    this.tooltipComponentRef.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  destroyTooltipComponent() {\r\n    if (this.tooltipComponentRef) {\r\n      const tooltipElement = this.tooltipComponentRef.location.nativeElement;\r\n      if (tooltipElement.parentNode) {\r\n        tooltipElement.parentNode.removeChild(tooltipElement);\r\n      }\r\n      this.tooltipComponentRef.destroy();\r\n      this.tooltipComponentRef = null;\r\n    }\r\n  }\r\n\r\n  getTooltipText(): string[] {\r\n    if (!this.params?.chipConfig) return [];\r\n    return this.params.chipConfig.map(chip => chip.text);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.hideTooltip();\r\n    if (this.overlayRef) {\r\n      this.overlayRef.dispose();\r\n    }\r\n  }\r\n}\r\n","<div class=\"grid-cell {{params.cellType}}\">\r\n\r\n  <img class=\"icons\" src={{params.iconPath}} [style.display]=\"(params.viewLeadingIcon) ? 'block' : 'none'\" alt=\"\">\r\n\r\n  <sa-avatar [id]=\"params.avatarConfig?.id\" [altText]=\"params.avatarConfig?.altText\"\r\n    [imagePath]=\"params.avatarConfig?.imagePath\" [size]=\"params.avatarConfig?.size\"\r\n    [style.display]=\"(params.viewAvatar) ? 'block' : 'none'\" (onClickEvent)=\"avatarClicked($event)\">\r\n  </sa-avatar>\r\n\r\n  <div class=\"grid-text\" [style.display]=\"(params.viewText) ? 'block' : 'none'\">\r\n    <div [style.display]=\"(params.text) ? 'block' : 'none'\" (click)=\"linkClicked()\" class=\"main-text\">{{params.text}}\r\n    </div>\r\n\r\n    <div [style.display]=\"(params.subText) ? 'block' : 'none'\" class=\"sub-text\">{{params.subText}}</div>\r\n  </div>\r\n\r\n  <img class=\"icons\" src={{params.iconPath}} [style.display]=\"(params.viewTrailingIcon) ? 'block' : 'none'\" alt=\"\">\r\n  <div class=\"chips-container\" [style.display]=\"(params.viewChip) ? 'flex' : 'none'\">\r\n\r\n  <div *ngFor=\"let config of displayedChips\">\r\n    <sa-chip [id]=\"config.id\" [filling]=\"config.filling\" id=\"chip_{{rowNum}}_{{config.id}}\" [iconPath]=\"config.iconPath\"\r\n      [iconPosition]=\"config.iconPosition\" [largeStateIcon]=\"config.largeStateIcon\" [state]=\"config.state\"\r\n      [type]=\"config.type\" [text]=\"config.text\" [class.small]=\"config.type === 'small'\"\r\n      [class.neutral]=\"config.state === 'neutral'\" (onClickEvent)=\"chipClicked($event)\"></sa-chip>\r\n  </div>\r\n  <div class=\"chip-tooltip-container\" *ngIf=\"remainingChipsCount > 0\" style=\"position: relative;\"\r\n    (mouseenter)=\"showTooltip(remainingChipsCount, $event)\" (mouseleave)=\"hideTooltip()\">\r\n    <sa-chip [id]=\"'chip_' + rowNum + '_more'\" [text]=\"'+' + remainingChipsCount\" [filling]=\"displayedChips[0]?.filling\"\r\n      [type]=\"displayedChips[0]?.type\" [state]=\"displayedChips[0]?.state\" (onClickEvent)=\"chipClicked($event)\"></sa-chip>\r\n</div>\r\n\r\n  <sa-button [iconPosition]=\"params.buttonConfig?.iconPosition\" [ImagePath]=\"params.buttonConfig?.imagePath\"\r\n    [id]=\"params.buttonConfig?.id\" [size]=\"params.buttonConfig?.size\" [state]=\"params.buttonConfig?.state\"\r\n    [type]=\"params.buttonConfig?.type\" [text]=\"params.buttonConfig?.text\" [href]=\"params.buttonConfig?.href\"\r\n    [hrefTarget]=\"params.buttonConfig?.hrefTarget\" [style.display]=\"(params.viewButton) ? 'block' : 'none'\"\r\n    (onClickEvent)=\"buttonClicked($event)\"></sa-button>\r\n\r\n</div>\r\n\r\n  <div *ngIf=\"params.cellType === 'actions'\" class=\"actions-container\">\r\n    <img [src]=\"params.buttonConfig?.imagePath\" alt=\"actions\" class=\"actions-icon\" (click)=\"toggleDropdown(actionsButton)\"\r\n      #actionsButton />\r\n  \r\n    <ng-template #dropdownTemplate>\r\n      <div class=\"actions-dropdown\">\r\n        <div *ngFor=\"let action of params.actions\" class=\"action-item\" (click)=\"handleActionClick(action, $event)\">\r\n          <img *ngIf=\"action.icon\" [src]=\"action.icon\" class=\"action-icon\" />\r\n          <span class=\"action-label\">{{action.label}}</span>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -24,13 +24,13 @@ export class SAMenuItemComponent {
|
|
|
24
24
|
this.onEvent.emit({ type: 'click', item });
|
|
25
25
|
}
|
|
26
26
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: SAMenuItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
27
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: SAMenuItemComponent, isStandalone: true, selector: "sa-menu-item", inputs: { item: "item", showRound: "showRound" }, outputs: { onEvent: "onEvent" }, providers: [IconService], viewQueries: [{ propertyName: "menuDirective", first: true, predicate: i0.forwardRef(() => MenuDirective), descendants: true }], ngImport: i0, template: "<!-- <div mat-menu-item class=\"sa-menu-item\">\r\n <span>{{item.label}}</span>\r\n</div> -->\r\n\r\n<div class=\"section-item {{item?.sepratorPosition}}\" [ngStyle]=\"{ 'border-radius': showRound ? '5px' : '0' }\" [ngClass]=\"item.isSelected ? 'selected' : ''\" (click)=\"optionClicked(item)\">\r\n <div class=\"status\" [saMenu]=\"item?.subMenu\">\r\n <sa-status-dot *ngIf=\"item.statusDot\" [config]=\"item?.statusDot\"></sa-status-dot>\r\n <sa-icon class=\"flex\" *ngIf=\"item.icon\" [icon]=\"item?.icon?.icon\" [iconPath]=\"item['icon']?.iconPath\" [iconUrl]=\"item['icon']?.iconUrl\" [size]=\"item['icon']?.size\" [customClass]=\"item['icon']?.customClass\"></sa-icon>\r\n <span class=\"sa-groupItem-lable\" >{{item.label}}</span>\r\n <div *ngIf=\"item?.subMenu\">\r\n <sa-icon [icon]=\"'rightChevronOutlined'\" [size]=\"'20'\"></sa-icon>\r\n </div>\r\n </div>\r\n <!-- Section for showing chips if chips are available in object -->\r\n <div *ngIf=\"item.chips\" class=\"tags\">\r\n @for (itm of item.chips; track $index) {\r\n <sa-chip *ngIf=\"itm.text\" [type]=\"itm.type\" [state]=\"itm.state\" [filling]=\"itm.filling\"\r\n [text]=\"itm.text\"></sa-chip>\r\n <!-- <span [ngClass]=\"itm.status == 'active' ? 'tag-active' : 'tag-inactive'\" class=\"\">{{itm.label}}</span> -->\r\n }\r\n </div>\r\n</div>\r\n", styles: [".sa-menu-item{padding:12px}.sa-menu-item:hover{background-color:var(--primary-500)}.sa-menu-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.sa-menu-item:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.section-item{display:flex;justify-content:space-between;align-items:center
|
|
27
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: SAMenuItemComponent, isStandalone: true, selector: "sa-menu-item", inputs: { item: "item", showRound: "showRound" }, outputs: { onEvent: "onEvent" }, providers: [IconService], viewQueries: [{ propertyName: "menuDirective", first: true, predicate: i0.forwardRef(() => MenuDirective), descendants: true }], ngImport: i0, template: "<!-- <div mat-menu-item class=\"sa-menu-item\">\r\n <span>{{item.label}}</span>\r\n</div> -->\r\n\r\n<div class=\"section-item {{item?.sepratorPosition}}\" [ngStyle]=\"{ 'border-radius': showRound ? '5px' : '0' }\" [ngClass]=\"item.isSelected ? 'selected' : ''\" (click)=\"optionClicked(item)\">\r\n <div class=\"status {{item['className']}}\" [saMenu]=\"item?.subMenu\">\r\n <sa-status-dot *ngIf=\"item.statusDot\" [config]=\"item?.statusDot\"></sa-status-dot>\r\n <sa-icon class=\"flex\" *ngIf=\"item.icon\" [icon]=\"item?.icon?.icon\" [iconPath]=\"item['icon']?.iconPath\" [iconUrl]=\"item['icon']?.iconUrl\" [size]=\"item['icon']?.size\" [customClass]=\"item['icon']?.customClass\"></sa-icon>\r\n <span class=\"sa-groupItem-lable\" >{{item.label}}</span>\r\n <div *ngIf=\"item?.subMenu\" class=\"flex ml-auto\">\r\n <sa-icon [icon]=\"'rightChevronOutlined'\" class=\"flex\" [size]=\"'20'\"></sa-icon>\r\n </div>\r\n </div>\r\n <!-- Section for showing chips if chips are available in object -->\r\n <div *ngIf=\"item.chips\" class=\"tags\">\r\n @for (itm of item.chips; track $index) {\r\n <sa-chip *ngIf=\"itm.text\" [type]=\"itm.type\" [state]=\"itm.state\" [filling]=\"itm.filling\"\r\n [text]=\"itm.text\"></sa-chip>\r\n <!-- <span [ngClass]=\"itm.status == 'active' ? 'tag-active' : 'tag-inactive'\" class=\"\">{{itm.label}}</span> -->\r\n }\r\n </div>\r\n</div>\r\n", styles: [".sa-menu-item{padding:12px}.sa-menu-item:hover{background-color:var(--primary-500)}.sa-menu-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.sa-menu-item:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.section-item{display:flex;justify-content:space-between;align-items:center}.section-item .status{padding:.75rem}.section-item:hover{background-color:var(--primary-500)}.section-item:hover span{font-weight:500}.selected{background-color:var(--primary-500)}.section-item .tags{display:flex;gap:.25rem}.tag{background-color:#6b46c1;font-size:.2rem;padding:.25rem .5rem;border-radius:.25rem}.tag-active{background-color:#6b46c1!important;font-size:.2rem;padding:.25rem .5rem;border-radius:.25rem}.tag-inactive{background-color:#d27f2b!important;font-size:.2rem;padding:.25rem .5rem;border-radius:.25rem}.status{display:flex;align-items:center;gap:.6rem}.status-dot{width:.5rem;height:.5rem;border-radius:50%}.status-active{background-color:#48bb78}.status-inactive{background-color:#f19e4f}hr{border:0;border-top:1px solid #718096;margin-bottom:1rem}.sa-groupItem-lable{cursor:pointer;font-size:14px;font-weight:400}.flex{display:flex}.top{border-top:1px solid #475467}.bottom{border-bottom:1px solid #475467}.ml-auto{margin-left:auto}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(() => CommonModule) }, { kind: "directive", type: i0.forwardRef(() => i1.NgClass), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(() => i1.NgIf), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(() => i1.NgStyle), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i0.forwardRef(() => ChipsComponent), selector: "sa-chip", inputs: ["id", "iconPath", "text", "type", "state", "filling", "iconPosition", "largeStateIcon", "largeStateText", "tooltip", "className"], outputs: ["onClickEvent"] }, { kind: "ngmodule", type: i0.forwardRef(() => HttpClientModule) }, { kind: "component", type: i0.forwardRef(() => IconComponent), selector: "sa-icon", inputs: ["img", "icon", "size", "color", "iconPath", "iconUrl", "customClass", "href", "hrefTarget"], outputs: ["onClickEvent"] }, { kind: "component", type: i0.forwardRef(() => StatusDotComponent), selector: "sa-status-dot", inputs: ["config"] }, { kind: "directive", type: i0.forwardRef(() => MenuDirective), selector: "[saMenu]", inputs: ["saMenuRef", "saMenu", "saManuPosition"], outputs: ["onMenuEvent", "onEvent", "onAttached", "onDetached"] }] }); }
|
|
28
28
|
}
|
|
29
29
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: SAMenuItemComponent, decorators: [{
|
|
30
30
|
type: Component,
|
|
31
31
|
args: [{ selector: 'sa-menu-item', standalone: true, imports: [CommonModule, ChipsComponent, HttpClientModule, IconComponent, StatusDotComponent,
|
|
32
32
|
forwardRef(() => MenuDirective)
|
|
33
|
-
], providers: [IconService], template: "<!-- <div mat-menu-item class=\"sa-menu-item\">\r\n <span>{{item.label}}</span>\r\n</div> -->\r\n\r\n<div class=\"section-item {{item?.sepratorPosition}}\" [ngStyle]=\"{ 'border-radius': showRound ? '5px' : '0' }\" [ngClass]=\"item.isSelected ? 'selected' : ''\" (click)=\"optionClicked(item)\">\r\n <div class=\"status\" [saMenu]=\"item?.subMenu\">\r\n <sa-status-dot *ngIf=\"item.statusDot\" [config]=\"item?.statusDot\"></sa-status-dot>\r\n <sa-icon class=\"flex\" *ngIf=\"item.icon\" [icon]=\"item?.icon?.icon\" [iconPath]=\"item['icon']?.iconPath\" [iconUrl]=\"item['icon']?.iconUrl\" [size]=\"item['icon']?.size\" [customClass]=\"item['icon']?.customClass\"></sa-icon>\r\n <span class=\"sa-groupItem-lable\" >{{item.label}}</span>\r\n <div *ngIf=\"item?.subMenu\">\r\n <sa-icon [icon]=\"'rightChevronOutlined'\" [size]=\"'20'\"></sa-icon>\r\n </div>\r\n </div>\r\n <!-- Section for showing chips if chips are available in object -->\r\n <div *ngIf=\"item.chips\" class=\"tags\">\r\n @for (itm of item.chips; track $index) {\r\n <sa-chip *ngIf=\"itm.text\" [type]=\"itm.type\" [state]=\"itm.state\" [filling]=\"itm.filling\"\r\n [text]=\"itm.text\"></sa-chip>\r\n <!-- <span [ngClass]=\"itm.status == 'active' ? 'tag-active' : 'tag-inactive'\" class=\"\">{{itm.label}}</span> -->\r\n }\r\n </div>\r\n</div>\r\n", styles: [".sa-menu-item{padding:12px}.sa-menu-item:hover{background-color:var(--primary-500)}.sa-menu-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.sa-menu-item:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.section-item{display:flex;justify-content:space-between;align-items:center
|
|
33
|
+
], providers: [IconService], template: "<!-- <div mat-menu-item class=\"sa-menu-item\">\r\n <span>{{item.label}}</span>\r\n</div> -->\r\n\r\n<div class=\"section-item {{item?.sepratorPosition}}\" [ngStyle]=\"{ 'border-radius': showRound ? '5px' : '0' }\" [ngClass]=\"item.isSelected ? 'selected' : ''\" (click)=\"optionClicked(item)\">\r\n <div class=\"status {{item['className']}}\" [saMenu]=\"item?.subMenu\">\r\n <sa-status-dot *ngIf=\"item.statusDot\" [config]=\"item?.statusDot\"></sa-status-dot>\r\n <sa-icon class=\"flex\" *ngIf=\"item.icon\" [icon]=\"item?.icon?.icon\" [iconPath]=\"item['icon']?.iconPath\" [iconUrl]=\"item['icon']?.iconUrl\" [size]=\"item['icon']?.size\" [customClass]=\"item['icon']?.customClass\"></sa-icon>\r\n <span class=\"sa-groupItem-lable\" >{{item.label}}</span>\r\n <div *ngIf=\"item?.subMenu\" class=\"flex ml-auto\">\r\n <sa-icon [icon]=\"'rightChevronOutlined'\" class=\"flex\" [size]=\"'20'\"></sa-icon>\r\n </div>\r\n </div>\r\n <!-- Section for showing chips if chips are available in object -->\r\n <div *ngIf=\"item.chips\" class=\"tags\">\r\n @for (itm of item.chips; track $index) {\r\n <sa-chip *ngIf=\"itm.text\" [type]=\"itm.type\" [state]=\"itm.state\" [filling]=\"itm.filling\"\r\n [text]=\"itm.text\"></sa-chip>\r\n <!-- <span [ngClass]=\"itm.status == 'active' ? 'tag-active' : 'tag-inactive'\" class=\"\">{{itm.label}}</span> -->\r\n }\r\n </div>\r\n</div>\r\n", styles: [".sa-menu-item{padding:12px}.sa-menu-item:hover{background-color:var(--primary-500)}.sa-menu-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.sa-menu-item:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.section-item{display:flex;justify-content:space-between;align-items:center}.section-item .status{padding:.75rem}.section-item:hover{background-color:var(--primary-500)}.section-item:hover span{font-weight:500}.selected{background-color:var(--primary-500)}.section-item .tags{display:flex;gap:.25rem}.tag{background-color:#6b46c1;font-size:.2rem;padding:.25rem .5rem;border-radius:.25rem}.tag-active{background-color:#6b46c1!important;font-size:.2rem;padding:.25rem .5rem;border-radius:.25rem}.tag-inactive{background-color:#d27f2b!important;font-size:.2rem;padding:.25rem .5rem;border-radius:.25rem}.status{display:flex;align-items:center;gap:.6rem}.status-dot{width:.5rem;height:.5rem;border-radius:50%}.status-active{background-color:#48bb78}.status-inactive{background-color:#f19e4f}hr{border:0;border-top:1px solid #718096;margin-bottom:1rem}.sa-groupItem-lable{cursor:pointer;font-size:14px;font-weight:400}.flex{display:flex}.top{border-top:1px solid #475467}.bottom{border-bottom:1px solid #475467}.ml-auto{margin-left:auto}\n"] }]
|
|
34
34
|
}], propDecorators: { item: [{
|
|
35
35
|
type: Input,
|
|
36
36
|
args: ['item']
|
|
@@ -43,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
43
43
|
type: ViewChild,
|
|
44
44
|
args: [forwardRef(() => MenuDirective)]
|
|
45
45
|
}] } });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudC1saWJyYXJ5L3NyYy9saWIvbWVudS9tZW51LWxpc3QvbWVudS1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudC1saWJyYXJ5L3NyYy9saWIvbWVudS9tZW51LWxpc3QvbWVudS1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQWlCLFNBQVMsRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUNoSSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBRTFELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0seUJBQXlCLENBQUM7OztBQVl0RCxNQUFNLE9BQU8sbUJBQW1CO0lBVmhDO1FBYVksWUFBTyxHQUFzQixJQUFJLFlBQVksRUFBRSxDQUFDO0tBZTNEO0lBYkMsMkRBQTJEO0lBRTNELGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN2QixJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtnQkFDN0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQywrQkFBK0I7WUFDM0QsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO0lBQ0gsQ0FBQztJQUVELGFBQWEsQ0FBQyxJQUFlO1FBQzNCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQzdDLENBQUM7OEdBakJVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLDhJQUpuQixDQUFDLFdBQVcsQ0FBQyw2RkFRSSxhQUFhLGlEQ3hCM0MsMDhDQXNCQSxpMUNEVFksWUFBWSwwWUFBRSxjQUFjLCtPQUFDLGdCQUFnQixvREFBRSxhQUFhLDBNQUFFLGtCQUFrQixtR0FDdkUsYUFBYTs7MkZBTXJCLG1CQUFtQjtrQkFWL0IsU0FBUzsrQkFDRSxjQUFjLGNBQ1osSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGNBQWMsRUFBQyxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsa0JBQWtCO3dCQUN4RixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsYUFBYSxDQUFDO3FCQUNoQyxhQUNVLENBQUMsV0FBVyxDQUFDOzhCQUtULElBQUk7c0JBQWxCLEtBQUs7dUJBQUMsTUFBTTtnQkFDTyxTQUFTO3NCQUE1QixLQUFLO3VCQUFDLFdBQVc7Z0JBQ1IsT0FBTztzQkFBaEIsTUFBTTtnQkFDcUMsYUFBYTtzQkFBeEQsU0FBUzt1QkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIGZvcndhcmRSZWYsIElucHV0LCBPdXRwdXQsIFZpZXdDaGlsZCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2hpcHNDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jaGlwcy9jaGlwcy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBJY29uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vaWNvbi9pY29uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElNZW51SXRlbSB9IGZyb20gJy4uLy4uLy4uL2ludGVyZmFjZXMvbWVudS5pbnRlcmZhY2UnO1xyXG5pbXBvcnQgeyBTdGF0dXNEb3RDb21wb25lbnQgfSBmcm9tICcuLi8uLi9zdGF0dXMtZG90L3N0YXR1cy1kb3QuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWVudURpcmVjdGl2ZSB9IGZyb20gJy4uL21lbnUuZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgSWNvblNlcnZpY2UgfSBmcm9tICcuLi8uLi9pY29uL2ljb24uc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NhLW1lbnUtaXRlbScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBDaGlwc0NvbXBvbmVudCxIdHRwQ2xpZW50TW9kdWxlLCBJY29uQ29tcG9uZW50LCBTdGF0dXNEb3RDb21wb25lbnQsXHJcbiAgICBmb3J3YXJkUmVmKCgpID0+IE1lbnVEaXJlY3RpdmUpIFxyXG4gIF0sXHJcbiAgcHJvdmlkZXJzOiBbSWNvblNlcnZpY2VdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9tZW51LWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9tZW51LWl0ZW0uY29tcG9uZW50LmNzcydcclxufSlcclxuZXhwb3J0IGNsYXNzIFNBTWVudUl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcclxuICBASW5wdXQoJ2l0ZW0nKSBpdGVtOiBJTWVudUl0ZW07XHJcbiAgQElucHV0KCdzaG93Um91bmQnKSBzaG93Um91bmQ6IGJvb2xlYW47XHJcbiAgQE91dHB1dCgpIG9uRXZlbnQ6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gIEBWaWV3Q2hpbGQoZm9yd2FyZFJlZigoKSA9PiBNZW51RGlyZWN0aXZlKSkgbWVudURpcmVjdGl2ZTogTWVudURpcmVjdGl2ZTtcclxuICAvLyBAVmlld0NoaWxkKE1lbnVEaXJlY3RpdmUpIG1lbnVEaXJlY3RpdmU/OiBNZW51RGlyZWN0aXZlO1xyXG5cclxuICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICBpZiAodGhpcy5tZW51RGlyZWN0aXZlKSB7XHJcbiAgICAgIHRoaXMubWVudURpcmVjdGl2ZS5vbkV2ZW50LnN1YnNjcmliZSgoZXZlbnQpID0+IHtcclxuICAgICAgICB0aGlzLm9uRXZlbnQuZW1pdChldmVudCk7IC8vIOKchSByZS1lbWl0IHRvIFNBTWVudUNvbXBvbmVudFxyXG4gICAgICB9KTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG9wdGlvbkNsaWNrZWQoaXRlbTogSU1lbnVJdGVtKSB7XHJcbiAgICB0aGlzLm9uRXZlbnQuZW1pdCh7IHR5cGU6ICdjbGljaycsIGl0ZW0gfSk7XHJcbiAgfVxyXG59XHJcbiIsIjwhLS0gPGRpdiBtYXQtbWVudS1pdGVtIGNsYXNzPVwic2EtbWVudS1pdGVtXCI+XHJcbiAgICA8c3Bhbj57e2l0ZW0ubGFiZWx9fTwvc3Bhbj5cclxuPC9kaXY+IC0tPlxyXG5cclxuPGRpdiBjbGFzcz1cInNlY3Rpb24taXRlbSB7e2l0ZW0/LnNlcHJhdG9yUG9zaXRpb259fVwiIFtuZ1N0eWxlXT1cInsgJ2JvcmRlci1yYWRpdXMnOiBzaG93Um91bmQgPyAnNXB4JyA6ICcwJyB9XCIgW25nQ2xhc3NdPVwiaXRlbS5pc1NlbGVjdGVkID8gJ3NlbGVjdGVkJyA6ICcnXCIgKGNsaWNrKT1cIm9wdGlvbkNsaWNrZWQoaXRlbSlcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJzdGF0dXMge3tpdGVtWydjbGFzc05hbWUnXX19XCIgW3NhTWVudV09XCJpdGVtPy5zdWJNZW51XCI+XHJcbiAgICAgICAgPHNhLXN0YXR1cy1kb3QgKm5nSWY9XCJpdGVtLnN0YXR1c0RvdFwiIFtjb25maWddPVwiaXRlbT8uc3RhdHVzRG90XCI+PC9zYS1zdGF0dXMtZG90PlxyXG4gICAgICAgIDxzYS1pY29uIGNsYXNzPVwiZmxleFwiICpuZ0lmPVwiaXRlbS5pY29uXCIgW2ljb25dPVwiaXRlbT8uaWNvbj8uaWNvblwiICBbaWNvblBhdGhdPVwiaXRlbVsnaWNvbiddPy5pY29uUGF0aFwiIFtpY29uVXJsXT1cIml0ZW1bJ2ljb24nXT8uaWNvblVybFwiIFtzaXplXT1cIml0ZW1bJ2ljb24nXT8uc2l6ZVwiIFtjdXN0b21DbGFzc109XCJpdGVtWydpY29uJ10/LmN1c3RvbUNsYXNzXCI+PC9zYS1pY29uPlxyXG4gICAgICAgIDxzcGFuIGNsYXNzPVwic2EtZ3JvdXBJdGVtLWxhYmxlXCIgPnt7aXRlbS5sYWJlbH19PC9zcGFuPlxyXG4gICAgICAgIDxkaXYgKm5nSWY9XCJpdGVtPy5zdWJNZW51XCIgY2xhc3M9XCJmbGV4IG1sLWF1dG9cIj5cclxuICAgICAgICAgICAgPHNhLWljb24gW2ljb25dPVwiJ3JpZ2h0Q2hldnJvbk91dGxpbmVkJ1wiIGNsYXNzPVwiZmxleFwiIFtzaXplXT1cIicyMCdcIj48L3NhLWljb24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuICAgIDwhLS0gU2VjdGlvbiBmb3Igc2hvd2luZyBjaGlwcyBpZiBjaGlwcyBhcmUgYXZhaWxhYmxlIGluIG9iamVjdCAgLS0+XHJcbiAgICA8ZGl2ICpuZ0lmPVwiaXRlbS5jaGlwc1wiIGNsYXNzPVwidGFnc1wiPlxyXG4gICAgICAgIEBmb3IgKGl0bSBvZiBpdGVtLmNoaXBzOyB0cmFjayAkaW5kZXgpIHtcclxuICAgICAgICA8c2EtY2hpcCAqbmdJZj1cIml0bS50ZXh0XCIgW3R5cGVdPVwiaXRtLnR5cGVcIiBbc3RhdGVdPVwiaXRtLnN0YXRlXCIgW2ZpbGxpbmddPVwiaXRtLmZpbGxpbmdcIlxyXG4gICAgICAgICAgICBbdGV4dF09XCJpdG0udGV4dFwiPjwvc2EtY2hpcD5cclxuICAgICAgICA8IS0tIDxzcGFuIFtuZ0NsYXNzXT1cIml0bS5zdGF0dXMgPT0gJ2FjdGl2ZScgPyAndGFnLWFjdGl2ZScgOiAndGFnLWluYWN0aXZlJ1wiIGNsYXNzPVwiXCI+e3tpdG0ubGFiZWx9fTwvc3Bhbj4gLS0+XHJcbiAgICAgICAgfVxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
|