@edm-sdui/sdui 1.0.25 → 1.0.27

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.
@@ -19,6 +19,8 @@ export class ProfileButtonComponent {
19
19
  ngAfterViewInit() {
20
20
  if (this.uiComponent.element) {
21
21
  this.applyElement(this.uiComponent.element);
22
+ // esperar o layout para medir o texto já com estilos aplicados
23
+ setTimeout(() => this.fitLabelToTwoLines(), 0);
22
24
  }
23
25
  }
24
26
  applyElement(element) {
@@ -34,15 +36,69 @@ export class ProfileButtonComponent {
34
36
  this.renderer.setStyle(this.profileButtonLabelElementRef.nativeElement, 'font-size', this.fontSizeMappingService.getMapping()[UITextStyle.CAPTION_2]);
35
37
  this.renderer.setStyle(this.profileButtonLabelElementRef.nativeElement, 'color', colorMapping[UIColor.MAIN1]);
36
38
  }
39
+ fitLabelToTwoLines(maxLines = 2, minFontSizePx = 10) {
40
+ if (typeof window === 'undefined') {
41
+ return;
42
+ }
43
+ const labelElement = this.profileButtonLabelElementRef?.nativeElement;
44
+ if (!labelElement) {
45
+ return;
46
+ }
47
+ const computedStyles = window.getComputedStyle(labelElement);
48
+ let fontSize = parseFloat(computedStyles.fontSize);
49
+ if (!Number.isFinite(fontSize)) {
50
+ return;
51
+ }
52
+ const lineHeight = computedStyles.lineHeight === 'normal'
53
+ ? fontSize * 1.2
54
+ : parseFloat(computedStyles.lineHeight);
55
+ if (!Number.isFinite(lineHeight) || lineHeight <= 0) {
56
+ return;
57
+ }
58
+ const lineHeightRatio = lineHeight / fontSize;
59
+ const applyMetrics = () => {
60
+ const currentLineHeight = lineHeightRatio * fontSize;
61
+ const allowedHeight = currentLineHeight * maxLines;
62
+ this.renderer.setStyle(labelElement, 'line-height', `${currentLineHeight}px`);
63
+ this.renderer.setStyle(labelElement, 'max-height', `${allowedHeight}px`);
64
+ return allowedHeight;
65
+ };
66
+ const fits = (allowedHeight) => {
67
+ const EPSILON = 0.5;
68
+ const availableWidth = labelElement.clientWidth;
69
+ if (availableWidth <= 0) {
70
+ return true;
71
+ }
72
+ return (labelElement.scrollHeight <= allowedHeight + EPSILON &&
73
+ labelElement.scrollWidth <= availableWidth + EPSILON);
74
+ };
75
+ this.renderer.removeClass(labelElement, 'truncate');
76
+ this.renderer.removeStyle(labelElement, 'height');
77
+ let allowedHeight = applyMetrics();
78
+ let contentFits = fits(allowedHeight);
79
+ while (!contentFits && fontSize > minFontSizePx) {
80
+ fontSize -= 1;
81
+ this.renderer.setStyle(labelElement, 'font-size', `${fontSize}px`);
82
+ allowedHeight = applyMetrics();
83
+ contentFits = fits(allowedHeight);
84
+ }
85
+ if (!contentFits) {
86
+ this.renderer.addClass(labelElement, 'truncate');
87
+ }
88
+ else {
89
+ this.renderer.removeClass(labelElement, 'truncate');
90
+ this.renderer.removeStyle(labelElement, 'max-height');
91
+ }
92
+ }
37
93
  getAssetPath(asset) {
38
94
  return assetMapping[asset];
39
95
  }
40
96
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ProfileButtonComponent, deps: [{ token: 'uiComponent' }, { token: i0.Renderer2 }, { token: i1.FontSizeMappingService }], target: i0.ɵɵFactoryTarget.Component }); }
41
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: ProfileButtonComponent, isStandalone: false, selector: "edm-sdui-profile-button", viewQueries: [{ propertyName: "profileButtonElementRef", first: true, predicate: ["profileButtonElement"], descendants: true }, { propertyName: "profileButtonLabelElementRef", first: true, predicate: ["profileButtonLabelElement"], descendants: true }, { propertyName: "profileButtonImageElementRef", first: true, predicate: ["profileButtonImageElement"], descendants: true }], ngImport: i0, template: "<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n", styles: [":host{display:contents}.profile-button{display:flex;padding:16px 16px 0;border-radius:20px;background-color:var(--bt-profile);border:none;cursor:pointer;flex-direction:column;height:108px;width:108px;align-items:start;justify-content:start;gap:24px}.profile-button:hover{background-color:#0000000d;cursor:pointer}.profile-button .profile-image{width:24px;height:24px}.profile-button .profile-label{white-space:normal;word-break:break-word;overflow-wrap:break-word;max-width:100%;display:block;text-align:left}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
97
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: ProfileButtonComponent, isStandalone: false, selector: "edm-sdui-profile-button", viewQueries: [{ propertyName: "profileButtonElementRef", first: true, predicate: ["profileButtonElement"], descendants: true }, { propertyName: "profileButtonLabelElementRef", first: true, predicate: ["profileButtonLabelElement"], descendants: true }, { propertyName: "profileButtonImageElementRef", first: true, predicate: ["profileButtonImageElement"], descendants: true }], ngImport: i0, template: "<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n", styles: [":host{display:contents}.profile-button{display:flex;padding:16px 16px 0;border-radius:20px;background-color:var(--bt-profile);border:none;cursor:pointer;flex-direction:column;height:108px;width:108px;align-items:start;justify-content:start;gap:24px}.profile-button:hover{background-color:#0000000d;cursor:pointer}.profile-button .profile-image{width:24px;height:24px}.profile-button .profile-label{max-width:100%;white-space:normal;word-break:keep-all;overflow-wrap:normal;text-align:left;overflow:hidden;display:block}.profile-button .profile-label.truncate{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
42
98
  }
43
99
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ProfileButtonComponent, decorators: [{
44
100
  type: Component,
45
- args: [{ selector: 'edm-sdui-profile-button', standalone: false, template: "<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n", styles: [":host{display:contents}.profile-button{display:flex;padding:16px 16px 0;border-radius:20px;background-color:var(--bt-profile);border:none;cursor:pointer;flex-direction:column;height:108px;width:108px;align-items:start;justify-content:start;gap:24px}.profile-button:hover{background-color:#0000000d;cursor:pointer}.profile-button .profile-image{width:24px;height:24px}.profile-button .profile-label{white-space:normal;word-break:break-word;overflow-wrap:break-word;max-width:100%;display:block;text-align:left}\n"] }]
101
+ args: [{ selector: 'edm-sdui-profile-button', standalone: false, template: "<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n", styles: [":host{display:contents}.profile-button{display:flex;padding:16px 16px 0;border-radius:20px;background-color:var(--bt-profile);border:none;cursor:pointer;flex-direction:column;height:108px;width:108px;align-items:start;justify-content:start;gap:24px}.profile-button:hover{background-color:#0000000d;cursor:pointer}.profile-button .profile-image{width:24px;height:24px}.profile-button .profile-label{max-width:100%;white-space:normal;word-break:keep-all;overflow-wrap:normal;text-align:left;overflow:hidden;display:block}.profile-button .profile-label.truncate{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;text-overflow:ellipsis}\n"] }]
46
102
  }], ctorParameters: () => [{ type: undefined, decorators: [{
47
103
  type: Inject,
48
104
  args: ['uiComponent']
@@ -56,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
56
112
  type: ViewChild,
57
113
  args: ['profileButtonImageElement']
58
114
  }] } });
