brainloper-ui 18.0.0 → 19.0.0
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/fesm2022/brainloper-ui.mjs +116 -107
- package/fesm2022/brainloper-ui.mjs.map +1 -1
- package/package.json +13 -15
- package/esm2022/brainloper-ui.mjs +0 -5
- package/esm2022/public_api.mjs +0 -58
- package/esm2022/src/app/modules/brainloper-ui/brainloper-ui.module.mjs +0 -303
- package/esm2022/src/app/modules/brainloper-ui/components/bread-crumb/bread-crumb.component.mjs +0 -30
- package/esm2022/src/app/modules/brainloper-ui/components/buttons/button-icon/button-icon.component.mjs +0 -23
- package/esm2022/src/app/modules/brainloper-ui/components/buttons/button-label/button-label.component.mjs +0 -83
- package/esm2022/src/app/modules/brainloper-ui/components/carousel/carousel.component.mjs +0 -42
- package/esm2022/src/app/modules/brainloper-ui/components/combos/combos.component.mjs +0 -183
- package/esm2022/src/app/modules/brainloper-ui/components/data-table/data-table.component.mjs +0 -747
- package/esm2022/src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.mjs +0 -120
- package/esm2022/src/app/modules/brainloper-ui/components/file-input/file-input.component.mjs +0 -205
- package/esm2022/src/app/modules/brainloper-ui/components/file-input/imagenes/doc.mjs +0 -2
- package/esm2022/src/app/modules/brainloper-ui/components/file-input/imagenes/fondoTransparente.mjs +0 -2
- package/esm2022/src/app/modules/brainloper-ui/components/file-input/imagenes/pdf.mjs +0 -2
- package/esm2022/src/app/modules/brainloper-ui/components/filters/filters.component.mjs +0 -227
- package/esm2022/src/app/modules/brainloper-ui/components/report/template-fuel/template-fuel.component.mjs +0 -89
- package/esm2022/src/app/modules/brainloper-ui/components/report/template-ot/template-ot.component.mjs +0 -86
- package/esm2022/src/app/modules/brainloper-ui/components/select-filter/select-filter.component.mjs +0 -117
- package/esm2022/src/app/modules/directives/carousel-item.directive.mjs +0 -20
- package/esm2022/src/app/modules/interfaces/buttons/button-icon.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/buttons/button-lavel-edit.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/combos/combos-configuration.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/data-table/params.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/data-table/rules.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/data-table/table-columns.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/data-table/table-configuration.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/enum/enumActions.mjs +0 -8
- package/esm2022/src/app/modules/interfaces/enum/enumRules.mjs +0 -8
- package/esm2022/src/app/modules/interfaces/enum/httpResponseType.mjs +0 -8
- package/esm2022/src/app/modules/interfaces/file-forms-service/file-forms-params.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/file-forms-service/file-input-params.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/filters/header-filters.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/menu-break-crumb/menu-break-crumb.mjs +0 -6
- package/esm2022/src/app/modules/interfaces/report/template-pdf-base.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/report/template-pdf-ot.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/report/template-pdf-purchase-order.mjs +0 -2
- package/esm2022/src/app/modules/interfaces/report/template-pfd-fo.mjs +0 -2
- package/esm2022/src/app/modules/services/crypto.service.mjs +0 -38
- package/esm2022/src/app/modules/services/export-data.service.mjs +0 -169
- package/esm2022/src/app/modules/services/file-forms.service.mjs +0 -24
- package/esm2022/src/app/modules/services/fuel-order-pdf.service.mjs +0 -346
- package/esm2022/src/app/modules/services/functions.service.mjs +0 -75
- package/esm2022/src/app/modules/services/generate-pdf.service.mjs +0 -93
- package/esm2022/src/app/modules/services/http.service.mjs +0 -142
- package/esm2022/src/app/modules/services/loading/loading.component.mjs +0 -30
- package/esm2022/src/app/modules/services/local-storage.service.mjs +0 -115
- package/esm2022/src/app/modules/services/message.service.mjs +0 -202
- package/esm2022/src/app/modules/services/purchase-order-pdf.service.mjs +0 -179
- package/esm2022/src/app/modules/services/screen-size-util.mjs +0 -6
- package/esm2022/src/app/modules/services/session.service.mjs +0 -43
- package/esm2022/src/app/modules/services/work-order-pdf.service.mjs +0 -363
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@angular/common";
|
|
4
|
-
import * as i2 from "@angular/material/icon";
|
|
5
|
-
import * as i3 from "@angular/material/input";
|
|
6
|
-
import * as i4 from "@angular/material/tooltip";
|
|
7
|
-
import * as i5 from "@angular/forms";
|
|
8
|
-
export class ButtonLabelComponent {
|
|
9
|
-
constructor() { }
|
|
10
|
-
updateLabel = new EventEmitter();
|
|
11
|
-
labels = [];
|
|
12
|
-
labelsEdit = [];
|
|
13
|
-
color = null;
|
|
14
|
-
iconColor = null;
|
|
15
|
-
modeEdit = [];
|
|
16
|
-
currentValueToEdit = "";
|
|
17
|
-
indexToedit = -1;
|
|
18
|
-
spanElement;
|
|
19
|
-
initEventClink = false;
|
|
20
|
-
ngOnInit() {
|
|
21
|
-
}
|
|
22
|
-
ngOnChanges(changes) {
|
|
23
|
-
if (changes) {
|
|
24
|
-
if (changes.labelsEdit && !this.initEventClink && this.labelsEdit.length > 0 && this.labelsEdit.find(x => x.edit == true)) {
|
|
25
|
-
document.addEventListener('click', ($event) => this.onPageClick($event));
|
|
26
|
-
this.initEventClink = true;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
finishEditLabel(index) {
|
|
31
|
-
this.labelsEdit[index].value = this.currentValueToEdit;
|
|
32
|
-
this.modeEdit[index] = false;
|
|
33
|
-
this.updateLabel.emit({
|
|
34
|
-
value: this.labelsEdit[index].value,
|
|
35
|
-
labels: this.labelsEdit[index].label,
|
|
36
|
-
position: index
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
editLabel(index) {
|
|
40
|
-
this.spanElement = document.getElementById('button-edit-' + index);
|
|
41
|
-
this.currentValueToEdit = this.labelsEdit[index].value;
|
|
42
|
-
this.modeEdit[index] = true;
|
|
43
|
-
this.indexToedit = index;
|
|
44
|
-
}
|
|
45
|
-
onPageClick($event) {
|
|
46
|
-
if (!ButtonLabelComponent.isDescendant($event.target, this.spanElement) && this.modeEdit) {
|
|
47
|
-
for (let [index, value] of this.modeEdit.entries()) {
|
|
48
|
-
this.modeEdit[index] = this.indexToedit == index ? true : false;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
this.indexToedit = -1;
|
|
52
|
-
}
|
|
53
|
-
static isDescendant(child, parent) {
|
|
54
|
-
let node = child.parentNode;
|
|
55
|
-
while (node != null) {
|
|
56
|
-
if (node === parent) {
|
|
57
|
-
return true;
|
|
58
|
-
}
|
|
59
|
-
node = node.parentNode;
|
|
60
|
-
}
|
|
61
|
-
return false;
|
|
62
|
-
}
|
|
63
|
-
ngOnDestroy() {
|
|
64
|
-
document.removeEventListener('click', ($event) => this.onPageClick($event));
|
|
65
|
-
}
|
|
66
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ButtonLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
67
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: ButtonLabelComponent, selector: "app-button-label", inputs: { labels: "labels", labelsEdit: "labelsEdit", color: "color", iconColor: "iconColor" }, outputs: { updateLabel: "updateLabel" }, usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"labels\" class=\"d-flex justify-content-center my-3 flex-wrap\">\n <div *ngFor=\"let item of labels;\">\n <h4 *ngIf=\"item && item != ''\" class=\"mat-elevation-z2 label-text d-flex d-flex-row\" [style.background]=\"color?color:'#343a401a'\">\n {{item}}\n </h4>\n </div>\n</div>\n\n<div *ngIf=\"labelsEdit\" class=\"d-flex justify-content-center my-3 flex-wrap\">\n <div *ngFor=\"let item of labelsEdit; let i = index\">\n <h4 *ngIf=\"item && item != ''\" class=\"mat-elevation-z2 label-text d-flex d-flex-row\" [style.background]=\"color?color:'#343a401a'\" [id]=\"'button-edit-' + i\">\n <h6 *ngIf=\"item.label\" class=\"mr-1 font-weight-bold m-0\">{{item.label}} </h6>\n <div *ngIf=\"!modeEdit[i]\">{{item.value}}</div>\n <div class=\"cursor-pointer\" (click)='editLabel(i)' *ngIf=\"!modeEdit[i] && item.edit\" matTooltip=\"Editar\" matTooltipPosition=\"above\">\n <mat-icon class=\"ml-1 pencil-edit cursor-pointer\" matTooltip=\"Editar\" matTooltipPosition=\"above\" [style.color]=\"iconColor\">edit</mat-icon>\n </div>\n\n <input *ngIf=\"modeEdit[i] && item.edit\" type=\"text\" [(ngModel)]='currentValueToEdit' matInput placeholder=\"Filtrar\">\n\n <div class=\"cursor-pointer\" (click)='finishEditLabel(i)' *ngIf=\"modeEdit[i] && item.edit\" matTooltip=\"Aceptar\" matTooltipPosition=\"above\">\n <i class=\"fa fa-check btn-accion\" style=\"margin-left: 15px;\"></i>\n </div>\n\n </h4>\n </div>\n</div>\n", styles: [".label-text{padding:5px;margin:5px 10px;border-radius:10px;text-decoration:center;font-weight:500}.pencil-edit{font-size:16px;display:flex;align-items:center;justify-content:center}.cursor-pointer{cursor:pointer}\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.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
68
|
-
}
|
|
69
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ButtonLabelComponent, decorators: [{
|
|
70
|
-
type: Component,
|
|
71
|
-
args: [{ selector: 'app-button-label', template: "<div *ngIf=\"labels\" class=\"d-flex justify-content-center my-3 flex-wrap\">\n <div *ngFor=\"let item of labels;\">\n <h4 *ngIf=\"item && item != ''\" class=\"mat-elevation-z2 label-text d-flex d-flex-row\" [style.background]=\"color?color:'#343a401a'\">\n {{item}}\n </h4>\n </div>\n</div>\n\n<div *ngIf=\"labelsEdit\" class=\"d-flex justify-content-center my-3 flex-wrap\">\n <div *ngFor=\"let item of labelsEdit; let i = index\">\n <h4 *ngIf=\"item && item != ''\" class=\"mat-elevation-z2 label-text d-flex d-flex-row\" [style.background]=\"color?color:'#343a401a'\" [id]=\"'button-edit-' + i\">\n <h6 *ngIf=\"item.label\" class=\"mr-1 font-weight-bold m-0\">{{item.label}} </h6>\n <div *ngIf=\"!modeEdit[i]\">{{item.value}}</div>\n <div class=\"cursor-pointer\" (click)='editLabel(i)' *ngIf=\"!modeEdit[i] && item.edit\" matTooltip=\"Editar\" matTooltipPosition=\"above\">\n <mat-icon class=\"ml-1 pencil-edit cursor-pointer\" matTooltip=\"Editar\" matTooltipPosition=\"above\" [style.color]=\"iconColor\">edit</mat-icon>\n </div>\n\n <input *ngIf=\"modeEdit[i] && item.edit\" type=\"text\" [(ngModel)]='currentValueToEdit' matInput placeholder=\"Filtrar\">\n\n <div class=\"cursor-pointer\" (click)='finishEditLabel(i)' *ngIf=\"modeEdit[i] && item.edit\" matTooltip=\"Aceptar\" matTooltipPosition=\"above\">\n <i class=\"fa fa-check btn-accion\" style=\"margin-left: 15px;\"></i>\n </div>\n\n </h4>\n </div>\n</div>\n", styles: [".label-text{padding:5px;margin:5px 10px;border-radius:10px;text-decoration:center;font-weight:500}.pencil-edit{font-size:16px;display:flex;align-items:center;justify-content:center}.cursor-pointer{cursor:pointer}\n"] }]
|
|
72
|
-
}], ctorParameters: () => [], propDecorators: { updateLabel: [{
|
|
73
|
-
type: Output
|
|
74
|
-
}], labels: [{
|
|
75
|
-
type: Input
|
|
76
|
-
}], labelsEdit: [{
|
|
77
|
-
type: Input
|
|
78
|
-
}], color: [{
|
|
79
|
-
type: Input
|
|
80
|
-
}], iconColor: [{
|
|
81
|
-
type: Input
|
|
82
|
-
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWxhYmVsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9icmFpbmxvcGVyLXVpL2NvbXBvbmVudHMvYnV0dG9ucy9idXR0b24tbGFiZWwvYnV0dG9uLWxhYmVsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9icmFpbmxvcGVyLXVpL2NvbXBvbmVudHMvYnV0dG9ucy9idXR0b24tbGFiZWwvYnV0dG9uLWxhYmVsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxZQUFZLEVBQTRCLE1BQU0sZUFBZSxDQUFDOzs7Ozs7O0FBT3pHLE1BQU0sT0FBTyxvQkFBb0I7SUFFL0IsZ0JBQWdCLENBQUM7SUFFUCxXQUFXLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQTtJQUN0QyxNQUFNLEdBQWtCLEVBQUUsQ0FBQTtJQUMxQixVQUFVLEdBQWUsRUFBRSxDQUFBO0lBQzNCLEtBQUssR0FBVSxJQUFJLENBQUE7SUFDbkIsU0FBUyxHQUFVLElBQUksQ0FBQTtJQUV6QixRQUFRLEdBQW1CLEVBQUUsQ0FBQTtJQUM3QixrQkFBa0IsR0FBVyxFQUFFLENBQUE7SUFFOUIsV0FBVyxHQUFVLENBQUMsQ0FBQyxDQUFBO0lBQy9CLFdBQVcsQ0FBYztJQUNqQixjQUFjLEdBQUcsS0FBSyxDQUFBO0lBRTlCLFFBQVE7SUFDUixDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUcsT0FBTyxFQUFDLENBQUM7WUFDVixJQUFHLE9BQU8sQ0FBQyxVQUFVLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLEVBQUMsQ0FBQztnQkFDeEgsUUFBUSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO2dCQUN6RSxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQTtZQUM1QixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxlQUFlLENBQUMsS0FBWTtRQUMxQixJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUE7UUFDdEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FBRyxLQUFLLENBQUE7UUFDNUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7WUFDcEIsS0FBSyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsS0FBSztZQUNuQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxLQUFLO1lBQ3BDLFFBQVEsRUFBRSxLQUFLO1NBQ2hCLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFFRCxTQUFTLENBQUMsS0FBWTtRQUNwQixJQUFJLENBQUMsV0FBVyxHQUFHLFFBQVEsQ0FBQyxjQUFjLENBQUMsY0FBYyxHQUFHLEtBQUssQ0FBQyxDQUFDO1FBQ25FLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssQ0FBQTtRQUN0RCxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQTtRQUMzQixJQUFJLENBQUMsV0FBVyxHQUFHLEtBQUssQ0FBQTtJQUMxQixDQUFDO0lBRU0sV0FBVyxDQUFDLE1BQWtCO1FBQ25DLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLE1BQXFCLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUMsQ0FBQztZQUN2RyxLQUFLLElBQUksQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDO2dCQUNuRCxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxXQUFXLElBQUksS0FBSyxDQUFBLENBQUMsQ0FBQSxJQUFJLENBQUEsQ0FBQyxDQUFBLEtBQUssQ0FBQTtZQUM3RCxDQUFDO1FBQ0gsQ0FBQztRQUNELElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDLENBQUE7SUFDdkIsQ0FBQztJQUVELE1BQU0sQ0FBQyxZQUFZLENBQUMsS0FBa0IsRUFBRSxNQUFtQjtRQUN6RCxJQUFJLElBQUksR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDO1FBQzVCLE9BQU8sSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ3BCLElBQUksSUFBSSxLQUFLLE1BQU0sRUFBRSxDQUFDO2dCQUNwQixPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7WUFDRCxJQUFJLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQztRQUN6QixDQUFDO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsV0FBVztRQUNULFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztJQUM5RSxDQUFDO3dHQXBFVSxvQkFBb0I7NEZBQXBCLG9CQUFvQixzTkNQakMsdzlDQTBCQTs7NEZEbkJhLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxrQkFBa0I7d0RBUWxCLFdBQVc7c0JBQXBCLE1BQU07Z0JBQ0UsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyLCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWJ1dHRvbi1sYWJlbCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9idXR0b24tbGFiZWwuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9idXR0b24tbGFiZWwuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBCdXR0b25MYWJlbENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIEBPdXRwdXQoKSB1cGRhdGVMYWJlbCA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpXG4gIEBJbnB1dCgpIGxhYmVsczogQXJyYXk8c3RyaW5nPiA9IFtdXG4gIEBJbnB1dCgpIGxhYmVsc0VkaXQ6IEFycmF5PGFueT4gPSBbXVxuICBASW5wdXQoKSBjb2xvcjpzdHJpbmcgPSBudWxsXG4gIEBJbnB1dCgpIGljb25Db2xvcjpzdHJpbmcgPSBudWxsXG5cbiAgcHVibGljIG1vZGVFZGl0OiBBcnJheTxib29sZWFuPiA9IFtdXG4gIHB1YmxpYyBjdXJyZW50VmFsdWVUb0VkaXQ6IHN0cmluZyA9IFwiXCJcblxuICBwcml2YXRlIGluZGV4VG9lZGl0Om51bWJlciA9IC0xXG4gIHNwYW5FbGVtZW50OiBIVE1MRWxlbWVudDtcbiAgcHJpdmF0ZSBpbml0RXZlbnRDbGluayA9IGZhbHNlXG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgaWYoY2hhbmdlcyl7XG4gICAgICBpZihjaGFuZ2VzLmxhYmVsc0VkaXQgJiYgIXRoaXMuaW5pdEV2ZW50Q2xpbmsgJiYgdGhpcy5sYWJlbHNFZGl0Lmxlbmd0aCA+IDAgJiYgdGhpcy5sYWJlbHNFZGl0LmZpbmQoeCA9PiB4LmVkaXQgPT0gdHJ1ZSkpe1xuICAgICAgICBkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKCdjbGljaycsICgkZXZlbnQpID0+IHRoaXMub25QYWdlQ2xpY2soJGV2ZW50KSk7XG4gICAgICAgIHRoaXMuaW5pdEV2ZW50Q2xpbmsgPSB0cnVlXG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgZmluaXNoRWRpdExhYmVsKGluZGV4Om51bWJlcil7XG4gICAgdGhpcy5sYWJlbHNFZGl0W2luZGV4XS52YWx1ZSA9IHRoaXMuY3VycmVudFZhbHVlVG9FZGl0XG4gICAgdGhpcy5tb2RlRWRpdFtpbmRleF0gPSBmYWxzZVxuICAgIHRoaXMudXBkYXRlTGFiZWwuZW1pdCh7XG4gICAgICB2YWx1ZTogdGhpcy5sYWJlbHNFZGl0W2luZGV4XS52YWx1ZSxcbiAgICAgIGxhYmVsczogdGhpcy5sYWJlbHNFZGl0W2luZGV4XS5sYWJlbCxcbiAgICAgIHBvc2l0aW9uOiBpbmRleFxuICAgIH0pXG4gIH1cblxuICBlZGl0TGFiZWwoaW5kZXg6bnVtYmVyKXtcbiAgICB0aGlzLnNwYW5FbGVtZW50ID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ2J1dHRvbi1lZGl0LScgKyBpbmRleCk7XG4gICAgdGhpcy5jdXJyZW50VmFsdWVUb0VkaXQgPSB0aGlzLmxhYmVsc0VkaXRbaW5kZXhdLnZhbHVlXG4gICAgdGhpcy5tb2RlRWRpdFtpbmRleF0gPSB0cnVlXG4gICAgdGhpcy5pbmRleFRvZWRpdCA9IGluZGV4XG4gIH1cblxuICBwdWJsaWMgb25QYWdlQ2xpY2soJGV2ZW50OiBNb3VzZUV2ZW50KXtcbiAgICBpZiAoIUJ1dHRvbkxhYmVsQ29tcG9uZW50LmlzRGVzY2VuZGFudCgkZXZlbnQudGFyZ2V0IGFzIEhUTUxFbGVtZW50LCB0aGlzLnNwYW5FbGVtZW50KSAmJiB0aGlzLm1vZGVFZGl0KXtcbiAgICAgIGZvciAobGV0IFtpbmRleCwgdmFsdWVdIG9mIHRoaXMubW9kZUVkaXQuZW50cmllcygpKSB7XG4gICAgICAgIHRoaXMubW9kZUVkaXRbaW5kZXhdID0gdGhpcy5pbmRleFRvZWRpdCA9PSBpbmRleD90cnVlOmZhbHNlXG4gICAgICB9XG4gICAgfVxuICAgIHRoaXMuaW5kZXhUb2VkaXQgPSAtMVxuICB9XG5cbiAgc3RhdGljIGlzRGVzY2VuZGFudChjaGlsZDogSFRNTEVsZW1lbnQsIHBhcmVudDogSFRNTEVsZW1lbnQpIHtcbiAgICBsZXQgbm9kZSA9IGNoaWxkLnBhcmVudE5vZGU7XG4gICAgd2hpbGUgKG5vZGUgIT0gbnVsbCkge1xuICAgICAgaWYgKG5vZGUgPT09IHBhcmVudCkge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH1cbiAgICAgIG5vZGUgPSBub2RlLnBhcmVudE5vZGU7XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCkge1xuICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgKCRldmVudCkgPT4gdGhpcy5vblBhZ2VDbGljaygkZXZlbnQpKTtcbiAgfVxuXG59XG5cblxuIiwiPGRpdiAqbmdJZj1cImxhYmVsc1wiIGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1jZW50ZXIgbXktMyBmbGV4LXdyYXBcIj5cbiAgPGRpdiAqbmdGb3I9XCJsZXQgaXRlbSBvZiBsYWJlbHM7XCI+XG4gICAgPGg0ICpuZ0lmPVwiaXRlbSAmJiBpdGVtICE9ICcnXCIgY2xhc3M9XCJtYXQtZWxldmF0aW9uLXoyIGxhYmVsLXRleHQgZC1mbGV4IGQtZmxleC1yb3dcIiBbc3R5bGUuYmFja2dyb3VuZF09XCJjb2xvcj9jb2xvcjonIzM0M2E0MDFhJ1wiPlxuICAgICAge3tpdGVtfX1cbiAgICA8L2g0PlxuICA8L2Rpdj5cbjwvZGl2PlxuXG48ZGl2ICpuZ0lmPVwibGFiZWxzRWRpdFwiIGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1jZW50ZXIgbXktMyBmbGV4LXdyYXBcIj5cbiAgPGRpdiAqbmdGb3I9XCJsZXQgaXRlbSBvZiBsYWJlbHNFZGl0OyBsZXQgaSA9IGluZGV4XCI+XG4gICAgPGg0ICpuZ0lmPVwiaXRlbSAmJiBpdGVtICE9ICcnXCIgY2xhc3M9XCJtYXQtZWxldmF0aW9uLXoyIGxhYmVsLXRleHQgZC1mbGV4IGQtZmxleC1yb3dcIiBbc3R5bGUuYmFja2dyb3VuZF09XCJjb2xvcj9jb2xvcjonIzM0M2E0MDFhJ1wiIFtpZF09XCInYnV0dG9uLWVkaXQtJyArIGlcIj5cbiAgICAgIDxoNiAqbmdJZj1cIml0ZW0ubGFiZWxcIiBjbGFzcz1cIm1yLTEgZm9udC13ZWlnaHQtYm9sZCBtLTBcIj57e2l0ZW0ubGFiZWx9fSA8L2g2PlxuICAgICAgPGRpdiAqbmdJZj1cIiFtb2RlRWRpdFtpXVwiPnt7aXRlbS52YWx1ZX19PC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY3Vyc29yLXBvaW50ZXJcIiAoY2xpY2spPSdlZGl0TGFiZWwoaSknICpuZ0lmPVwiIW1vZGVFZGl0W2ldICYmIGl0ZW0uZWRpdFwiIG1hdFRvb2x0aXA9XCJFZGl0YXJcIiBtYXRUb29sdGlwUG9zaXRpb249XCJhYm92ZVwiPlxuICAgICAgICA8bWF0LWljb24gY2xhc3M9XCJtbC0xIHBlbmNpbC1lZGl0IGN1cnNvci1wb2ludGVyXCIgbWF0VG9vbHRpcD1cIkVkaXRhclwiIG1hdFRvb2x0aXBQb3NpdGlvbj1cImFib3ZlXCIgW3N0eWxlLmNvbG9yXT1cImljb25Db2xvclwiPmVkaXQ8L21hdC1pY29uPlxuICAgICAgPC9kaXY+XG5cbiAgICAgIDxpbnB1dCAqbmdJZj1cIm1vZGVFZGl0W2ldICYmIGl0ZW0uZWRpdFwiIHR5cGU9XCJ0ZXh0XCIgWyhuZ01vZGVsKV09J2N1cnJlbnRWYWx1ZVRvRWRpdCcgbWF0SW5wdXQgcGxhY2Vob2xkZXI9XCJGaWx0cmFyXCI+XG5cbiAgICAgIDxkaXYgY2xhc3M9XCJjdXJzb3ItcG9pbnRlclwiIChjbGljayk9J2ZpbmlzaEVkaXRMYWJlbChpKScgKm5nSWY9XCJtb2RlRWRpdFtpXSAmJiBpdGVtLmVkaXRcIiBtYXRUb29sdGlwPVwiQWNlcHRhclwiIG1hdFRvb2x0aXBQb3NpdGlvbj1cImFib3ZlXCI+XG4gICAgICAgIDxpIGNsYXNzPVwiZmEgZmEtY2hlY2sgYnRuLWFjY2lvblwiIHN0eWxlPVwibWFyZ2luLWxlZnQ6IDE1cHg7XCI+PC9pPlxuICAgICAgPC9kaXY+XG5cbiAgICA8L2g0PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { Component, ContentChildren, Input } from '@angular/core';
|
|
2
|
-
import { CarouselItemDirective } from '../../../directives/carousel-item.directive';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/common";
|
|
5
|
-
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
6
|
-
export class CarouselComponent {
|
|
7
|
-
cdr;
|
|
8
|
-
carouselInterval = 0;
|
|
9
|
-
enableControlsOffset = true;
|
|
10
|
-
sortedCarouselItems = [];
|
|
11
|
-
carouselItems;
|
|
12
|
-
constructor(cdr) {
|
|
13
|
-
this.cdr = cdr;
|
|
14
|
-
}
|
|
15
|
-
ngOnInit() { }
|
|
16
|
-
ngAfterContentInit() {
|
|
17
|
-
this.carouselItems.changes.subscribe(() => {
|
|
18
|
-
this.updateCarouselItems();
|
|
19
|
-
this.cdr.detectChanges();
|
|
20
|
-
});
|
|
21
|
-
this.updateCarouselItems();
|
|
22
|
-
this.cdr.detectChanges();
|
|
23
|
-
}
|
|
24
|
-
updateCarouselItems() {
|
|
25
|
-
this.sortedCarouselItems = this.carouselItems.toArray().sort((a, b) => Number(a.carouselItem) - Number(b.carouselItem));
|
|
26
|
-
console.log('Ítems ordenados:', this.sortedCarouselItems.map(item => item.carouselItem));
|
|
27
|
-
}
|
|
28
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CarouselComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
29
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: CarouselComponent, selector: "app-carousel", inputs: { carouselInterval: "carouselInterval", enableControlsOffset: "enableControlsOffset" }, queries: [{ propertyName: "carouselItems", predicate: CarouselItemDirective }], ngImport: i0, template: "<div [class.controls-offset-enabled]=\"enableControlsOffset\">\n <ngb-carousel *ngIf=\"sortedCarouselItems.length\" [interval]=\"carouselInterval\" [showNavigationIndicators]=\"false\">\n <ng-container *ngFor=\"let item of sortedCarouselItems\">\n <ng-template ngbSlide [id]=\"'carouselItem' + item.carouselItem\">\n <div class=\"item-container\">\n <ng-container *ngTemplateOutlet=\"item.templateRef\"></ng-container>\n </div>\n </ng-template>\n </ng-container>\n </ngb-carousel>\n</div>", styles: ["::ng-deep .carousel-control-next-icon{background-image:url()!important}::ng-deep .carousel-control-next{display:flex!important;justify-content:flex-end!important}::ng-deep .carousel-control-prev-icon{background-image:url()!important}::ng-deep .carousel-control-prev{display:flex!important;justify-content:flex-start!important}::ng-deep .carousel-indicators li{background-color:#212121!important}.item-container{min-height:60vh;margin:0 30px}::ng-deep .carousel-control-prev,::ng-deep .carousel-control-next{width:48px!important;min-width:0!important;max-width:48px!important;align-items:center!important;justify-content:center!important;background:transparent!important;z-index:2;border-radius:50%;top:50%;transform:translateY(-50%);height:48px!important;padding:0!important}@media screen and (max-width: 600px){.item-container{margin:0 10px}::ng-deep .carousel-control-prev,::ng-deep .carousel-control-next{width:32px!important;height:32px!important}.controls-offset-enabled ::ng-deep .carousel-control-prev{left:-15px!important}.controls-offset-enabled ::ng-deep .carousel-control-next{right:-15px!important}}\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: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.NgbCarousel, selector: "ngb-carousel", inputs: ["animation", "activeId", "interval", "wrap", "keyboard", "pauseOnHover", "pauseOnFocus", "showNavigationArrows", "showNavigationIndicators"], outputs: ["slide", "slid"], exportAs: ["ngbCarousel"] }, { kind: "directive", type: i2.NgbSlide, selector: "ng-template[ngbSlide]", inputs: ["id"], outputs: ["slid"] }] });
|
|
30
|
-
}
|
|
31
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CarouselComponent, decorators: [{
|
|
32
|
-
type: Component,
|
|
33
|
-
args: [{ selector: 'app-carousel', template: "<div [class.controls-offset-enabled]=\"enableControlsOffset\">\n <ngb-carousel *ngIf=\"sortedCarouselItems.length\" [interval]=\"carouselInterval\" [showNavigationIndicators]=\"false\">\n <ng-container *ngFor=\"let item of sortedCarouselItems\">\n <ng-template ngbSlide [id]=\"'carouselItem' + item.carouselItem\">\n <div class=\"item-container\">\n <ng-container *ngTemplateOutlet=\"item.templateRef\"></ng-container>\n </div>\n </ng-template>\n </ng-container>\n </ngb-carousel>\n</div>", styles: ["::ng-deep .carousel-control-next-icon{background-image:url()!important}::ng-deep .carousel-control-next{display:flex!important;justify-content:flex-end!important}::ng-deep .carousel-control-prev-icon{background-image:url()!important}::ng-deep .carousel-control-prev{display:flex!important;justify-content:flex-start!important}::ng-deep .carousel-indicators li{background-color:#212121!important}.item-container{min-height:60vh;margin:0 30px}::ng-deep .carousel-control-prev,::ng-deep .carousel-control-next{width:48px!important;min-width:0!important;max-width:48px!important;align-items:center!important;justify-content:center!important;background:transparent!important;z-index:2;border-radius:50%;top:50%;transform:translateY(-50%);height:48px!important;padding:0!important}@media screen and (max-width: 600px){.item-container{margin:0 10px}::ng-deep .carousel-control-prev,::ng-deep .carousel-control-next{width:32px!important;height:32px!important}.controls-offset-enabled ::ng-deep .carousel-control-prev{left:-15px!important}.controls-offset-enabled ::ng-deep .carousel-control-next{right:-15px!important}}\n"] }]
|
|
34
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { carouselInterval: [{
|
|
35
|
-
type: Input
|
|
36
|
-
}], enableControlsOffset: [{
|
|
37
|
-
type: Input
|
|
38
|
-
}], carouselItems: [{
|
|
39
|
-
type: ContentChildren,
|
|
40
|
-
args: [CarouselItemDirective]
|
|
41
|
-
}] } });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2Fyb3VzZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL2JyYWlubG9wZXItdWkvY29tcG9uZW50cy9jYXJvdXNlbC9jYXJvdXNlbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvYnJhaW5sb3Blci11aS9jb21wb25lbnRzL2Nhcm91c2VsL2Nhcm91c2VsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQTRCLGVBQWUsRUFBZ0MsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFILE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDOzs7O0FBT3BGLE1BQU0sT0FBTyxpQkFBaUI7SUFRUjtJQU5YLGdCQUFnQixHQUFXLENBQUMsQ0FBQztJQUM3QixvQkFBb0IsR0FBWSxJQUFJLENBQUM7SUFDdkMsbUJBQW1CLEdBQTRCLEVBQUUsQ0FBQztJQUVqQixhQUFhLENBQW9DO0lBRXpGLFlBQW9CLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO0lBQUksQ0FBQztJQUUvQyxRQUFRLEtBQVcsQ0FBQztJQUVwQixrQkFBa0I7UUFDaEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUN4QyxJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztZQUMzQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQzNCLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7UUFDM0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRU8sbUJBQW1CO1FBQ3pCLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDO1FBQ3hILE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLEVBQUUsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDO0lBQzNGLENBQUM7d0dBeEJVLGlCQUFpQjs0RkFBakIsaUJBQWlCLGtMQU1YLHFCQUFxQiw2QkNkeEMsbWhCQVVNOzs0RkRGTyxpQkFBaUI7a0JBTDdCLFNBQVM7K0JBQ0UsY0FBYztzRkFNZixnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0csb0JBQW9CO3NCQUE1QixLQUFLO2dCQUdrQyxhQUFhO3NCQUFwRCxlQUFlO3VCQUFDLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBBZnRlckNvbnRlbnRJbml0LCBDb250ZW50Q2hpbGRyZW4sIFF1ZXJ5TGlzdCwgQ2hhbmdlRGV0ZWN0b3JSZWYsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDYXJvdXNlbEl0ZW1EaXJlY3RpdmUgfSBmcm9tICcuLi8uLi8uLi9kaXJlY3RpdmVzL2Nhcm91c2VsLWl0ZW0uZGlyZWN0aXZlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWNhcm91c2VsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Nhcm91c2VsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2Fyb3VzZWwuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDYXJvdXNlbENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJDb250ZW50SW5pdCB7XG5cbiAgQElucHV0KCkgY2Fyb3VzZWxJbnRlcnZhbDogbnVtYmVyID0gMDtcbiAgQElucHV0KCkgZW5hYmxlQ29udHJvbHNPZmZzZXQ6IGJvb2xlYW4gPSB0cnVlO1xuICBwdWJsaWMgc29ydGVkQ2Fyb3VzZWxJdGVtczogQ2Fyb3VzZWxJdGVtRGlyZWN0aXZlW10gPSBbXTtcblxuICBAQ29udGVudENoaWxkcmVuKENhcm91c2VsSXRlbURpcmVjdGl2ZSkgY2Fyb3VzZWxJdGVtcyE6IFF1ZXJ5TGlzdDxDYXJvdXNlbEl0ZW1EaXJlY3RpdmU+O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikgeyB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7IH1cblxuICBuZ0FmdGVyQ29udGVudEluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5jYXJvdXNlbEl0ZW1zLmNoYW5nZXMuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMudXBkYXRlQ2Fyb3VzZWxJdGVtcygpO1xuICAgICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICAgIH0pO1xuICAgIHRoaXMudXBkYXRlQ2Fyb3VzZWxJdGVtcygpO1xuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIHByaXZhdGUgdXBkYXRlQ2Fyb3VzZWxJdGVtcygpOiB2b2lkIHtcbiAgICB0aGlzLnNvcnRlZENhcm91c2VsSXRlbXMgPSB0aGlzLmNhcm91c2VsSXRlbXMudG9BcnJheSgpLnNvcnQoKGEsIGIpID0+IE51bWJlcihhLmNhcm91c2VsSXRlbSkgLSBOdW1iZXIoYi5jYXJvdXNlbEl0ZW0pKTtcbiAgICBjb25zb2xlLmxvZygnw410ZW1zIG9yZGVuYWRvczonLCB0aGlzLnNvcnRlZENhcm91c2VsSXRlbXMubWFwKGl0ZW0gPT4gaXRlbS5jYXJvdXNlbEl0ZW0pKTtcbiAgfVxufSIsIjxkaXYgW2NsYXNzLmNvbnRyb2xzLW9mZnNldC1lbmFibGVkXT1cImVuYWJsZUNvbnRyb2xzT2Zmc2V0XCI+XG4gIDxuZ2ItY2Fyb3VzZWwgKm5nSWY9XCJzb3J0ZWRDYXJvdXNlbEl0ZW1zLmxlbmd0aFwiIFtpbnRlcnZhbF09XCJjYXJvdXNlbEludGVydmFsXCIgW3Nob3dOYXZpZ2F0aW9uSW5kaWNhdG9yc109XCJmYWxzZVwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGl0ZW0gb2Ygc29ydGVkQ2Fyb3VzZWxJdGVtc1wiPlxuICAgICAgPG5nLXRlbXBsYXRlIG5nYlNsaWRlIFtpZF09XCInY2Fyb3VzZWxJdGVtJyArIGl0ZW0uY2Fyb3VzZWxJdGVtXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJpdGVtLWNvbnRhaW5lclwiPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJpdGVtLnRlbXBsYXRlUmVmXCI+PC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgPC9uZ2ItY2Fyb3VzZWw+XG48L2Rpdj4iXX0=
|
|
@@ -1,183 +0,0 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter, ViewChild, } from '@angular/core';
|
|
2
|
-
import { UntypedFormControl } from '@angular/forms';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "../../../services/http.service";
|
|
5
|
-
import * as i2 from "@angular/common";
|
|
6
|
-
import * as i3 from "@angular/material/icon";
|
|
7
|
-
import * as i4 from "@angular/material/form-field";
|
|
8
|
-
import * as i5 from "@angular/material/select";
|
|
9
|
-
import * as i6 from "@angular/material/core";
|
|
10
|
-
import * as i7 from "@angular/material/tooltip";
|
|
11
|
-
import * as i8 from "@angular/forms";
|
|
12
|
-
import * as i9 from "../select-filter/select-filter.component";
|
|
13
|
-
export class CombosComponent {
|
|
14
|
-
http;
|
|
15
|
-
dataCombos;
|
|
16
|
-
additionalData;
|
|
17
|
-
configuration;
|
|
18
|
-
filter = false;
|
|
19
|
-
checkbox = false;
|
|
20
|
-
required = false;
|
|
21
|
-
disabled = false;
|
|
22
|
-
addFinal = false;
|
|
23
|
-
appearance = '';
|
|
24
|
-
reloadCombo;
|
|
25
|
-
control = new UntypedFormControl();
|
|
26
|
-
tooltipDescription = null;
|
|
27
|
-
tooltipActive = false;
|
|
28
|
-
tooltip;
|
|
29
|
-
changeOption = new EventEmitter();
|
|
30
|
-
changeOptionDataComplete = new EventEmitter();
|
|
31
|
-
returnDataCombo = new EventEmitter();
|
|
32
|
-
filteredList;
|
|
33
|
-
constructor(http) {
|
|
34
|
-
this.http = http;
|
|
35
|
-
}
|
|
36
|
-
ngOnInit() {
|
|
37
|
-
if (!this.configuration.label) {
|
|
38
|
-
this.configuration.label = this.configuration.visibleField;
|
|
39
|
-
}
|
|
40
|
-
this.initData();
|
|
41
|
-
if (this.reloadCombo) {
|
|
42
|
-
this.reloadCombo.subscribe((res) => {
|
|
43
|
-
if (res == 'selected') {
|
|
44
|
-
this.control.setValue(this.configuration.selected);
|
|
45
|
-
}
|
|
46
|
-
else {
|
|
47
|
-
this.initData();
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
this.control.setValue(this.configuration.selected);
|
|
52
|
-
//console.log(this.configuration)
|
|
53
|
-
}
|
|
54
|
-
ngOnChanges(changes) {
|
|
55
|
-
if (this.dataCombos && changes?.dataCombos) {
|
|
56
|
-
this.dataCombos = changes.dataCombos.currentValue;
|
|
57
|
-
this.filteredList = this.dataCombos.slice();
|
|
58
|
-
}
|
|
59
|
-
if (this.control && this.control.value) {
|
|
60
|
-
this.configuration.selected = this.control.value;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
initData() {
|
|
64
|
-
if (this.configuration.urlCombo) {
|
|
65
|
-
this.getData();
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
if (this.dataCombos) {
|
|
69
|
-
this.filteredList = this.dataCombos.slice();
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
getData() {
|
|
74
|
-
this.http
|
|
75
|
-
.getData(this.configuration.urlCombo, this.configuration.urlParams)
|
|
76
|
-
.subscribe((res) => {
|
|
77
|
-
if (res['code'] === 0) {
|
|
78
|
-
this.dataCombos = res['body'];
|
|
79
|
-
if (this.additionalData) {
|
|
80
|
-
if (this.addFinal) {
|
|
81
|
-
this.dataCombos = this.dataCombos.concat(this.additionalData);
|
|
82
|
-
}
|
|
83
|
-
else {
|
|
84
|
-
this.dataCombos = this.additionalData.concat(this.dataCombos);
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
this.returnDataCombo.emit(this.dataCombos);
|
|
88
|
-
this.filteredList = this.dataCombos.slice();
|
|
89
|
-
}
|
|
90
|
-
else {
|
|
91
|
-
console.log('error en la consulta para datos combo');
|
|
92
|
-
}
|
|
93
|
-
}, (err) => {
|
|
94
|
-
console.log(err);
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
selectedData($event) {
|
|
98
|
-
this.findData($event);
|
|
99
|
-
this.changeOption.emit($event.value);
|
|
100
|
-
}
|
|
101
|
-
findData($event) {
|
|
102
|
-
let d = [];
|
|
103
|
-
if (this.checkbox) {
|
|
104
|
-
const lookup = new Map(this.dataCombos.map((item) => [
|
|
105
|
-
item[this.configuration.selectionField],
|
|
106
|
-
item,
|
|
107
|
-
]));
|
|
108
|
-
for (const id of $event.value) {
|
|
109
|
-
const foundItem = lookup.get(id);
|
|
110
|
-
if (foundItem) {
|
|
111
|
-
d.push(foundItem);
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
else {
|
|
116
|
-
d = this.dataCombos.find((x) => x[this.configuration.selectionField] == $event.value);
|
|
117
|
-
}
|
|
118
|
-
this.changeOptionDataComplete.emit(d);
|
|
119
|
-
if (this.configuration.fileTooltip && !this.checkbox) {
|
|
120
|
-
if (d) {
|
|
121
|
-
this.tooltipDescription = d[this.configuration.fileTooltip];
|
|
122
|
-
this.tooltipActive = true;
|
|
123
|
-
setTimeout(() => {
|
|
124
|
-
this.tooltip.show();
|
|
125
|
-
}, 50);
|
|
126
|
-
setTimeout(() => {
|
|
127
|
-
this.tooltip.hide();
|
|
128
|
-
}, 10000);
|
|
129
|
-
}
|
|
130
|
-
else
|
|
131
|
-
this.tooltipDescription = null;
|
|
132
|
-
}
|
|
133
|
-
else
|
|
134
|
-
this.tooltipDescription = null;
|
|
135
|
-
}
|
|
136
|
-
toggleTooltip() {
|
|
137
|
-
this.tooltipActive = !this.tooltipActive;
|
|
138
|
-
if (this.tooltipActive) {
|
|
139
|
-
this.tooltip.show();
|
|
140
|
-
}
|
|
141
|
-
else {
|
|
142
|
-
this.tooltip.hide();
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CombosComponent, deps: [{ token: i1.HttpService }], target: i0.ɵɵFactoryTarget.Component });
|
|
146
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: CombosComponent, selector: "combos", inputs: { dataCombos: "dataCombos", additionalData: "additionalData", configuration: "configuration", filter: "filter", checkbox: "checkbox", required: "required", disabled: "disabled", addFinal: "addFinal", appearance: "appearance", reloadCombo: "reloadCombo", control: "control" }, outputs: { changeOption: "changeOption", changeOptionDataComplete: "changeOptionDataComplete", returnDataCombo: "returnDataCombo" }, viewQueries: [{ propertyName: "tooltip", first: true, predicate: ["tooltip"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div style=\"display: flex; flex-direction: row; justify-content: space-between\">\n <div class=\"combo-container\">\n\n <mat-icon\n class=\"m-1 icon-information\"\n *ngIf=\"tooltipDescription\"\n matTooltip=\"{{tooltipDescription}}\"\n matTooltipPosition=\"above\"\n #tooltip=\"matTooltip\"\n (click)=\"toggleTooltip()\"\n matTooltipClass=\"custom-tooltip\"\n >info</mat-icon>\n\n <mat-form-field style=\"width: 100%\" [appearance]=\"appearance\">\n <mat-label style=\"text-transform: capitalize\">{{\n configuration.label\n }}</mat-label>\n <mat-select [multiple]=\"checkbox\" (selectionChange)=\"selectedData(control)\" [required]=\"required\"\n [formControl]=\"$any(control)\" [disabled]=\"disabled\">\n <app-select-filter [noResultsMessage]=\"'No hay resultados'\" *ngIf=\"filter\" [placeholder]=\"'Filter'\" [displayMember]=\"configuration.visibleField\"\n [array]=\"dataCombos\" (filteredReturn)=\"filteredList = $event\">\n </app-select-filter>\n <mat-option [value]=\"data[configuration.selectionField]\" *ngFor=\"let data of filteredList\">\n {{ data[configuration.visibleField] }}\n </mat-option>\n </mat-select>\n <mat-error *ngIf=\"required\">Campo requerido</mat-error>\n </mat-form-field>\n </div>\n</div>\n\n", styles: [".mat-mdc-form-field{width:100%}.combo-container{width:100%;display:flex;align-items:center}.icon-information{cursor:pointer;color:gray}.mat-icon{font-size:1.1rem}::ng-deep .custom-tooltip{background-color:#fbe870!important;color:#000!important;line-height:17px!important;font-size:.8rem}@media (max-width: 400px){combo-container{width:100%;justify-content:center;padding-left:8px;padding-right:8px}.mat-mdc-form-field{width:100%!important;min-width:120px;max-width:100vw;font-size:14px}.mat-mdc-select{font-size:14px}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i8.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i9.SelectFilterComponent, selector: "app-select-filter", inputs: ["array", "placeholder", "color", "displayMember", "showSpinner", "noResultsMessage", "hasGroup", "groupArrayName"], outputs: ["filteredReturn"] }] });
|
|
147
|
-
}
|
|
148
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CombosComponent, decorators: [{
|
|
149
|
-
type: Component,
|
|
150
|
-
args: [{ selector: 'combos', template: "<div style=\"display: flex; flex-direction: row; justify-content: space-between\">\n <div class=\"combo-container\">\n\n <mat-icon\n class=\"m-1 icon-information\"\n *ngIf=\"tooltipDescription\"\n matTooltip=\"{{tooltipDescription}}\"\n matTooltipPosition=\"above\"\n #tooltip=\"matTooltip\"\n (click)=\"toggleTooltip()\"\n matTooltipClass=\"custom-tooltip\"\n >info</mat-icon>\n\n <mat-form-field style=\"width: 100%\" [appearance]=\"appearance\">\n <mat-label style=\"text-transform: capitalize\">{{\n configuration.label\n }}</mat-label>\n <mat-select [multiple]=\"checkbox\" (selectionChange)=\"selectedData(control)\" [required]=\"required\"\n [formControl]=\"$any(control)\" [disabled]=\"disabled\">\n <app-select-filter [noResultsMessage]=\"'No hay resultados'\" *ngIf=\"filter\" [placeholder]=\"'Filter'\" [displayMember]=\"configuration.visibleField\"\n [array]=\"dataCombos\" (filteredReturn)=\"filteredList = $event\">\n </app-select-filter>\n <mat-option [value]=\"data[configuration.selectionField]\" *ngFor=\"let data of filteredList\">\n {{ data[configuration.visibleField] }}\n </mat-option>\n </mat-select>\n <mat-error *ngIf=\"required\">Campo requerido</mat-error>\n </mat-form-field>\n </div>\n</div>\n\n", styles: [".mat-mdc-form-field{width:100%}.combo-container{width:100%;display:flex;align-items:center}.icon-information{cursor:pointer;color:gray}.mat-icon{font-size:1.1rem}::ng-deep .custom-tooltip{background-color:#fbe870!important;color:#000!important;line-height:17px!important;font-size:.8rem}@media (max-width: 400px){combo-container{width:100%;justify-content:center;padding-left:8px;padding-right:8px}.mat-mdc-form-field{width:100%!important;min-width:120px;max-width:100vw;font-size:14px}.mat-mdc-select{font-size:14px}}\n"] }]
|
|
151
|
-
}], ctorParameters: () => [{ type: i1.HttpService }], propDecorators: { dataCombos: [{
|
|
152
|
-
type: Input
|
|
153
|
-
}], additionalData: [{
|
|
154
|
-
type: Input
|
|
155
|
-
}], configuration: [{
|
|
156
|
-
type: Input
|
|
157
|
-
}], filter: [{
|
|
158
|
-
type: Input
|
|
159
|
-
}], checkbox: [{
|
|
160
|
-
type: Input
|
|
161
|
-
}], required: [{
|
|
162
|
-
type: Input
|
|
163
|
-
}], disabled: [{
|
|
164
|
-
type: Input
|
|
165
|
-
}], addFinal: [{
|
|
166
|
-
type: Input
|
|
167
|
-
}], appearance: [{
|
|
168
|
-
type: Input
|
|
169
|
-
}], reloadCombo: [{
|
|
170
|
-
type: Input
|
|
171
|
-
}], control: [{
|
|
172
|
-
type: Input
|
|
173
|
-
}], tooltip: [{
|
|
174
|
-
type: ViewChild,
|
|
175
|
-
args: ['tooltip']
|
|
176
|
-
}], changeOption: [{
|
|
177
|
-
type: Output
|
|
178
|
-
}], changeOptionDataComplete: [{
|
|
179
|
-
type: Output
|
|
180
|
-
}], returnDataCombo: [{
|
|
181
|
-
type: Output
|
|
182
|
-
}] } });
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tYm9zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9icmFpbmxvcGVyLXVpL2NvbXBvbmVudHMvY29tYm9zL2NvbWJvcy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvYnJhaW5sb3Blci11aS9jb21wb25lbnRzL2NvbWJvcy9jb21ib3MuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFFVCxLQUFLLEVBQ0wsTUFBTSxFQUNOLFlBQVksRUFHWixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFtQixrQkFBa0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7Ozs7OztBQVFyRSxNQUFNLE9BQU8sZUFBZTtJQXVCTjtJQXRCWCxVQUFVLENBQWE7SUFDdkIsY0FBYyxDQUFhO0lBQzNCLGFBQWEsQ0FBc0I7SUFDbkMsTUFBTSxHQUFZLEtBQUssQ0FBQztJQUN4QixRQUFRLEdBQVksS0FBSyxDQUFDO0lBQzFCLFFBQVEsR0FBWSxLQUFLLENBQUM7SUFDMUIsUUFBUSxHQUFZLEtBQUssQ0FBQztJQUMxQixRQUFRLEdBQVksS0FBSyxDQUFDO0lBQzFCLFVBQVUsR0FBUSxFQUFFLENBQUM7SUFDckIsV0FBVyxDQUFvQjtJQUMvQixPQUFPLEdBQWdELElBQUksa0JBQWtCLEVBQUUsQ0FBQztJQUVsRixrQkFBa0IsR0FBVyxJQUFJLENBQUM7SUFDbEMsYUFBYSxHQUFZLEtBQUssQ0FBQztJQUVoQixPQUFPLENBQWE7SUFFaEMsWUFBWSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFDdkMsd0JBQXdCLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUNuRCxlQUFlLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUVwRCxZQUFZLENB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LGVBQWUsd2tCQ2xCNUIsbTFDQStCQTs7NEZEYmEsZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxRQUFRO2dGQUtULFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBS2dCLE9BQU87c0JBQTVCLFNBQVM7dUJBQUMsU0FBUztnQkFFVixZQUFZO3NCQUFyQixNQUFNO2dCQUNHLHdCQUF3QjtzQkFBakMsTUFBTTtnQkFDRyxlQUFlO3NCQUF4QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBPbkluaXQsXG4gIElucHV0LFxuICBPdXRwdXQsXG4gIEV2ZW50RW1pdHRlcixcbiAgU2ltcGxlQ2hhbmdlcyxcbiAgT25DaGFuZ2VzLFxuICBWaWV3Q2hpbGQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBVbnR5cGVkRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBIdHRwU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2h0dHAuc2VydmljZSc7XG5pbXBvcnQgeyBNYXRUb29sdGlwIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjb21ib3MnLFxuICB0ZW1wbGF0ZVVybDogJy4vY29tYm9zLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY29tYm9zLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIENvbWJvc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgQElucHV0KCkgZGF0YUNvbWJvczogQXJyYXk8YW55PjtcbiAgQElucHV0KCkgYWRkaXRpb25hbERhdGE6IEFycmF5PGFueT47XG4gIEBJbnB1dCgpIGNvbmZpZ3VyYXRpb246IENvbWJvc0NvbmZpZ3VyYXRpb247XG4gIEBJbnB1dCgpIGZpbHRlcjogYm9vbGVhbiA9IGZhbHNlO1xuICBASW5wdXQoKSBjaGVja2JveDogYm9vbGVhbiA9IGZhbHNlO1xuICBASW5wdXQoKSByZXF1aXJlZDogYm9vbGVhbiA9IGZhbHNlO1xuICBASW5wdXQoKSBkaXNhYmxlZDogYm9vbGVhbiA9IGZhbHNlO1xuICBASW5wdXQoKSBhZGRGaW5hbDogYm9vbGVhbiA9IGZhbHNlO1xuICBASW5wdXQoKSBhcHBlYXJhbmNlOiBhbnkgPSAnJztcbiAgQElucHV0KCkgcmVsb2FkQ29tYm86IEV2ZW50RW1pdHRlcjxhbnk+O1xuICBASW5wdXQoKSBjb250cm9sOiBBYnN0cmFjdENvbnRyb2wgfCBVbnR5cGVkRm9ybUNvbnRyb2wgfCBudWxsID0gbmV3IFVudHlwZWRGb3JtQ29udHJvbCgpO1xuXG4gIHB1YmxpYyB0b29sdGlwRGVzY3JpcHRpb246IHN0cmluZyA9IG51bGw7XG4gIHB1YmxpYyB0b29sdGlwQWN0aXZlOiBib29sZWFuID0gZmFsc2U7XG5cbiAgQFZpZXdDaGlsZCgndG9vbHRpcCcpIHRvb2x0aXA6IE1hdFRvb2x0aXA7XG5cbiAgQE91dHB1dCgpIGNoYW5nZU9wdGlvbiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuICBAT3V0cHV0KCkgY2hhbmdlT3B0aW9uRGF0YUNvbXBsZXRlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG4gIEBPdXRwdXQoKSByZXR1cm5EYXRhQ29tYm8gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBmaWx0ZXJlZExpc3Q6IEFycmF5PGFueT47XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cDogSHR0cFNlcnZpY2UpIHt9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLmNvbmZpZ3VyYXRpb24ubGFiZWwpIHtcbiAgICAgIHRoaXMuY29uZmlndXJhdGlvbi5sYWJlbCA9IHRoaXMuY29uZmlndXJhdGlvbi52aXNpYmxlRmllbGQ7XG4gICAgfVxuXG4gICAgdGhpcy5pbml0RGF0YSgpO1xuXG4gICAgaWYgKHRoaXMucmVsb2FkQ29tYm8pIHtcbiAgICAgIHRoaXMucmVsb2FkQ29tYm8uc3Vic2NyaWJlKChyZXMpID0+IHtcbiAgICAgICAgaWYgKHJlcyA9PSAnc2VsZWN0ZWQnKSB7XG4gICAgICAgICAgdGhpcy5jb250cm9sLnNldFZhbHVlKHRoaXMuY29uZmlndXJhdGlvbi5zZWxlY3RlZCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgdGhpcy5pbml0RGF0YSgpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gICAgdGhpcy5jb250cm9sLnNldFZhbHVlKHRoaXMuY29uZmlndXJhdGlvbi5zZWxlY3RlZCk7XG4gICAgLy9jb25zb2xlLmxvZyh0aGlzLmNvbmZpZ3VyYXRpb24pXG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgaWYgKHRoaXMuZGF0YUNvbWJvcyAmJiBjaGFuZ2VzPy5kYXRhQ29tYm9zKSB7XG4gICAgICB0aGlzLmRhdGFDb21ib3MgPSBjaGFuZ2VzLmRhdGFDb21ib3MuY3VycmVudFZhbHVlO1xuICAgICAgdGhpcy5maWx0ZXJlZExpc3QgPSB0aGlzLmRhdGFDb21ib3Muc2xpY2UoKTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5jb250cm9sICYmIHRoaXMuY29udHJvbC52YWx1ZSkge1xuICAgICAgdGhpcy5jb25maWd1cmF0aW9uLnNlbGVjdGVkID0gdGhpcy5jb250cm9sLnZhbHVlO1xuICAgIH1cbiAgfVxuXG4gIGluaXREYXRhKCkge1xuICAgIGlmICh0aGlzLmNvbmZpZ3VyYXRpb24udXJsQ29tYm8pIHtcbiAgICAgIHRoaXMuZ2V0RGF0YSgpO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAodGhpcy5kYXRhQ29tYm9zKSB7XG4gICAgICAgIHRoaXMuZmlsdGVyZWRMaXN0ID0gdGhpcy5kYXRhQ29tYm9zLnNsaWNlKCk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgZ2V0RGF0YSgpIHtcbiAgICB0aGlzLmh0dHBcbiAgICAgIC5nZXREYXRhKHRoaXMuY29uZmlndXJhdGlvbi51cmxDb21ibywgdGhpcy5jb25maWd1cmF0aW9uLnVybFBhcmFtcylcbiAgICAgIC5zdWJzY3JpYmUoXG4gICAgICAgIChyZXMpID0+IHtcbiAgICAgICAgICBpZiAocmVzWydjb2RlJ10gPT09IDApIHtcbiAgICAgICAgICAgIHRoaXMuZGF0YUNvbWJvcyA9IHJlc1snYm9keSddO1xuICAgICAgICAgICAgaWYgKHRoaXMuYWRkaXRpb25hbERhdGEpIHtcbiAgICAgICAgICAgICAgaWYgKHRoaXMuYWRkRmluYWwpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmRhdGFDb21ib3MgPSB0aGlzLmRhdGFDb21ib3MuY29uY2F0KHRoaXMuYWRkaXRpb25hbERhdGEpO1xuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHRoaXMuZGF0YUNvbWJvcyA9IHRoaXMuYWRkaXRpb25hbERhdGEuY29uY2F0KHRoaXMuZGF0YUNvbWJvcyk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRoaXMucmV0dXJuRGF0YUNvbWJvLmVtaXQodGhpcy5kYXRhQ29tYm9zKTtcbiAgICAgICAgICAgIHRoaXMuZmlsdGVyZWRMaXN0ID0gdGhpcy5kYXRhQ29tYm9zLnNsaWNlKCk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKCdlcnJvciBlbiBsYSBjb25zdWx0YSBwYXJhIGRhdG9zIGNvbWJvJyk7XG4gICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICAoZXJyKSA9PiB7XG4gICAgICAgICAgY29uc29sZS5sb2coZXJyKTtcbiAgICAgICAgfVxuICAgICAgKTtcbiAgfVxuXG4gIHNlbGVjdGVkRGF0YSgkZXZlbnQpIHtcbiAgICB0aGlzLmZpbmREYXRhKCRldmVudCk7XG4gICAgdGhpcy5jaGFuZ2VPcHRpb24uZW1pdCgkZXZlbnQudmFsdWUpO1xuICB9XG5cbiAgZmluZERhdGEoJGV2ZW50KSB7XG4gICAgbGV0IGQgPSBbXTtcbiAgICBpZiAodGhpcy5jaGVja2JveCkge1xuICAgICAgY29uc3QgbG9va3VwID0gbmV3IE1hcChcbiAgICAgICAgdGhpcy5kYXRhQ29tYm9zLm1hcCgoaXRlbSkgPT4gW1xuICAgICAgICAgIGl0ZW1bdGhpcy5jb25maWd1cmF0aW9uLnNlbGVjdGlvbkZpZWxkXSxcbiAgICAgICAgICBpdGVtLFxuICAgICAgICBdKVxuICAgICAgKTtcbiAgICAgIGZvciAoY29uc3QgaWQgb2YgJGV2ZW50LnZhbHVlKSB7XG4gICAgICAgIGNvbnN0IGZvdW5kSXRlbSA9IGxvb2t1cC5nZXQoaWQpO1xuICAgICAgICBpZiAoZm91bmRJdGVtKSB7XG4gICAgICAgICAgZC5wdXNoKGZvdW5kSXRlbSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgZCA9IHRoaXMuZGF0YUNvbWJvcy5maW5kKFxuICAgICAgICAoeCkgPT4geFt0aGlzLmNvbmZpZ3VyYXRpb24uc2VsZWN0aW9uRmllbGRdID09ICRldmVudC52YWx1ZVxuICAgICAgKTtcbiAgICB9XG4gICAgdGhpcy5jaGFuZ2VPcHRpb25EYXRhQ29tcGxldGUuZW1pdChkKTtcblxuICAgIGlmICh0aGlzLmNvbmZpZ3VyYXRpb24uZmlsZVRvb2x0aXAgJiYgIXRoaXMuY2hlY2tib3gpIHtcbiAgICAgIGlmIChkKSB7XG4gICAgICAgIHRoaXMudG9vbHRpcERlc2NyaXB0aW9uID0gZFt0aGlzLmNvbmZpZ3VyYXRpb24uZmlsZVRvb2x0aXBdO1xuICAgICAgICB0aGlzLnRvb2x0aXBBY3RpdmUgPSB0cnVlO1xuICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICB0aGlzLnRvb2x0aXAuc2hvdygpO1xuICAgICAgICB9LCA1MCk7XG4gICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgIHRoaXMudG9vbHRpcC5oaWRlKCk7XG4gICAgICAgIH0sIDEwMDAwKTtcbiAgICAgIH0gZWxzZSB0aGlzLnRvb2x0aXBEZXNjcmlwdGlvbiA9IG51bGw7XG4gICAgfSBlbHNlIHRoaXMudG9vbHRpcERlc2NyaXB0aW9uID0gbnVsbDtcbiAgfVxuXG4gIHRvZ2dsZVRvb2x0aXAoKSB7XG4gICAgdGhpcy50b29sdGlwQWN0aXZlID0gIXRoaXMudG9vbHRpcEFjdGl2ZTtcbiAgICBpZiAodGhpcy50b29sdGlwQWN0aXZlKSB7XG4gICAgICB0aGlzLnRvb2x0aXAuc2hvdygpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnRvb2x0aXAuaGlkZSgpO1xuICAgIH1cbiAgfVxufVxuXG5pbnRlcmZhY2UgQ29tYm9zQ29uZmlndXJhdGlvbiB7XG4gIHNlbGVjdGlvbkZpZWxkPzogc3RyaW5nO1xuICB2aXNpYmxlRmllbGQ/OiBzdHJpbmc7XG4gIHVybENvbWJvPzogc3RyaW5nO1xuICB1cmxQYXJhbXM/OiBhbnlbXTtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYW55O1xuICBmaWxlVG9vbHRpcD86IHN0cmluZztcbn1cbiIsIjxkaXYgc3R5bGU9XCJkaXNwbGF5OiBmbGV4OyBmbGV4LWRpcmVjdGlvbjogcm93OyBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW5cIj5cbiAgPGRpdiBjbGFzcz1cImNvbWJvLWNvbnRhaW5lclwiPlxuXG4gICAgPG1hdC1pY29uXG4gICAgICBjbGFzcz1cIm0tMSBpY29uLWluZm9ybWF0aW9uXCJcbiAgICAgICpuZ0lmPVwidG9vbHRpcERlc2NyaXB0aW9uXCJcbiAgICAgIG1hdFRvb2x0aXA9XCJ7e3Rvb2x0aXBEZXNjcmlwdGlvbn19XCJcbiAgICAgIG1hdFRvb2x0aXBQb3NpdGlvbj1cImFib3ZlXCJcbiAgICAgICN0b29sdGlwPVwibWF0VG9vbHRpcFwiXG4gICAgICAoY2xpY2spPVwidG9nZ2xlVG9vbHRpcCgpXCJcbiAgICAgIG1hdFRvb2x0aXBDbGFzcz1cImN1c3RvbS10b29sdGlwXCJcbiAgICAgPmluZm88L21hdC1pY29uPlxuXG4gICAgPG1hdC1mb3JtLWZpZWxkIHN0eWxlPVwid2lkdGg6IDEwMCVcIiBbYXBwZWFyYW5jZV09XCJhcHBlYXJhbmNlXCI+XG4gICAgICA8bWF0LWxhYmVsIHN0eWxlPVwidGV4dC10cmFuc2Zvcm06IGNhcGl0YWxpemVcIj57e1xuICAgICAgICBjb25maWd1cmF0aW9uLmxhYmVsXG4gICAgICAgIH19PC9tYXQtbGFiZWw+XG4gICAgICA8bWF0LXNlbGVjdCBbbXVsdGlwbGVdPVwiY2hlY2tib3hcIiAoc2VsZWN0aW9uQ2hhbmdlKT1cInNlbGVjdGVkRGF0YShjb250cm9sKVwiIFtyZXF1aXJlZF09XCJyZXF1aXJlZFwiXG4gICAgICAgIFtmb3JtQ29udHJvbF09XCIkYW55KGNvbnRyb2wpXCIgW2Rpc2FibGVkXT1cImRpc2FibGVkXCI+XG4gICAgICAgIDxhcHAtc2VsZWN0LWZpbHRlciBbbm9SZXN1bHRzTWVzc2FnZV09XCInTm8gaGF5IHJlc3VsdGFkb3MnXCIgKm5nSWY9XCJmaWx0ZXJcIiBbcGxhY2Vob2xkZXJdPVwiJ0ZpbHRlcidcIiBbZGlzcGxheU1lbWJlcl09XCJjb25maWd1cmF0aW9uLnZpc2libGVGaWVsZFwiXG4gICAgICAgICAgW2FycmF5XT1cImRhdGFDb21ib3NcIiAoZmlsdGVyZWRSZXR1cm4pPVwiZmlsdGVyZWRMaXN0ID0gJGV2ZW50XCI+XG4gICAgICAgIDwvYXBwLXNlbGVjdC1maWx0ZXI+XG4gICAgICAgIDxtYXQtb3B0aW9uIFt2YWx1ZV09XCJkYXRhW2NvbmZpZ3VyYXRpb24uc2VsZWN0aW9uRmllbGRdXCIgKm5nRm9yPVwibGV0IGRhdGEgb2YgZmlsdGVyZWRMaXN0XCI+XG4gICAgICAgICAge3sgZGF0YVtjb25maWd1cmF0aW9uLnZpc2libGVGaWVsZF0gfX1cbiAgICAgICAgPC9tYXQtb3B0aW9uPlxuICAgICAgPC9tYXQtc2VsZWN0PlxuICAgICAgPG1hdC1lcnJvciAqbmdJZj1cInJlcXVpcmVkXCI+Q2FtcG8gcmVxdWVyaWRvPC9tYXQtZXJyb3I+XG4gICAgPC9tYXQtZm9ybS1maWVsZD5cbiAgPC9kaXY+XG48L2Rpdj5cblxuIl19
|