@edm-sdui/sdui 1.0.26 → 1.0.28
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/edm-sdui-sdui-1.0.28.tgz +0 -0
- package/esm2022/lib/components/uicomponent/profile-button/profile-button.component.mjs +30 -20
- package/esm2022/lib/components/uiscreen/uiscreen.component.mjs +9 -3
- package/esm2022/lib/core/services/ui-action.service.mjs +29 -1
- package/esm2022/lib/core/services/uiscreen.service.mjs +22 -2
- package/esm2022/lib/core/uicomposition/enums/uiscreen-container-type.mjs +6 -0
- package/esm2022/lib/core/uicomposition/models/uiscreen-config.mjs +2 -0
- package/esm2022/lib/core/uicomposition/models/uiscreen.mjs +1 -1
- package/esm2022/lib/core/uicomposition/models/uiview.mjs +1 -1
- package/esm2022/lib/core/uitheme/enums/uiaction-type.mjs +2 -1
- package/esm2022/lib/core/uitheme/enums/uiasset.mjs +5 -1
- package/esm2022/lib/core/uitheme/enums/uisize.mjs +3 -1
- package/esm2022/lib/core/uitheme/mapping/asset-mapping.mjs +5 -1
- package/esm2022/lib/core/uitheme/mapping/size-mapping.mjs +5 -1
- package/esm2022/lib/directives/uiview.directive.mjs +4 -1
- package/fesm2022/edm-sdui-sdui.mjs +104 -22
- package/fesm2022/edm-sdui-sdui.mjs.map +1 -1
- package/lib/components/uicomponent/profile-button/profile-button.component.d.ts.map +1 -1
- package/lib/components/uiscreen/uiscreen.component.d.ts +2 -0
- package/lib/components/uiscreen/uiscreen.component.d.ts.map +1 -1
- package/lib/core/services/ui-action.service.d.ts +1 -0
- package/lib/core/services/ui-action.service.d.ts.map +1 -1
- package/lib/core/services/uiscreen.service.d.ts +1 -0
- package/lib/core/services/uiscreen.service.d.ts.map +1 -1
- package/lib/core/uicomposition/enums/uiscreen-container-type.d.ts +5 -0
- package/lib/core/uicomposition/enums/uiscreen-container-type.d.ts.map +1 -0
- package/lib/core/uicomposition/models/uiscreen-config.d.ts +6 -0
- package/lib/core/uicomposition/models/uiscreen-config.d.ts.map +1 -0
- package/lib/core/uicomposition/models/uiscreen.d.ts +2 -0
- package/lib/core/uicomposition/models/uiscreen.d.ts.map +1 -1
- package/lib/core/uicomposition/models/uiview.d.ts +1 -0
- package/lib/core/uicomposition/models/uiview.d.ts.map +1 -1
- package/lib/core/uitheme/enums/uiaction-type.d.ts +1 -0
- package/lib/core/uitheme/enums/uiaction-type.d.ts.map +1 -1
- package/lib/core/uitheme/enums/uiasset.d.ts +5 -1
- package/lib/core/uitheme/enums/uiasset.d.ts.map +1 -1
- package/lib/core/uitheme/enums/uisize.d.ts +2 -0
- package/lib/core/uitheme/enums/uisize.d.ts.map +1 -1
- package/lib/core/uitheme/mapping/asset-mapping.d.ts.map +1 -1
- package/lib/core/uitheme/mapping/size-mapping.d.ts.map +1 -1
- package/lib/directives/uiview.directive.d.ts.map +1 -1
- package/package.json +1 -1
|
Binary file
|
|
@@ -56,39 +56,49 @@ export class ProfileButtonComponent {
|
|
|
56
56
|
return;
|
|
57
57
|
}
|
|
58
58
|
const lineHeightRatio = lineHeight / fontSize;
|
|
59
|
-
const
|
|
60
|
-
const
|
|
61
|
-
|
|
62
|
-
this.renderer.setStyle(labelElement, '
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
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;
|
|
68
71
|
}
|
|
69
|
-
return
|
|
72
|
+
return (labelElement.scrollHeight <= allowedHeight + EPSILON &&
|
|
73
|
+
labelElement.scrollWidth <= availableWidth + EPSILON);
|
|
70
74
|
};
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
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) {
|
|
74
80
|
fontSize -= 1;
|
|
75
81
|
this.renderer.setStyle(labelElement, 'font-size', `${fontSize}px`);
|
|
76
|
-
|
|
77
|
-
|
|
82
|
+
allowedHeight = applyMetrics();
|
|
83
|
+
contentFits = fits(allowedHeight);
|
|
84
|
+
}
|
|
85
|
+
if (!contentFits) {
|
|
86
|
+
this.renderer.addClass(labelElement, 'truncate');
|
|
78
87
|
}
|
|
79
|
-
|
|
80
|
-
this.renderer.
|
|
88
|
+
else {
|
|
89
|
+
this.renderer.removeClass(labelElement, 'truncate');
|
|
90
|
+
this.renderer.removeStyle(labelElement, 'max-height');
|
|
81
91
|
}
|
|
82
92
|
}
|
|
83
93
|
getAssetPath(asset) {
|
|
84
94
|
return assetMapping[asset];
|
|
85
95
|
}
|
|
86
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 }); }
|
|
87
|
-
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;
|
|
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"] }] }); }
|
|
88
98
|
}
|
|
89
99
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ProfileButtonComponent, decorators: [{
|
|
90
100
|
type: Component,
|
|
91
|
-
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;
|
|
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"] }]
|
|
92
102
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
93
103
|
type: Inject,
|
|
94
104
|
args: ['uiComponent']
|
|
@@ -102,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
102
112
|
type: ViewChild,
|
|
103
113
|
args: ['profileButtonImageElement']
|
|
104
114
|
}] } });
|
|
105
|
-
//# 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":"AAAA,OAAO,EAEL,SAAS,EACT,UAAU,EACV,MAAM,EAEN,SAAS,EACT,SAAS,GACV,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,YAAY,EAAE,MAAM,6CAA6C,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,kDAAkD,CAAC;AAC1F,OAAO,EAAE,YAAY,EAAE,MAAM,6CAA6C,CAAC;AAE3E,OAAO,EAAE,WAAW,EAAE,MAAM,0CAA0C,CAAC;AACvE,OAAO,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;;;;;AAQ9D,MAAM,OAAO,sBAAsB;IAKjC,YACgC,WAAwB,EAC9C,QAAmB,EACnB,sBAA8C;QAFxB,gBAAW,GAAX,WAAW,CAAa;QAC9C,aAAQ,GAAR,QAAQ,CAAW;QACnB,2BAAsB,GAAtB,sBAAsB,CAAwB;IACrD,CAAC;IAEJ,QAAQ;IACR,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC5C,+DAA+D;YAC/D,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC,CAAC;QACjD,CAAC;IACH,CAAC;IAEO,YAAY,CAAC,OAAkB;QACrC,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAC9C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,uBAAuB,CAAC,aAAa,EAC1C,OAAO,EACP,KAAK,CACN,CAAC;QACJ,CAAC;QAED,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,MAAM,wBAAwB,GAAG,IAAI,CAAC,sBAAsB,CAAC,UAAU,EAAE,CAAC;YAC1E,MAAM,QAAQ,GAAG,wBAAwB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAC7D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,uBAAuB,CAAC,aAAa,EAC1C,WAAW,EACX,QAAQ,CACT,CAAC;QACJ,CAAC;QAGD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,4BAA4B,CAAC,aAAa,EAC/C,WAAW,EACX,IAAI,CAAC,sBAAsB,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC,CAChE,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,4BAA4B,CAAC,aAAa,EAC/C,OAAO,EACP,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC,CAC5B,CAAC;IACJ,CAAC;IAEO,kBAAkB,CAAC,QAAQ,GAAG,CAAC,EAAE,aAAa,GAAG,EAAE;QACzD,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;YAClC,OAAO;QACT,CAAC;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,4BAA4B,EAAE,aAAa,CAAC;QACtE,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,OAAO;QACT,CAAC;QAED,MAAM,cAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;QAC7D,IAAI,QAAQ,GAAG,UAAU,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAEnD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,MAAM,UAAU,GAAG,cAAc,CAAC,UAAU,KAAK,QAAQ;YACvD,CAAC,CAAC,QAAQ,GAAG,GAAG;YAChB,CAAC,CAAC,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;QAE1C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,UAAU,IAAI,CAAC,EAAE,CAAC;YACpD,OAAO;QACT,CAAC;QAED,MAAM,eAAe,GAAG,UAAU,GAAG,QAAQ,CAAC;QAE9C,MAAM,aAAa,GAAG,CAAC,WAAoB,EAAE,EAAE;YAC7C,MAAM,YAAY,GAAG,eAAe,GAAG,QAAQ,GAAG,QAAQ,CAAC;YAC3D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,EAAE,aAAa,EAAE,GAAG,eAAe,GAAG,QAAQ,IAAI,CAAC,CAAC;YACvF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,EAAE,YAAY,EAAE,GAAG,YAAY,IAAI,CAAC,CAAC;YACxE,IAAI,WAAW,EAAE,CAAC;gBAChB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,EAAE,GAAG,YAAY,IAAI,CAAC,CAAC;YACtE,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;YACpD,CAAC;YACD,OAAO,YAAY,CAAC;QACtB,CAAC,CAAC;QAEF,IAAI,YAAY,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;QACxC,IAAI,WAAW,GAAG,KAAK,CAAC;QAExB,OAAO,YAAY,CAAC,YAAY,GAAG,YAAY,IAAI,QAAQ,GAAG,aAAa,EAAE,CAAC;YAC5E,QAAQ,IAAI,CAAC,CAAC;YACd,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,EAAE,WAAW,EAAE,GAAG,QAAQ,IAAI,CAAC,CAAC;YACnE,YAAY,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;YACnC,WAAW,GAAG,IAAI,CAAC;QACrB,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACpD,CAAC;IACH,CAAC;IAED,YAAY,CAAC,KAAc;QACzB,OAAO,YAAY,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;+GA/GU,sBAAsB,kBAMvB,aAAa;mGANZ,sBAAsB,6cCxBnC,uYAIA;;4FDoBa,sBAAsB;kBANlC,SAAS;+BACE,yBAAyB,cAGvB,KAAK;;0BAQd,MAAM;2BAAC,aAAa;sGALY,uBAAuB;sBAAzD,SAAS;uBAAC,sBAAsB;gBACO,4BAA4B;sBAAnE,SAAS;uBAAC,2BAA2B;gBACE,4BAA4B;sBAAnE,SAAS;uBAAC,2BAA2B","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 updateMetrics = (forceHeight: boolean) => {\n      const targetHeight = lineHeightRatio * fontSize * maxLines;\n      this.renderer.setStyle(labelElement, 'line-height', `${lineHeightRatio * fontSize}px`);\n      this.renderer.setStyle(labelElement, 'max-height', `${targetHeight}px`);\n      if (forceHeight) {\n        this.renderer.setStyle(labelElement, 'height', `${targetHeight}px`);\n      } else {\n        this.renderer.removeStyle(labelElement, 'height');\n      }\n      return targetHeight;\n    };\n\n    let targetHeight = updateMetrics(false);\n    let constrained = false;\n\n    while (labelElement.scrollHeight > targetHeight && fontSize > minFontSizePx) {\n      fontSize -= 1;\n      this.renderer.setStyle(labelElement, 'font-size', `${fontSize}px`);\n      targetHeight = updateMetrics(true);\n      constrained = true;\n    }\n\n    if (!constrained) {\n      this.renderer.removeStyle(labelElement, '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"]}
|
|
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"]}
|
|
@@ -13,11 +13,17 @@ export class UIScreenComponent {
|
|
|
13
13
|
this.viewModel = viewModel;
|
|
14
14
|
this.UIScreenIdentifier = UIScreenIdentifier;
|
|
15
15
|
}
|
|
16
|
+
containerClass(config) {
|
|
17
|
+
const container = (config?.container || 'fluid').toString().toLowerCase();
|
|
18
|
+
return container === 'contained'
|
|
19
|
+
? 'ui-screen--contained'
|
|
20
|
+
: 'ui-screen--fluid';
|
|
21
|
+
}
|
|
16
22
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: UIScreenComponent, deps: [{ token: i1.UIScreenViewModel }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
17
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: UIScreenComponent, isStandalone: false, selector: "edm-sdui-uiscreen", ngImport: i0, template: "<ng-container *ngIf=\"viewModel.isLoading$ | async; else loaded\">\n <div class=\"loading-spinner\">\n <div class=\"spinner\"></div>\n </div>\n</ng-container>\n\n<ng-template #loaded>\n <ng-container\n *ngIf=\"viewModel.error$ | async as errorMessage; else renderScreen\"\n >\n <div class=\"error-label\">\n Erro ao carregar a tela:\n <pre>{{ errorMessage }}</pre>\n </div>\n </ng-container>\n\n <ng-template #renderScreen>\n <div\n class=\"ui-screen\"\n *ngIf=\"viewModel.uiScreen$ | async as uiScreen\"\n [edmSduiView]=\"uiScreen\"\n >\n <edm-sdui-navigation-controls\n [edmSduiView]=\"uiScreen\"\n ></edm-sdui-navigation-controls>\n\n <ng-container [ngSwitch]=\"uiScreen.identifier\">\n <edm-sdui-single-column-layout\n *ngSwitchCase=\"UIScreenIdentifier.SINGLE_COLUMN\"\n [uiLayout]=\"uiScreen.content\"\n ></edm-sdui-single-column-layout>\n\n <edm-sdui-centered-content-layout\n *ngSwitchCase=\"UIScreenIdentifier.CENTERED_CONTENT\"\n [uiLayout]=\"uiScreen.content\"\n ></edm-sdui-centered-content-layout>\n </ng-container>\n </div>\n </ng-template>\n</ng-template>\n", styles: [":host{display:contents}.ui-screen{width:
|
|
23
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: UIScreenComponent, isStandalone: false, selector: "edm-sdui-uiscreen", ngImport: i0, template: "<ng-container *ngIf=\"viewModel.isLoading$ | async; else loaded\">\n <div class=\"loading-spinner\">\n <div class=\"spinner\"></div>\n </div>\n</ng-container>\n\n<ng-template #loaded>\n <ng-container\n *ngIf=\"viewModel.error$ | async as errorMessage; else renderScreen\"\n >\n <div class=\"error-label\">\n Erro ao carregar a tela:\n <pre>{{ errorMessage }}</pre>\n </div>\n </ng-container>\n\n <ng-template #renderScreen>\n <div\n class=\"ui-screen\"\n *ngIf=\"viewModel.uiScreen$ | async as uiScreen\"\n [ngClass]=\"containerClass(uiScreen.config)\"\n [edmSduiView]=\"uiScreen\"\n >\n <edm-sdui-navigation-controls\n [edmSduiView]=\"uiScreen\"\n ></edm-sdui-navigation-controls>\n\n <ng-container [ngSwitch]=\"uiScreen.identifier\">\n <edm-sdui-single-column-layout\n *ngSwitchCase=\"UIScreenIdentifier.SINGLE_COLUMN\"\n [uiLayout]=\"uiScreen.content\"\n ></edm-sdui-single-column-layout>\n\n <edm-sdui-centered-content-layout\n *ngSwitchCase=\"UIScreenIdentifier.CENTERED_CONTENT\"\n [uiLayout]=\"uiScreen.content\"\n ></edm-sdui-centered-content-layout>\n </ng-container>\n </div>\n </ng-template>\n</ng-template>\n", styles: [":host{display:contents}.ui-screen{width:100%;min-height:100vh}.ui-screen--fluid{width:100vw}.ui-screen--contained{width:100%;max-width:1200px;margin:0 auto;padding:16px;box-sizing:border-box}.error-label{color:var(--input-error)}.loading-spinner{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;box-sizing:border-box;position:relative}.spinner{width:48px;height:48px;border:5px solid var(--actindcolor);border-top-color:#333;border-radius:50%;animation:spin 1s linear infinite;top:50%;left:50%}@keyframes spin{to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.SingleColumnLayoutComponent, selector: "edm-sdui-single-column-layout", inputs: ["uiLayout"] }, { kind: "component", type: i4.CenteredContentLayoutComponent, selector: "edm-sdui-centered-content-layout", inputs: ["uiLayout"] }, { kind: "directive", type: i5.UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }, { kind: "component", type: i6.NavigationControlsComponent, selector: "edm-sdui-navigation-controls" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] }); }
|
|
18
24
|
}
|
|
19
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: UIScreenComponent, decorators: [{
|
|
20
26
|
type: Component,
|
|
21
|
-
args: [{ selector: 'edm-sdui-uiscreen', standalone: false, template: "<ng-container *ngIf=\"viewModel.isLoading$ | async; else loaded\">\n <div class=\"loading-spinner\">\n <div class=\"spinner\"></div>\n </div>\n</ng-container>\n\n<ng-template #loaded>\n <ng-container\n *ngIf=\"viewModel.error$ | async as errorMessage; else renderScreen\"\n >\n <div class=\"error-label\">\n Erro ao carregar a tela:\n <pre>{{ errorMessage }}</pre>\n </div>\n </ng-container>\n\n <ng-template #renderScreen>\n <div\n class=\"ui-screen\"\n *ngIf=\"viewModel.uiScreen$ | async as uiScreen\"\n [edmSduiView]=\"uiScreen\"\n >\n <edm-sdui-navigation-controls\n [edmSduiView]=\"uiScreen\"\n ></edm-sdui-navigation-controls>\n\n <ng-container [ngSwitch]=\"uiScreen.identifier\">\n <edm-sdui-single-column-layout\n *ngSwitchCase=\"UIScreenIdentifier.SINGLE_COLUMN\"\n [uiLayout]=\"uiScreen.content\"\n ></edm-sdui-single-column-layout>\n\n <edm-sdui-centered-content-layout\n *ngSwitchCase=\"UIScreenIdentifier.CENTERED_CONTENT\"\n [uiLayout]=\"uiScreen.content\"\n ></edm-sdui-centered-content-layout>\n </ng-container>\n </div>\n </ng-template>\n</ng-template>\n", styles: [":host{display:contents}.ui-screen{width:
|
|
27
|
+
args: [{ selector: 'edm-sdui-uiscreen', standalone: false, template: "<ng-container *ngIf=\"viewModel.isLoading$ | async; else loaded\">\n <div class=\"loading-spinner\">\n <div class=\"spinner\"></div>\n </div>\n</ng-container>\n\n<ng-template #loaded>\n <ng-container\n *ngIf=\"viewModel.error$ | async as errorMessage; else renderScreen\"\n >\n <div class=\"error-label\">\n Erro ao carregar a tela:\n <pre>{{ errorMessage }}</pre>\n </div>\n </ng-container>\n\n <ng-template #renderScreen>\n <div\n class=\"ui-screen\"\n *ngIf=\"viewModel.uiScreen$ | async as uiScreen\"\n [ngClass]=\"containerClass(uiScreen.config)\"\n [edmSduiView]=\"uiScreen\"\n >\n <edm-sdui-navigation-controls\n [edmSduiView]=\"uiScreen\"\n ></edm-sdui-navigation-controls>\n\n <ng-container [ngSwitch]=\"uiScreen.identifier\">\n <edm-sdui-single-column-layout\n *ngSwitchCase=\"UIScreenIdentifier.SINGLE_COLUMN\"\n [uiLayout]=\"uiScreen.content\"\n ></edm-sdui-single-column-layout>\n\n <edm-sdui-centered-content-layout\n *ngSwitchCase=\"UIScreenIdentifier.CENTERED_CONTENT\"\n [uiLayout]=\"uiScreen.content\"\n ></edm-sdui-centered-content-layout>\n </ng-container>\n </div>\n </ng-template>\n</ng-template>\n", styles: [":host{display:contents}.ui-screen{width:100%;min-height:100vh}.ui-screen--fluid{width:100vw}.ui-screen--contained{width:100%;max-width:1200px;margin:0 auto;padding:16px;box-sizing:border-box}.error-label{color:var(--input-error)}.loading-spinner{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;box-sizing:border-box;position:relative}.spinner{width:48px;height:48px;border:5px solid var(--actindcolor);border-top-color:#333;border-radius:50%;animation:spin 1s linear infinite;top:50%;left:50%}@keyframes spin{to{transform:rotate(360deg)}}\n"] }]
|
|
22
28
|
}], ctorParameters: () => [{ type: i1.UIScreenViewModel }] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWlzY3JlZW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZHVpL3NyYy9saWIvY29tcG9uZW50cy91aXNjcmVlbi91aXNjcmVlbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb21wb25lbnRzL3Vpc2NyZWVuL3Vpc2NyZWVuLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDOUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0RBQW9ELENBQUM7Ozs7Ozs7O0FBU3hGLE1BQU0sT0FBTyxpQkFBaUI7SUFHNUIsWUFBbUIsU0FBNEI7UUFBNUIsY0FBUyxHQUFULFNBQVMsQ0FBbUI7UUFGdEMsdUJBQWtCLEdBQUcsa0JBQWtCLENBQUM7SUFFQyxDQUFDO0lBRW5ELGNBQWMsQ0FBQyxNQUE4QjtRQUMzQyxNQUFNLFNBQVMsR0FBRyxDQUFDLE1BQU0sRUFBRSxTQUFTLElBQUksT0FBTyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDMUUsT0FBTyxTQUFTLEtBQUssV0FBVztZQUM5QixDQUFDLENBQUMsc0JBQXNCO1lBQ3hCLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQztJQUN6QixDQUFDOytHQVZVLGlCQUFpQjttR0FBakIsaUJBQWlCLDhFQ1g5Qix1dkNBeUNBOzs0RkQ5QmEsaUJBQWlCO2tCQU43QixTQUFTOytCQUNFLG1CQUFtQixjQUdqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBVSVNjcmVlblZpZXdNb2RlbCB9IGZyb20gJy4uLy4uL2NvcmUvdmlldy1tb2RlbHMvdWlzY3JlZW4udmlld21vZGVsJztcbmltcG9ydCB7IFVJU2NyZWVuSWRlbnRpZmllciB9IGZyb20gJy4uLy4uL2NvcmUvdWljb21wb3NpdGlvbi9lbnVtcy91aXNjcmVlbi1pZGVudGlmaWVyJztcbmltcG9ydCB7IFVJU2NyZWVuQ29uZmlnIH0gZnJvbSAnLi4vLi4vY29yZS91aWNvbXBvc2l0aW9uL21vZGVscy91aXNjcmVlbi1jb25maWcnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlZG0tc2R1aS11aXNjcmVlbicsXG4gIHRlbXBsYXRlVXJsOiAnLi91aXNjcmVlbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi91aXNjcmVlbi5jb21wb25lbnQuc2NzcycsXG4gIHN0YW5kYWxvbmU6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBVSVNjcmVlbkNvbXBvbmVudCB7XG4gIHJlYWRvbmx5IFVJU2NyZWVuSWRlbnRpZmllciA9IFVJU2NyZWVuSWRlbnRpZmllcjtcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgdmlld01vZGVsOiBVSVNjcmVlblZpZXdNb2RlbCkge31cblxuICBjb250YWluZXJDbGFzcyhjb25maWc/OiBVSVNjcmVlbkNvbmZpZyB8IG51bGwpOiBzdHJpbmcge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IChjb25maWc/LmNvbnRhaW5lciB8fCAnZmx1aWQnKS50b1N0cmluZygpLnRvTG93ZXJDYXNlKCk7XG4gICAgcmV0dXJuIGNvbnRhaW5lciA9PT0gJ2NvbnRhaW5lZCdcbiAgICAgID8gJ3VpLXNjcmVlbi0tY29udGFpbmVkJ1xuICAgICAgOiAndWktc2NyZWVuLS1mbHVpZCc7XG4gIH1cbn1cbiIsIjxuZy1jb250YWluZXIgKm5nSWY9XCJ2aWV3TW9kZWwuaXNMb2FkaW5nJCB8IGFzeW5jOyBlbHNlIGxvYWRlZFwiPlxuICA8ZGl2IGNsYXNzPVwibG9hZGluZy1zcGlubmVyXCI+XG4gICAgPGRpdiBjbGFzcz1cInNwaW5uZXJcIj48L2Rpdj5cbiAgPC9kaXY+XG48L25nLWNvbnRhaW5lcj5cblxuPG5nLXRlbXBsYXRlICNsb2FkZWQ+XG4gIDxuZy1jb250YWluZXJcbiAgICAqbmdJZj1cInZpZXdNb2RlbC5lcnJvciQgfCBhc3luYyBhcyBlcnJvck1lc3NhZ2U7IGVsc2UgcmVuZGVyU2NyZWVuXCJcbiAgPlxuICAgIDxkaXYgY2xhc3M9XCJlcnJvci1sYWJlbFwiPlxuICAgICAgRXJybyBhbyBjYXJyZWdhciBhIHRlbGE6XG4gICAgICA8cHJlPnt7IGVycm9yTWVzc2FnZSB9fTwvcHJlPlxuICAgIDwvZGl2PlxuICA8L25nLWNvbnRhaW5lcj5cblxuICA8bmctdGVtcGxhdGUgI3JlbmRlclNjcmVlbj5cbiAgICA8ZGl2XG4gICAgICBjbGFzcz1cInVpLXNjcmVlblwiXG4gICAgICAqbmdJZj1cInZpZXdNb2RlbC51aVNjcmVlbiQgfCBhc3luYyBhcyB1aVNjcmVlblwiXG4gICAgICBbbmdDbGFzc109XCJjb250YWluZXJDbGFzcyh1aVNjcmVlbi5jb25maWcpXCJcbiAgICAgIFtlZG1TZHVpVmlld109XCJ1aVNjcmVlblwiXG4gICAgPlxuICAgICAgPGVkbS1zZHVpLW5hdmlnYXRpb24tY29udHJvbHNcbiAgICAgICAgW2VkbVNkdWlWaWV3XT1cInVpU2NyZWVuXCJcbiAgICAgID48L2VkbS1zZHVpLW5hdmlnYXRpb24tY29udHJvbHM+XG5cbiAgICAgIDxuZy1jb250YWluZXIgW25nU3dpdGNoXT1cInVpU2NyZWVuLmlkZW50aWZpZXJcIj5cbiAgICAgICAgPGVkbS1zZHVpLXNpbmdsZS1jb2x1bW4tbGF5b3V0XG4gICAgICAgICAgKm5nU3dpdGNoQ2FzZT1cIlVJU2NyZWVuSWRlbnRpZmllci5TSU5HTEVfQ09MVU1OXCJcbiAgICAgICAgICBbdWlMYXlvdXRdPVwidWlTY3JlZW4uY29udGVudFwiXG4gICAgICAgID48L2VkbS1zZHVpLXNpbmdsZS1jb2x1bW4tbGF5b3V0PlxuXG4gICAgICAgIDxlZG0tc2R1aS1jZW50ZXJlZC1jb250ZW50LWxheW91dFxuICAgICAgICAgICpuZ1N3aXRjaENhc2U9XCJVSVNjcmVlbklkZW50aWZpZXIuQ0VOVEVSRURfQ09OVEVOVFwiXG4gICAgICAgICAgW3VpTGF5b3V0XT1cInVpU2NyZWVuLmNvbnRlbnRcIlxuICAgICAgICA+PC9lZG0tc2R1aS1jZW50ZXJlZC1jb250ZW50LWxheW91dD5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvZGl2PlxuICA8L25nLXRlbXBsYXRlPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
@@ -58,9 +58,37 @@ export class UIActionService {
|
|
|
58
58
|
const modal = this.modalService.open(action.url);
|
|
59
59
|
}
|
|
60
60
|
break;
|
|
61
|
+
case UIActionType.ANCHOR:
|
|
62
|
+
this.scrollToAnchor(action);
|
|
63
|
+
break;
|
|
61
64
|
// Outros tipos de ação podem ser adicionados aqui
|
|
62
65
|
}
|
|
63
66
|
}
|
|
67
|
+
scrollToAnchor(action) {
|
|
68
|
+
// Confluence: param = string para uso geral; aqui priorizamos param como id do elemento
|
|
69
|
+
const raw = action.param || action.url || '';
|
|
70
|
+
const targetId = String(raw).replace(/^#/, '').trim();
|
|
71
|
+
if (!targetId) {
|
|
72
|
+
console.warn('[UIActionService] ANCHOR sem destino informado');
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
const el = document.getElementById(targetId);
|
|
76
|
+
if (!el) {
|
|
77
|
+
console.warn('[UIActionService] ANCHOR não encontrou elemento com id:', targetId);
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
try {
|
|
81
|
+
el.scrollIntoView({ behavior: 'smooth', block: 'start', inline: 'nearest' });
|
|
82
|
+
}
|
|
83
|
+
catch {
|
|
84
|
+
el.scrollIntoView();
|
|
85
|
+
}
|
|
86
|
+
// guarda o último anchor acessado (usado pelo app host para restaurar)
|
|
87
|
+
try {
|
|
88
|
+
sessionStorage.setItem('exploreLastAnchor', targetId);
|
|
89
|
+
}
|
|
90
|
+
catch { }
|
|
91
|
+
}
|
|
64
92
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: UIActionService, deps: [{ token: i1.Router }, { token: i2.ModalService }, { token: i3.UIActionHandlersService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
65
93
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: UIActionService, providedIn: 'root' }); }
|
|
66
94
|
}
|
|
@@ -68,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
68
96
|
type: Injectable,
|
|
69
97
|
args: [{ providedIn: 'root' }]
|
|
70
98
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.ModalService }, { type: i3.UIActionHandlersService }] });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action.service.js","sourceRoot":"","sources":["../../../../../../../libs/sdui/src/lib/core/services/ui-action.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { UIActionType } from '../uitheme/enums/uiaction-type';\nimport { UIAction } from '../uitheme/models/uiaction';\nimport { resolveSduiUrl, isSduiUrl } from '../utils/url-parser.util';\nimport { SDUI_URL_PARAM } from '../view-models/uiscreen.viewmodel';\nimport { UIActionHandlersService } from './ui-action-handlers.service';\nimport { ModalService } from './modal.service';\n\n@Injectable({ providedIn: 'root' })\nexport class UIActionService {\n  constructor(private router: Router,\n    private modalService: ModalService,\n    private actionHandlers: UIActionHandlersService\n\n  ) { }\n\n  execute(action: UIAction): void {\n    if (!action || !action.type) return;\n    console.log(action)\n    switch (action.type) {\n      case UIActionType.INTERNAL_URL:\n        if (action.url && isSduiUrl(action.url)) {\n          const resolved = resolveSduiUrl(action.url);\n          this.router.navigate([], {\n            queryParams: { [SDUI_URL_PARAM]: resolved },\n            queryParamsHandling: 'merge',\n          });\n        }else {\n          if(action.url) this.actionHandlers.handleInternalNavigation(action.url);\n        }\n        break;\n      case UIActionType.RELOAD_INTERNAL_URL:\n        if (action.url) {\n          console.debug('[UIActionService] Navigating to:', action.url);\n\n          if (isSduiUrl(action.url)) {\n            const resolved = resolveSduiUrl(action.url);\n            this.router.navigate([], {\n              queryParams: { [SDUI_URL_PARAM]: resolved },\n              queryParamsHandling: 'merge',\n            });\n          } else {\n            this.router.navigateByUrl(action.url, { replaceUrl: false });\n          }\n        }\n        break;\n      case UIActionType.EXTERNAL_URL:\n        if (action.url) {\n          window.open(action.url, '_blank');\n        }\n        break;\n      case UIActionType.WEBVIEW_URL:\n        if (action.url) {\n          const modal = this.modalService.open(action.url);\n        }\n        break;\n      case UIActionType.ANCHOR:\n        this.scrollToAnchor(action);\n        break;\n      // Outros tipos de ação podem ser adicionados aqui\n    }\n  }\n\n  private scrollToAnchor(action: UIAction): void {\n    // Confluence: param = string para uso geral; aqui priorizamos param como id do elemento\n    const raw = (action as any).param || action.url || '';\n    const targetId = String(raw).replace(/^#/, '').trim();\n    if (!targetId) {\n      console.warn('[UIActionService] ANCHOR sem destino informado');\n      return;\n    }\n\n    const el = document.getElementById(targetId);\n    if (!el) {\n      console.warn('[UIActionService] ANCHOR não encontrou elemento com id:', targetId);\n      return;\n    }\n\n    try {\n      el.scrollIntoView({ behavior: 'smooth', block: 'start', inline: 'nearest' });\n    } catch {\n      el.scrollIntoView();\n    }\n\n    // guarda o último anchor acessado (usado pelo app host para restaurar)\n    try {\n      sessionStorage.setItem('exploreLastAnchor', targetId);\n    } catch {}\n  }\n}\n"]}
|
|
@@ -19,14 +19,19 @@ export class UIScreenService {
|
|
|
19
19
|
.pipe(map((json) => this.mapToUIScreen(json)));
|
|
20
20
|
}
|
|
21
21
|
mapToUIScreen(json) {
|
|
22
|
-
const { identifier, content } = json;
|
|
22
|
+
const { identifier, content, config } = json;
|
|
23
23
|
if (!identifier) {
|
|
24
24
|
throw new Error(`Identificador da tela ausente no JSON recebido.`);
|
|
25
25
|
}
|
|
26
26
|
const layout = this.getLayout(identifier, content);
|
|
27
|
+
const normalizedConfig = config ??
|
|
28
|
+
(json.container
|
|
29
|
+
? { container: json.container }
|
|
30
|
+
: null);
|
|
27
31
|
return {
|
|
28
32
|
identifier: identifier,
|
|
29
33
|
content: layout,
|
|
34
|
+
config: this.mapToUIScreenConfig(normalizedConfig),
|
|
30
35
|
...this.mapToUIView(json),
|
|
31
36
|
};
|
|
32
37
|
}
|
|
@@ -102,6 +107,7 @@ export class UIScreenService {
|
|
|
102
107
|
}
|
|
103
108
|
mapToUIView(json) {
|
|
104
109
|
return {
|
|
110
|
+
id: json.id ?? null,
|
|
105
111
|
padding: json.padding,
|
|
106
112
|
background: json.background ? this.mapBackground(json.background) : null,
|
|
107
113
|
action: json.action ? this.mapAction(json.action) : null,
|
|
@@ -120,6 +126,19 @@ export class UIScreenService {
|
|
|
120
126
|
justify: json.justify ? json.justify : null,
|
|
121
127
|
};
|
|
122
128
|
}
|
|
129
|
+
mapToUIScreenConfig(config) {
|
|
130
|
+
if (!config) {
|
|
131
|
+
return null;
|
|
132
|
+
}
|
|
133
|
+
const containerValue = config.container;
|
|
134
|
+
const containerNormalized = containerValue
|
|
135
|
+
? String(containerValue).toLowerCase()
|
|
136
|
+
: null;
|
|
137
|
+
return {
|
|
138
|
+
alwaysReload: config.always_reload ?? config.alwaysReload ?? null,
|
|
139
|
+
container: containerNormalized,
|
|
140
|
+
};
|
|
141
|
+
}
|
|
123
142
|
mapBackground(json) {
|
|
124
143
|
return {
|
|
125
144
|
backgroundColor: json.background_color ? json.background_color : null,
|
|
@@ -132,6 +151,7 @@ export class UIScreenService {
|
|
|
132
151
|
canAccess: json.can_acces ?? null,
|
|
133
152
|
type: json.type ? json.type : null,
|
|
134
153
|
url: json.url ?? null,
|
|
154
|
+
param: json.param ?? null,
|
|
135
155
|
};
|
|
136
156
|
}
|
|
137
157
|
mapRadius(json) {
|
|
@@ -158,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
158
178
|
type: Inject,
|
|
159
179
|
args: [SDUI_BASE_URL]
|
|
160
180
|
}] }] });
|
|
161
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiscreen.service.js","sourceRoot":"","sources":["../../../../../../../libs/sdui/src/lib/core/services/uiscreen.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, Optional } from '@angular/core';\nimport { Observable, map } from 'rxjs';\nimport { HttpClient } from '@angular/common/http';\nimport { UIScreen } from '../uicomposition/models/uiscreen';\nimport { UILayout } from '../uicomposition/models/uilayout';\nimport { UIScreenIdentifier } from '../uicomposition/enums/uiscreen-identifier';\nimport { UISingleColumnLayout } from '../uicomposition/models/uisingle-column-layout';\nimport { UINavigation } from '../uicomposition/models/uinavigation';\nimport { UIComponent } from '../uicomposition/models/uicomponent';\nimport { UIComponentType } from '../uicomposition/enums/uicomponent-type';\nimport { UIElement } from '../uicomposition/models/uielement';\nimport { UIView } from '../uicomposition/models/uiview';\nimport { UIPadding } from '../uitheme/models/uipadding';\nimport { UIBackground } from '../uitheme/models/uibackground';\nimport { UIAction } from '../uitheme/models/uiaction';\nimport { UIShadow } from '../uitheme/models/uishadow';\nimport { UIRadius } from '../uitheme/models/uiradius';\nimport { UIActionType } from '../uitheme/enums/uiaction-type';\nimport { UIColor } from '../uitheme/enums/uicolor';\nimport { UITextStyle } from '../uitheme/enums/uitext-style';\nimport { UIAsset } from '../uitheme/enums/uiasset';\nimport { UIAlignmentType } from '../uitheme/enums/uialignment-type';\nimport { UISpacingLevel } from '../uitheme/enums/uispacing-level';\nimport { SDUI_BASE_URL } from '../tokens/sdui-config.token';\nimport { resolveSduiUrl } from '../utils/url-parser.util';\nimport { UICenteredContentLayout } from '../uicomposition/models/uicentered-content-layout';\nimport { UIRadiusLevel } from '../uitheme/enums/uiradius-level';\nimport { UIContentType } from '../uitheme/enums/uicontent-type';\nimport { UIAspectType } from '../uitheme/enums/uiaspect-type';\nimport { UIDimension } from '../uitheme/enums/uidimension';\nimport { UIJustify } from '../uitheme/enums/uijustify';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class UIScreenService {\n  constructor(\n    private http: HttpClient,\n    @Optional() @Inject(SDUI_BASE_URL) private baseUrl: string = ''\n  ) {}\n\n  getUIScreen(url: string): Observable<UIScreen> {\n    let finalUrl = resolveSduiUrl(url, this.baseUrl);\n\n    return this.http\n      .get<any>(finalUrl)\n      .pipe(map((json) => this.mapToUIScreen(json)));\n  }\n\n  private mapToUIScreen(json: Partial<UIScreen>): UIScreen {\n    const { identifier, content } = json;\n\n    if (!identifier) {\n      throw new Error(`Identificador da tela ausente no JSON recebido.`);\n    }\n\n    const layout = this.getLayout(identifier as UIScreenIdentifier, content);\n\n    return {\n      identifier: identifier as UIScreenIdentifier,\n      content: layout,\n      ...this.mapToUIView(json),\n    };\n  }\n\n  private getLayout(\n    identifier: UIScreenIdentifier,\n    content: UILayout | undefined\n  ): UILayout {\n    switch (identifier) {\n      case UIScreenIdentifier.SINGLE_COLUMN:\n        return this.mapToSingleColumnLayout(content ?? {});\n\n      case UIScreenIdentifier.CENTERED_CONTENT:\n        return this.mapToCenteredContentLayout(content ?? {});\n\n      default:\n        throw new Error(`Tipo de tela desconhecido: ${identifier}`);\n    }\n  }\n\n  private mapToSingleColumnLayout(\n    json: Partial<UISingleColumnLayout>\n  ): UISingleColumnLayout {\n    return {\n      nav: json.nav ? this.mapToUINavigation(json.nav) : null,\n      header: json.header ? this.mapToUIComponent(json.header) : null,\n      main: json.main ? this.mapToUIComponent(json.main) : null,\n      footer: json.footer ? this.mapToUIComponent(json.footer) : null,\n      fab: json.fab ? this.mapToUIElement(json.fab) : null,\n    };\n  }\n\n  private mapToCenteredContentLayout(\n    json: Partial<UICenteredContentLayout>\n  ): UICenteredContentLayout {\n    return {\n      nav: json.nav ? this.mapToUINavigation(json.nav) : null,\n      backgroundComponent: json.backgroundComponent\n        ? this.mapToUIComponent(json.backgroundComponent)\n        : null,\n      header: json.header ? this.mapToUIComponent(json.header) : null,\n      centered: json.centered ? this.mapToUIComponent(json.centered) : null,\n      footer: json.footer ? this.mapToUIComponent(json.footer) : null,\n    };\n  }\n\n  private mapToUINavigation(json: any): UINavigation {\n    return {\n      title: json.title ?? null,\n      titleComponent: json.title_component\n        ? this.mapToUIComponent(json.title_component)\n        : null,\n    };\n  }\n\n  private mapToUIComponent(json: Partial<UIComponent>): UIComponent {\n    return {\n      type: json.type || UIComponentType.COLUMN, // Define um tipo padrão\n      components: json.components\n        ? json.components.map((c) => this.mapToUIComponent(c))\n        : [],\n      element: json.element ? this.mapToUIElement(json.element) : null,\n    };\n  }\n\n  private mapToUIElement(json: any): UIElement {\n    return {\n      label: json.label ?? null,\n      textColor: json.text_color ? (json.text_color as UIColor) : null,\n      textStyle: json.text_style ? (json.text_style as UITextStyle) : null,\n      maxLines: json.max_lines ?? null,\n      asset: json.asset ? (json.asset as UIAsset) : null,\n      url: json.url ?? null,\n      enabled: json.enabled ?? true,\n      size: json.size ?? null,\n      opacity: json.opacity ?? null,\n      contentType: (json.content_type as UIContentType) ?? null,\n      aspect: (json.aspect as UIAspectType) ?? null,\n      grow: json.grow ?? null,\n      placeholder: json.placeholder ?? null,\n      placeholderTextColor: json.placeholder_text_color ?? null,\n      placeholderTextStyle: json.placeholder_text_style ?? null,\n      aspectRatio: json.aspect_ratio ?? null,\n      progress: json.progress ?? null,\n      progressColor: json.progress_color ? (json.progress_color as UIColor) : null,\n      ...this.mapToUIView(json),\n    };\n  }\n\n  private mapToUIView(json: any): UIView {\n    return {\n      padding: json.padding as UIPadding,\n      background: json.background ? this.mapBackground(json.background) : null,\n      action: json.action ? this.mapAction(json.action) : null,\n      alignment: json.alignment\n        ? { alignment: json.alignment as UIAlignmentType }\n        : null,\n      shadow: json.shadow as UIShadow,\n      radius: json.radius ? this.mapRadius(json.radius) : null,\n      spacing: json.spacing\n        ? { spacing: json.spacing as UISpacingLevel }\n        : null,\n      height: json.height ? (json.height as UIDimension) : null,\n      width: json.width ? (json.width as UIDimension) : null,\n      borderWidth: json.border_width ?? null,\n      borderColor: json.border_color ? (json.border_color as UIColor) : null,\n      justify: json.justify ? (json.justify as UIJustify) : null,\n    };\n  }\n\n  private mapBackground(json: any): UIBackground {\n    return {\n      backgroundColor: json.background_color ? (json.background_color as UIColor) : null,\n      gradientColor1: json.gradient_color_1 ? (json.gradient_color_1 as UIColor) : null,\n      gradientColor2: json.gradient_color_2 ? (json.gradient_color_2 as UIColor) : null,\n    };\n  }\n\n  private mapAction(json: any): UIAction {\n    return {\n      canAccess: json.can_acces ?? null,\n      type: json.type ? (json.type as UIActionType) : null,\n      url: json.url ?? null,\n    };\n  }\n\n  private mapRadius(json: any): UIRadius {\n    return {\n      topLeft: json.top_left ? (json.top_left as UIRadiusLevel) : null,\n      topRight: json.top_right ? (json.top_right as UIRadiusLevel) : null,\n      bottomLeft: json.bottom_left ? (json.bottom_left as UIRadiusLevel) : null,\n      bottomRight: json.bottom_right\n        ? (json.bottom_right as UIRadiusLevel)\n        : null,\n    };\n  }\n}\n"]}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiscreen.service.js","sourceRoot":"","sources":["../../../../../../../libs/sdui/src/lib/core/services/uiscreen.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, Optional } from '@angular/core';\nimport { Observable, map } from 'rxjs';\nimport { HttpClient } from '@angular/common/http';\nimport { UIScreen } from '../uicomposition/models/uiscreen';\nimport { UILayout } from '../uicomposition/models/uilayout';\nimport { UIScreenIdentifier } from '../uicomposition/enums/uiscreen-identifier';\nimport { UISingleColumnLayout } from '../uicomposition/models/uisingle-column-layout';\nimport { UINavigation } from '../uicomposition/models/uinavigation';\nimport { UIComponent } from '../uicomposition/models/uicomponent';\nimport { UIComponentType } from '../uicomposition/enums/uicomponent-type';\nimport { UIElement } from '../uicomposition/models/uielement';\nimport { UIView } from '../uicomposition/models/uiview';\nimport { UIScreenConfig } from '../uicomposition/models/uiscreen-config';\nimport { UIScreenContainerType } from '../uicomposition/enums/uiscreen-container-type';\nimport { UIPadding } from '../uitheme/models/uipadding';\nimport { UIBackground } from '../uitheme/models/uibackground';\nimport { UIAction } from '../uitheme/models/uiaction';\nimport { UIShadow } from '../uitheme/models/uishadow';\nimport { UIRadius } from '../uitheme/models/uiradius';\nimport { UIActionType } from '../uitheme/enums/uiaction-type';\nimport { UIColor } from '../uitheme/enums/uicolor';\nimport { UITextStyle } from '../uitheme/enums/uitext-style';\nimport { UIAsset } from '../uitheme/enums/uiasset';\nimport { UIAlignmentType } from '../uitheme/enums/uialignment-type';\nimport { UISpacingLevel } from '../uitheme/enums/uispacing-level';\nimport { SDUI_BASE_URL } from '../tokens/sdui-config.token';\nimport { resolveSduiUrl } from '../utils/url-parser.util';\nimport { UICenteredContentLayout } from '../uicomposition/models/uicentered-content-layout';\nimport { UIRadiusLevel } from '../uitheme/enums/uiradius-level';\nimport { UIContentType } from '../uitheme/enums/uicontent-type';\nimport { UIAspectType } from '../uitheme/enums/uiaspect-type';\nimport { UIDimension } from '../uitheme/enums/uidimension';\nimport { UIJustify } from '../uitheme/enums/uijustify';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class UIScreenService {\n  constructor(\n    private http: HttpClient,\n    @Optional() @Inject(SDUI_BASE_URL) private baseUrl: string = ''\n  ) {}\n\n  getUIScreen(url: string): Observable<UIScreen> {\n    let finalUrl = resolveSduiUrl(url, this.baseUrl);\n\n    return this.http\n      .get<any>(finalUrl)\n      .pipe(map((json) => this.mapToUIScreen(json)));\n  }\n\n  private mapToUIScreen(json: Partial<UIScreen>): UIScreen {\n    const { identifier, content, config } = json;\n\n    if (!identifier) {\n      throw new Error(`Identificador da tela ausente no JSON recebido.`);\n    }\n\n    const layout = this.getLayout(identifier as UIScreenIdentifier, content);\n    const normalizedConfig =\n      config ??\n      ((json as any).container\n        ? { container: (json as any).container }\n        : null);\n\n    return {\n      identifier: identifier as UIScreenIdentifier,\n      content: layout,\n      config: this.mapToUIScreenConfig(normalizedConfig),\n      ...this.mapToUIView(json),\n    };\n  }\n\n  private getLayout(\n    identifier: UIScreenIdentifier,\n    content: UILayout | undefined\n  ): UILayout {\n    switch (identifier) {\n      case UIScreenIdentifier.SINGLE_COLUMN:\n        return this.mapToSingleColumnLayout(content ?? {});\n\n      case UIScreenIdentifier.CENTERED_CONTENT:\n        return this.mapToCenteredContentLayout(content ?? {});\n\n      default:\n        throw new Error(`Tipo de tela desconhecido: ${identifier}`);\n    }\n  }\n\n  private mapToSingleColumnLayout(\n    json: Partial<UISingleColumnLayout>\n  ): UISingleColumnLayout {\n    return {\n      nav: json.nav ? this.mapToUINavigation(json.nav) : null,\n      header: json.header ? this.mapToUIComponent(json.header) : null,\n      main: json.main ? this.mapToUIComponent(json.main) : null,\n      footer: json.footer ? this.mapToUIComponent(json.footer) : null,\n      fab: json.fab ? this.mapToUIElement(json.fab) : null,\n    };\n  }\n\n  private mapToCenteredContentLayout(\n    json: Partial<UICenteredContentLayout>\n  ): UICenteredContentLayout {\n    return {\n      nav: json.nav ? this.mapToUINavigation(json.nav) : null,\n      backgroundComponent: json.backgroundComponent\n        ? this.mapToUIComponent(json.backgroundComponent)\n        : null,\n      header: json.header ? this.mapToUIComponent(json.header) : null,\n      centered: json.centered ? this.mapToUIComponent(json.centered) : null,\n      footer: json.footer ? this.mapToUIComponent(json.footer) : null,\n    };\n  }\n\n  private mapToUINavigation(json: any): UINavigation {\n    return {\n      title: json.title ?? null,\n      titleComponent: json.title_component\n        ? this.mapToUIComponent(json.title_component)\n        : null,\n    };\n  }\n\n  private mapToUIComponent(json: Partial<UIComponent>): UIComponent {\n    return {\n      type: json.type || UIComponentType.COLUMN, // Define um tipo padrão\n      components: json.components\n        ? json.components.map((c) => this.mapToUIComponent(c))\n        : [],\n      element: json.element ? this.mapToUIElement(json.element) : null,\n    };\n  }\n\n  private mapToUIElement(json: any): UIElement {\n    return {\n      label: json.label ?? null,\n      textColor: json.text_color ? (json.text_color as UIColor) : null,\n      textStyle: json.text_style ? (json.text_style as UITextStyle) : null,\n      maxLines: json.max_lines ?? null,\n      asset: json.asset ? (json.asset as UIAsset) : null,\n      url: json.url ?? null,\n      enabled: json.enabled ?? true,\n      size: json.size ?? null,\n      opacity: json.opacity ?? null,\n      contentType: (json.content_type as UIContentType) ?? null,\n      aspect: (json.aspect as UIAspectType) ?? null,\n      grow: json.grow ?? null,\n      placeholder: json.placeholder ?? null,\n      placeholderTextColor: json.placeholder_text_color ?? null,\n      placeholderTextStyle: json.placeholder_text_style ?? null,\n      aspectRatio: json.aspect_ratio ?? null,\n      progress: json.progress ?? null,\n      progressColor: json.progress_color ? (json.progress_color as UIColor) : null,\n      ...this.mapToUIView(json),\n    };\n  }\n\n  private mapToUIView(json: any): UIView {\n    return {\n      id: json.id ?? null,\n      padding: json.padding as UIPadding,\n      background: json.background ? this.mapBackground(json.background) : null,\n      action: json.action ? this.mapAction(json.action) : null,\n      alignment: json.alignment\n        ? { alignment: json.alignment as UIAlignmentType }\n        : null,\n      shadow: json.shadow as UIShadow,\n      radius: json.radius ? this.mapRadius(json.radius) : null,\n      spacing: json.spacing\n        ? { spacing: json.spacing as UISpacingLevel }\n        : null,\n      height: json.height ? (json.height as UIDimension) : null,\n      width: json.width ? (json.width as UIDimension) : null,\n      borderWidth: json.border_width ?? null,\n      borderColor: json.border_color ? (json.border_color as UIColor) : null,\n      justify: json.justify ? (json.justify as UIJustify) : null,\n    };\n  }\n\n  private mapToUIScreenConfig(\n    config?: Partial<UIScreenConfig> | null\n  ): UIScreenConfig | null {\n    if (!config) {\n      return null;\n    }\n\n    const containerValue = (config as any).container;\n    const containerNormalized = containerValue\n      ? (String(containerValue).toLowerCase() as UIScreenContainerType)\n      : null;\n\n    return {\n      alwaysReload:\n        (config as any).always_reload ?? (config as any).alwaysReload ?? null,\n      container: containerNormalized,\n    };\n  }\n\n  private mapBackground(json: any): UIBackground {\n    return {\n      backgroundColor: json.background_color ? (json.background_color as UIColor) : null,\n      gradientColor1: json.gradient_color_1 ? (json.gradient_color_1 as UIColor) : null,\n      gradientColor2: json.gradient_color_2 ? (json.gradient_color_2 as UIColor) : null,\n    };\n  }\n\n  private mapAction(json: any): UIAction {\n    return {\n      canAccess: json.can_acces ?? null,\n      type: json.type ? (json.type as UIActionType) : null,\n      url: json.url ?? null,\n      param: json.param ?? null,\n    };\n  }\n\n  private mapRadius(json: any): UIRadius {\n    return {\n      topLeft: json.top_left ? (json.top_left as UIRadiusLevel) : null,\n      topRight: json.top_right ? (json.top_right as UIRadiusLevel) : null,\n      bottomLeft: json.bottom_left ? (json.bottom_left as UIRadiusLevel) : null,\n      bottomRight: json.bottom_right\n        ? (json.bottom_right as UIRadiusLevel)\n        : null,\n    };\n  }\n}\n"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export var UIScreenContainerType;
|
|
2
|
+
(function (UIScreenContainerType) {
|
|
3
|
+
UIScreenContainerType["CONTAINED"] = "contained";
|
|
4
|
+
UIScreenContainerType["FLUID"] = "fluid";
|
|
5
|
+
})(UIScreenContainerType || (UIScreenContainerType = {}));
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWlzY3JlZW4tY29udGFpbmVyLXR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb3JlL3VpY29tcG9zaXRpb24vZW51bXMvdWlzY3JlZW4tY29udGFpbmVyLXR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVkscUJBR1g7QUFIRCxXQUFZLHFCQUFxQjtJQUMvQixnREFBdUIsQ0FBQTtJQUN2Qix3Q0FBZSxDQUFBO0FBQ2pCLENBQUMsRUFIVyxxQkFBcUIsS0FBckIscUJBQXFCLFFBR2hDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gVUlTY3JlZW5Db250YWluZXJUeXBlIHtcbiAgQ09OVEFJTkVEID0gJ2NvbnRhaW5lZCcsXG4gIEZMVUlEID0gJ2ZsdWlkJyxcbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWlzY3JlZW4tY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZHVpL3NyYy9saWIvY29yZS91aWNvbXBvc2l0aW9uL21vZGVscy91aXNjcmVlbi1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVJU2NyZWVuQ29udGFpbmVyVHlwZSB9IGZyb20gJy4uL2VudW1zL3Vpc2NyZWVuLWNvbnRhaW5lci10eXBlJztcblxuZXhwb3J0IGludGVyZmFjZSBVSVNjcmVlbkNvbmZpZyB7XG4gIGFsd2F5c1JlbG9hZD86IGJvb2xlYW4gfCBudWxsO1xuICBjb250YWluZXI/OiBVSVNjcmVlbkNvbnRhaW5lclR5cGUgfCBudWxsO1xufVxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWlzY3JlZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb3JlL3VpY29tcG9zaXRpb24vbW9kZWxzL3Vpc2NyZWVuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBVSUJhY2tncm91bmQgfSBmcm9tICcuLi8uLi91aXRoZW1lL21vZGVscy91aWJhY2tncm91bmQnO1xuaW1wb3J0IHsgVUlQYWRkaW5nIH0gZnJvbSAnLi4vLi4vdWl0aGVtZS9tb2RlbHMvdWlwYWRkaW5nJztcbmltcG9ydCB7IFVJU2NlbmUgfSBmcm9tICcuLi9lbnVtcy91aXNjZW5lJztcbmltcG9ydCB7IFVJU2NyZWVuSWRlbnRpZmllciB9IGZyb20gJy4uL2VudW1zL3Vpc2NyZWVuLWlkZW50aWZpZXInO1xuaW1wb3J0IHsgVUlTY3JlZW5Db25maWcgfSBmcm9tICcuL3Vpc2NyZWVuLWNvbmZpZyc7XG5pbXBvcnQgeyBVSUxheW91dCB9IGZyb20gJy4vdWlsYXlvdXQnO1xuaW1wb3J0IHsgVUlWaWV3IH0gZnJvbSAnLi91aXZpZXcnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFVJU2NyZWVuIGV4dGVuZHMgVUlWaWV3IHtcbiAgaWRlbnRpZmllcjogVUlTY3JlZW5JZGVudGlmaWVyO1xuICBjb250ZW50OiBVSUxheW91dDtcbiAgc2NlbmU/OiBVSVNjZW5lIHwgbnVsbDtcbiAgcGFkZGluZz86IFVJUGFkZGluZyB8IG51bGw7XG4gIGJhY2tncm91bmQ/OiBVSUJhY2tncm91bmQgfCBudWxsO1xuICBjb25maWc/OiBVSVNjcmVlbkNvbmZpZyB8IG51bGw7XG59XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWl2aWV3LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZHVpL3NyYy9saWIvY29yZS91aWNvbXBvc2l0aW9uL21vZGVscy91aXZpZXcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVJRGltZW5zaW9uIH0gZnJvbSAnLi4vLi4vdWl0aGVtZS9lbnVtcy91aWRpbWVuc2lvbic7XG5pbXBvcnQgeyBVSUFjdGlvbiB9IGZyb20gJy4uLy4uL3VpdGhlbWUvbW9kZWxzL3VpYWN0aW9uJztcbmltcG9ydCB7IFVJQWxpZ25tZW50IH0gZnJvbSAnLi4vLi4vdWl0aGVtZS9tb2RlbHMvdWlhbGlnbm1lbnQnO1xuaW1wb3J0IHsgVUlCYWNrZ3JvdW5kIH0gZnJvbSAnLi4vLi4vdWl0aGVtZS9tb2RlbHMvdWliYWNrZ3JvdW5kJztcbmltcG9ydCB7IFVJUGFkZGluZyB9IGZyb20gJy4uLy4uL3VpdGhlbWUvbW9kZWxzL3VpcGFkZGluZyc7XG5pbXBvcnQgeyBVSVJhZGl1cyB9IGZyb20gJy4uLy4uL3VpdGhlbWUvbW9kZWxzL3VpcmFkaXVzJztcbmltcG9ydCB7IFVJU2hhZG93IH0gZnJvbSAnLi4vLi4vdWl0aGVtZS9tb2RlbHMvdWlzaGFkb3cnO1xuaW1wb3J0IHsgVUlTcGFjaW5nIH0gZnJvbSAnLi4vLi4vdWl0aGVtZS9tb2RlbHMvdWlzcGFjaW5nJztcbmltcG9ydCB7VUlDb2xvcn0gZnJvbSAnLi4vLi4vdWl0aGVtZS9lbnVtcy91aWNvbG9yJztcbmltcG9ydCB7VUlKdXN0aWZ5fSBmcm9tICcuLi8uLi91aXRoZW1lL2VudW1zL3VpanVzdGlmeSc7XG5cbi8vIGludGVyZmFjZSBBQlNUUkFUQSAtIG7Do28gZGV2ZSBleGlzdGlyIG9iamV0b3MgZGVsYSFcbmV4cG9ydCBpbnRlcmZhY2UgVUlWaWV3IHtcbiAgaWQ/OiBzdHJpbmcgfCBudWxsO1xuICBwYWRkaW5nPzogVUlQYWRkaW5nIHwgbnVsbDtcbiAgYmFja2dyb3VuZD86IFVJQmFja2dyb3VuZCB8IG51bGw7XG4gIGFjdGlvbj86IFVJQWN0aW9uIHwgbnVsbDtcbiAgYWxpZ25tZW50PzogVUlBbGlnbm1lbnQgfCBudWxsO1xuICBzaGFkb3c/OiBVSVNoYWRvdyB8IG51bGw7XG4gIHJhZGl1cz86IFVJUmFkaXVzIHwgbnVsbDtcbiAgc3BhY2luZz86IFVJU3BhY2luZyB8IG51bGw7XG4gIGhlaWdodD86IFVJRGltZW5zaW9uIHwgbnVsbDtcbiAgd2lkdGg/OiBVSURpbWVuc2lvbiB8IG51bGw7XG4gIGJvcmRlcldpZHRoPzogbnVtYmVyIHwgbnVsbDtcbiAgYm9yZGVyQ29sb3I/OiBVSUNvbG9yIHwgbnVsbDtcbiAganVzdGlmeT86IFVJSnVzdGlmeSB8IG51bGw7XG59XG4iXX0=
|
|
@@ -6,6 +6,7 @@ export var UIActionType;
|
|
|
6
6
|
UIActionType["DISMISS_TO_SCENE"] = "DISMISS_TO_SCENE";
|
|
7
7
|
UIActionType["EXTERNAL_URL"] = "EXTERNAL_URL";
|
|
8
8
|
UIActionType["WEBVIEW_URL"] = "WEBVIEW_URL";
|
|
9
|
+
UIActionType["ANCHOR"] = "ANCHOR";
|
|
9
10
|
// paywall
|
|
10
11
|
UIActionType["PAYWALL"] = "PAYWALL";
|
|
11
12
|
UIActionType["REGISTER"] = "REGISTER";
|
|
@@ -13,4 +14,4 @@ export var UIActionType;
|
|
|
13
14
|
UIActionType["HTML"] = "HTML";
|
|
14
15
|
UIActionType["FILE"] = "FILE";
|
|
15
16
|
})(UIActionType || (UIActionType = {}));
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWlhY3Rpb24tdHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2R1aS9zcmMvbGliL2NvcmUvdWl0aGVtZS9lbnVtcy91aWFjdGlvbi10eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLFlBZ0JYO0FBaEJELFdBQVksWUFBWTtJQUN0QixZQUFZO0lBQ1osNkNBQTZCLENBQUE7SUFDN0IsMkRBQTJDLENBQUE7SUFDM0MscURBQXFDLENBQUE7SUFDckMsNkNBQTZCLENBQUE7SUFDN0IsMkNBQTJCLENBQUE7SUFDM0IsaUNBQWlCLENBQUE7SUFFakIsVUFBVTtJQUNWLG1DQUFtQixDQUFBO0lBQ25CLHFDQUFxQixDQUFBO0lBRXJCLFdBQVc7SUFDWCw2QkFBYSxDQUFBO0lBQ2IsNkJBQWEsQ0FBQTtBQUNmLENBQUMsRUFoQlcsWUFBWSxLQUFaLFlBQVksUUFnQnZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gVUlBY3Rpb25UeXBlIHtcbiAgLy8gbmF2ZWdhw6fDo29cbiAgSU5URVJOQUxfVVJMID0gJ0lOVEVSTkFMX1VSTCcsXG4gIFJFTE9BRF9JTlRFUk5BTF9VUkwgPSAnUkVMT0FEX0lOVEVSTkFMX1VSTCcsXG4gIERJU01JU1NfVE9fU0NFTkUgPSAnRElTTUlTU19UT19TQ0VORScsXG4gIEVYVEVSTkFMX1VSTCA9ICdFWFRFUk5BTF9VUkwnLFxuICBXRUJWSUVXX1VSTCA9ICdXRUJWSUVXX1VSTCcsXG4gIEFOQ0hPUiA9ICdBTkNIT1InLFxuXG4gIC8vIHBheXdhbGxcbiAgUEFZV0FMTCA9ICdQQVlXQUxMJyxcbiAgUkVHSVNURVIgPSAnUkVHSVNURVInLFxuXG4gIC8vIGNvbnRlw7pkb1xuICBIVE1MID0gJ0hUTUwnLFxuICBGSUxFID0gJ0ZJTEUnLFxufVxuIl19
|