@po-ui/ng-components 17.26.4 → 17.26.6
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/po-accordion/po-accordion-item-header/po-accordion-item-header.component.mjs +31 -13
- package/esm2022/lib/components/po-accordion/po-accordion-manager/po-accordion-manager.component.mjs +47 -12
- package/esm2022/lib/components/po-accordion/po-accordion.module.mjs +5 -4
- package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.mjs +2 -2
- package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.mjs +114 -3
- package/esm2022/lib/components/po-page/po-page-default/po-page-default-base.component.mjs +2 -2
- package/esm2022/lib/components/po-page/po-page-default/po-page-default.component.mjs +9 -1
- package/fesm2022/po-ui-ng-components.mjs +211 -41
- package/fesm2022/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-accordion/po-accordion-item-header/po-accordion-item-header.component.d.ts +2 -0
- package/lib/components/po-accordion/po-accordion-manager/po-accordion-manager.component.d.ts +8 -2
- package/lib/components/po-accordion/po-accordion.module.d.ts +2 -1
- package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.d.ts +1 -1
- package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.d.ts +7 -2
- package/lib/components/po-page/po-page-default/po-page-default-base.component.d.ts +1 -0
- package/lib/components/po-page/po-page-default/po-page-default.component.d.ts +2 -0
- package/package.json +4 -4
- package/po-ui-ng-components-17.26.6.tgz +0 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/v15/index.js +1 -1
- package/schematics/ng-update/v16/index.js +1 -1
- package/schematics/ng-update/v17/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/po-ui-ng-components-17.26.4.tgz +0 -0
|
@@ -5,16 +5,19 @@ import * as i1 from "../../../services/po-language";
|
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
6
6
|
import * as i3 from "../../po-tag/po-tag.component";
|
|
7
7
|
import * as i4 from "../../po-icon/po-icon.component";
|
|
8
|
+
import * as i5 from "../../../directives/po-tooltip/po-tooltip.directive";
|
|
8
9
|
const _c0 = ["accordionElement"];
|
|
9
|
-
|
|
10
|
-
|
|
10
|
+
const _c1 = ["accordionHeaderElement"];
|
|
11
|
+
function PoAccordionItemHeaderComponent_po_tag_7_Template(rf, ctx) { if (rf & 1) {
|
|
12
|
+
i0.ɵɵelement(0, "po-tag", 8);
|
|
11
13
|
} if (rf & 2) {
|
|
12
|
-
const
|
|
13
|
-
i0.ɵɵproperty("p-value",
|
|
14
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
15
|
+
i0.ɵɵproperty("p-value", ctx_r2.labelTag)("p-type", ctx_r2.typeTag);
|
|
14
16
|
} }
|
|
15
17
|
export class PoAccordionItemHeaderComponent {
|
|
16
18
|
language = poLocaleDefault;
|
|
17
19
|
accordionElement;
|
|
20
|
+
accordionHeaderElement;
|
|
18
21
|
expanded = false;
|
|
19
22
|
label;
|
|
20
23
|
labelTag;
|
|
@@ -28,38 +31,53 @@ export class PoAccordionItemHeaderComponent {
|
|
|
28
31
|
this.expanded = !this.expanded;
|
|
29
32
|
this.toggle.emit(this.expanded);
|
|
30
33
|
}
|
|
34
|
+
getTooltip() {
|
|
35
|
+
const widthContainer = this.accordionElement.nativeElement.offsetWidth - 56;
|
|
36
|
+
const widthHeaderElement = this.accordionHeaderElement.nativeElement.offsetWidth;
|
|
37
|
+
if (widthHeaderElement >= widthContainer) {
|
|
38
|
+
return this.label;
|
|
39
|
+
}
|
|
40
|
+
return null;
|
|
41
|
+
}
|
|
31
42
|
static ɵfac = function PoAccordionItemHeaderComponent_Factory(t) { return new (t || PoAccordionItemHeaderComponent)(i0.ɵɵdirectiveInject(i1.PoLanguageService)); };
|
|
32
43
|
static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoAccordionItemHeaderComponent, selectors: [["po-accordion-item-header"]], viewQuery: function PoAccordionItemHeaderComponent_Query(rf, ctx) { if (rf & 1) {
|
|
33
44
|
i0.ɵɵviewQuery(_c0, 7, ElementRef);
|
|
45
|
+
i0.ɵɵviewQuery(_c1, 7, ElementRef);
|
|
34
46
|
} if (rf & 2) {
|
|
35
47
|
let _t;
|
|
36
48
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.accordionElement = _t.first);
|
|
37
|
-
|
|
49
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.accordionHeaderElement = _t.first);
|
|
50
|
+
} }, inputs: { expanded: [i0.ɵɵInputFlags.None, "p-expanded", "expanded"], label: [i0.ɵɵInputFlags.None, "p-label", "label"], labelTag: [i0.ɵɵInputFlags.None, "p-label-tag", "labelTag"], typeTag: [i0.ɵɵInputFlags.None, "p-type-tag", "typeTag"], disabledItem: [i0.ɵɵInputFlags.None, "p-disabled", "disabledItem"] }, outputs: { toggle: "p-toggle" }, decls: 9, vars: 6, consts: [[1, "po-accordion-item-header"], [1, "po-accordion-item-header-button", "po-clickable", 3, "disabled", "click"], ["accordionElement", ""], [1, "po-accordion-item-header-button-content", 3, "p-tooltip"], [1, "po-text-ellipsis", "po-accordion-item-header-title"], ["accordionHeaderElement", ""], ["class", "po-accordion-item-header-tag", 3, "p-value", "p-type", 4, "ngIf"], ["p-icon", "ICON_ARROW_DOWN", 1, "po-icon", "po-accordion-item-header-icon"], [1, "po-accordion-item-header-tag", 3, "p-value", "p-type"]], template: function PoAccordionItemHeaderComponent_Template(rf, ctx) { if (rf & 1) {
|
|
38
51
|
i0.ɵɵelementStart(0, "div", 0)(1, "button", 1, 2);
|
|
39
52
|
i0.ɵɵlistener("click", function PoAccordionItemHeaderComponent_Template_button_click_1_listener() { return ctx.onClick(); });
|
|
40
|
-
i0.ɵɵelementStart(3, "div", 3)(4, "div", 4);
|
|
41
|
-
i0.ɵɵtext(
|
|
53
|
+
i0.ɵɵelementStart(3, "div", 3)(4, "div", 4, 5);
|
|
54
|
+
i0.ɵɵtext(6);
|
|
42
55
|
i0.ɵɵelementEnd();
|
|
43
|
-
i0.ɵɵtemplate(
|
|
56
|
+
i0.ɵɵtemplate(7, PoAccordionItemHeaderComponent_po_tag_7_Template, 1, 2, "po-tag", 6);
|
|
44
57
|
i0.ɵɵelementEnd();
|
|
45
|
-
i0.ɵɵelement(
|
|
58
|
+
i0.ɵɵelement(8, "po-icon", 7);
|
|
46
59
|
i0.ɵɵelementEnd()();
|
|
47
60
|
} if (rf & 2) {
|
|
48
61
|
i0.ɵɵadvance();
|
|
49
62
|
i0.ɵɵproperty("disabled", ctx.disabledItem);
|
|
50
63
|
i0.ɵɵattribute("aria-label", ctx.label)("aria-expanded", ctx.expanded || false);
|
|
51
|
-
i0.ɵɵadvance(
|
|
64
|
+
i0.ɵɵadvance(2);
|
|
65
|
+
i0.ɵɵproperty("p-tooltip", ctx.getTooltip());
|
|
66
|
+
i0.ɵɵadvance(3);
|
|
52
67
|
i0.ɵɵtextInterpolate(ctx.label);
|
|
53
68
|
i0.ɵɵadvance();
|
|
54
69
|
i0.ɵɵproperty("ngIf", ctx.labelTag);
|
|
55
|
-
} }, dependencies: [i2.NgIf, i3.PoTagComponent, i4.PoIconComponent], encapsulation: 2, changeDetection: 0 });
|
|
70
|
+
} }, dependencies: [i2.NgIf, i3.PoTagComponent, i4.PoIconComponent, i5.PoTooltipDirective], encapsulation: 2, changeDetection: 0 });
|
|
56
71
|
}
|
|
57
72
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoAccordionItemHeaderComponent, [{
|
|
58
73
|
type: Component,
|
|
59
|
-
args: [{ selector: 'po-accordion-item-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"po-accordion-item-header\">\n <button\n #accordionElement\n [disabled]=\"disabledItem\"\n [attr.aria-label]=\"label\"\n [attr.aria-expanded]=\"expanded || false\"\n class=\"po-accordion-item-header-button po-clickable\"\n (click)=\"onClick()\"\n >\n <div class=\"po-accordion-item-header-button-content\">\n <div class=\"po-text-ellipsis po-accordion-item-header-title\">{{ label }}</div>\n <po-tag *ngIf=\"labelTag\" class=\"po-accordion-item-header-tag\" [p-value]=\"labelTag\" [p-type]=\"typeTag\"> </po-tag>\n </div>\n <po-icon p-icon=\"ICON_ARROW_DOWN\" class=\"po-icon po-accordion-item-header-icon\"></po-icon>\n </button>\n</div>\n" }]
|
|
74
|
+
args: [{ selector: 'po-accordion-item-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"po-accordion-item-header\">\n <button\n #accordionElement\n [disabled]=\"disabledItem\"\n [attr.aria-label]=\"label\"\n [attr.aria-expanded]=\"expanded || false\"\n class=\"po-accordion-item-header-button po-clickable\"\n (click)=\"onClick()\"\n >\n <div class=\"po-accordion-item-header-button-content\" [p-tooltip]=\"getTooltip()\">\n <div #accordionHeaderElement class=\"po-text-ellipsis po-accordion-item-header-title\">{{ label }}</div>\n <po-tag *ngIf=\"labelTag\" class=\"po-accordion-item-header-tag\" [p-value]=\"labelTag\" [p-type]=\"typeTag\"> </po-tag>\n </div>\n <po-icon p-icon=\"ICON_ARROW_DOWN\" class=\"po-icon po-accordion-item-header-icon\"></po-icon>\n </button>\n</div>\n" }]
|
|
60
75
|
}], () => [{ type: i1.PoLanguageService }], { accordionElement: [{
|
|
61
76
|
type: ViewChild,
|
|
62
77
|
args: ['accordionElement', { read: ElementRef, static: true }]
|
|
78
|
+
}], accordionHeaderElement: [{
|
|
79
|
+
type: ViewChild,
|
|
80
|
+
args: ['accordionHeaderElement', { read: ElementRef, static: true }]
|
|
63
81
|
}], expanded: [{
|
|
64
82
|
type: Input,
|
|
65
83
|
args: ['p-expanded']
|
|
@@ -80,4 +98,4 @@ export class PoAccordionItemHeaderComponent {
|
|
|
80
98
|
args: ['p-toggle']
|
|
81
99
|
}] }); })();
|
|
82
100
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoAccordionItemHeaderComponent, { className: "PoAccordionItemHeaderComponent", filePath: "lib/components/po-accordion/po-accordion-item-header/po-accordion-item-header.component.ts", lineNumber: 10 }); })();
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tYWNjb3JkaW9uLWl0ZW0taGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1hY2NvcmRpb24vcG8tYWNjb3JkaW9uLWl0ZW0taGVhZGVyL3BvLWFjY29yZGlvbi1pdGVtLWhlYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tYWNjb3JkaW9uL3BvLWFjY29yZGlvbi1pdGVtLWhlYWRlci9wby1hY2NvcmRpb24taXRlbS1oZWFkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXZILE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvREFBb0QsQ0FBQzs7Ozs7Ozs7OztJQ1MvRSw0QkFBZ0g7OztJQUFsRCx5Q0FBb0IsMEJBQUE7O0FERnhGLE1BQU0sT0FBTyw4QkFBOEI7SUFDakMsUUFBUSxHQUFXLGVBQWUsQ0FBQztJQUV3QixnQkFBZ0IsQ0FBYTtJQUN2QixzQkFBc0IsQ0FBYTtJQUV2RixRQUFRLEdBQVksS0FBSyxDQUFDO0lBRTdCLEtBQUssQ0FBUztJQUVWLFFBQVEsQ0FBUztJQUVsQixPQUFPLENBQVM7SUFFaEIsWUFBWSxDQUFVO0lBRXZCLE1BQU0sR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO0lBRXpELFlBQVksZUFBa0M7UUFDNUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxlQUFlLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUNyRCxDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDO1FBRS9CLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQsVUFBVTtRQUNSLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsV0FBVyxHQUFHLEVBQUUsQ0FBQztRQUM1RSxNQUFNLGtCQUFrQixHQUFHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDO1FBRWpGLElBQUksa0JBQWtCLElBQUksY0FBYyxFQUFFO1lBQ3hDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztTQUNuQjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzt3RkFwQ1UsOEJBQThCOzZEQUE5Qiw4QkFBOEI7bUNBR0YsVUFBVTttQ0FDSixVQUFVOzs7Ozs7WUNiekQsOEJBQXNDLG1CQUFBO1lBT2xDLDJHQUFTLGFBQVMsSUFBQztZQUVuQiw4QkFBZ0YsZ0JBQUE7WUFDTyxZQUFXO1lBQUEsaUJBQU07WUFDdEcscUZBQWdIO1lBQ2xILGlCQUFNO1lBQ04sNkJBQTBGO1lBQzVGLGlCQUFTLEVBQUE7O1lBWFAsY0FBeUI7WUFBekIsMkNBQXlCO1lBQ3pCLHVDQUF5Qix3Q0FBQTtZQUs0QixlQUEwQjtZQUExQiw0Q0FBMEI7WUFDUSxlQUFXO1lBQVgsK0JBQVc7WUFDdkYsY0FBYztZQUFkLG1DQUFjOzs7aUZERmhCLDhCQUE4QjtjQUwxQyxTQUFTOzJCQUNFLDBCQUEwQixtQkFFbkIsdUJBQXVCLENBQUMsTUFBTTtrREFLb0IsZ0JBQWdCO2tCQUFsRixTQUFTO21CQUFDLGtCQUFrQixFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO1lBQ1Esc0JBQXNCO2tCQUE5RixTQUFTO21CQUFDLHdCQUF3QixFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO1lBRWxELFFBQVE7a0JBQTVCLEtBQUs7bUJBQUMsWUFBWTtZQUVELEtBQUs7a0JBQXRCLEtBQUs7bUJBQUMsU0FBUztZQUVNLFFBQVE7a0JBQTdCLEtBQUs7bUJBQUMsYUFBYTtZQUVDLE9BQU87a0JBQTNCLEtBQUs7bUJBQUMsWUFBWTtZQUVFLFlBQVk7a0JBQWhDLEtBQUs7bUJBQUMsWUFBWTtZQUVDLE1BQU07a0JBQXpCLE1BQU07bUJBQUMsVUFBVTs7a0ZBaEJQLDhCQUE4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQb0xhbmd1YWdlU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL3BvLWxhbmd1YWdlJztcbmltcG9ydCB7IHBvTG9jYWxlRGVmYXVsdCB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL3BvLWxhbmd1YWdlL3BvLWxhbmd1YWdlLmNvbnN0YW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncG8tYWNjb3JkaW9uLWl0ZW0taGVhZGVyJyxcbiAgdGVtcGxhdGVVcmw6ICdwby1hY2NvcmRpb24taXRlbS1oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBQb0FjY29yZGlvbkl0ZW1IZWFkZXJDb21wb25lbnQge1xuICBwcml2YXRlIGxhbmd1YWdlOiBzdHJpbmcgPSBwb0xvY2FsZURlZmF1bHQ7XG5cbiAgQFZpZXdDaGlsZCgnYWNjb3JkaW9uRWxlbWVudCcsIHsgcmVhZDogRWxlbWVudFJlZiwgc3RhdGljOiB0cnVlIH0pIGFjY29yZGlvbkVsZW1lbnQ6IEVsZW1lbnRSZWY7XG4gIEBWaWV3Q2hpbGQoJ2FjY29yZGlvbkhlYWRlckVsZW1lbnQnLCB7IHJlYWQ6IEVsZW1lbnRSZWYsIHN0YXRpYzogdHJ1ZSB9KSBhY2NvcmRpb25IZWFkZXJFbGVtZW50OiBFbGVtZW50UmVmO1xuXG4gIEBJbnB1dCgncC1leHBhbmRlZCcpIGV4cGFuZGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgQElucHV0KCdwLWxhYmVsJykgbGFiZWw6IHN0cmluZztcblxuICBASW5wdXQoJ3AtbGFiZWwtdGFnJykgbGFiZWxUYWc6IHN0cmluZztcblxuICBASW5wdXQoJ3AtdHlwZS10YWcnKSB0eXBlVGFnOiBzdHJpbmc7XG5cbiAgQElucHV0KCdwLWRpc2FibGVkJykgZGlzYWJsZWRJdGVtOiBib29sZWFuO1xuXG4gIEBPdXRwdXQoJ3AtdG9nZ2xlJykgdG9nZ2xlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xuXG4gIGNvbnN0cnVjdG9yKGxhbmd1YWdlU2VydmljZTogUG9MYW5ndWFnZVNlcnZpY2UpIHtcbiAgICB0aGlzLmxhbmd1YWdlID0gbGFuZ3VhZ2VTZXJ2aWNlLmdldFNob3J0TGFuZ3VhZ2UoKTtcbiAgfVxuXG4gIG9uQ2xpY2soKSB7XG4gICAgdGhpcy5leHBhbmRlZCA9ICF0aGlzLmV4cGFuZGVkO1xuXG4gICAgdGhpcy50b2dnbGUuZW1pdCh0aGlzLmV4cGFuZGVkKTtcbiAgfVxuXG4gIGdldFRvb2x0aXAoKSB7XG4gICAgY29uc3Qgd2lkdGhDb250YWluZXIgPSB0aGlzLmFjY29yZGlvbkVsZW1lbnQubmF0aXZlRWxlbWVudC5vZmZzZXRXaWR0aCAtIDU2O1xuICAgIGNvbnN0IHdpZHRoSGVhZGVyRWxlbWVudCA9IHRoaXMuYWNjb3JkaW9uSGVhZGVyRWxlbWVudC5uYXRpdmVFbGVtZW50Lm9mZnNldFdpZHRoO1xuXG4gICAgaWYgKHdpZHRoSGVhZGVyRWxlbWVudCA+PSB3aWR0aENvbnRhaW5lcikge1xuICAgICAgcmV0dXJuIHRoaXMubGFiZWw7XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwicG8tYWNjb3JkaW9uLWl0ZW0taGVhZGVyXCI+XG4gIDxidXR0b25cbiAgICAjYWNjb3JkaW9uRWxlbWVudFxuICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZEl0ZW1cIlxuICAgIFthdHRyLmFyaWEtbGFiZWxdPVwibGFiZWxcIlxuICAgIFthdHRyLmFyaWEtZXhwYW5kZWRdPVwiZXhwYW5kZWQgfHwgZmFsc2VcIlxuICAgIGNsYXNzPVwicG8tYWNjb3JkaW9uLWl0ZW0taGVhZGVyLWJ1dHRvbiBwby1jbGlja2FibGVcIlxuICAgIChjbGljayk9XCJvbkNsaWNrKClcIlxuICA+XG4gICAgPGRpdiBjbGFzcz1cInBvLWFjY29yZGlvbi1pdGVtLWhlYWRlci1idXR0b24tY29udGVudFwiIFtwLXRvb2x0aXBdPVwiZ2V0VG9vbHRpcCgpXCI+XG4gICAgICA8ZGl2ICNhY2NvcmRpb25IZWFkZXJFbGVtZW50IGNsYXNzPVwicG8tdGV4dC1lbGxpcHNpcyBwby1hY2NvcmRpb24taXRlbS1oZWFkZXItdGl0bGVcIj57eyBsYWJlbCB9fTwvZGl2PlxuICAgICAgPHBvLXRhZyAqbmdJZj1cImxhYmVsVGFnXCIgY2xhc3M9XCJwby1hY2NvcmRpb24taXRlbS1oZWFkZXItdGFnXCIgW3AtdmFsdWVdPVwibGFiZWxUYWdcIiBbcC10eXBlXT1cInR5cGVUYWdcIj4gPC9wby10YWc+XG4gICAgPC9kaXY+XG4gICAgPHBvLWljb24gcC1pY29uPVwiSUNPTl9BUlJPV19ET1dOXCIgY2xhc3M9XCJwby1pY29uIHBvLWFjY29yZGlvbi1pdGVtLWhlYWRlci1pY29uXCI+PC9wby1pY29uPlxuICA8L2J1dHRvbj5cbjwvZGl2PlxuIl19
|
package/esm2022/lib/components/po-accordion/po-accordion-manager/po-accordion-manager.component.mjs
CHANGED
|
@@ -1,36 +1,71 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/common";
|
|
4
4
|
import * as i2 from "../../po-icon/po-icon.component";
|
|
5
|
+
import * as i3 from "../../../directives/po-tooltip/po-tooltip.directive";
|
|
6
|
+
const _c0 = ["accordionHeaderButtonManagerElement"];
|
|
7
|
+
const _c1 = ["accordionHeaderManagerElement"];
|
|
5
8
|
export class PoAccordionManagerComponent {
|
|
9
|
+
labelValue = '';
|
|
10
|
+
changeDetector = inject(ChangeDetectorRef);
|
|
11
|
+
accordionElement;
|
|
12
|
+
accordionHeaderElement;
|
|
6
13
|
expandedAllItems = false;
|
|
7
14
|
literals;
|
|
8
15
|
clickManager = new EventEmitter();
|
|
16
|
+
ngOnChanges(changes) {
|
|
17
|
+
this.labelValue = changes.expandedAllItems.currentValue
|
|
18
|
+
? this.literals.closeAllItems
|
|
19
|
+
: this.literals.expandAllItems;
|
|
20
|
+
this.changeDetector.detectChanges();
|
|
21
|
+
}
|
|
9
22
|
onClick() {
|
|
10
23
|
this.clickManager.emit();
|
|
11
24
|
}
|
|
25
|
+
getTooltip() {
|
|
26
|
+
const widthContainer = this.accordionElement.nativeElement.offsetWidth - 69;
|
|
27
|
+
const widthHeaderElement = this.accordionHeaderElement.nativeElement.offsetWidth;
|
|
28
|
+
if (widthHeaderElement >= widthContainer) {
|
|
29
|
+
return this.labelValue;
|
|
30
|
+
}
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
12
33
|
static ɵfac = function PoAccordionManagerComponent_Factory(t) { return new (t || PoAccordionManagerComponent)(); };
|
|
13
|
-
static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoAccordionManagerComponent, selectors: [["po-accordion-manager"]],
|
|
14
|
-
i0.ɵɵ
|
|
34
|
+
static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoAccordionManagerComponent, selectors: [["po-accordion-manager"]], viewQuery: function PoAccordionManagerComponent_Query(rf, ctx) { if (rf & 1) {
|
|
35
|
+
i0.ɵɵviewQuery(_c0, 7, ElementRef);
|
|
36
|
+
i0.ɵɵviewQuery(_c1, 7, ElementRef);
|
|
37
|
+
} if (rf & 2) {
|
|
38
|
+
let _t;
|
|
39
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.accordionElement = _t.first);
|
|
40
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.accordionHeaderElement = _t.first);
|
|
41
|
+
} }, inputs: { expandedAllItems: [i0.ɵɵInputFlags.None, "p-expanded-all-items", "expandedAllItems"], literals: [i0.ɵɵInputFlags.None, "p-literals", "literals"] }, outputs: { clickManager: "p-click" }, features: [i0.ɵɵNgOnChangesFeature], decls: 7, vars: 4, consts: [[1, "po-accordion-manager-header"], [1, "po-accordion-manager-button", "po-clickable", 3, "p-tooltip", "click"], ["accordionHeaderButtonManagerElement", ""], [1, "po-text-ellipsis", "po-accordion-manager-button-content"], ["accordionHeaderManagerElement", ""], ["p-icon", "ICON_LAST_PAGE", 1, "po-icon", "po-accordion-manager-icon", 3, "ngClass"]], template: function PoAccordionManagerComponent_Template(rf, ctx) { if (rf & 1) {
|
|
42
|
+
i0.ɵɵelementStart(0, "div", 0)(1, "button", 1, 2);
|
|
15
43
|
i0.ɵɵlistener("click", function PoAccordionManagerComponent_Template_button_click_1_listener() { return ctx.onClick(); });
|
|
16
|
-
i0.ɵɵelementStart(
|
|
17
|
-
i0.ɵɵtext(
|
|
44
|
+
i0.ɵɵelementStart(3, "div", 3, 4);
|
|
45
|
+
i0.ɵɵtext(5);
|
|
18
46
|
i0.ɵɵelementEnd();
|
|
19
|
-
i0.ɵɵelement(
|
|
47
|
+
i0.ɵɵelement(6, "po-icon", 5);
|
|
20
48
|
i0.ɵɵelementEnd()();
|
|
21
49
|
} if (rf & 2) {
|
|
22
50
|
i0.ɵɵadvance();
|
|
51
|
+
i0.ɵɵproperty("p-tooltip", ctx.getTooltip());
|
|
23
52
|
i0.ɵɵattribute("aria-expanded", ctx.expandedAllItems);
|
|
24
|
-
i0.ɵɵadvance(
|
|
53
|
+
i0.ɵɵadvance(4);
|
|
25
54
|
i0.ɵɵtextInterpolate1(" ", ctx.expandedAllItems ? ctx.literals.closeAllItems : ctx.literals.expandAllItems, " ");
|
|
26
55
|
i0.ɵɵadvance();
|
|
27
56
|
i0.ɵɵproperty("ngClass", ctx.expandedAllItems ? "icon-down" : "icon-up");
|
|
28
|
-
} }, dependencies: [i1.NgClass, i2.PoIconComponent], encapsulation: 2 });
|
|
57
|
+
} }, dependencies: [i1.NgClass, i2.PoIconComponent, i3.PoTooltipDirective], encapsulation: 2 });
|
|
29
58
|
}
|
|
30
59
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoAccordionManagerComponent, [{
|
|
31
60
|
type: Component,
|
|
32
|
-
args: [{ selector: 'po-accordion-manager', template: "<div class=\"po-accordion-manager-header\">\n <button
|
|
33
|
-
}], null, {
|
|
61
|
+
args: [{ selector: 'po-accordion-manager', template: "<div class=\"po-accordion-manager-header\">\n <button\n #accordionHeaderButtonManagerElement\n class=\"po-accordion-manager-button po-clickable\"\n (click)=\"onClick()\"\n [attr.aria-expanded]=\"expandedAllItems\"\n [p-tooltip]=\"getTooltip()\"\n >\n <div #accordionHeaderManagerElement class=\"po-text-ellipsis po-accordion-manager-button-content\">\n {{ expandedAllItems ? literals.closeAllItems : literals.expandAllItems }}\n </div>\n <po-icon\n p-icon=\"ICON_LAST_PAGE\"\n [ngClass]=\"expandedAllItems ? 'icon-down' : 'icon-up'\"\n class=\"po-icon po-accordion-manager-icon\"\n >\n </po-icon>\n </button>\n</div>\n" }]
|
|
62
|
+
}], null, { accordionElement: [{
|
|
63
|
+
type: ViewChild,
|
|
64
|
+
args: ['accordionHeaderButtonManagerElement', { read: ElementRef, static: true }]
|
|
65
|
+
}], accordionHeaderElement: [{
|
|
66
|
+
type: ViewChild,
|
|
67
|
+
args: ['accordionHeaderManagerElement', { read: ElementRef, static: true }]
|
|
68
|
+
}], expandedAllItems: [{
|
|
34
69
|
type: Input,
|
|
35
70
|
args: ['p-expanded-all-items']
|
|
36
71
|
}], literals: [{
|
|
@@ -40,5 +75,5 @@ export class PoAccordionManagerComponent {
|
|
|
40
75
|
type: Output,
|
|
41
76
|
args: ['p-click']
|
|
42
77
|
}] }); })();
|
|
43
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoAccordionManagerComponent, { className: "PoAccordionManagerComponent", filePath: "lib/components/po-accordion/po-accordion-manager/po-accordion-manager.component.ts", lineNumber:
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoAccordionManagerComponent, { className: "PoAccordionManagerComponent", filePath: "lib/components/po-accordion/po-accordion-manager/po-accordion-manager.component.ts", lineNumber: 19 }); })();
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tYWNjb3JkaW9uLW1hbmFnZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLWFjY29yZGlvbi9wby1hY2NvcmRpb24tbWFuYWdlci9wby1hY2NvcmRpb24tbWFuYWdlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tYWNjb3JkaW9uL3BvLWFjY29yZGlvbi1tYW5hZ2VyL3BvLWFjY29yZGlvbi1tYW5hZ2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxpQkFBaUIsRUFDakIsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFFTCxNQUFNLEVBRU4sU0FBUyxFQUNWLE1BQU0sZUFBZSxDQUFDOzs7Ozs7O0FBT3ZCLE1BQU0sT0FBTywyQkFBMkI7SUFDdEMsVUFBVSxHQUFXLEVBQUUsQ0FBQztJQUN4QixjQUFjLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFFMkMsZ0JBQWdCLENBQWE7SUFDbkMsc0JBQXNCLENBQWE7SUFFcEYsZ0JBQWdCLEdBQVksS0FBSyxDQUFDO0lBRTVDLFFBQVEsQ0FBc0I7SUFFaEMsWUFBWSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7SUFFOUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDLGdCQUFnQixDQUFDLFlBQVk7WUFDckQsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYTtZQUM3QixDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUM7UUFDakMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN0QyxDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFVBQVU7UUFDUixNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxDQUFDLFdBQVcsR0FBRyxFQUFFLENBQUM7UUFDNUUsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQztRQUVqRixJQUFJLGtCQUFrQixJQUFJLGNBQWMsRUFBRTtZQUN4QyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7U0FDeEI7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7cUZBaENVLDJCQUEyQjs2REFBM0IsMkJBQTJCO21DQUlvQixVQUFVO21DQUNoQixVQUFVOzs7Ozs7WUN2QmhFLDhCQUF5QyxtQkFBQTtZQUlyQyx3R0FBUyxhQUFTLElBQUM7WUFJbkIsaUNBQWlHO1lBQy9GLFlBQ0Y7WUFBQSxpQkFBTTtZQUNOLDZCQUtVO1lBQ1osaUJBQVMsRUFBQTs7WUFYUCxjQUEwQjtZQUExQiw0Q0FBMEI7WUFEMUIscURBQXVDO1lBSXJDLGVBQ0Y7WUFERSxnSEFDRjtZQUdFLGNBQXNEO1lBQXRELHdFQUFzRDs7O2lGREsvQywyQkFBMkI7Y0FKdkMsU0FBUzsyQkFDRSxzQkFBc0I7Z0JBT3NELGdCQUFnQjtrQkFBckcsU0FBUzttQkFBQyxxQ0FBcUMsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtZQUNKLHNCQUFzQjtrQkFBckcsU0FBUzttQkFBQywrQkFBK0IsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtZQUUvQyxnQkFBZ0I7a0JBQTlDLEtBQUs7bUJBQUMsc0JBQXNCO1lBRVIsUUFBUTtrQkFBNUIsS0FBSzttQkFBQyxZQUFZO1lBRUEsWUFBWTtrQkFBOUIsTUFBTTttQkFBQyxTQUFTOztrRkFYTiwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBFdmVudEVtaXR0ZXIsXG4gIGluamVjdCxcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT3V0cHV0LFxuICBTaW1wbGVDaGFuZ2VzLFxuICBWaWV3Q2hpbGRcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQb0FjY29yZGlvbkxpdGVyYWxzIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9wby1hY2NvcmRpb24tbGl0ZXJhbHMuaW50ZXJmYWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncG8tYWNjb3JkaW9uLW1hbmFnZXInLFxuICB0ZW1wbGF0ZVVybDogJ3BvLWFjY29yZGlvbi1tYW5hZ2VyLmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBQb0FjY29yZGlvbk1hbmFnZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICBsYWJlbFZhbHVlOiBzdHJpbmcgPSAnJztcbiAgY2hhbmdlRGV0ZWN0b3IgPSBpbmplY3QoQ2hhbmdlRGV0ZWN0b3JSZWYpO1xuXG4gIEBWaWV3Q2hpbGQoJ2FjY29yZGlvbkhlYWRlckJ1dHRvbk1hbmFnZXJFbGVtZW50JywgeyByZWFkOiBFbGVtZW50UmVmLCBzdGF0aWM6IHRydWUgfSkgYWNjb3JkaW9uRWxlbWVudDogRWxlbWVudFJlZjtcbiAgQFZpZXdDaGlsZCgnYWNjb3JkaW9uSGVhZGVyTWFuYWdlckVsZW1lbnQnLCB7IHJlYWQ6IEVsZW1lbnRSZWYsIHN0YXRpYzogdHJ1ZSB9KSBhY2NvcmRpb25IZWFkZXJFbGVtZW50OiBFbGVtZW50UmVmO1xuXG4gIEBJbnB1dCgncC1leHBhbmRlZC1hbGwtaXRlbXMnKSBleHBhbmRlZEFsbEl0ZW1zOiBib29sZWFuID0gZmFsc2U7XG5cbiAgQElucHV0KCdwLWxpdGVyYWxzJykgbGl0ZXJhbHM6IFBvQWNjb3JkaW9uTGl0ZXJhbHM7XG5cbiAgQE91dHB1dCgncC1jbGljaycpIGNsaWNrTWFuYWdlciA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgdGhpcy5sYWJlbFZhbHVlID0gY2hhbmdlcy5leHBhbmRlZEFsbEl0ZW1zLmN1cnJlbnRWYWx1ZVxuICAgICAgPyB0aGlzLmxpdGVyYWxzLmNsb3NlQWxsSXRlbXNcbiAgICAgIDogdGhpcy5saXRlcmFscy5leHBhbmRBbGxJdGVtcztcbiAgICB0aGlzLmNoYW5nZURldGVjdG9yLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIG9uQ2xpY2soKSB7XG4gICAgdGhpcy5jbGlja01hbmFnZXIuZW1pdCgpO1xuICB9XG5cbiAgZ2V0VG9vbHRpcCgpIHtcbiAgICBjb25zdCB3aWR0aENvbnRhaW5lciA9IHRoaXMuYWNjb3JkaW9uRWxlbWVudC5uYXRpdmVFbGVtZW50Lm9mZnNldFdpZHRoIC0gNjk7XG4gICAgY29uc3Qgd2lkdGhIZWFkZXJFbGVtZW50ID0gdGhpcy5hY2NvcmRpb25IZWFkZXJFbGVtZW50Lm5hdGl2ZUVsZW1lbnQub2Zmc2V0V2lkdGg7XG5cbiAgICBpZiAod2lkdGhIZWFkZXJFbGVtZW50ID49IHdpZHRoQ29udGFpbmVyKSB7XG4gICAgICByZXR1cm4gdGhpcy5sYWJlbFZhbHVlO1xuICAgIH1cbiAgICByZXR1cm4gbnVsbDtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInBvLWFjY29yZGlvbi1tYW5hZ2VyLWhlYWRlclwiPlxuICA8YnV0dG9uXG4gICAgI2FjY29yZGlvbkhlYWRlckJ1dHRvbk1hbmFnZXJFbGVtZW50XG4gICAgY2xhc3M9XCJwby1hY2NvcmRpb24tbWFuYWdlci1idXR0b24gcG8tY2xpY2thYmxlXCJcbiAgICAoY2xpY2spPVwib25DbGljaygpXCJcbiAgICBbYXR0ci5hcmlhLWV4cGFuZGVkXT1cImV4cGFuZGVkQWxsSXRlbXNcIlxuICAgIFtwLXRvb2x0aXBdPVwiZ2V0VG9vbHRpcCgpXCJcbiAgPlxuICAgIDxkaXYgI2FjY29yZGlvbkhlYWRlck1hbmFnZXJFbGVtZW50IGNsYXNzPVwicG8tdGV4dC1lbGxpcHNpcyBwby1hY2NvcmRpb24tbWFuYWdlci1idXR0b24tY29udGVudFwiPlxuICAgICAge3sgZXhwYW5kZWRBbGxJdGVtcyA/IGxpdGVyYWxzLmNsb3NlQWxsSXRlbXMgOiBsaXRlcmFscy5leHBhbmRBbGxJdGVtcyB9fVxuICAgIDwvZGl2PlxuICAgIDxwby1pY29uXG4gICAgICBwLWljb249XCJJQ09OX0xBU1RfUEFHRVwiXG4gICAgICBbbmdDbGFzc109XCJleHBhbmRlZEFsbEl0ZW1zID8gJ2ljb24tZG93bicgOiAnaWNvbi11cCdcIlxuICAgICAgY2xhc3M9XCJwby1pY29uIHBvLWFjY29yZGlvbi1tYW5hZ2VyLWljb25cIlxuICAgID5cbiAgICA8L3BvLWljb24+XG4gIDwvYnV0dG9uPlxuPC9kaXY+XG4iXX0=
|
|
@@ -3,6 +3,7 @@ import { NgModule } from '@angular/core';
|
|
|
3
3
|
import { PoDividerModule } from '../po-divider';
|
|
4
4
|
import { PoIconModule } from '../po-icon';
|
|
5
5
|
import { PoTagModule } from '../po-tag';
|
|
6
|
+
import { PoTooltipModule } from '../../directives/po-tooltip/po-tooltip.module';
|
|
6
7
|
import { PoAccordionItemBodyComponent } from './po-accordion-item-body/po-accordion-item-body.component';
|
|
7
8
|
import { PoAccordionItemHeaderComponent } from './po-accordion-item-header/po-accordion-item-header.component';
|
|
8
9
|
import { PoAccordionItemComponent } from './po-accordion-item/po-accordion-item.component';
|
|
@@ -43,12 +44,12 @@ import * as i0 from "@angular/core";
|
|
|
43
44
|
export class PoAccordionModule {
|
|
44
45
|
static ɵfac = function PoAccordionModule_Factory(t) { return new (t || PoAccordionModule)(); };
|
|
45
46
|
static ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: PoAccordionModule });
|
|
46
|
-
static ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ imports: [CommonModule, PoTagModule, PoIconModule, PoDividerModule] });
|
|
47
|
+
static ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ imports: [CommonModule, PoTagModule, PoIconModule, PoDividerModule, PoTooltipModule] });
|
|
47
48
|
}
|
|
48
49
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoAccordionModule, [{
|
|
49
50
|
type: NgModule,
|
|
50
51
|
args: [{
|
|
51
|
-
imports: [CommonModule, PoTagModule, PoIconModule, PoDividerModule],
|
|
52
|
+
imports: [CommonModule, PoTagModule, PoIconModule, PoDividerModule, PoTooltipModule],
|
|
52
53
|
declarations: [
|
|
53
54
|
PoAccordionComponent,
|
|
54
55
|
PoAccordionItemBodyComponent,
|
|
@@ -63,5 +64,5 @@ export class PoAccordionModule {
|
|
|
63
64
|
PoAccordionItemBodyComponent,
|
|
64
65
|
PoAccordionItemComponent,
|
|
65
66
|
PoAccordionItemHeaderComponent,
|
|
66
|
-
PoAccordionManagerComponent], imports: [CommonModule, PoTagModule, PoIconModule, PoDividerModule], exports: [PoAccordionComponent, PoAccordionItemComponent] }); })();
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
PoAccordionManagerComponent], imports: [CommonModule, PoTagModule, PoIconModule, PoDividerModule, PoTooltipModule], exports: [PoAccordionComponent, PoAccordionItemComponent] }); })();
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tYWNjb3JkaW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1hY2NvcmRpb24vcG8tYWNjb3JkaW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDMUMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUN4QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFFaEYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sMkRBQTJELENBQUM7QUFDekcsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sK0RBQStELENBQUM7QUFDL0csT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDM0YsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDcEcsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBRWhFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E4Qkc7QUFZSCxNQUFNLE9BQU8saUJBQWlCOzJFQUFqQixpQkFBaUI7NERBQWpCLGlCQUFpQjtnRUFWbEIsWUFBWSxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFFLGVBQWU7O2lGQVV4RSxpQkFBaUI7Y0FYN0IsUUFBUTtlQUFDO2dCQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLGVBQWUsRUFBRSxlQUFlLENBQUM7Z0JBQ3BGLFlBQVksRUFBRTtvQkFDWixvQkFBb0I7b0JBQ3BCLDRCQUE0QjtvQkFDNUIsd0JBQXdCO29CQUN4Qiw4QkFBOEI7b0JBQzlCLDJCQUEyQjtpQkFDNUI7Z0JBQ0QsT0FBTyxFQUFFLENBQUMsb0JBQW9CLEVBQUUsd0JBQXdCLENBQUM7YUFDMUQ7O3dGQUNZLGlCQUFpQixtQkFSMUIsb0JBQW9CO1FBQ3BCLDRCQUE0QjtRQUM1Qix3QkFBd0I7UUFDeEIsOEJBQThCO1FBQzlCLDJCQUEyQixhQU5uQixZQUFZLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxlQUFlLEVBQUUsZUFBZSxhQVF6RSxvQkFBb0IsRUFBRSx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgUG9EaXZpZGVyTW9kdWxlIH0gZnJvbSAnLi4vcG8tZGl2aWRlcic7XG5pbXBvcnQgeyBQb0ljb25Nb2R1bGUgfSBmcm9tICcuLi9wby1pY29uJztcbmltcG9ydCB7IFBvVGFnTW9kdWxlIH0gZnJvbSAnLi4vcG8tdGFnJztcbmltcG9ydCB7IFBvVG9vbHRpcE1vZHVsZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMvcG8tdG9vbHRpcC9wby10b29sdGlwLm1vZHVsZSc7XG5cbmltcG9ydCB7IFBvQWNjb3JkaW9uSXRlbUJvZHlDb21wb25lbnQgfSBmcm9tICcuL3BvLWFjY29yZGlvbi1pdGVtLWJvZHkvcG8tYWNjb3JkaW9uLWl0ZW0tYm9keS5jb21wb25lbnQnO1xuaW1wb3J0IHsgUG9BY2NvcmRpb25JdGVtSGVhZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9wby1hY2NvcmRpb24taXRlbS1oZWFkZXIvcG8tYWNjb3JkaW9uLWl0ZW0taGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQb0FjY29yZGlvbkl0ZW1Db21wb25lbnQgfSBmcm9tICcuL3BvLWFjY29yZGlvbi1pdGVtL3BvLWFjY29yZGlvbi1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQb0FjY29yZGlvbk1hbmFnZXJDb21wb25lbnQgfSBmcm9tICcuL3BvLWFjY29yZGlvbi1tYW5hZ2VyL3BvLWFjY29yZGlvbi1tYW5hZ2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQb0FjY29yZGlvbkNvbXBvbmVudCB9IGZyb20gJy4vcG8tYWNjb3JkaW9uLmNvbXBvbmVudCc7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uXG4gKlxuICogTcOzZHVsbyBkbyBjb21wb25lbnRlIGBwby1hY2NvcmRpb25gLlxuICpcbiAqID4gUGFyYSBvIGNvcnJldG8gZnVuY2lvbmFtZW50byBkbyBjb21wb25lbnRlIGBwby1hY2NvcmRpb25gLCBkZXZlIHNlciBpbXBvcnRhZG8gbyBtw7NkdWxvIGBCcm93c2VyQW5pbWF0aW9uc01vZHVsZWAgbm9cbiAqID4gbcOzZHVsbyBwcmluY2lwYWwgZGEgc3VhIGFwbGljYcOnw6NvLlxuICpcbiAqIE3Ds2R1bG8gZGEgYXBsaWNhw6fDo286XG4gKiBgYGBcbiAqIGltcG9ydCB7IEJyb3dzZXJBbmltYXRpb25zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci9hbmltYXRpb25zJztcbiAqIGltcG9ydCB7IFBvTW9kdWxlIH0gZnJvbSAnQHBvLXVpL25nLWNvbXBvbmVudHMnO1xuICogLi4uXG4gKlxuICogQE5nTW9kdWxlKHtcbiAqICAgaW1wb3J0czogW1xuICogICAgIEJyb3dzZXJNb2R1bGUsXG4gKiAgICAgQnJvd3NlckFuaW1hdGlvbnNNb2R1bGUsXG4gKiAgICAgLi4uXG4gKiAgICAgUG9Nb2R1bGVcbiAqICAgXSxcbiAqICAgZGVjbGFyYXRpb25zOiBbXG4gKiAgICAgQXBwQ29tcG9uZW50LFxuICogICAgIC4uLlxuICogICBdLFxuICogICBwcm92aWRlcnM6IFtdLFxuICogICBib290c3RyYXA6IFtBcHBDb21wb25lbnRdXG4gKiB9KVxuICogZXhwb3J0IGNsYXNzIEFwcE1vZHVsZSB7IH1cbiAqIGBgYFxuICovXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBQb1RhZ01vZHVsZSwgUG9JY29uTW9kdWxlLCBQb0RpdmlkZXJNb2R1bGUsIFBvVG9vbHRpcE1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFBvQWNjb3JkaW9uQ29tcG9uZW50LFxuICAgIFBvQWNjb3JkaW9uSXRlbUJvZHlDb21wb25lbnQsXG4gICAgUG9BY2NvcmRpb25JdGVtQ29tcG9uZW50LFxuICAgIFBvQWNjb3JkaW9uSXRlbUhlYWRlckNvbXBvbmVudCxcbiAgICBQb0FjY29yZGlvbk1hbmFnZXJDb21wb25lbnRcbiAgXSxcbiAgZXhwb3J0czogW1BvQWNjb3JkaW9uQ29tcG9uZW50LCBQb0FjY29yZGlvbkl0ZW1Db21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIFBvQWNjb3JkaW9uTW9kdWxlIHt9XG4iXX0=
|
package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.mjs
CHANGED
|
@@ -45,7 +45,7 @@ export class PoDynamicFormBaseComponent {
|
|
|
45
45
|
* o `po-textarea`, caso o valor da propriedade `rows` seja menor que 3 o componente criado será o `po-input`.
|
|
46
46
|
* - Caso seja informada a propriedade `secret` o componente criado será o `po-password`.
|
|
47
47
|
* - Caso o *type* informado seja *string* o componente criado será o `po-input`.
|
|
48
|
-
*
|
|
48
|
+
* > Ao alterar o valor das `properties` e/ou agrupamentos via container, os `fields` que utilizam serviço podem refazer as chamadas para as API's.
|
|
49
49
|
* @default `[]`
|
|
50
50
|
*/
|
|
51
51
|
fields;
|
|
@@ -268,4 +268,4 @@ export class PoDynamicFormBaseComponent {
|
|
|
268
268
|
type: Input,
|
|
269
269
|
args: [{ alias: 'p-validate-on-input', transform: convertToBoolean }]
|
|
270
270
|
}] }); })();
|
|
271
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAIvD;;;;;;;GAOG;AAEH,MAAM,OAAO,0BAA0B;IACrC;;;;;;OAMG;IACoB,SAAS,CAAU;IAE1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACgB,MAAM,CAA4B;IAErD;;;;;;;OAOG;IACe,KAAK,CAAM;IAE7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAmDG;IACe,UAAU,GAAyB,IAAI,YAAY,EAAU,CAAC;IAEhF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACc,IAAI,CAAqB;IAE1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAuCG;IACkB,QAAQ,CAAqB;IAElD;;;;;;OAMG;IACyB,cAAc,CAAiB;IAEnD,UAAU,GAAa,KAAK,CAAC;IAErC;;;;;;;;;;;;;;;OAeG;IACH,IAA2B,SAAS,CAAC,KAAc;QACjD,IAAI,CAAC,UAAU,GAAQ,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACvE,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACmE,eAAe,GAAY,KAAK,CAAC;oFA3O5F,0BAA0B;6DAA1B,0BAA0B,whBA2Oa,gBAAgB;;iFA3OvD,0BAA0B;cADtC,SAAS;gBASe,SAAS;kBAA/B,KAAK;mBAAC,cAAc;YAgCF,MAAM;kBAAxB,KAAK;mBAAC,UAAU;YAUC,KAAK;kBAAtB,KAAK;mBAAC,SAAS;YAsDE,UAAU;kBAA3B,MAAM;mBAAC,QAAQ;YAkCC,IAAI;kBAApB,KAAK;mBAAC,QAAQ;YA0CM,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YASS,cAAc;kBAAzC,KAAK;mBAAC,mBAAmB;YAoBC,SAAS;kBAAnC,KAAK;mBAAC,cAAc;YA0BiD,eAAe;kBAApF,KAAK;mBAAC,EAAE,KAAK,EAAE,qBAAqB,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { Directive, EventEmitter, Input, Output } from '@angular/core';\nimport { NgForm } from '@angular/forms';\nimport { convertToBoolean } from '../../../utils/util';\n\nimport { PoDynamicFormField } from './po-dynamic-form-field.interface';\n\n/**\n *\n * @description\n *\n * Componente para criação de formulários dinâmicos a partir de uma lista de objetos.\n *\n * Também é possível verificar se o formulário está válido e informar valores para a exibição de informações.\n */\n@Directive()\nexport class PoDynamicFormBaseComponent {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Nome da propriedade, atribuída ao `PoDynamicFormField.property`, que iniciará o campo com foco.\n   */\n  @Input('p-auto-focus') autoFocus?: string;\n\n  /**\n   * @description\n   *\n   * Coleção de objetos que implementam a interface `PoDynamicFormField`, para definição dos campos que serão criados\n   * dinamicamente.\n   *\n   * > Ex: `[ { property: 'name' } ]`\n   *\n   * Regras de tipagem e criação dos componentes:\n   *\n   * - Caso o *type* informado seja *boolean* o componente criado será o `po-switch`.\n   * - Caso o *type* informado seja *currency* e não seja informado um *mask* ou *pattern* o componente criado será o `po-decimal`,\n   * caso seja informado um *mask* ou *pattern* o componente criado será o `po-input`.\n   * - Caso o *type* informado seja *number* e não seja informado um *mask* ou *pattern* o componente criado será o `po-number`, caso seja\n   * informado um *mask* ou *pattern* o componente criado será o `po-input`.\n   * - Caso a lista possua a propriedade `options` e a mesma possua até 3 itens o componente criado será o `po-radio-group`\n   * ou `po-checkbox-group` se informar a propriedade `optionsMulti`.\n   * - Caso a mesma possua 3 ou mais itens, será criado o componente `po-select` ou, `po-multiselect` se a propriedade `optionsMulti`\n   * for verdadeira.\n   * - Caso o *type* informado seja *date* ou *datetime* o componente criado será o `po-datepicker`.\n   * - Caso seja informado a propriedade `optionsService` o componente criado será o `po-combo`.\n   * - Caso o *type* informado seja *time* o componente criado será um `po-input` podendo receber um *mask* para formatar\n   * o valor exibido, caso não seja informado um *mask* o componente será criado com a máscara '99:99' por padrão.\n   * - Caso a lista possua a propriedade `rows` e esta seja definida com valor maior ou igual a 3 o componente criado será\n   * o `po-textarea`, caso o valor da propriedade `rows` seja menor que 3 o componente criado será o `po-input`.\n   * - Caso seja informada a propriedade `secret` o componente criado será o `po-password`.\n   * - Caso o *type* informado seja *string* o componente criado será o `po-input`.\n   *\n   * @default `[]`\n   */\n  @Input('p-fields') fields: Array<PoDynamicFormField>;\n\n  /**\n   * Objeto que será utilizado como valor para exibir as informações, será recuperado e preenchido através do atributo *property*\n   * dos objetos contidos na propridade `p-fields`.\n   *\n   * Pode iniciar com valor ou apenas com um objeto vazio que será preenchido conforme descrito acima.\n   *\n   * > Ex: `{ name: 'po' }`\n   */\n  @Input('p-value') value: any;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Na inicialização do componente será repassado o objeto de formulário utilizado no componente,\n   * podendo ser utilizado para validações e/ou detecção de mudança dos valores.\n   *\n   * Portanto existem duas maneiras de recuperar o formulário,\n   * através de *template reference* e através do *output*, veja os exemplos abaixo:\n   *\n   * > *template reference*\n   *\n   * ```html\n   *  <po-dynamic-form #dynamicForm>\n   *  </po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.form.invalid\">\n   *  </po-button>\n   *\n   * ```\n   *\n   * > *Output*\n   *\n   * ```html\n   *  ...\n   *  <po-dynamic-form (p-form)=\"getForm($event)\">\n   *  </po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.invalid\">\n   *  </po-button>\n   *  ...\n   *\n   * ```\n   *\n   * ```ts\n   *  ...\n   *\n   *  export class AppComponent {\n   *\n   *    dynamicForm: NgForm;\n   *\n   *    getForm(form: NgForm) {\n   *      this.dynamicForm = form;\n   *    }\n   *\n   *  }\n   * ```\n   *\n   * > Caso a propriedade `p-group-form` for verdadeira não será repassado o formulário, pois o mesmo utilizará\n   * o formulário pai.\n   */\n  @Output('p-form') formOutput: EventEmitter<NgForm> = new EventEmitter<NgForm>();\n\n  /**\n   * Função ou serviço que será executado na inicialização do componente.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * Ao ser executado, irá receber como parâmetro o objeto informado no `p-value`.\n   *\n   * O retorno desta função deve ser do tipo [PoDynamicFormLoad](documentation/po-dynamic-form#po-dynamic-form-load),\n   * onde o usuário poderá determinar as novas atualizações dos campos, valores e determinar o campo a ser focado.\n   *\n   * Por exemplo:\n   *\n   * ```\n   * onLoadFields(): PoDynamicFormLoad {\n   *\n   *   return {\n   *     value: { cpf: undefined },\n   *     fields: [\n   *       { property: 'cpf' }\n   *     ],\n   *     focus: 'cpf'\n   *   };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-load]=\"onLoadFields.bind(this)\"\n   * ```\n   */\n  @Input('p-load') load?: string | Function;\n\n  /**\n   * Função ou serviço para validar as **mudanças do formulário**.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade\n   * alterada e o novo valor, conforme a interface `PoDynamicFormFieldChanged`:\n   *\n   * ```\n   * { property: 'property name', value: 'new value' }\n   * ```\n   *\n   * O retorno desta função deve ser do tipo [PoDynamicFormValidation](documentation/po-dynamic-form#po-dynamic-form-validation),\n   * onde o usuário poderá determinar as novas atualizações dos campos.\n   * Por exemplo:\n   *\n   * ```\n   * onChangeFields(changeValue): PoDynamicFormValidation {\n   *\n   * if (changeValue.property === 'state') {\n   *\n   *   return {\n   *     value: { city: undefined },\n   *     fields: [\n   *       { property: 'city', options: this.getCity(changeValue.value.state) }\n   *     ],\n   *     focus: 'city'\n   *   };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-validate]=\"this.myFunction.bind(this)\"\n   * ```\n   *\n   * > Se houver uma lista de campos para validação definida em `p-validate-fields`, a propriedade `validate` só receberá o disparo para os campos equivalentes.\n   */\n  @Input('p-validate') validate?: string | Function;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista que define os campos que irão disparar o validate do form.\n   */\n  @Input('p-validate-fields') validateFields?: Array<string>;\n\n  private _groupForm?: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   * Ao informar esta propriedade, o componente passará a utilizar o formulário pai para criar os `FormControl`\n   * e com isso é possível recuperar o valor do formulário e suas validações a partir do formulário pai.\n   *\n   * ```html\n   * <form #parentForm=\"ngForm\">\n   *\n   *   <po-dynamic-form p-group-form [p-fields]=\"fields\"></po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"parentForm.invalid\"></po-button>\n   * </form>\n   * ```\n   */\n  @Input('p-group-form') set groupForm(value: boolean) {\n    this._groupForm = <any>value === '' ? true : convertToBoolean(value);\n  }\n\n  get groupForm(): boolean {\n    return this._groupForm;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ao informar esta propriedade, o componente passará a emitir o valor a cada caractere digitado.\n   *\n   * Pode ser aplicado nos seguintes componentes:\n   * - po-input\n   * - po-number\n   * - po-decimal\n   * - po-textarea\n   * - po-password\n   *\n   * Deve informar os campos que deseja receber as emissões na propriedade `p-validate-fields`.\n   *\n   *\n   */\n  @Input({ alias: 'p-validate-on-input', transform: convertToBoolean }) validateOnInput: boolean = false;\n}\n"]}
|
|
271
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAIvD;;;;;;;GAOG;AAEH,MAAM,OAAO,0BAA0B;IACrC;;;;;;OAMG;IACoB,SAAS,CAAU;IAE1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACgB,MAAM,CAA4B;IAErD;;;;;;;OAOG;IACe,KAAK,CAAM;IAE7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAmDG;IACe,UAAU,GAAyB,IAAI,YAAY,EAAU,CAAC;IAEhF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACc,IAAI,CAAqB;IAE1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAuCG;IACkB,QAAQ,CAAqB;IAElD;;;;;;OAMG;IACyB,cAAc,CAAiB;IAEnD,UAAU,GAAa,KAAK,CAAC;IAErC;;;;;;;;;;;;;;;OAeG;IACH,IAA2B,SAAS,CAAC,KAAc;QACjD,IAAI,CAAC,UAAU,GAAQ,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACvE,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACmE,eAAe,GAAY,KAAK,CAAC;oFA3O5F,0BAA0B;6DAA1B,0BAA0B,whBA2Oa,gBAAgB;;iFA3OvD,0BAA0B;cADtC,SAAS;gBASe,SAAS;kBAA/B,KAAK;mBAAC,cAAc;YAgCF,MAAM;kBAAxB,KAAK;mBAAC,UAAU;YAUC,KAAK;kBAAtB,KAAK;mBAAC,SAAS;YAsDE,UAAU;kBAA3B,MAAM;mBAAC,QAAQ;YAkCC,IAAI;kBAApB,KAAK;mBAAC,QAAQ;YA0CM,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YASS,cAAc;kBAAzC,KAAK;mBAAC,mBAAmB;YAoBC,SAAS;kBAAnC,KAAK;mBAAC,cAAc;YA0BiD,eAAe;kBAApF,KAAK;mBAAC,EAAE,KAAK,EAAE,qBAAqB,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { Directive, EventEmitter, Input, Output } from '@angular/core';\nimport { NgForm } from '@angular/forms';\nimport { convertToBoolean } from '../../../utils/util';\n\nimport { PoDynamicFormField } from './po-dynamic-form-field.interface';\n\n/**\n *\n * @description\n *\n * Componente para criação de formulários dinâmicos a partir de uma lista de objetos.\n *\n * Também é possível verificar se o formulário está válido e informar valores para a exibição de informações.\n */\n@Directive()\nexport class PoDynamicFormBaseComponent {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Nome da propriedade, atribuída ao `PoDynamicFormField.property`, que iniciará o campo com foco.\n   */\n  @Input('p-auto-focus') autoFocus?: string;\n\n  /**\n   * @description\n   *\n   * Coleção de objetos que implementam a interface `PoDynamicFormField`, para definição dos campos que serão criados\n   * dinamicamente.\n   *\n   * > Ex: `[ { property: 'name' } ]`\n   *\n   * Regras de tipagem e criação dos componentes:\n   *\n   * - Caso o *type* informado seja *boolean* o componente criado será o `po-switch`.\n   * - Caso o *type* informado seja *currency* e não seja informado um *mask* ou *pattern* o componente criado será o `po-decimal`,\n   * caso seja informado um *mask* ou *pattern* o componente criado será o `po-input`.\n   * - Caso o *type* informado seja *number* e não seja informado um *mask* ou *pattern* o componente criado será o `po-number`, caso seja\n   * informado um *mask* ou *pattern* o componente criado será o `po-input`.\n   * - Caso a lista possua a propriedade `options` e a mesma possua até 3 itens o componente criado será o `po-radio-group`\n   * ou `po-checkbox-group` se informar a propriedade `optionsMulti`.\n   * - Caso a mesma possua 3 ou mais itens, será criado o componente `po-select` ou, `po-multiselect` se a propriedade `optionsMulti`\n   * for verdadeira.\n   * - Caso o *type* informado seja *date* ou *datetime* o componente criado será o `po-datepicker`.\n   * - Caso seja informado a propriedade `optionsService` o componente criado será o `po-combo`.\n   * - Caso o *type* informado seja *time* o componente criado será um `po-input` podendo receber um *mask* para formatar\n   * o valor exibido, caso não seja informado um *mask* o componente será criado com a máscara '99:99' por padrão.\n   * - Caso a lista possua a propriedade `rows` e esta seja definida com valor maior ou igual a 3 o componente criado será\n   * o `po-textarea`, caso o valor da propriedade `rows` seja menor que 3 o componente criado será o `po-input`.\n   * - Caso seja informada a propriedade `secret` o componente criado será o `po-password`.\n   * - Caso o *type* informado seja *string* o componente criado será o `po-input`.\n   * > Ao alterar o valor das `properties` e/ou agrupamentos via container, os `fields` que utilizam serviço podem refazer as chamadas para as API's.\n   * @default `[]`\n   */\n  @Input('p-fields') fields: Array<PoDynamicFormField>;\n\n  /**\n   * Objeto que será utilizado como valor para exibir as informações, será recuperado e preenchido através do atributo *property*\n   * dos objetos contidos na propridade `p-fields`.\n   *\n   * Pode iniciar com valor ou apenas com um objeto vazio que será preenchido conforme descrito acima.\n   *\n   * > Ex: `{ name: 'po' }`\n   */\n  @Input('p-value') value: any;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Na inicialização do componente será repassado o objeto de formulário utilizado no componente,\n   * podendo ser utilizado para validações e/ou detecção de mudança dos valores.\n   *\n   * Portanto existem duas maneiras de recuperar o formulário,\n   * através de *template reference* e através do *output*, veja os exemplos abaixo:\n   *\n   * > *template reference*\n   *\n   * ```html\n   *  <po-dynamic-form #dynamicForm>\n   *  </po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.form.invalid\">\n   *  </po-button>\n   *\n   * ```\n   *\n   * > *Output*\n   *\n   * ```html\n   *  ...\n   *  <po-dynamic-form (p-form)=\"getForm($event)\">\n   *  </po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.invalid\">\n   *  </po-button>\n   *  ...\n   *\n   * ```\n   *\n   * ```ts\n   *  ...\n   *\n   *  export class AppComponent {\n   *\n   *    dynamicForm: NgForm;\n   *\n   *    getForm(form: NgForm) {\n   *      this.dynamicForm = form;\n   *    }\n   *\n   *  }\n   * ```\n   *\n   * > Caso a propriedade `p-group-form` for verdadeira não será repassado o formulário, pois o mesmo utilizará\n   * o formulário pai.\n   */\n  @Output('p-form') formOutput: EventEmitter<NgForm> = new EventEmitter<NgForm>();\n\n  /**\n   * Função ou serviço que será executado na inicialização do componente.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * Ao ser executado, irá receber como parâmetro o objeto informado no `p-value`.\n   *\n   * O retorno desta função deve ser do tipo [PoDynamicFormLoad](documentation/po-dynamic-form#po-dynamic-form-load),\n   * onde o usuário poderá determinar as novas atualizações dos campos, valores e determinar o campo a ser focado.\n   *\n   * Por exemplo:\n   *\n   * ```\n   * onLoadFields(): PoDynamicFormLoad {\n   *\n   *   return {\n   *     value: { cpf: undefined },\n   *     fields: [\n   *       { property: 'cpf' }\n   *     ],\n   *     focus: 'cpf'\n   *   };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-load]=\"onLoadFields.bind(this)\"\n   * ```\n   */\n  @Input('p-load') load?: string | Function;\n\n  /**\n   * Função ou serviço para validar as **mudanças do formulário**.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade\n   * alterada e o novo valor, conforme a interface `PoDynamicFormFieldChanged`:\n   *\n   * ```\n   * { property: 'property name', value: 'new value' }\n   * ```\n   *\n   * O retorno desta função deve ser do tipo [PoDynamicFormValidation](documentation/po-dynamic-form#po-dynamic-form-validation),\n   * onde o usuário poderá determinar as novas atualizações dos campos.\n   * Por exemplo:\n   *\n   * ```\n   * onChangeFields(changeValue): PoDynamicFormValidation {\n   *\n   * if (changeValue.property === 'state') {\n   *\n   *   return {\n   *     value: { city: undefined },\n   *     fields: [\n   *       { property: 'city', options: this.getCity(changeValue.value.state) }\n   *     ],\n   *     focus: 'city'\n   *   };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-validate]=\"this.myFunction.bind(this)\"\n   * ```\n   *\n   * > Se houver uma lista de campos para validação definida em `p-validate-fields`, a propriedade `validate` só receberá o disparo para os campos equivalentes.\n   */\n  @Input('p-validate') validate?: string | Function;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista que define os campos que irão disparar o validate do form.\n   */\n  @Input('p-validate-fields') validateFields?: Array<string>;\n\n  private _groupForm?: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   * Ao informar esta propriedade, o componente passará a utilizar o formulário pai para criar os `FormControl`\n   * e com isso é possível recuperar o valor do formulário e suas validações a partir do formulário pai.\n   *\n   * ```html\n   * <form #parentForm=\"ngForm\">\n   *\n   *   <po-dynamic-form p-group-form [p-fields]=\"fields\"></po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"parentForm.invalid\"></po-button>\n   * </form>\n   * ```\n   */\n  @Input('p-group-form') set groupForm(value: boolean) {\n    this._groupForm = <any>value === '' ? true : convertToBoolean(value);\n  }\n\n  get groupForm(): boolean {\n    return this._groupForm;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ao informar esta propriedade, o componente passará a emitir o valor a cada caractere digitado.\n   *\n   * Pode ser aplicado nos seguintes componentes:\n   * - po-input\n   * - po-number\n   * - po-decimal\n   * - po-textarea\n   * - po-password\n   *\n   * Deve informar os campos que deseja receber as emissões na propriedade `p-validate-fields`.\n   *\n   *\n   */\n  @Input({ alias: 'p-validate-on-input', transform: convertToBoolean }) validateOnInput: boolean = false;\n}\n"]}
|