59
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZHVpL3NyYy9saWIvY29tcG9uZW50cy91aWNvbXBvbmVudC9wcm9maWxlLWJ1dHRvbi9wcm9maWxlLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb21wb25lbnRzL3VpY29tcG9uZW50L3Byb2ZpbGUtYnV0dG9uL3Byb2ZpbGUtYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxTQUFTLEVBQ1QsVUFBVSxFQUNWLE1BQU0sRUFFTixTQUFTLEVBQ1QsU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBR3ZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUMzRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrREFBa0QsQ0FBQztBQUMxRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFFM0UsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQzs7Ozs7QUFROUQsTUFBTSxPQUFPLHNCQUFzQjtJQUtqQyxZQUNnQyxXQUF3QixFQUM5QyxRQUFtQixFQUNuQixzQkFBOEM7UUFGeEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFDOUMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUNuQiwyQkFBc0IsR0FBdEIsc0JBQXNCLENBQXdCO0lBQ3JELENBQUM7SUFFSixRQUFRO0lBQ1IsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDN0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzlDLENBQUM7SUFDSCxDQUFDO0lBRU8sWUFBWSxDQUFDLE9BQWtCO1FBQ3JDLElBQUksT0FBTyxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3RCLE1BQU0sS0FBSyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDOUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQ3BCLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxhQUFhLEVBQzFDLE9BQU8sRUFDUCxLQUFLLENBQ04sQ0FBQztRQUNKLENBQUM7UUFFRCxJQUFJLE9BQU8sQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUN0QixNQUFNLHdCQUF3QixHQUFHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUMxRSxNQUFNLFFBQVEsR0FBRyx3QkFBd0IsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDN0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQ3BCLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxhQUFhLEVBQzFDLFdBQVcsRUFDWCxRQUFRLENBQ1QsQ0FBQztRQUNKLENBQUM7UUFHRCxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FDcEIsSUFBSSxDQUFDLDRCQUE0QixDQUFDLGFBQWEsRUFDL0MsV0FBVyxFQUNYLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQTtRQUNsRSxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FDcEIsSUFBSSxDQUFDLDRCQUE0QixDQUFDLGFBQWEsRUFDL0MsT0FBTyxFQUNQLFlBQVksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQTtJQUVoQyxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWM7UUFDekIsT0FBTyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0IsQ0FBQzsrR0F0RFUsc0JBQXNCLGtCQU12QixhQUFhO21HQU5aLHNCQUFzQiw2Y0N4Qm5DLHVZQUlBOzs0RkRvQmEsc0JBQXNCO2tCQU5sQyxTQUFTOytCQUNFLHlCQUF5QixjQUd2QixLQUFLOzswQkFRZCxNQUFNOzJCQUFDLGFBQWE7c0dBTFksdUJBQXVCO3NCQUF6RCxTQUFTO3VCQUFDLHNCQUFzQjtnQkFDTyw0QkFBNEI7c0JBQW5FLFNBQVM7dUJBQUMsMkJBQTJCO2dCQUNFLDRCQUE0QjtzQkFBbkUsU0FBUzt1QkFBQywyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEluamVjdCxcbiAgT25Jbml0LFxuICBSZW5kZXJlcjIsXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBVSUNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL2NvcmUvdWljb21wb3NpdGlvbi9tb2RlbHMvdWljb21wb25lbnQnO1xuaW1wb3J0IHsgVUlFbGVtZW50IH0gZnJvbSAnLi4vLi4vLi4vY29yZS91aWNvbXBvc2l0aW9uL21vZGVscy91aWVsZW1lbnQnO1xuaW1wb3J0IHsgY29sb3JNYXBwaW5nIH0gZnJvbSAnLi4vLi4vLi4vY29yZS91aXRoZW1lL21hcHBpbmcvY29sb3ItbWFwcGluZyc7XG5pbXBvcnQgeyBGb250U2l6ZU1hcHBpbmdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vY29yZS9zZXJ2aWNlcy9mb250LXNpemUtbWFwcGluZy5zZXJ2aWNlJztcbmltcG9ydCB7IGFzc2V0TWFwcGluZyB9IGZyb20gJy4uLy4uLy4uL2NvcmUvdWl0aGVtZS9tYXBwaW5nL2Fzc2V0LW1hcHBpbmcnO1xuaW1wb3J0IHsgVUlBc3NldCB9IGZyb20gJy4uLy4uLy4uL2NvcmUvdWl0aGVtZS9lbnVtcy91aWFzc2V0JztcbmltcG9ydCB7IFVJVGV4dFN0eWxlIH0gZnJvbSAnLi4vLi4vLi4vY29yZS91aXRoZW1lL2VudW1zL3VpdGV4dC1zdHlsZSc7XG5pbXBvcnQgeyBVSUNvbG9yIH0gZnJvbSAnLi4vLi4vLi4vY29yZS91aXRoZW1lL2VudW1zL3VpY29sb3InO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlZG0tc2R1aS1wcm9maWxlLWJ1dHRvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9wcm9maWxlLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9wcm9maWxlLWJ1dHRvbi5jb21wb25lbnQuc2NzcycsXG4gIHN0YW5kYWxvbmU6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBQcm9maWxlQnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0IHtcbiAgQFZpZXdDaGlsZCgncHJvZmlsZUJ1dHRvbkVsZW1lbnQnKSBwcm9maWxlQnV0dG9uRWxlbWVudFJlZiE6IEVsZW1lbnRSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+O1xuICBAVmlld0NoaWxkKCdwcm9maWxlQnV0dG9uTGFiZWxFbGVtZW50JykgcHJvZmlsZUJ1dHRvbkxhYmVsRWxlbWVudFJlZiE6IEVsZW1lbnRSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+O1xuICBAVmlld0NoaWxkKCdwcm9maWxlQnV0dG9uSW1hZ2VFbGVtZW50JykgcHJvZmlsZUJ1dHRvbkltYWdlRWxlbWVudFJlZiE6IEVsZW1lbnRSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+O1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoJ3VpQ29tcG9uZW50JykgcHVibGljIHVpQ29tcG9uZW50OiBVSUNvbXBvbmVudCxcbiAgICBwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIsXG4gICAgcHJpdmF0ZSBmb250U2l6ZU1hcHBpbmdTZXJ2aWNlOiBGb250U2l6ZU1hcHBpbmdTZXJ2aWNlXG4gICkge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy51aUNvbXBvbmVudC5lbGVtZW50KSB7XG4gICAgICB0aGlzLmFwcGx5RWxlbWVudCh0aGlzLnVpQ29tcG9uZW50LmVsZW1lbnQpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgYXBwbHlFbGVtZW50KGVsZW1lbnQ6IFVJRWxlbWVudCkge1xuICAgIGlmIChlbGVtZW50LnRleHRDb2xvcikge1xuICAgICAgY29uc3QgY29sb3IgPSBjb2xvck1hcHBpbmdbZWxlbWVudC50ZXh0Q29sb3JdO1xuICAgICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZShcbiAgICAgICAgdGhpcy5wcm9maWxlQnV0dG9uRWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LFxuICAgICAgICAnY29sb3InLFxuICAgICAgICBjb2xvclxuICAgICAgKTtcbiAgICB9XG5cbiAgICBpZiAoZWxlbWVudC50ZXh0U3R5bGUpIHtcbiAgICAgIGNvbnN0IHRleHRTdHlsZU1hcHBpbmdGb250U2l6ZSA9IHRoaXMuZm9udFNpemVNYXBwaW5nU2VydmljZS5nZXRNYXBwaW5nKCk7XG4gICAgICBjb25zdCBmb250U2l6ZSA9IHRleHRTdHlsZU1hcHBpbmdGb250U2l6ZVtlbGVtZW50LnRleHRTdHlsZV07XG4gICAgICB0aGlzLnJlbmRlcmVyLnNldFN0eWxlKFxuICAgICAgICB0aGlzLnByb2ZpbGVCdXR0b25FbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsXG4gICAgICAgICdmb250LXNpemUnLFxuICAgICAgICBmb250U2l6ZVxuICAgICAgKTtcbiAgICB9XG5cblxuICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUoXG4gICAgICB0aGlzLnByb2ZpbGVCdXR0b25MYWJlbEVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCxcbiAgICAgICdmb250LXNpemUnLFxuICAgICAgdGhpcy5mb250U2l6ZU1hcHBpbmdTZXJ2aWNlLmdldE1hcHBpbmcoKVtVSVRleHRTdHlsZS5DQVBUSU9OXzJdKVxuICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUoXG4gICAgICB0aGlzLnByb2ZpbGVCdXR0b25MYWJlbEVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCxcbiAgICAgICdjb2xvcicsXG4gICAgICBjb2xvck1hcHBpbmdbVUlDb2xvci5NQUlOMV0pXG5cbiAgfVxuXG4gIGdldEFzc2V0UGF0aChhc3NldDogVUlBc3NldCkge1xuICAgIHJldHVybiBhc3NldE1hcHBpbmdbYXNzZXRdO1xuICB9XG59XG4iLCI8YnV0dG9uICNwcm9maWxlQnV0dG9uRWxlbWVudCBbZWRtU2R1aVZpZXddPVwidWlDb21wb25lbnQuZWxlbWVudFwiIGNsYXNzPVwicHJvZmlsZS1idXR0b25cIiAqbmdJZj1cInVpQ29tcG9uZW50XCI+XG4gIDxpbWcgI3Byb2ZpbGVCdXR0b25JbWFnZUVsZW1lbnQgKm5nSWY9XCJ1aUNvbXBvbmVudC5lbGVtZW50LmFzc2V0XCIgW3NyY109XCJnZXRBc3NldFBhdGgodWlDb21wb25lbnQuZWxlbWVudC5hc3NldClcIiBhbHQ9XCJQcm9maWxlXCIgY2xhc3M9XCJwcm9maWxlLWltYWdlXCI+XG4gIDxzcGFuICNwcm9maWxlQnV0dG9uTGFiZWxFbGVtZW50IGNsYXNzPVwicHJvZmlsZS1sYWJlbFwiPnt7IHVpQ29tcG9uZW50LmVsZW1lbnQubGFiZWwgfX08L3NwYW4+XG48L2J1dHRvbj5cbiJdfQ==
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile-button.component.js","sourceRoot":"","sources":["../../../../../../../../libs/sdui/src/lib/components/uicomponent/profile-button/profile-button.component.ts","../../../../../../../../libs/sdui/src/lib/components/uicomponent/profile-button/profile-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Inject,\n  OnInit,\n  Renderer2,\n  ViewChild,\n} from '@angular/core';\nimport { UIComponent } from '../../../core/uicomposition/models/uicomponent';\nimport { UIElement } from '../../../core/uicomposition/models/uielement';\nimport { colorMapping } from '../../../core/uitheme/mapping/color-mapping';\nimport { FontSizeMappingService } from '../../../core/services/font-size-mapping.service';\nimport { assetMapping } from '../../../core/uitheme/mapping/asset-mapping';\nimport { UIAsset } from '../../../core/uitheme/enums/uiasset';\nimport { UITextStyle } from '../../../core/uitheme/enums/uitext-style';\nimport { UIColor } from '../../../core/uitheme/enums/uicolor';\n\n@Component({\n  selector: 'edm-sdui-profile-button',\n  templateUrl: './profile-button.component.html',\n  styleUrl: './profile-button.component.scss',\n  standalone: false,\n})\nexport class ProfileButtonComponent implements OnInit, AfterViewInit {\n  @ViewChild('profileButtonElement') profileButtonElementRef!: ElementRef<HTMLButtonElement>;\n  @ViewChild('profileButtonLabelElement') profileButtonLabelElementRef!: ElementRef<HTMLButtonElement>;\n  @ViewChild('profileButtonImageElement') profileButtonImageElementRef!: ElementRef<HTMLButtonElement>;\n\n  constructor(\n    @Inject('uiComponent') public uiComponent: UIComponent,\n    private renderer: Renderer2,\n    private fontSizeMappingService: FontSizeMappingService\n  ) {}\n\n  ngOnInit(): void {\n  }\n\n  ngAfterViewInit(): void {\n    if (this.uiComponent.element) {\n      this.applyElement(this.uiComponent.element);\n      // esperar o layout para medir o texto já com estilos aplicados\n      setTimeout(() => this.fitLabelToTwoLines(), 0);\n    }\n  }\n\n  private applyElement(element: UIElement) {\n    if (element.textColor) {\n      const color = colorMapping[element.textColor];\n      this.renderer.setStyle(\n        this.profileButtonElementRef.nativeElement,\n        'color',\n        color\n      );\n    }\n\n    if (element.textStyle) {\n      const textStyleMappingFontSize = this.fontSizeMappingService.getMapping();\n      const fontSize = textStyleMappingFontSize[element.textStyle];\n      this.renderer.setStyle(\n        this.profileButtonElementRef.nativeElement,\n        'font-size',\n        fontSize\n      );\n    }\n\n\n    this.renderer.setStyle(\n      this.profileButtonLabelElementRef.nativeElement,\n      'font-size',\n      this.fontSizeMappingService.getMapping()[UITextStyle.CAPTION_2]\n    );\n    this.renderer.setStyle(\n      this.profileButtonLabelElementRef.nativeElement,\n      'color',\n      colorMapping[UIColor.MAIN1]\n    );\n  }\n\n  private fitLabelToTwoLines(maxLines = 2, minFontSizePx = 10) {\n    if (typeof window === 'undefined') {\n      return;\n    }\n\n    const labelElement = this.profileButtonLabelElementRef?.nativeElement;\n    if (!labelElement) {\n      return;\n    }\n\n    const computedStyles = window.getComputedStyle(labelElement);\n    let fontSize = parseFloat(computedStyles.fontSize);\n\n    if (!Number.isFinite(fontSize)) {\n      return;\n    }\n\n    const lineHeight = computedStyles.lineHeight === 'normal'\n      ? fontSize * 1.2\n      : parseFloat(computedStyles.lineHeight);\n\n    if (!Number.isFinite(lineHeight) || lineHeight <= 0) {\n      return;\n    }\n\n    const lineHeightRatio = lineHeight / fontSize;\n\n    const applyMetrics = () => {\n      const currentLineHeight = lineHeightRatio * fontSize;\n      const allowedHeight = currentLineHeight * maxLines;\n      this.renderer.setStyle(labelElement, 'line-height', `${currentLineHeight}px`);\n      this.renderer.setStyle(labelElement, 'max-height', `${allowedHeight}px`);\n      return allowedHeight;\n    };\n\n    const fits = (allowedHeight: number) => {\n      const EPSILON = 0.5;\n      const availableWidth = labelElement.clientWidth;\n\n      if (availableWidth <= 0) {\n        return true;\n      }\n\n      return (\n        labelElement.scrollHeight <= allowedHeight + EPSILON &&\n        labelElement.scrollWidth <= availableWidth + EPSILON\n      );\n    };\n\n    this.renderer.removeClass(labelElement, 'truncate');\n    this.renderer.removeStyle(labelElement, 'height');\n\n    let allowedHeight = applyMetrics();\n    let contentFits = fits(allowedHeight);\n\n    while (!contentFits && fontSize > minFontSizePx) {\n      fontSize -= 1;\n      this.renderer.setStyle(labelElement, 'font-size', `${fontSize}px`);\n      allowedHeight = applyMetrics();\n      contentFits = fits(allowedHeight);\n    }\n\n    if (!contentFits) {\n      this.renderer.addClass(labelElement, 'truncate');\n    } else {\n      this.renderer.removeClass(labelElement, 'truncate');\n      this.renderer.removeStyle(labelElement, 'max-height');\n    }\n  }\n\n  getAssetPath(asset: UIAsset) {\n    return assetMapping[asset];\n  }\n}\n","<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n  <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n  <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n"]}
@@ -3147,6 +3147,8 @@ class ProfileButtonComponent {
3147
3147
  ngAfterViewInit() {
3148
3148
  if (this.uiComponent.element) {
3149
3149
  this.applyElement(this.uiComponent.element);
3150
+ // esperar o layout para medir o texto já com estilos aplicados
3151
+ setTimeout(() => this.fitLabelToTwoLines(), 0);
3150
3152
  }
3151
3153
  }
3152
3154
  applyElement(element) {
@@ -3162,15 +3164,69 @@ class ProfileButtonComponent {
3162
3164
  this.renderer.setStyle(this.profileButtonLabelElementRef.nativeElement, 'font-size', this.fontSizeMappingService.getMapping()[UITextStyle.CAPTION_2]);
3163
3165
  this.renderer.setStyle(this.profileButtonLabelElementRef.nativeElement, 'color', colorMapping[UIColor.MAIN1]);
3164
3166
  }
3167
+ fitLabelToTwoLines(maxLines = 2, minFontSizePx = 10) {
3168
+ if (typeof window === 'undefined') {
3169
+ return;
3170
+ }
3171
+ const labelElement = this.profileButtonLabelElementRef?.nativeElement;
3172
+ if (!labelElement) {
3173
+ return;
3174
+ }
3175
+ const computedStyles = window.getComputedStyle(labelElement);
3176
+ let fontSize = parseFloat(computedStyles.fontSize);
3177
+ if (!Number.isFinite(fontSize)) {
3178
+ return;
3179
+ }
3180
+ const lineHeight = computedStyles.lineHeight === 'normal'
3181
+ ? fontSize * 1.2
3182
+ : parseFloat(computedStyles.lineHeight);
3183
+ if (!Number.isFinite(lineHeight) || lineHeight <= 0) {
3184
+ return;
3185
+ }
3186
+ const lineHeightRatio = lineHeight / fontSize;
3187
+ const applyMetrics = () => {
3188
+ const currentLineHeight = lineHeightRatio * fontSize;
3189
+ const allowedHeight = currentLineHeight * maxLines;
3190
+ this.renderer.setStyle(labelElement, 'line-height', `${currentLineHeight}px`);
3191
+ this.renderer.setStyle(labelElement, 'max-height', `${allowedHeight}px`);
3192
+ return allowedHeight;
3193
+ };
3194
+ const fits = (allowedHeight) => {
3195
+ const EPSILON = 0.5;
3196
+ const availableWidth = labelElement.clientWidth;
3197
+ if (availableWidth <= 0) {
3198
+ return true;
3199
+ }
3200
+ return (labelElement.scrollHeight <= allowedHeight + EPSILON &&
3201
+ labelElement.scrollWidth <= availableWidth + EPSILON);
3202
+ };
3203
+ this.renderer.removeClass(labelElement, 'truncate');
3204
+ this.renderer.removeStyle(labelElement, 'height');
3205
+ let allowedHeight = applyMetrics();
3206
+ let contentFits = fits(allowedHeight);
3207
+ while (!contentFits && fontSize > minFontSizePx) {
3208
+ fontSize -= 1;
3209
+ this.renderer.setStyle(labelElement, 'font-size', `${fontSize}px`);
3210
+ allowedHeight = applyMetrics();
3211
+ contentFits = fits(allowedHeight);
3212
+ }
3213
+ if (!contentFits) {
3214
+ this.renderer.addClass(labelElement, 'truncate');
3215
+ }
3216
+ else {
3217
+ this.renderer.removeClass(labelElement, 'truncate');
3218
+ this.renderer.removeStyle(labelElement, 'max-height');
3219
+ }
3220
+ }
3165
3221
  getAssetPath(asset) {
3166
3222
  return assetMapping[asset];
3167
3223
  }
3168
3224
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ProfileButtonComponent, deps: [{ token: 'uiComponent' }, { token: i0.Renderer2 }, { token: FontSizeMappingService }], target: i0.ɵɵFactoryTarget.Component }); }
3169
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: ProfileButtonComponent, isStandalone: false, selector: "edm-sdui-profile-button", viewQueries: [{ propertyName: "profileButtonElementRef", first: true, predicate: ["profileButtonElement"], descendants: true }, { propertyName: "profileButtonLabelElementRef", first: true, predicate: ["profileButtonLabelElement"], descendants: true }, { propertyName: "profileButtonImageElementRef", first: true, predicate: ["profileButtonImageElement"], descendants: true }], ngImport: i0, template: "<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n", styles: [":host{display:contents}.profile-button{display:flex;padding:16px 16px 0;border-radius:20px;background-color:var(--bt-profile);border:none;cursor:pointer;flex-direction:column;height:108px;width:108px;align-items:start;justify-content:start;gap:24px}.profile-button:hover{background-color:#0000000d;cursor:pointer}.profile-button .profile-image{width:24px;height:24px}.profile-button .profile-label{white-space:normal;word-break:break-word;overflow-wrap:break-word;max-width:100%;display:block;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
3225
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: ProfileButtonComponent, isStandalone: false, selector: "edm-sdui-profile-button", viewQueries: [{ propertyName: "profileButtonElementRef", first: true, predicate: ["profileButtonElement"], descendants: true }, { propertyName: "profileButtonLabelElementRef", first: true, predicate: ["profileButtonLabelElement"], descendants: true }, { propertyName: "profileButtonImageElementRef", first: true, predicate: ["profileButtonImageElement"], descendants: true }], ngImport: i0, template: "<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n", styles: [":host{display:contents}.profile-button{display:flex;padding:16px 16px 0;border-radius:20px;background-color:var(--bt-profile);border:none;cursor:pointer;flex-direction:column;height:108px;width:108px;align-items:start;justify-content:start;gap:24px}.profile-button:hover{background-color:#0000000d;cursor:pointer}.profile-button .profile-image{width:24px;height:24px}.profile-button .profile-label{max-width:100%;white-space:normal;word-break:keep-all;overflow-wrap:normal;text-align:left;overflow:hidden;display:block}.profile-button .profile-label.truncate{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
3170
3226
  }
3171
3227
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ProfileButtonComponent, decorators: [{
3172
3228
  type: Component,
3173
- args: [{ selector: 'edm-sdui-profile-button', standalone: false, template: "<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n", styles: [":host{display:contents}.profile-button{display:flex;padding:16px 16px 0;border-radius:20px;background-color:var(--bt-profile);border:none;cursor:pointer;flex-direction:column;height:108px;width:108px;align-items:start;justify-content:start;gap:24px}.profile-button:hover{background-color:#0000000d;cursor:pointer}.profile-button .profile-image{width:24px;height:24px}.profile-button .profile-label{white-space:normal;word-break:break-word;overflow-wrap:break-word;max-width:100%;display:block;text-align:left}\n"] }]
3229
+ args: [{ selector: 'edm-sdui-profile-button', standalone: false, template: "<button #profileButtonElement [edmSduiView]=\"uiComponent.element\" class=\"profile-button\" *ngIf=\"uiComponent\">\n <img #profileButtonImageElement *ngIf=\"uiComponent.element.asset\" [src]=\"getAssetPath(uiComponent.element.asset)\" alt=\"Profile\" class=\"profile-image\">\n <span #profileButtonLabelElement class=\"profile-label\">{{ uiComponent.element.label }}</span>\n</button>\n", styles: [":host{display:contents}.profile-button{display:flex;padding:16px 16px 0;border-radius:20px;background-color:var(--bt-profile);border:none;cursor:pointer;flex-direction:column;height:108px;width:108px;align-items:start;justify-content:start;gap:24px}.profile-button:hover{background-color:#0000000d;cursor:pointer}.profile-button .profile-image{width:24px;height:24px}.profile-button .profile-label{max-width:100%;white-space:normal;word-break:keep-all;overflow-wrap:normal;text-align:left;overflow:hidden;display:block}.profile-button .profile-label.truncate{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;text-overflow:ellipsis}\n"] }]
3174
3230
  }], ctorParameters: () => [{ type: undefined, decorators: [{
3175
3231
  type: Inject,
3176
3232
  args: ['uiComponent']