@edm-sdui/sdui 1.0.15 → 1.0.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/uicomponent/column/column.component.mjs +2 -2
- package/esm2022/lib/components/uicomponent/image/image.component.mjs +3 -6
- package/esm2022/lib/components/uicomponent/modal/modal.component.mjs +30 -0
- package/esm2022/lib/components/uilayout/uinavigation/uinavigation.component.mjs +3 -3
- package/esm2022/lib/core/services/modal.service.mjs +30 -0
- package/esm2022/lib/core/services/ui-action.service.mjs +13 -4
- package/esm2022/lib/core/uitheme/mapping/aspect-mapping.mjs +6 -0
- package/esm2022/lib/directives/uiview.directive.mjs +1 -17
- package/fesm2022/edm-sdui-sdui.mjs +89 -35
- package/fesm2022/edm-sdui-sdui.mjs.map +1 -1
- package/lib/components/uicomponent/image/image.component.d.ts.map +1 -1
- package/lib/components/uicomponent/modal/modal.component.d.ts +15 -0
- package/lib/components/uicomponent/modal/modal.component.d.ts.map +1 -0
- package/lib/core/services/modal.service.d.ts +12 -0
- package/lib/core/services/modal.service.d.ts.map +1 -0
- package/lib/core/services/ui-action.service.d.ts +3 -1
- package/lib/core/services/ui-action.service.d.ts.map +1 -1
- package/lib/core/uitheme/mapping/aspect-mapping.d.ts +3 -0
- package/lib/core/uitheme/mapping/aspect-mapping.d.ts.map +1 -0
- package/lib/directives/uiview.directive.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -11,11 +11,11 @@ export class ColumnComponent {
|
|
|
11
11
|
// console.debug('column.uiComponent: ', this.uiComponent);
|
|
12
12
|
}
|
|
13
13
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ColumnComponent, deps: [{ token: 'uiComponent' }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
14
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ColumnComponent, selector: "edm-sdui-column", ngImport: i0, template: "<div class=\"column\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <edm-sdui-component\n *ngFor=\"let child of uiComponent.components\"\n [uiComponent]=\"child\"\n >\n </edm-sdui-component>\n</div>\n", styles: [":host{display:contents}.column{display:flex;flex-direction:column
|
|
14
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ColumnComponent, selector: "edm-sdui-column", ngImport: i0, template: "<div class=\"column\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <edm-sdui-component\n *ngFor=\"let child of uiComponent.components\"\n [uiComponent]=\"child\"\n >\n </edm-sdui-component>\n</div>\n", styles: [":host{display:contents}.column{display:flex;flex-direction:column}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.UIComponentComponent, selector: "edm-sdui-component", inputs: ["uiComponent", "translateLabel"] }, { kind: "directive", type: i3.UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
|
|
15
15
|
}
|
|
16
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ColumnComponent, decorators: [{
|
|
17
17
|
type: Component,
|
|
18
|
-
args: [{ selector: 'edm-sdui-column', standalone: false, template: "<div class=\"column\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <edm-sdui-component\n *ngFor=\"let child of uiComponent.components\"\n [uiComponent]=\"child\"\n >\n </edm-sdui-component>\n</div>\n", styles: [":host{display:contents}.column{display:flex;flex-direction:column
|
|
18
|
+
args: [{ selector: 'edm-sdui-column', standalone: false, template: "<div class=\"column\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <edm-sdui-component\n *ngFor=\"let child of uiComponent.components\"\n [uiComponent]=\"child\"\n >\n </edm-sdui-component>\n</div>\n", styles: [":host{display:contents}.column{display:flex;flex-direction:column}\n"] }]
|
|
19
19
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
20
20
|
type: Inject,
|
|
21
21
|
args: ['uiComponent']
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Component, ElementRef, Inject, Renderer2, ViewChild, } from '@angular/core';
|
|
2
2
|
import { assetMapping } from '../../../core/uitheme/mapping/asset-mapping';
|
|
3
3
|
import { sizeMappingHeight, sizeMappingWidth, } from '../../../core/uitheme/mapping/size-mapping';
|
|
4
|
-
import {
|
|
4
|
+
import { aspectMapping } from '../../../core/uitheme/mapping/aspect-mapping';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
7
7
|
import * as i2 from "../../../directives/uiview.directive";
|
|
@@ -29,12 +29,9 @@ export class ImageComponent {
|
|
|
29
29
|
const width = sizeMappingWidth[element.size];
|
|
30
30
|
this.renderer.setStyle(this.imgElementRef.nativeElement, 'height', height);
|
|
31
31
|
this.renderer.setStyle(this.imgElementRef.nativeElement, 'width', width);
|
|
32
|
-
if (element.size === UISize.THUMB_2) {
|
|
33
|
-
this.renderer.setStyle(this.imgElementRef.nativeElement, 'object-fit', 'contain');
|
|
34
|
-
}
|
|
35
32
|
}
|
|
36
33
|
if (element.aspect) {
|
|
37
|
-
this.renderer.setStyle(this.imgElementRef.nativeElement, 'object-fit', element.aspect);
|
|
34
|
+
this.renderer.setStyle(this.imgElementRef.nativeElement, 'object-fit', aspectMapping[element.aspect]);
|
|
38
35
|
}
|
|
39
36
|
if (element.aspectRatio) {
|
|
40
37
|
this.renderer.setStyle(this.imgElementRef.nativeElement, 'aspect-ratio', element.aspectRatio);
|
|
@@ -53,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
53
50
|
type: ViewChild,
|
|
54
51
|
args: ['imgElement']
|
|
55
52
|
}] } });
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZHVpL3NyYy9saWIvY29tcG9uZW50cy91aWNvbXBvbmVudC9pbWFnZS9pbWFnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb21wb25lbnRzL3VpY29tcG9uZW50L2ltYWdlL2ltYWdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxTQUFTLEVBQ1QsVUFBVSxFQUNWLE1BQU0sRUFFTixTQUFTLEVBQ1QsU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBR3ZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUMzRSxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLGdCQUFnQixHQUNqQixNQUFNLDRDQUE0QyxDQUFDO0FBRXBELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQzs7OztBQVE3RSxNQUFNLE9BQU8sY0FBYztJQUd6QixZQUNnQyxXQUF3QixFQUM5QyxRQUFtQjtRQURHLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQzlDLGFBQVEsR0FBUixRQUFRLENBQVc7SUFDekIsQ0FBQztJQUVMLFFBQVEsS0FBVyxDQUFDO0lBRXBCLGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUUsT0FBTyxFQUFFLENBQUM7WUFDOUIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzlDLENBQUM7SUFDSCxDQUFDO0lBRU8sWUFBWSxDQUFDLE9BQWtCO1FBQ3JDLElBQUksT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2xCLE1BQU0sS0FBSyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDMUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQ3hCLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxFQUNoQyxLQUFLLEVBQ0wsS0FBSyxDQUNOLENBQUM7UUFDSixDQUFDO2FBQU0sSUFBSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDdkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQ3hCLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxFQUNoQyxLQUFLLEVBQ0wsT0FBTyxDQUFDLEdBQUcsQ0FDWixDQUFDO1FBQ0osQ0FBQztRQUVELElBQUksT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ2pCLE1BQU0sTUFBTSxHQUFHLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUMvQyxNQUFNLEtBQUssR0FBRyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDN0MsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQ3BCLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxFQUNoQyxRQUFRLEVBQ1IsTUFBTSxDQUNQLENBQUM7WUFDRixJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsRUFBRSxPQUFPLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0UsQ0FBQztRQUVELElBQUcsT0FBTyxDQUFDLE1BQU0sRUFBQyxDQUFDO1lBQ2pCLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxFQUFFLFlBQVksRUFBRSxhQUFhLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFDeEcsQ0FBQztRQUVELElBQUcsT0FBTyxDQUFDLFdBQVcsRUFBQyxDQUFDO1lBQ3RCLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxFQUFFLGNBQWMsRUFBRSxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDaEcsQ0FBQztJQUNILENBQUM7K0dBbERVLGNBQWMsa0JBSWYsYUFBYTttR0FKWixjQUFjLG1LQ3pCM0IsbUZBQ0E7OzRGRHdCYSxjQUFjO2tCQU4xQixTQUFTOytCQUNFLGdCQUFnQixjQUdkLEtBQUs7OzBCQU1kLE1BQU07MkJBQUMsYUFBYTtpRUFIRSxhQUFhO3NCQUFyQyxTQUFTO3VCQUFDLFlBQVkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEluamVjdCxcbiAgT25Jbml0LFxuICBSZW5kZXJlcjIsXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBVSUNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL2NvcmUvdWljb21wb3NpdGlvbi9tb2RlbHMvdWljb21wb25lbnQnO1xuaW1wb3J0IHsgVUlFbGVtZW50IH0gZnJvbSAnLi4vLi4vLi4vY29yZS91aWNvbXBvc2l0aW9uL21vZGVscy91aWVsZW1lbnQnO1xuaW1wb3J0IHsgYXNzZXRNYXBwaW5nIH0gZnJvbSAnLi4vLi4vLi4vY29yZS91aXRoZW1lL21hcHBpbmcvYXNzZXQtbWFwcGluZyc7XG5pbXBvcnQge1xuICBzaXplTWFwcGluZ0hlaWdodCxcbiAgc2l6ZU1hcHBpbmdXaWR0aCxcbn0gZnJvbSAnLi4vLi4vLi4vY29yZS91aXRoZW1lL21hcHBpbmcvc2l6ZS1tYXBwaW5nJztcbmltcG9ydCB7IFVJU2l6ZSB9IGZyb20gJy4uLy4uLy4uL2NvcmUvdWl0aGVtZS9lbnVtcy91aXNpemUnO1xuaW1wb3J0IHsgYXNwZWN0TWFwcGluZyB9IGZyb20gJy4uLy4uLy4uL2NvcmUvdWl0aGVtZS9tYXBwaW5nL2FzcGVjdC1tYXBwaW5nJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZWRtLXNkdWktaW1hZ2UnLFxuICB0ZW1wbGF0ZVVybDogJy4vaW1hZ2UuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vaW1hZ2UuY29tcG9uZW50LnNjc3MnLFxuICBzdGFuZGFsb25lOiBmYWxzZSxcbn0pXG5leHBvcnQgY2xhc3MgSW1hZ2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0luaXQge1xuICBAVmlld0NoaWxkKCdpbWdFbGVtZW50JykgaW1nRWxlbWVudFJlZiE6IEVsZW1lbnRSZWY8SFRNTEltYWdlRWxlbWVudD47XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdCgndWlDb21wb25lbnQnKSBwdWJsaWMgdWlDb21wb25lbnQ6IFVJQ29tcG9uZW50LFxuICAgIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMlxuICApIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQgeyB9XG5cbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLnVpQ29tcG9uZW50Py5lbGVtZW50KSB7XG4gICAgICB0aGlzLmFwcGx5RWxlbWVudCh0aGlzLnVpQ29tcG9uZW50LmVsZW1lbnQpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgYXBwbHlFbGVtZW50KGVsZW1lbnQ6IFVJRWxlbWVudCkge1xuICAgIGlmIChlbGVtZW50LmFzc2V0KSB7XG4gICAgICBjb25zdCBhc3NldCA9IGFzc2V0TWFwcGluZ1tlbGVtZW50LmFzc2V0XTtcbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0QXR0cmlidXRlKFxuICAgICAgICB0aGlzLmltZ0VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCxcbiAgICAgICAgJ3NyYycsXG4gICAgICAgIGFzc2V0XG4gICAgICApO1xuICAgIH0gZWxzZSBpZiAoZWxlbWVudC51cmwpIHtcbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0QXR0cmlidXRlKFxuICAgICAgICB0aGlzLmltZ0VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCxcbiAgICAgICAgJ3NyYycsXG4gICAgICAgIGVsZW1lbnQudXJsXG4gICAgICApO1xuICAgIH1cblxuICAgIGlmIChlbGVtZW50LnNpemUpIHtcbiAgICAgIGNvbnN0IGhlaWdodCA9IHNpemVNYXBwaW5nSGVpZ2h0W2VsZW1lbnQuc2l6ZV07XG4gICAgICBjb25zdCB3aWR0aCA9IHNpemVNYXBwaW5nV2lkdGhbZWxlbWVudC5zaXplXTtcbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUoXG4gICAgICAgIHRoaXMuaW1nRWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LFxuICAgICAgICAnaGVpZ2h0JyxcbiAgICAgICAgaGVpZ2h0XG4gICAgICApO1xuICAgICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZSh0aGlzLmltZ0VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ3dpZHRoJywgd2lkdGgpO1xuICAgIH1cblxuICAgIGlmKGVsZW1lbnQuYXNwZWN0KXtcbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUodGhpcy5pbWdFbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICdvYmplY3QtZml0JywgYXNwZWN0TWFwcGluZ1tlbGVtZW50LmFzcGVjdF0pO1xuICAgIH1cblxuICAgIGlmKGVsZW1lbnQuYXNwZWN0UmF0aW8pe1xuICAgICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZSh0aGlzLmltZ0VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ2FzcGVjdC1yYXRpbycsIGVsZW1lbnQuYXNwZWN0UmF0aW8pO1xuICAgIH1cbiAgfVxufVxuIiwiPGltZyAjaW1nRWxlbWVudCBbZWRtU2R1aVZpZXddPVwidWlDb21wb25lbnQuZWxlbWVudFwiICpuZ0lmPVwidWlDb21wb25lbnRcIiAvPlxuIl19
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from "@angular/core";
|
|
2
|
+
import { DomSanitizer } from "@angular/platform-browser";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/platform-browser";
|
|
5
|
+
export class ModalComponent {
|
|
6
|
+
constructor(sanitizer) {
|
|
7
|
+
this.sanitizer = sanitizer;
|
|
8
|
+
this.title = '';
|
|
9
|
+
this.closed = new EventEmitter();
|
|
10
|
+
}
|
|
11
|
+
get safeUrl() {
|
|
12
|
+
return this.sanitizer.bypassSecurityTrustResourceUrl(this.url);
|
|
13
|
+
}
|
|
14
|
+
close() {
|
|
15
|
+
this.closed.emit();
|
|
16
|
+
}
|
|
17
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModalComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
18
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ModalComponent, isStandalone: true, selector: "edm-modal", inputs: { url: "url", title: "title" }, outputs: { closed: "closed" }, ngImport: i0, template: "<div class=\"edm-modal-backdrop\" (click)=\"close()\">\n <div class=\"edm-modal-content\" (click)=\"$event.stopPropagation()\">\n\n <div class=\"edm-modal-header\">\n <span class=\"edm-modal-title\">{{ title }}</span>\n <button class=\"edm-modal-close-btn\" (click)=\"close()\">\n <img src=\"/assets/images/bt-close.svg\" width=\"28px\" height=\"28px\" />\n </button>\n </div>\n\n <iframe [src]=\"safeUrl\" frameborder=\"0\"></iframe>\n\n </div>\n</div>\n", styles: [".edm-modal-backdrop{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;z-index:999999}.edm-modal-content{min-width:50vw;max-width:90vw;height:80vh;box-shadow:0 0 16px #ffffff1a;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;position:relative}.edm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg);color:var(--main-1);font-size:1rem;font-weight:600;border-bottom:1px solid var(--aux)}.edm-modal-title{flex:1}.edm-modal-close-btn{background:var(--bg-module);border:none;cursor:pointer}iframe{flex:1;padding-top:16px;width:100%;border:none}\n"] }); }
|
|
19
|
+
}
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModalComponent, decorators: [{
|
|
21
|
+
type: Component,
|
|
22
|
+
args: [{ selector: 'edm-modal', standalone: true, template: "<div class=\"edm-modal-backdrop\" (click)=\"close()\">\n <div class=\"edm-modal-content\" (click)=\"$event.stopPropagation()\">\n\n <div class=\"edm-modal-header\">\n <span class=\"edm-modal-title\">{{ title }}</span>\n <button class=\"edm-modal-close-btn\" (click)=\"close()\">\n <img src=\"/assets/images/bt-close.svg\" width=\"28px\" height=\"28px\" />\n </button>\n </div>\n\n <iframe [src]=\"safeUrl\" frameborder=\"0\"></iframe>\n\n </div>\n</div>\n", styles: [".edm-modal-backdrop{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;z-index:999999}.edm-modal-content{min-width:50vw;max-width:90vw;height:80vh;box-shadow:0 0 16px #ffffff1a;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;position:relative}.edm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg);color:var(--main-1);font-size:1rem;font-weight:600;border-bottom:1px solid var(--aux)}.edm-modal-title{flex:1}.edm-modal-close-btn{background:var(--bg-module);border:none;cursor:pointer}iframe{flex:1;padding-top:16px;width:100%;border:none}\n"] }]
|
|
23
|
+
}], ctorParameters: () => [{ type: i1.DomSanitizer }], propDecorators: { url: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], title: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}], closed: [{
|
|
28
|
+
type: Output
|
|
29
|
+
}] } });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZHVpL3NyYy9saWIvY29tcG9uZW50cy91aWNvbXBvbmVudC9tb2RhbC9tb2RhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb21wb25lbnRzL3VpY29tcG9uZW50L21vZGFsL21vZGFsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFFLFlBQVksRUFBbUIsTUFBTSwyQkFBMkIsQ0FBQzs7O0FBUTFFLE1BQU0sT0FBTyxjQUFjO0lBS3pCLFlBQW9CLFNBQXVCO1FBQXZCLGNBQVMsR0FBVCxTQUFTLENBQWM7UUFIbEMsVUFBSyxHQUFXLEVBQUUsQ0FBQztRQUNsQixXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztJQUVFLENBQUM7SUFFL0MsSUFBSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLDhCQUE4QixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRUQsS0FBSztRQUNILElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDckIsQ0FBQzsrR0FiVSxjQUFjO21HQUFkLGNBQWMsNElDVDNCLDBlQWNBOzs0RkRMYSxjQUFjO2tCQU4xQixTQUFTOytCQUNFLFdBQVcsY0FHVCxJQUFJO2lGQUdQLEdBQUc7c0JBQVgsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0ksTUFBTTtzQkFBZixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgRG9tU2FuaXRpemVyLCBTYWZlUmVzb3VyY2VVcmwgfSBmcm9tIFwiQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3NlclwiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlZG0tbW9kYWwnLFxuICB0ZW1wbGF0ZVVybDogJy4vbW9kYWwuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9tb2RhbC5jb21wb25lbnQuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIE1vZGFsQ29tcG9uZW50IHtcbiAgQElucHV0KCkgdXJsITogc3RyaW5nO1xuICBASW5wdXQoKSB0aXRsZTogc3RyaW5nID0gJyc7XG4gIEBPdXRwdXQoKSBjbG9zZWQgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzYW5pdGl6ZXI6IERvbVNhbml0aXplcikge31cblxuICBnZXQgc2FmZVVybCgpOiBTYWZlUmVzb3VyY2VVcmwge1xuICAgIHJldHVybiB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0UmVzb3VyY2VVcmwodGhpcy51cmwpO1xuICB9XG5cbiAgY2xvc2UoKSB7XG4gICAgdGhpcy5jbG9zZWQuZW1pdCgpO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZWRtLW1vZGFsLWJhY2tkcm9wXCIgKGNsaWNrKT1cImNsb3NlKClcIj5cbiAgPGRpdiBjbGFzcz1cImVkbS1tb2RhbC1jb250ZW50XCIgKGNsaWNrKT1cIiRldmVudC5zdG9wUHJvcGFnYXRpb24oKVwiPlxuXG4gICAgPGRpdiBjbGFzcz1cImVkbS1tb2RhbC1oZWFkZXJcIj5cbiAgICAgIDxzcGFuIGNsYXNzPVwiZWRtLW1vZGFsLXRpdGxlXCI+e3sgdGl0bGUgfX08L3NwYW4+XG4gICAgICA8YnV0dG9uIGNsYXNzPVwiZWRtLW1vZGFsLWNsb3NlLWJ0blwiIChjbGljayk9XCJjbG9zZSgpXCI+XG4gICAgICAgIDxpbWcgc3JjPVwiL2Fzc2V0cy9pbWFnZXMvYnQtY2xvc2Uuc3ZnXCIgd2lkdGg9XCIyOHB4XCIgaGVpZ2h0PVwiMjhweFwiIC8+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2Rpdj5cblxuICAgIDxpZnJhbWUgW3NyY109XCJzYWZlVXJsXCIgZnJhbWVib3JkZXI9XCIwXCI+PC9pZnJhbWU+XG5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -4,12 +4,12 @@ import * as i1 from "@angular/common";
|
|
|
4
4
|
import * as i2 from "../../uicomponent/uicomponent.component";
|
|
5
5
|
export class UINavigationComponent {
|
|
6
6
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UINavigationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
7
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UINavigationComponent, selector: "edm-sdui-navigation", inputs: { uiNavigation: "uiNavigation" }, ngImport: i0, template: "<div class=\"nav-main\" *ngIf=\"uiNavigation\">\n <
|
|
7
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UINavigationComponent, selector: "edm-sdui-navigation", inputs: { uiNavigation: "uiNavigation" }, ngImport: i0, template: "<div class=\"nav-main\" *ngIf=\"uiNavigation\">\n <h2 *ngIf=\"uiNavigation.title\">{{ uiNavigation.title }}</h2>\n\n <edm-sdui-component\n [uiComponent]=\"uiNavigation.titleComponent\"\n *ngIf=\"uiNavigation.titleComponent\"\n ></edm-sdui-component>\n</div>\n", styles: [":host{display:contents}.nav-main h2{text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.UIComponentComponent, selector: "edm-sdui-component", inputs: ["uiComponent", "translateLabel"] }] }); }
|
|
8
8
|
}
|
|
9
9
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UINavigationComponent, decorators: [{
|
|
10
10
|
type: Component,
|
|
11
|
-
args: [{ selector: 'edm-sdui-navigation', standalone: false, template: "<div class=\"nav-main\" *ngIf=\"uiNavigation\">\n <
|
|
11
|
+
args: [{ selector: 'edm-sdui-navigation', standalone: false, template: "<div class=\"nav-main\" *ngIf=\"uiNavigation\">\n <h2 *ngIf=\"uiNavigation.title\">{{ uiNavigation.title }}</h2>\n\n <edm-sdui-component\n [uiComponent]=\"uiNavigation.titleComponent\"\n *ngIf=\"uiNavigation.titleComponent\"\n ></edm-sdui-component>\n</div>\n", styles: [":host{display:contents}.nav-main h2{text-align:center}\n"] }]
|
|
12
12
|
}], propDecorators: { uiNavigation: [{
|
|
13
13
|
type: Input
|
|
14
14
|
}] } });
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWluYXZpZ2F0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2R1aS9zcmMvbGliL2NvbXBvbmVudHMvdWlsYXlvdXQvdWluYXZpZ2F0aW9uL3VpbmF2aWdhdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb21wb25lbnRzL3VpbGF5b3V0L3VpbmF2aWdhdGlvbi91aW5hdmlnYXRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBU2hFLE1BQU0sT0FBTyxxQkFBcUI7K0dBQXJCLHFCQUFxQjttR0FBckIscUJBQXFCLHFHQ1RsQyw4UUFRQTs7NEZEQ2EscUJBQXFCO2tCQU5qQyxTQUFTOytCQUNFLHFCQUFxQixjQUduQixLQUFLOzhCQUdSLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBVSU5hdmlnYXRpb24gfSBmcm9tICcuLi8uLi8uLi9jb3JlL3VpY29tcG9zaXRpb24vbW9kZWxzL3VpbmF2aWdhdGlvbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VkbS1zZHVpLW5hdmlnYXRpb24nLFxuICBzdHlsZVVybDogJy4vdWluYXZpZ2F0aW9uLmNvbXBvbmVudC5zY3NzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3VpbmF2aWdhdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0YW5kYWxvbmU6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBVSU5hdmlnYXRpb25Db21wb25lbnQge1xuICBASW5wdXQoKSB1aU5hdmlnYXRpb24/
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWluYXZpZ2F0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2R1aS9zcmMvbGliL2NvbXBvbmVudHMvdWlsYXlvdXQvdWluYXZpZ2F0aW9uL3VpbmF2aWdhdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb21wb25lbnRzL3VpbGF5b3V0L3VpbmF2aWdhdGlvbi91aW5hdmlnYXRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBU2hFLE1BQU0sT0FBTyxxQkFBcUI7K0dBQXJCLHFCQUFxQjttR0FBckIscUJBQXFCLHFHQ1RsQyw4UUFRQTs7NEZEQ2EscUJBQXFCO2tCQU5qQyxTQUFTOytCQUNFLHFCQUFxQixjQUduQixLQUFLOzhCQUdSLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBVSU5hdmlnYXRpb24gfSBmcm9tICcuLi8uLi8uLi9jb3JlL3VpY29tcG9zaXRpb24vbW9kZWxzL3VpbmF2aWdhdGlvbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VkbS1zZHVpLW5hdmlnYXRpb24nLFxuICBzdHlsZVVybDogJy4vdWluYXZpZ2F0aW9uLmNvbXBvbmVudC5zY3NzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3VpbmF2aWdhdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0YW5kYWxvbmU6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBVSU5hdmlnYXRpb25Db21wb25lbnQge1xuICBASW5wdXQoKSB1aU5hdmlnYXRpb24/OiBVSU5hdmlnYXRpb247XG59XG4iLCI8ZGl2IGNsYXNzPVwibmF2LW1haW5cIiAqbmdJZj1cInVpTmF2aWdhdGlvblwiPlxuICA8aDIgKm5nSWY9XCJ1aU5hdmlnYXRpb24udGl0bGVcIj57eyB1aU5hdmlnYXRpb24udGl0bGUgfX08L2gyPlxuXG4gIDxlZG0tc2R1aS1jb21wb25lbnRcbiAgICBbdWlDb21wb25lbnRdPVwidWlOYXZpZ2F0aW9uLnRpdGxlQ29tcG9uZW50XCJcbiAgICAqbmdJZj1cInVpTmF2aWdhdGlvbi50aXRsZUNvbXBvbmVudFwiXG4gID48L2VkbS1zZHVpLWNvbXBvbmVudD5cbjwvZGl2PlxuIl19
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ApplicationRef, ComponentFactoryResolver, Injectable, Injector } from "@angular/core";
|
|
2
|
+
import { ModalComponent } from "../../components/uicomponent/modal/modal.component";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ModalService {
|
|
5
|
+
constructor(injector, appRef, cfr) {
|
|
6
|
+
this.injector = injector;
|
|
7
|
+
this.appRef = appRef;
|
|
8
|
+
this.cfr = cfr;
|
|
9
|
+
}
|
|
10
|
+
open(url, title = '') {
|
|
11
|
+
const factory = this.cfr.resolveComponentFactory(ModalComponent);
|
|
12
|
+
const componentRef = factory.create(this.injector);
|
|
13
|
+
componentRef.instance.url = url;
|
|
14
|
+
componentRef.instance.title = title;
|
|
15
|
+
componentRef.instance.closed.subscribe(() => {
|
|
16
|
+
this.appRef.detachView(componentRef.hostView);
|
|
17
|
+
componentRef.destroy();
|
|
18
|
+
});
|
|
19
|
+
this.appRef.attachView(componentRef.hostView);
|
|
20
|
+
const domElem = componentRef.hostView.rootNodes[0];
|
|
21
|
+
document.body.appendChild(domElem);
|
|
22
|
+
}
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModalService, deps: [{ token: i0.Injector }, { token: i0.ApplicationRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
24
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModalService, providedIn: 'root' }); }
|
|
25
|
+
}
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModalService, decorators: [{
|
|
27
|
+
type: Injectable,
|
|
28
|
+
args: [{ providedIn: 'root' }]
|
|
29
|
+
}], ctorParameters: () => [{ type: i0.Injector }, { type: i0.ApplicationRef }, { type: i0.ComponentFactoryResolver }] });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2R1aS9zcmMvbGliL2NvcmUvc2VydmljZXMvbW9kYWwuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLHdCQUF3QixFQUFtQixVQUFVLEVBQUUsUUFBUSxFQUFvQixNQUFNLGVBQWUsQ0FBQztBQUNsSSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0RBQW9ELENBQUM7O0FBR3BGLE1BQU0sT0FBTyxZQUFZO0lBQ3JCLFlBQ1EsUUFBa0IsRUFDbEIsTUFBc0IsRUFDdEIsR0FBNkI7UUFGN0IsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUNsQixXQUFNLEdBQU4sTUFBTSxDQUFnQjtRQUN0QixRQUFHLEdBQUgsR0FBRyxDQUEwQjtJQUNwQyxDQUFDO0lBRUosSUFBSSxDQUFDLEdBQVcsRUFBRSxRQUFnQixFQUFFO1FBQ2xDLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsdUJBQXVCLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDakUsTUFBTSxZQUFZLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFbkQsWUFBWSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBQ2hDLFlBQVksQ0FBQyxRQUFRLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNwQyxZQUFZLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQzFDLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM5QyxZQUFZLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDekIsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDOUMsTUFBTSxPQUFPLEdBQUksWUFBWSxDQUFDLFFBQWlDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBZ0IsQ0FBQztRQUM1RixRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNyQyxDQUFDOytHQXJCVSxZQUFZO21IQUFaLFlBQVksY0FEQyxNQUFNOzs0RkFDbkIsWUFBWTtrQkFEeEIsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHBsaWNhdGlvblJlZiwgQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLCBFbWJlZGRlZFZpZXdSZWYsIEluamVjdGFibGUsIEluamVjdG9yLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1vZGFsQ29tcG9uZW50IH0gZnJvbSBcIi4uLy4uL2NvbXBvbmVudHMvdWljb21wb25lbnQvbW9kYWwvbW9kYWwuY29tcG9uZW50XCI7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgTW9kYWxTZXJ2aWNlIHtcbiAgICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGluamVjdG9yOiBJbmplY3RvcixcbiAgICBwcml2YXRlIGFwcFJlZjogQXBwbGljYXRpb25SZWYsXG4gICAgcHJpdmF0ZSBjZnI6IENvbXBvbmVudEZhY3RvcnlSZXNvbHZlclxuICApIHt9XG5cbiAgb3Blbih1cmw6IHN0cmluZywgdGl0bGU6IHN0cmluZyA9ICcnKSB7XG4gICAgY29uc3QgZmFjdG9yeSA9IHRoaXMuY2ZyLnJlc29sdmVDb21wb25lbnRGYWN0b3J5KE1vZGFsQ29tcG9uZW50KTtcbiAgICBjb25zdCBjb21wb25lbnRSZWYgPSBmYWN0b3J5LmNyZWF0ZSh0aGlzLmluamVjdG9yKTtcblxuICAgIGNvbXBvbmVudFJlZi5pbnN0YW5jZS51cmwgPSB1cmw7XG4gICAgY29tcG9uZW50UmVmLmluc3RhbmNlLnRpdGxlID0gdGl0bGU7XG4gICAgY29tcG9uZW50UmVmLmluc3RhbmNlLmNsb3NlZC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5hcHBSZWYuZGV0YWNoVmlldyhjb21wb25lbnRSZWYuaG9zdFZpZXcpO1xuICAgICAgY29tcG9uZW50UmVmLmRlc3Ryb3koKTtcbiAgICB9KTtcblxuICAgIHRoaXMuYXBwUmVmLmF0dGFjaFZpZXcoY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcbiAgICBjb25zdCBkb21FbGVtID0gKGNvbXBvbmVudFJlZi5ob3N0VmlldyBhcyBFbWJlZGRlZFZpZXdSZWY8YW55Pikucm9vdE5vZGVzWzBdIGFzIEhUTUxFbGVtZW50O1xuICAgIGRvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQoZG9tRWxlbSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -4,13 +4,16 @@ import { UIActionType } from '../uitheme/enums/uiaction-type';
|
|
|
4
4
|
import { resolveSduiUrl, isSduiUrl } from '../utils/url-parser.util';
|
|
5
5
|
import { SDUI_URL_PARAM } from '../view-models/uiscreen.viewmodel';
|
|
6
6
|
import { UIActionHandlersService } from './ui-action-handlers.service';
|
|
7
|
+
import { ModalService } from './modal.service';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@angular/router";
|
|
9
10
|
import * as i2 from "./ui-action-handlers.service";
|
|
11
|
+
import * as i3 from "./modal.service";
|
|
10
12
|
export class UIActionService {
|
|
11
|
-
constructor(router, actionHandlers) {
|
|
13
|
+
constructor(router, actionHandlers, modalService) {
|
|
12
14
|
this.router = router;
|
|
13
15
|
this.actionHandlers = actionHandlers;
|
|
16
|
+
this.modalService = modalService;
|
|
14
17
|
}
|
|
15
18
|
execute(action) {
|
|
16
19
|
if (!action || !action.type)
|
|
@@ -48,6 +51,12 @@ export class UIActionService {
|
|
|
48
51
|
if (action.url) {
|
|
49
52
|
window.open(action.url, '_blank');
|
|
50
53
|
}
|
|
54
|
+
break;
|
|
55
|
+
case UIActionType.WEBVIEW_URL:
|
|
56
|
+
if (action.url) {
|
|
57
|
+
const modal = this.modalService.open(action.url);
|
|
58
|
+
}
|
|
59
|
+
break;
|
|
51
60
|
// Outros tipos de ação podem ser adicionados aqui
|
|
52
61
|
}
|
|
53
62
|
}
|
|
@@ -118,11 +127,11 @@ export class UIActionService {
|
|
|
118
127
|
}
|
|
119
128
|
return false; // nenhum dos casos especiais foi tratado
|
|
120
129
|
}
|
|
121
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UIActionService, deps: [{ token: i1.Router }, { token: i2.UIActionHandlersService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
130
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UIActionService, deps: [{ token: i1.Router }, { token: i2.UIActionHandlersService }, { token: i3.ModalService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
122
131
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UIActionService, providedIn: 'root' }); }
|
|
123
132
|
}
|
|
124
133
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UIActionService, decorators: [{
|
|
125
134
|
type: Injectable,
|
|
126
135
|
args: [{ providedIn: 'root' }]
|
|
127
|
-
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.UIActionHandlersService }] });
|
|
128
|
-
//# 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';\n\n@Injectable({ providedIn: 'root' })\nexport class UIActionService {\n  constructor(private router: Router,\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          this.handleCustomNavigation(action.url || '');\n        }\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\n       case UIActionType.EXTERNAL_URL:\n        if (action.url) {\n          window.open(action.url, '_blank');\n        }\n\n      // Outros tipos de ação podem ser adicionados aqui\n    }\n  }\n\n  private handleCustomNavigation(url: string): boolean {\n    if (url.includes('timeline/')) {\n      const broken = url.split('timeline/')[1];\n      this.router.navigate(['comunidade', 'postagem', broken], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if (url.includes('live/')) {\n      const broken = url.split('live/')[1];\n      this.router.navigate(['comunidade', 'postagem', 'live', broken], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if (url.includes('lesson/')) {\n      const lessonId = url.split('lesson/')[1];\n      const productId = url.includes('product/') ? url.split('product/')[1].split('/')[0] : null;\n      if (productId) {\n        this.router.navigate(['produtos', productId, 'aula', lessonId], { queryParams: { from: 'sdui' } });\n        return true;\n      }\n    }\n\n    if (url.includes('product/')) {\n      const productId = url.split('product/')[1];\n      this.router.navigate(['produtos', productId], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if (url.includes('posts/')) {\n      const postId = url.split('posts/')[1];\n      this.router.navigate(['comunidade', 'postagem', postId], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('my-purchases')) {\n      this.router.navigate(['perfil','compras'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('my-annotations')) {\n      this.router.navigate(['perfil','meu-caderno'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('my-list')) {\n      this.router.navigate(['perfil','minha-lista'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('my-certificates')) {\n      this.router.navigate(['perfil','certificados'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n    if(url.includes('my-subscriptions')) {\n      this.router.navigate(['perfil','assinaturas'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('edit-profile')){\n      this.router.navigate(['perfil','editar'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('ranking')){\n      this.router.navigate(['perfil','ranking'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('ranking/rules')){\n      this.router.navigate(['perfil','ranking','regras'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('logout')){\n      this.router.navigate(['logout'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    return false; // nenhum dos casos especiais foi tratado\n  }\n}\n"]}
|
|
136
|
+
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.UIActionHandlersService }, { type: i3.ModalService }] });
|
|
137
|
+
//# 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 actionHandlers: UIActionHandlersService,\n              private modalService: ModalService\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          this.handleCustomNavigation(action.url || '');\n        }\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\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      // Outros tipos de ação podem ser adicionados aqui\n    }\n  }\n\n  private handleCustomNavigation(url: string): boolean {\n    if (url.includes('timeline/')) {\n      const broken = url.split('timeline/')[1];\n      this.router.navigate(['comunidade', 'postagem', broken], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if (url.includes('live/')) {\n      const broken = url.split('live/')[1];\n      this.router.navigate(['comunidade', 'postagem', 'live', broken], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if (url.includes('lesson/')) {\n      const lessonId = url.split('lesson/')[1];\n      const productId = url.includes('product/') ? url.split('product/')[1].split('/')[0] : null;\n      if (productId) {\n        this.router.navigate(['produtos', productId, 'aula', lessonId], { queryParams: { from: 'sdui' } });\n        return true;\n      }\n    }\n\n    if (url.includes('product/')) {\n      const productId = url.split('product/')[1];\n      this.router.navigate(['produtos', productId], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if (url.includes('posts/')) {\n      const postId = url.split('posts/')[1];\n      this.router.navigate(['comunidade', 'postagem', postId], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('my-purchases')) {\n      this.router.navigate(['perfil','compras'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('my-annotations')) {\n      this.router.navigate(['perfil','meu-caderno'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('my-list')) {\n      this.router.navigate(['perfil','minha-lista'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('my-certificates')) {\n      this.router.navigate(['perfil','certificados'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n    if(url.includes('my-subscriptions')) {\n      this.router.navigate(['perfil','assinaturas'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('edit-profile')){\n      this.router.navigate(['perfil','editar'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('ranking')){\n      this.router.navigate(['perfil','ranking'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('ranking/rules')){\n      this.router.navigate(['perfil','ranking','regras'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    if(url.includes('logout')){\n      this.router.navigate(['logout'], { queryParams: { from: 'sdui' } });\n      return true;\n    }\n\n    return false; // nenhum dos casos especiais foi tratado\n  }\n}\n"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { UIAspectType } from "../enums/uiaspect-type";
|
|
2
|
+
export const aspectMapping = {
|
|
3
|
+
[UIAspectType.FILL]: 'cover',
|
|
4
|
+
[UIAspectType.FIT]: 'contain',
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNwZWN0LW1hcHBpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NkdWkvc3JjL2xpYi9jb3JlL3VpdGhlbWUvbWFwcGluZy9hc3BlY3QtbWFwcGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFdEQsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFpQztJQUN6RCxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsRUFBRSxPQUFPO0lBQzVCLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFNBQVM7Q0FDOUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVJQXNwZWN0VHlwZSB9IGZyb20gXCIuLi9lbnVtcy91aWFzcGVjdC10eXBlXCI7XG5cbmV4cG9ydCBjb25zdCBhc3BlY3RNYXBwaW5nOiBSZWNvcmQ8VUlBc3BlY3RUeXBlLCBzdHJpbmc+ID0ge1xuICBbVUlBc3BlY3RUeXBlLkZJTExdOiAnY292ZXInLFxuICBbVUlBc3BlY3RUeXBlLkZJVF06ICdjb250YWluJyxcbn1cbiJdfQ==
|
|
@@ -10,7 +10,6 @@ import { justifyMapping } from '../core/uitheme/mapping/justify-mapping';
|
|
|
10
10
|
import { Router } from '@angular/router';
|
|
11
11
|
import { UIScreenViewModel } from '../core/view-models/uiscreen.viewmodel';
|
|
12
12
|
import { UIActionService } from '../core/services/ui-action.service';
|
|
13
|
-
import { UIRadiusLevel } from '../core/uitheme/enums/uiradius-level';
|
|
14
13
|
import * as i0 from "@angular/core";
|
|
15
14
|
import * as i1 from "@angular/router";
|
|
16
15
|
import * as i2 from "../core/services/ui-action.service";
|
|
@@ -120,37 +119,22 @@ export class UIViewDirective {
|
|
|
120
119
|
}
|
|
121
120
|
}
|
|
122
121
|
applyRadius(uiRadius) {
|
|
123
|
-
let circle = false;
|
|
124
122
|
if (uiRadius.topLeft) {
|
|
125
123
|
const radius = radiusMapping[uiRadius.topLeft];
|
|
126
|
-
if (uiRadius.topLeft === UIRadiusLevel.R50) {
|
|
127
|
-
circle = true;
|
|
128
|
-
}
|
|
129
124
|
this.renderer.setStyle(this.elementRef.nativeElement, 'border-top-left-radius', radius);
|
|
130
125
|
}
|
|
131
126
|
if (uiRadius.topRight) {
|
|
132
127
|
const radius = radiusMapping[uiRadius.topRight];
|
|
133
|
-
if (uiRadius.topRight === UIRadiusLevel.R50) {
|
|
134
|
-
circle = true;
|
|
135
|
-
}
|
|
136
128
|
this.renderer.setStyle(this.elementRef.nativeElement, 'border-top-right-radius', radius);
|
|
137
129
|
}
|
|
138
130
|
if (uiRadius.bottomLeft) {
|
|
139
131
|
const radius = radiusMapping[uiRadius.bottomLeft];
|
|
140
|
-
if (uiRadius.bottomLeft === UIRadiusLevel.R50) {
|
|
141
|
-
circle = true;
|
|
142
|
-
}
|
|
143
132
|
this.renderer.setStyle(this.elementRef.nativeElement, 'border-bottom-left-radius', radius);
|
|
144
133
|
}
|
|
145
134
|
if (uiRadius.bottomRight) {
|
|
146
135
|
const radius = radiusMapping[uiRadius.bottomRight];
|
|
147
|
-
if (uiRadius.bottomRight === UIRadiusLevel.R50) {
|
|
148
|
-
circle = true;
|
|
149
|
-
}
|
|
150
136
|
this.renderer.setStyle(this.elementRef.nativeElement, 'border-bottom-right-radius', radius);
|
|
151
137
|
}
|
|
152
|
-
if (!circle)
|
|
153
|
-
this.renderer.setStyle(this.elementRef.nativeElement, 'overflow', 'hidden');
|
|
154
138
|
}
|
|
155
139
|
applySpacing(uiSpacing) {
|
|
156
140
|
if (uiSpacing.spacing) {
|
|
@@ -216,4 +200,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
216
200
|
type: HostListener,
|
|
217
201
|
args: ['click', ['$event']]
|
|
218
202
|
}] } });
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiview.directive.js","sourceRoot":"","sources":["../../../../../../libs/sdui/src/lib/directives/uiview.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Host,\n  HostListener,\n  Input,\n  OnChanges,\n  Optional,\n  Renderer2,\n  SimpleChanges,\n} from '@angular/core';\nimport { UIView } from '../core/uicomposition/models/uiview';\nimport { UIPadding } from '../core/uitheme/models/uipadding';\nimport { UIBackground } from '../core/uitheme/models/uibackground';\nimport { UIAction } from '../core/uitheme/models/uiaction';\nimport { UIAlignment } from '../core/uitheme/models/uialignment';\nimport { UIShadow } from '../core/uitheme/models/uishadow';\nimport { UIRadius } from '../core/uitheme/models/uiradius';\nimport { UISpacing } from '../core/uitheme/models/uispacing';\nimport { UIColor } from '../core/uitheme/enums/uicolor';\nimport { UIJustify } from '../core/uitheme/enums/uijustify';\nimport { UIDimension } from '../core/uitheme/enums/uidimension';\nimport { spaceMapping } from '../core/uitheme/mapping/space-mapping';\nimport { colorMapping } from '../core/uitheme/mapping/color-mapping';\nimport { padMapping } from '../core/uitheme/mapping/pad-mapping';\nimport { radiusMapping } from '../core/uitheme/mapping/radius-mapping';\nimport { alignmentMapping } from '../core/uitheme/mapping/alignment-mapping';\nimport { dimensionMapping } from '../core/uitheme/mapping/dimension-mapping';\nimport { shadowOffsetMapping, shadowBlurRadiusMapping } from '../core/uitheme/mapping/shadow-mapping';\nimport { justifyMapping } from '../core/uitheme/mapping/justify-mapping';\nimport { Router } from '@angular/router';\nimport { UIScreenViewModel } from '../core/view-models/uiscreen.viewmodel';\nimport { UIActionService } from '../core/services/ui-action.service';\nimport { UIRadiusLevel } from '../core/uitheme/enums/uiradius-level';\n\n@Directive({\n  selector: '[edmSduiView]',\n  standalone: false,\n})\nexport class UIViewDirective implements OnChanges {\n  @Input() edmSduiView?: UIView;\n  @Input() disableClick: boolean = false;\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private router: Router,\n    private actionService: UIActionService,\n    @Optional() private screenViewModel: UIScreenViewModel\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.edmSduiView) {\n      this.applyStyles(this.edmSduiView);\n    }\n  }\n\n  private applyStyles(uiView: UIView) {\n    if (uiView.padding) {\n      this.applyPadding(uiView.padding);\n    }\n\n    if (uiView.background) {\n      this.applyBackground(uiView.background);\n    }\n\n    if (uiView.action) {\n      this.applyAction(uiView.action);\n    }\n\n    if (uiView.alignment) {\n      this.applyAlignment(uiView.alignment);\n    }\n\n    if (uiView.shadow) {\n      this.applyShadow(uiView.shadow);\n    }\n\n    if (uiView.radius) {\n      this.applyRadius(uiView.radius);\n    }\n\n    if (uiView.spacing) {\n      this.applySpacing(uiView.spacing);\n    }\n\n    if (uiView.height) {\n      this.applyHeight(uiView.height);\n    }\n\n    if (uiView.width) {\n      this.applyWidth(uiView.width);\n    }\n\n    if (uiView.borderWidth) {\n      this.applyBorderWidth(uiView.borderWidth);\n    }\n\n    if (uiView.borderColor) {\n      this.applyBorderColor(uiView.borderColor);\n    }\n\n    if (uiView.justify) {\n      this.applyJustify(uiView.justify);\n    }\n  }\n\n  private applyPadding(uiPadding: UIPadding) {\n    if (uiPadding.top) {\n      const padValue = padMapping[uiPadding.top];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'padding-top',\n        padValue\n      );\n    }\n    if (uiPadding.left) {\n      const padValue = padMapping[uiPadding.left];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'padding-left',\n        padValue\n      );\n    }\n    if (uiPadding.right) {\n      const padValue = padMapping[uiPadding.right];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'padding-right',\n        padValue\n      );\n    }\n    if (uiPadding.bottom) {\n      const padValue = padMapping[uiPadding.bottom];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'padding-bottom',\n        padValue\n      );\n    }\n  }\n\n  private applyBackground(uiBackground: UIBackground) {\n    if (uiBackground.backgroundColor) {\n      const backgroundColor = colorMapping[uiBackground.backgroundColor];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'background-color',\n        backgroundColor\n      );\n    }\n  }\n\n  private applyAction(uiAction: UIAction) {\n    if (this.disableClick) {\n      return;\n    }\n\n    this.renderer.setStyle(this.elementRef.nativeElement, 'cursor', 'pointer');\n  }\n\n  private applyAlignment(uiAlignment: UIAlignment) {\n    if (uiAlignment.alignment) {\n      // console.debug('alignment:', uiAlignment.alignment);\n      const alignment = alignmentMapping[uiAlignment.alignment];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'align-items',\n        alignment\n      );\n    }\n  }\n\n  private applyShadow(uiShadow: UIShadow) {\n    if (uiShadow.color && uiShadow.offsetX && uiShadow.offsetY && uiShadow.blurRadius) {\n      const color = colorMapping[uiShadow.color];\n      const offsetX = shadowOffsetMapping[uiShadow.offsetX];\n      const offsetY = shadowOffsetMapping[uiShadow.offsetY];\n      const blurRadius = shadowBlurRadiusMapping[uiShadow.blurRadius];\n      const opacity = uiShadow.opacity !== undefined ? uiShadow.opacity : 1;\n\n      // Format: box-shadow: offsetX offsetY blurRadius color\n      const shadowValue = `${offsetX} ${offsetY} ${blurRadius} ${color}`;\n\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'box-shadow',\n        shadowValue\n      );\n\n      if (opacity !== 1) {\n        this.renderer.setStyle(\n          this.elementRef.nativeElement,\n          'opacity',\n          opacity.toString()\n        );\n      }\n    }\n  }\n\n  private applyRadius(uiRadius: UIRadius) {\n\n    let circle = false;\n\n    if (uiRadius.topLeft) {\n      const radius = radiusMapping[uiRadius.topLeft];\n      if(uiRadius.topLeft === UIRadiusLevel.R50){\n        circle = true;\n      }\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-top-left-radius',\n        radius\n      );\n    }\n\n    if (uiRadius.topRight) {\n      const radius = radiusMapping[uiRadius.topRight];\n      if(uiRadius.topRight === UIRadiusLevel.R50){\n        circle = true;\n      }\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-top-right-radius',\n        radius\n      );\n    }\n\n    if (uiRadius.bottomLeft) {\n      const radius = radiusMapping[uiRadius.bottomLeft];\n      if(uiRadius.bottomLeft === UIRadiusLevel.R50){\n        circle = true;\n      }\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-bottom-left-radius',\n        radius\n      );\n    }\n\n    if (uiRadius.bottomRight) {\n      const radius = radiusMapping[uiRadius.bottomRight];\n      if(uiRadius.bottomRight === UIRadiusLevel.R50){\n        circle = true;\n      }\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-bottom-right-radius',\n        radius\n      );\n    }\n    if(!circle) this.renderer.setStyle( this.elementRef.nativeElement, 'overflow', 'hidden');\n  }\n\n  private applySpacing(uiSpacing: UISpacing) {\n    if (uiSpacing.spacing) {\n      const spacingValue = spaceMapping[uiSpacing.spacing];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'gap',\n        spacingValue\n      );\n    }\n  }\n\n  private applyHeight(height: UIDimension) {\n    if (height) {\n      const heightValue = dimensionMapping[height];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'height',\n        heightValue\n      );\n    }\n  }\n\n  private applyWidth(width: UIDimension) {\n    if (width) {\n      const widthValue = dimensionMapping[width];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'width',\n        widthValue\n      );\n    }\n  }\n\n  private applyBorderWidth(borderWidth: number) {\n    if (borderWidth !== null && borderWidth !== undefined) {\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-width',\n        `${borderWidth}px`\n      );\n\n      // Ensure border style is set, otherwise border-width won't be visible\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-style',\n        'solid'\n      );\n    }\n  }\n\n  private applyBorderColor(borderColor: UIColor) {\n    if (borderColor) {\n      const color = colorMapping[borderColor];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-color',\n        color\n      );\n    }\n  }\n\n  private applyJustify(justify: UIJustify) {\n    if (justify) {\n      const justifyValue = justifyMapping[justify];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'justify-content',\n        justifyValue\n      );\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  onClick(event: Event): void {\n    if (this.disableClick) return;\n\n    if (this.edmSduiView?.action) {\n      event.stopPropagation();\n      this.actionService.execute(this.edmSduiView.action);\n    }\n  }\n}\n"]}
|
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiview.directive.js","sourceRoot":"","sources":["../../../../../../libs/sdui/src/lib/directives/uiview.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Host,\n  HostListener,\n  Input,\n  OnChanges,\n  Optional,\n  Renderer2,\n  SimpleChanges,\n} from '@angular/core';\nimport { UIView } from '../core/uicomposition/models/uiview';\nimport { UIPadding } from '../core/uitheme/models/uipadding';\nimport { UIBackground } from '../core/uitheme/models/uibackground';\nimport { UIAction } from '../core/uitheme/models/uiaction';\nimport { UIAlignment } from '../core/uitheme/models/uialignment';\nimport { UIShadow } from '../core/uitheme/models/uishadow';\nimport { UIRadius } from '../core/uitheme/models/uiradius';\nimport { UISpacing } from '../core/uitheme/models/uispacing';\nimport { UIColor } from '../core/uitheme/enums/uicolor';\nimport { UIJustify } from '../core/uitheme/enums/uijustify';\nimport { UIDimension } from '../core/uitheme/enums/uidimension';\nimport { spaceMapping } from '../core/uitheme/mapping/space-mapping';\nimport { colorMapping } from '../core/uitheme/mapping/color-mapping';\nimport { padMapping } from '../core/uitheme/mapping/pad-mapping';\nimport { radiusMapping } from '../core/uitheme/mapping/radius-mapping';\nimport { alignmentMapping } from '../core/uitheme/mapping/alignment-mapping';\nimport { dimensionMapping } from '../core/uitheme/mapping/dimension-mapping';\nimport { shadowOffsetMapping, shadowBlurRadiusMapping } from '../core/uitheme/mapping/shadow-mapping';\nimport { justifyMapping } from '../core/uitheme/mapping/justify-mapping';\nimport { Router } from '@angular/router';\nimport { UIScreenViewModel } from '../core/view-models/uiscreen.viewmodel';\nimport { UIActionService } from '../core/services/ui-action.service';\nimport { UIRadiusLevel } from '../core/uitheme/enums/uiradius-level';\n\n@Directive({\n  selector: '[edmSduiView]',\n  standalone: false,\n})\nexport class UIViewDirective implements OnChanges {\n  @Input() edmSduiView?: UIView;\n  @Input() disableClick: boolean = false;\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private router: Router,\n    private actionService: UIActionService,\n    @Optional() private screenViewModel: UIScreenViewModel\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.edmSduiView) {\n      this.applyStyles(this.edmSduiView);\n    }\n  }\n\n  private applyStyles(uiView: UIView) {\n    if (uiView.padding) {\n      this.applyPadding(uiView.padding);\n    }\n\n    if (uiView.background) {\n      this.applyBackground(uiView.background);\n    }\n\n    if (uiView.action) {\n      this.applyAction(uiView.action);\n    }\n\n    if (uiView.alignment) {\n      this.applyAlignment(uiView.alignment);\n    }\n\n    if (uiView.shadow) {\n      this.applyShadow(uiView.shadow);\n    }\n\n    if (uiView.radius) {\n      this.applyRadius(uiView.radius);\n    }\n\n    if (uiView.spacing) {\n      this.applySpacing(uiView.spacing);\n    }\n\n    if (uiView.height) {\n      this.applyHeight(uiView.height);\n    }\n\n    if (uiView.width) {\n      this.applyWidth(uiView.width);\n    }\n\n    if (uiView.borderWidth) {\n      this.applyBorderWidth(uiView.borderWidth);\n    }\n\n    if (uiView.borderColor) {\n      this.applyBorderColor(uiView.borderColor);\n    }\n\n    if (uiView.justify) {\n      this.applyJustify(uiView.justify);\n    }\n  }\n\n  private applyPadding(uiPadding: UIPadding) {\n    if (uiPadding.top) {\n      const padValue = padMapping[uiPadding.top];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'padding-top',\n        padValue\n      );\n    }\n    if (uiPadding.left) {\n      const padValue = padMapping[uiPadding.left];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'padding-left',\n        padValue\n      );\n    }\n    if (uiPadding.right) {\n      const padValue = padMapping[uiPadding.right];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'padding-right',\n        padValue\n      );\n    }\n    if (uiPadding.bottom) {\n      const padValue = padMapping[uiPadding.bottom];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'padding-bottom',\n        padValue\n      );\n    }\n  }\n\n  private applyBackground(uiBackground: UIBackground) {\n    if (uiBackground.backgroundColor) {\n      const backgroundColor = colorMapping[uiBackground.backgroundColor];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'background-color',\n        backgroundColor\n      );\n    }\n  }\n\n  private applyAction(uiAction: UIAction) {\n    if (this.disableClick) {\n      return;\n    }\n\n    this.renderer.setStyle(this.elementRef.nativeElement, 'cursor', 'pointer');\n  }\n\n  private applyAlignment(uiAlignment: UIAlignment) {\n    if (uiAlignment.alignment) {\n      // console.debug('alignment:', uiAlignment.alignment);\n      const alignment = alignmentMapping[uiAlignment.alignment];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'align-items',\n        alignment\n      );\n    }\n  }\n\n  private applyShadow(uiShadow: UIShadow) {\n    if (uiShadow.color && uiShadow.offsetX && uiShadow.offsetY && uiShadow.blurRadius) {\n      const color = colorMapping[uiShadow.color];\n      const offsetX = shadowOffsetMapping[uiShadow.offsetX];\n      const offsetY = shadowOffsetMapping[uiShadow.offsetY];\n      const blurRadius = shadowBlurRadiusMapping[uiShadow.blurRadius];\n      const opacity = uiShadow.opacity !== undefined ? uiShadow.opacity : 1;\n\n      // Format: box-shadow: offsetX offsetY blurRadius color\n      const shadowValue = `${offsetX} ${offsetY} ${blurRadius} ${color}`;\n\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'box-shadow',\n        shadowValue\n      );\n\n      if (opacity !== 1) {\n        this.renderer.setStyle(\n          this.elementRef.nativeElement,\n          'opacity',\n          opacity.toString()\n        );\n      }\n    }\n  }\n\n  private applyRadius(uiRadius: UIRadius) {\n    if (uiRadius.topLeft) {\n      const radius = radiusMapping[uiRadius.topLeft];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-top-left-radius',\n        radius\n      );\n    }\n\n    if (uiRadius.topRight) {\n      const radius = radiusMapping[uiRadius.topRight];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-top-right-radius',\n        radius\n      );\n    }\n\n    if (uiRadius.bottomLeft) {\n      const radius = radiusMapping[uiRadius.bottomLeft];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-bottom-left-radius',\n        radius\n      );\n    }\n\n    if (uiRadius.bottomRight) {\n      const radius = radiusMapping[uiRadius.bottomRight];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-bottom-right-radius',\n        radius\n      );\n    }\n\n  }\n\n  private applySpacing(uiSpacing: UISpacing) {\n    if (uiSpacing.spacing) {\n      const spacingValue = spaceMapping[uiSpacing.spacing];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'gap',\n        spacingValue\n      );\n    }\n  }\n\n  private applyHeight(height: UIDimension) {\n    if (height) {\n      const heightValue = dimensionMapping[height];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'height',\n        heightValue\n      );\n    }\n  }\n\n  private applyWidth(width: UIDimension) {\n    if (width) {\n      const widthValue = dimensionMapping[width];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'width',\n        widthValue\n      );\n    }\n  }\n\n  private applyBorderWidth(borderWidth: number) {\n    if (borderWidth !== null && borderWidth !== undefined) {\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-width',\n        `${borderWidth}px`\n      );\n\n      // Ensure border style is set, otherwise border-width won't be visible\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-style',\n        'solid'\n      );\n    }\n  }\n\n  private applyBorderColor(borderColor: UIColor) {\n    if (borderColor) {\n      const color = colorMapping[borderColor];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'border-color',\n        color\n      );\n    }\n  }\n\n  private applyJustify(justify: UIJustify) {\n    if (justify) {\n      const justifyValue = justifyMapping[justify];\n      this.renderer.setStyle(\n        this.elementRef.nativeElement,\n        'justify-content',\n        justifyValue\n      );\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  onClick(event: Event): void {\n    if (this.disableClick) return;\n\n    if (this.edmSduiView?.action) {\n      event.stopPropagation();\n      this.actionService.execute(this.edmSduiView.action);\n    }\n  }\n}\n"]}
|