@po-ui/ng-components 14.1.0 → 14.3.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.
Files changed (63) hide show
  1. package/esm2020/lib/components/po-breadcrumb/po-breadcrumb-dropdown/po-breadcrumb-dropdown.component.mjs +5 -3
  2. package/esm2020/lib/components/po-button/po-button-base.component.mjs +58 -8
  3. package/esm2020/lib/components/po-button/po-button-size.enum.mjs +6 -0
  4. package/esm2020/lib/components/po-button/po-button.component.mjs +4 -4
  5. package/esm2020/lib/components/po-button-group/po-button-group-base.component.mjs +8 -1
  6. package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.mjs +1 -1
  7. package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.mjs +12 -12
  8. package/esm2020/lib/components/po-field/po-checkbox/po-checkbox-base.component.mjs +11 -2
  9. package/esm2020/lib/components/po-field/po-checkbox/po-checkbox.component.mjs +24 -12
  10. package/esm2020/lib/components/po-field/po-checkbox-group/po-checkbox-group.component.mjs +14 -20
  11. package/esm2020/lib/components/po-field/po-checkbox-group/po-checkbox-group.module.mjs +5 -4
  12. package/esm2020/lib/components/po-field/po-combo/po-combo-base.component.mjs +74 -43
  13. package/esm2020/lib/components/po-field/po-combo/po-combo.component.mjs +17 -15
  14. package/esm2020/lib/components/po-field/po-datepicker/po-datepicker-base.component.mjs +3 -8
  15. package/esm2020/lib/components/po-field/po-datepicker/po-datepicker.component.mjs +2 -1
  16. package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range-base.component.mjs +25 -2
  17. package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range.component.mjs +5 -5
  18. package/esm2020/lib/components/po-field/po-lookup/po-lookup-base.component.mjs +28 -2
  19. package/esm2020/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal-base.component.mjs +28 -2
  20. package/esm2020/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +4 -4
  21. package/esm2020/lib/components/po-field/po-lookup/po-lookup.component.mjs +5 -3
  22. package/esm2020/lib/components/po-field/po-lookup/services/po-lookup-modal.service.mjs +6 -2
  23. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +2 -2
  24. package/esm2020/lib/components/po-field/po-rich-text/po-rich-text-toolbar/po-rich-text-toolbar.component.mjs +9 -9
  25. package/esm2020/lib/components/po-field/po-select/po-select.component.mjs +90 -25
  26. package/esm2020/lib/components/po-field/po-upload/po-upload-base.service.mjs +4 -2
  27. package/esm2020/lib/components/po-list-view/po-list-view.component.mjs +3 -3
  28. package/esm2020/lib/components/po-table/po-table-base.component.mjs +21 -2
  29. package/esm2020/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.mjs +3 -3
  30. package/esm2020/lib/components/po-table/po-table.component.mjs +511 -476
  31. package/esm2020/lib/components/po-widget/po-widget-base.component.mjs +3 -2
  32. package/esm2020/lib/components/po-widget/po-widget.component.mjs +24 -12
  33. package/esm2020/lib/utils/util.mjs +21 -12
  34. package/fesm2015/po-ui-ng-components.mjs +1288 -952
  35. package/fesm2015/po-ui-ng-components.mjs.map +1 -1
  36. package/fesm2020/po-ui-ng-components.mjs +1266 -937
  37. package/fesm2020/po-ui-ng-components.mjs.map +1 -1
  38. package/lib/components/po-button/po-button-base.component.d.ts +29 -4
  39. package/lib/components/po-button/po-button-size.enum.d.ts +4 -0
  40. package/lib/components/po-button-group/po-button-group-base.component.d.ts +7 -0
  41. package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.d.ts +18 -0
  42. package/lib/components/po-field/po-checkbox/po-checkbox-base.component.d.ts +2 -1
  43. package/lib/components/po-field/po-checkbox-group/po-checkbox-group.module.d.ts +2 -1
  44. package/lib/components/po-field/po-combo/po-combo-base.component.d.ts +27 -22
  45. package/lib/components/po-field/po-datepicker-range/po-datepicker-range-base.component.d.ts +13 -1
  46. package/lib/components/po-field/po-lookup/po-lookup-base.component.d.ts +21 -1
  47. package/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal-base.component.d.ts +21 -1
  48. package/lib/components/po-field/po-lookup/services/po-lookup-modal.service.d.ts +4 -0
  49. package/lib/components/po-field/po-select/po-select.component.d.ts +36 -7
  50. package/lib/components/po-table/po-table-base.component.d.ts +12 -1
  51. package/lib/components/po-table/po-table.component.d.ts +6 -0
  52. package/lib/components/po-widget/po-widget-base.component.d.ts +1 -0
  53. package/lib/utils/util.d.ts +2 -1
  54. package/package.json +4 -4
  55. package/po-ui-ng-components-14.3.0.tgz +0 -0
  56. package/schematics/ng-add/index.js +1 -1
  57. package/schematics/ng-update/v14/index.js +1 -1
  58. package/schematics/ng-update/v2/index.js +1 -1
  59. package/schematics/ng-update/v3/index.js +1 -1
  60. package/schematics/ng-update/v4/index.js +1 -1
  61. package/schematics/ng-update/v5/index.js +1 -1
  62. package/schematics/ng-update/v6/index.js +1 -1
  63. package/po-ui-ng-components-14.1.0.tgz +0 -0
@@ -1,11 +1,11 @@
1
1
  import { __decorate } from "tslib";
2
- import { ChangeDetectionStrategy, Component, ElementRef, forwardRef, HostListener, ViewChild, Input, Output, EventEmitter } from '@angular/core';
3
- import { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';
4
- import { isMobile, removeDuplicatedOptions, removeUndefinedAndNullOptions, validValue } from '../../../utils/util';
5
- import { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';
2
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, Output, ViewChild } from '@angular/core';
3
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { isMobile, removeDuplicatedOptions, removeDuplicatedOptionsWithFieldValue, removeUndefinedAndNullOptions, removeUndefinedAndNullOptionsWithFieldValue, validValue } from '../../../utils/util';
6
5
  import { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';
7
- import { PoFieldValidateModel } from '../po-field-validate.model';
6
+ import { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';
8
7
  import { InputBoolean } from '../../../decorators';
8
+ import { PoFieldValidateModel } from '../po-field-validate.model';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "./../../../services/po-control-position/po-control-position.service";
11
11
  import * as i2 from "@angular/common";
@@ -28,9 +28,9 @@ function PoSelectComponent_option_4_Template(rf, ctx) { if (rf & 1) {
28
28
  } if (rf & 2) {
29
29
  const option_r7 = ctx.$implicit;
30
30
  const ctx_r2 = i0.ɵɵnextContext();
31
- i0.ɵɵproperty("disabled", ctx_r2.readonly)("value", option_r7.value);
31
+ i0.ɵɵproperty("disabled", ctx_r2.readonly)("value", option_r7 == null ? null : option_r7[ctx_r2.fieldValue]);
32
32
  i0.ɵɵadvance(1);
33
- i0.ɵɵtextInterpolate1(" ", option_r7 == null ? null : option_r7.label, " ");
33
+ i0.ɵɵtextInterpolate1(" ", option_r7 == null ? null : option_r7[ctx_r2.fieldLabel], " ");
34
34
  } }
35
35
  function PoSelectComponent_li_15_ng_container_2_Template(rf, ctx) { if (rf & 1) {
36
36
  i0.ɵɵelementContainer(0);
@@ -41,8 +41,9 @@ function PoSelectComponent_li_15_ng_template_3_Template(rf, ctx) { if (rf & 1) {
41
41
  i0.ɵɵelementEnd();
42
42
  } if (rf & 2) {
43
43
  const option_r10 = i0.ɵɵnextContext().$implicit;
44
+ const ctx_r13 = i0.ɵɵnextContext();
44
45
  i0.ɵɵadvance(1);
45
- i0.ɵɵtextInterpolate(option_r10 == null ? null : option_r10.label);
46
+ i0.ɵɵtextInterpolate(option_r10 == null ? null : option_r10[ctx_r13.fieldLabel]);
46
47
  } }
47
48
  function PoSelectComponent_li_15_ng_template_5_Template(rf, ctx) { }
48
49
  const _c4 = function (a0) { return { $implicit: a0 }; };
@@ -60,8 +61,8 @@ function PoSelectComponent_li_15_Template(rf, ctx) { if (rf & 1) {
60
61
  const _r12 = i0.ɵɵreference(4);
61
62
  const _r14 = i0.ɵɵreference(6);
62
63
  const ctx_r6 = i0.ɵɵnextContext();
63
- i0.ɵɵclassProp("po-select-item-selected", ctx_r6.selectedValue === option_r10.value);
64
- i0.ɵɵproperty("value", option_r10.value);
64
+ i0.ɵɵclassProp("po-select-item-selected", ctx_r6.selectedValue === (option_r10 == null ? null : option_r10[ctx_r6.fieldLabel]));
65
+ i0.ɵɵproperty("value", option_r10 == null ? null : option_r10[ctx_r6.fieldValue]);
65
66
  i0.ɵɵadvance(2);
66
67
  i0.ɵɵproperty("ngIf", ctx_r6.selectOptionTemplate)("ngIfThen", _r14)("ngIfElse", _r12);
67
68
  i0.ɵɵadvance(3);
@@ -73,6 +74,8 @@ const _c7 = function (a0, a1) { return { "po-field-icon-disabled": a0, "po-field
73
74
  const _c8 = function (a0) { return { "po-invisible": a0 }; };
74
75
  const poSelectContentOffset = 8;
75
76
  const poSelectContentPositionDefault = 'bottom';
77
+ const PO_SELECT_FIELD_LABEL_DEFAULT = 'label';
78
+ const PO_SELECT_FIELD_VALUE_DEFAULT = 'value';
76
79
  /**
77
80
  * @docsExtends PoFieldValidateModel
78
81
  *
@@ -96,6 +99,11 @@ const poSelectContentPositionDefault = 'bottom';
96
99
  * <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.po.ts'> </file>
97
100
  * </example>
98
101
  *
102
+ * <example name="po-select-companies" title="PO Select Companies">
103
+ * <file name="sample-po-select-companies/sample-po-select-companies.component.html"> </file>
104
+ * <file name="sample-po-select-companies/sample-po-select-companies.component.ts"> </file>
105
+ * </example>
106
+ *
99
107
  * @description
100
108
  *
101
109
  * O componente po-select exibe uma lista de valores e permite que o usuário selecione um desses valores.
@@ -146,6 +154,8 @@ export class PoSelectComponent extends PoFieldValidateModel {
146
154
  this.isMobile = isMobile();
147
155
  this.open = false;
148
156
  this.selectIcon = 'po-icon-arrow-down';
157
+ this._fieldLabel = PO_SELECT_FIELD_LABEL_DEFAULT;
158
+ this._fieldValue = PO_SELECT_FIELD_VALUE_DEFAULT;
149
159
  this.onScroll = () => {
150
160
  this.controlPosition.adjustPosition(poSelectContentPositionDefault);
151
161
  };
@@ -168,14 +178,55 @@ export class PoSelectComponent extends PoFieldValidateModel {
168
178
  * ```
169
179
  */
170
180
  set options(options) {
171
- this._options = options;
172
- removeDuplicatedOptions(this._options);
173
- removeUndefinedAndNullOptions(this._options);
181
+ if (this.fieldLabel && this.fieldValue) {
182
+ options.map(option => {
183
+ option.label = option[this.fieldLabel];
184
+ option.value = option[this.fieldValue];
185
+ });
186
+ }
187
+ this.validateOptions([...options]);
174
188
  this.onUpdateOptions();
189
+ this._options = [...options];
175
190
  }
176
191
  get options() {
177
192
  return this._options;
178
193
  }
194
+ /**
195
+ * @optional
196
+ *
197
+ * @description
198
+ * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente
199
+ * (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.
200
+ *
201
+ * @default `label`
202
+ */
203
+ set fieldLabel(value) {
204
+ this._fieldLabel = value || PO_SELECT_FIELD_LABEL_DEFAULT;
205
+ if (this.options && this.options.length > 0) {
206
+ this.options = [...this.options];
207
+ }
208
+ }
209
+ get fieldLabel() {
210
+ return this._fieldLabel;
211
+ }
212
+ /**
213
+ * @optional
214
+ *
215
+ * @description
216
+ * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente
217
+ * (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.
218
+ *
219
+ * @default `value`
220
+ */
221
+ set fieldValue(value) {
222
+ this._fieldValue = value || PO_SELECT_FIELD_VALUE_DEFAULT;
223
+ if (this.options && this.options.length > 0) {
224
+ this.options = [...this.options];
225
+ }
226
+ }
227
+ get fieldValue() {
228
+ return this._fieldValue;
229
+ }
179
230
  get isInvisibleSelectNative() {
180
231
  return this.readonly && this.isMobile;
181
232
  }
@@ -209,6 +260,8 @@ export class PoSelectComponent extends PoFieldValidateModel {
209
260
  if (change) {
210
261
  removeDuplicatedOptions(this.options);
211
262
  removeUndefinedAndNullOptions(this.options);
263
+ removeDuplicatedOptionsWithFieldValue(this.options, this.fieldValue);
264
+ removeUndefinedAndNullOptionsWithFieldValue(this.options, this.fieldValue);
212
265
  }
213
266
  }
214
267
  /**
@@ -275,12 +328,12 @@ export class PoSelectComponent extends PoFieldValidateModel {
275
328
  }
276
329
  // Atualiza valores
277
330
  updateValues(option) {
278
- if (this.selectedValue !== option.value) {
279
- this.selectedValue = option.value;
280
- this.selectElement.nativeElement.value = option.value;
281
- this.updateModel(option.value);
282
- this.displayValue = option.label;
283
- this.emitChange(option.value);
331
+ if (this.selectedValue !== option[this.fieldValue]) {
332
+ this.selectedValue = option[this.fieldValue];
333
+ this.selectElement.nativeElement.value = option[this.fieldValue];
334
+ this.updateModel(option[this.fieldValue]);
335
+ this.displayValue = option[this.fieldLabel];
336
+ this.emitChange(option[this.fieldValue]);
284
337
  }
285
338
  }
286
339
  // Esconde Content do Select quando for clicado fora
@@ -295,9 +348,9 @@ export class PoSelectComponent extends PoFieldValidateModel {
295
348
  const optionFound = this.findOptionValue(value);
296
349
  if (optionFound) {
297
350
  this.selectElement.nativeElement.value = optionFound.value;
298
- this.selectedValue = optionFound.value;
299
- this.displayValue = optionFound.label;
300
- this.setScrollPosition(optionFound.value);
351
+ this.selectedValue = optionFound[this.fieldValue];
352
+ this.displayValue = optionFound[this.fieldLabel];
353
+ this.setScrollPosition(optionFound[this.fieldValue]);
301
354
  }
302
355
  else if (validValue(this.selectedValue)) {
303
356
  this.selectElement.nativeElement.value = undefined;
@@ -380,6 +433,12 @@ export class PoSelectComponent extends PoFieldValidateModel {
380
433
  }
381
434
  }
382
435
  }
436
+ validateOptions(options) {
437
+ removeDuplicatedOptions(options);
438
+ removeUndefinedAndNullOptions(options);
439
+ removeDuplicatedOptionsWithFieldValue(options, this.fieldValue);
440
+ removeUndefinedAndNullOptionsWithFieldValue(options, this.fieldValue);
441
+ }
383
442
  }
384
443
  PoSelectComponent.ɵfac = function PoSelectComponent_Factory(t) { return new (t || PoSelectComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i0.IterableDiffers), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i1.PoControlPositionService)); };
385
444
  PoSelectComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSelectComponent, selectors: [["po-select"]], viewQuery: function PoSelectComponent_Query(rf, ctx) { if (rf & 1) {
@@ -395,7 +454,7 @@ PoSelectComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSelectC
395
454
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.selectButtonElement = _t.first);
396
455
  } }, hostBindings: function PoSelectComponent_HostBindings(rf, ctx) { if (rf & 1) {
397
456
  i0.ɵɵlistener("keydown", function PoSelectComponent_keydown_HostBindingHandler($event) { return ctx.onKeydown($event); });
398
- } }, inputs: { readonly: ["p-readonly", "readonly"], placeholder: ["p-placeholder", "placeholder"], options: ["p-options", "options"] }, outputs: { ngModelChange: "ngModelChange" }, features: [i0.ɵɵProvidersFeature([
457
+ } }, inputs: { readonly: ["p-readonly", "readonly"], placeholder: ["p-placeholder", "placeholder"], options: ["p-options", "options"], fieldLabel: ["p-field-label", "fieldLabel"], fieldValue: ["p-field-value", "fieldValue"] }, outputs: { ngModelChange: "ngModelChange" }, features: [i0.ɵɵProvidersFeature([
399
458
  {
400
459
  provide: NG_VALUE_ACCESSOR,
401
460
  useExisting: forwardRef(() => PoSelectComponent),
@@ -464,7 +523,7 @@ __decorate([
464
523
  multi: true
465
524
  },
466
525
  PoControlPositionService
467
- ], template: "<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n <select\n #select\n class=\"po-select\"\n [attr.name]=\"name\"\n [disabled]=\"disabled\"\n [ngClass]=\"{ 'po-select-mobile': isMobile, 'po-invisible': isInvisibleSelectNative }\"\n [required]=\"required\"\n (change)=\"onSelectChange($event.target.value)\"\n (blur)=\"onBlur()\"\n >\n <option *ngIf=\"isMobile\" disabled hidden selected></option>\n <option *ngFor=\"let option of options\" [disabled]=\"readonly\" [value]=\"option.value\" (click)=\"onOptionClick(option)\">\n {{ option?.label }}\n </option>\n </select>\n\n <div class=\"po-select-container\">\n <div\n #selectButton\n class=\"po-select-button\"\n [ngClass]=\"{ 'po-select-button-disabled': disabled, 'po-select-button-readonly': readonly }\"\n (click)=\"toggleButton()\"\n >\n <span>{{ displayValue || placeholder }}</span>\n\n <div class=\"po-field-icon-container-right\">\n <span\n #icon\n class=\"po-icon {{ selectIcon }} po-field-icon\"\n [ngClass]=\"{ 'po-field-icon-disabled': disabled, 'po-field-icon-readonly': readonly }\"\n ></span>\n </div>\n </div>\n\n <ul #contentList class=\"po-select-content\" [ngClass]=\"{ 'po-invisible': isMobile }\">\n <li\n *ngFor=\"let option of options\"\n [class.po-select-item-selected]=\"selectedValue === option.value\"\n [value]=\"option.value\"\n (click)=\"onOptionClick(option)\"\n >\n <div class=\"po-select-item\">\n <ng-container *ngIf=\"selectOptionTemplate; then optionTemplate; else defaultOptionTemplate\"></ng-container>\n\n <ng-template #defaultOptionTemplate>\n <span>{{ option?.label }}</span>\n </ng-template>\n\n <ng-template\n #optionTemplate\n [ngTemplateOutlet]=\"selectOptionTemplate?.templateRef\"\n [ngTemplateOutletContext]=\"{ $implicit: option }\"\n >\n </ng-template>\n </div>\n </li>\n </ul>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
526
+ ], template: "<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n <select\n #select\n class=\"po-select\"\n [attr.name]=\"name\"\n [disabled]=\"disabled\"\n [ngClass]=\"{ 'po-select-mobile': isMobile, 'po-invisible': isInvisibleSelectNative }\"\n [required]=\"required\"\n (change)=\"onSelectChange($event.target.value)\"\n (blur)=\"onBlur()\"\n >\n <option *ngIf=\"isMobile\" disabled hidden selected></option>\n <option\n *ngFor=\"let option of options\"\n [disabled]=\"readonly\"\n [value]=\"option?.[this.fieldValue]\"\n (click)=\"onOptionClick(option)\"\n >\n {{ option?.[this.fieldLabel] }}\n </option>\n </select>\n\n <div class=\"po-select-container\">\n <div\n #selectButton\n class=\"po-select-button\"\n [ngClass]=\"{ 'po-select-button-disabled': disabled, 'po-select-button-readonly': readonly }\"\n (click)=\"toggleButton()\"\n >\n <span>{{ displayValue || placeholder }}</span>\n\n <div class=\"po-field-icon-container-right\">\n <span\n #icon\n class=\"po-icon {{ selectIcon }} po-field-icon\"\n [ngClass]=\"{ 'po-field-icon-disabled': disabled, 'po-field-icon-readonly': readonly }\"\n ></span>\n </div>\n </div>\n\n <ul #contentList class=\"po-select-content\" [ngClass]=\"{ 'po-invisible': isMobile }\">\n <li\n *ngFor=\"let option of options\"\n [class.po-select-item-selected]=\"selectedValue === option?.[this.fieldLabel]\"\n [value]=\"option?.[this.fieldValue]\"\n (click)=\"onOptionClick(option)\"\n >\n <div class=\"po-select-item\">\n <ng-container *ngIf=\"selectOptionTemplate; then optionTemplate; else defaultOptionTemplate\"></ng-container>\n\n <ng-template #defaultOptionTemplate>\n <span>{{ option?.[this.fieldLabel] }}</span>\n </ng-template>\n\n <ng-template\n #optionTemplate\n [ngTemplateOutlet]=\"selectOptionTemplate?.templateRef\"\n [ngTemplateOutletContext]=\"{ $implicit: option }\"\n >\n </ng-template>\n </div>\n </li>\n </ul>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
468
527
  }], function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.IterableDiffers }, { type: i0.Renderer2 }, { type: i1.PoControlPositionService }]; }, { contentList: [{
469
528
  type: ViewChild,
470
529
  args: ['contentList', { read: ElementRef, static: true }]
@@ -489,8 +548,14 @@ __decorate([
489
548
  }], options: [{
490
549
  type: Input,
491
550
  args: ['p-options']
551
+ }], fieldLabel: [{
552
+ type: Input,
553
+ args: ['p-field-label']
554
+ }], fieldValue: [{
555
+ type: Input,
556
+ args: ['p-field-value']
492
557
  }], onKeydown: [{
493
558
  type: HostListener,
494
559
  args: ['keydown', ['$event']]
495
560
  }] }); })();
496
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ContentChild,\n  Component,\n  DoCheck,\n  ElementRef,\n  forwardRef,\n  HostListener,\n  IterableDiffers,\n  Renderer2,\n  ViewChild,\n  Input,\n  Output,\n  EventEmitter\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS, AbstractControl } from '@angular/forms';\n\nimport { isMobile, removeDuplicatedOptions, removeUndefinedAndNullOptions, validValue } from '../../../utils/util';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\n\nimport { PoSelectOption } from './po-select-option.interface';\nimport { PoFieldValidateModel } from '../po-field-validate.model';\nimport { InputBoolean } from '../../../decorators';\n\nconst poSelectContentOffset = 8;\nconst poSelectContentPositionDefault = 'bottom';\n\n/**\n * @docsExtends PoFieldValidateModel\n *\n * @example\n *\n * <example name=\"po-select-basic\" title=\"PO Select Basic\">\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.html\"> </file>\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-labs\" title=\"PO Select Labs\">\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.html\"> </file>\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-customer-registration\" title=\"PO Select - Customer registration\">\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.html\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.ts\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.service.ts\"> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.e2e-spec.ts'> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.po.ts'> </file>\n * </example>\n *\n * @description\n *\n * O componente po-select exibe uma lista de valores e permite que o usuário selecione um desses valores.\n * Os valores listados podem ser fixos ou dinâmicos de acordo com a necessidade do desenvolvedor, dando mais flexibilidade ao componente.\n * O po-select não permite que o usuário informe um valor diferente dos valores listados, isso garante a consistência da informação.\n * O po-select não permite que sejam passados valores duplicados, undefined e null para as opções, excluindo-os da lista.\n *\n * > Ao passar um valor para o _model_ que não está na lista de opções, o mesmo será definido como `undefined`.\n *\n * Também existe a possibilidade de utilizar um _template_ para a exibição dos itens da lista,\n * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.\n *\n * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.\n */\n@Component({\n  selector: 'po-select',\n  templateUrl: './po-select.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    PoControlPositionService\n  ]\n})\nexport class PoSelectComponent extends PoFieldValidateModel<any> implements DoCheck {\n  @ViewChild('contentList', { read: ElementRef, static: true }) contentList: ElementRef;\n  @ViewChild('icon', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('select', { read: ElementRef, static: true }) selectElement: ElementRef;\n  @ViewChild('selectButton', { read: ElementRef, static: true }) selectButtonElement: ElementRef;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Função para atualizar o ngModel do componente, necessário quando não for utilizado dentro da tag form.\n   *\n   * Na versão 12.2.0 do Angular a verificação `strictTemplates` vem true como default. Portanto, para utilizar\n   * two-way binding no componente deve se utilizar da seguinte forma:\n   *\n   * ```\n   * <po-select ... [ngModel]=\"selectModel\" (ngModelChange)=\"selectModel = $event\"> </po-select>\n   * ```\n   */\n  @Output('ngModelChange') ngModelChange: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente para leitura.\n   *\n   * @default `false`\n   */\n  @Input('p-readonly') @InputBoolean() readonly: boolean = false;\n\n  /** Mensagem que aparecerá enquanto nenhuma opção estiver selecionada. */\n  @Input('p-placeholder') placeholder?: string;\n\n  displayValue;\n  isMobile: any = isMobile();\n  modelValue: any;\n  onModelChange: any;\n  open: boolean = false;\n  selectedValue: any;\n  selectOptionTemplate: any;\n  selectIcon: string = 'po-icon-arrow-down';\n  scrollPosition: number;\n\n  eventListenerFunction: () => void;\n  eventResizeListener: () => void;\n\n  onModelTouched: any;\n  protected clickoutListener: () => void;\n  private differ: any;\n  private _options: Array<PoSelectOption>;\n\n  /**\n   * Nesta propriedade deve ser definido uma coleção de objetos que implementam a interface `PoSelectOption`.\n   *\n   * Caso esta lista estiver vazia, o model será `undefined`.\n   *\n   * > Essa propriedade é imutável, ou seja, sempre que quiser atualizar a lista de opções disponíveis\n   * atualize a referência do objeto:\n   *\n   * ```\n   * // atualiza a referência do objeto garantindo a atualização do template\n   * this.options = [...this.options, { value: 'x', label: 'Nova opção' }];\n   *\n   * // evite, pois não atualiza a referência do objeto podendo gerar atrasos na atualização do template\n   * this.options.push({ value: 'x', label: 'Nova opção' });\n   * ```\n   */\n  @Input('p-options') set options(options: Array<PoSelectOption>) {\n    this._options = options;\n    removeDuplicatedOptions(this._options);\n    removeUndefinedAndNullOptions(this._options);\n    this.onUpdateOptions();\n  }\n\n  get options() {\n    return this._options;\n  }\n  /* istanbul ignore next */\n  constructor(\n    private element: ElementRef,\n    private changeDetector: ChangeDetectorRef,\n    differs: IterableDiffers,\n    public renderer: Renderer2,\n    private controlPosition: PoControlPositionService\n  ) {\n    super();\n    this.differ = differs.find([]).create(null);\n  }\n\n  get isInvisibleSelectNative() {\n    return this.readonly && this.isMobile;\n  }\n\n  @HostListener('keydown', ['$event']) onKeydown($event?: any) {\n    const charCode = $event.which || $event.keyCode;\n\n    // Tratamentos para quando o readonly for ativado.\n    if (this.readonly) {\n      // deve matar o evento do teclado devido a alterar o valor do model mesmo com os options fechados\n      if (charCode !== PoKeyCodeEnum.tab) {\n        this.disableDefaultEventAndToggleButton();\n        $event.preventDefault();\n      }\n      return;\n    }\n\n    // Seleciona os itens com as teclas \"up\" e \"down\"\n    if ((!this.open || $event.altKey) && (charCode === PoKeyCodeEnum.arrowDown || charCode === PoKeyCodeEnum.arrowUp)) {\n      this.disableDefaultEventAndToggleButton();\n    }\n\n    // Abre o po-select com as teclas \"enter\" e \"espaço\"\n    if (charCode === PoKeyCodeEnum.enter || charCode === PoKeyCodeEnum.space) {\n      this.disableDefaultEventAndToggleButton();\n    }\n\n    // Fecha o po-select com a tecla \"tab\"\n    if (this.open && charCode === PoKeyCodeEnum.tab) {\n      $event.preventDefault();\n      this.toggleButton();\n    }\n  }\n\n  ngDoCheck() {\n    const change = this.differ.diff(this.options);\n    if (change) {\n      removeDuplicatedOptions(this.options);\n      removeUndefinedAndNullOptions(this.options);\n    }\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoSelectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoSelectComponent, { static: true }) select: PoSelectComponent;\n   *\n   * focusSelect() {\n   *   this.select.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.selectElement.nativeElement.focus();\n    }\n  }\n\n  hideDropDown() {\n    this.selectIcon = 'po-icon-arrow-down';\n    this.selector('.po-select-container').classList.remove('po-select-show');\n    this.open = false;\n\n    this.changeDetector.markForCheck();\n    this.selectElement.nativeElement.focus();\n\n    this.removeListeners();\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  onOptionClick(option: PoSelectOption) {\n    this.updateValues(option);\n    this.toggleButton();\n  }\n\n  // Altera o valor ao selecionar um item.\n  onSelectChange(value: any) {\n    if (value && this.options && this.options.length) {\n      const optionFound: PoSelectOption = this.findOptionValue(value);\n\n      if (optionFound) {\n        this.updateValues(optionFound);\n        this.setScrollPosition(optionFound.value);\n      }\n    }\n  }\n\n  onUpdateOptions() {\n    if (this.modelValue) {\n      this.onSelectChange(this.modelValue);\n    }\n  }\n\n  scrollValue(index, clientHeight) {\n    const heightScrollValue: number = index * this.getSelectItemHeight();\n\n    return (this.scrollPosition = heightScrollValue > clientHeight ? heightScrollValue : 0);\n  }\n\n  selector(query: string): Element {\n    return this.element.nativeElement.querySelector(query);\n  }\n\n  toggleButton(): void {\n    this.open ? this.hideDropDown() : this.showDropdown();\n  }\n\n  // Atualiza valores\n  updateValues(option: PoSelectOption): void {\n    if (this.selectedValue !== option.value) {\n      this.selectedValue = option.value;\n      this.selectElement.nativeElement.value = option.value;\n      this.updateModel(option.value);\n      this.displayValue = option.label;\n      this.emitChange(option.value);\n    }\n  }\n\n  // Esconde Content do Select quando for clicado fora\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      !this.selectButtonElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target)\n    ) {\n      this.hideDropDown();\n    }\n  }\n\n  // Recebe as alterações do model\n  onWriteValue(value: any) {\n    const optionFound: PoSelectOption = this.findOptionValue(value);\n\n    if (optionFound) {\n      this.selectElement.nativeElement.value = optionFound.value;\n      this.selectedValue = optionFound.value;\n      this.displayValue = optionFound.label;\n      this.setScrollPosition(optionFound.value);\n    } else if (validValue(this.selectedValue)) {\n      this.selectElement.nativeElement.value = undefined;\n      this.updateModel(undefined);\n      this.selectedValue = undefined;\n      this.displayValue = undefined;\n    }\n\n    this.modelValue = value;\n    this.changeDetector.detectChanges();\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  private isEqual(value: any, inputValue: any): boolean {\n    if ((value || value === 0) && inputValue) {\n      return value.toString() === inputValue.toString();\n    }\n\n    if ((value === null && inputValue !== null) || (value === undefined && inputValue !== undefined)) {\n      value = `${value}`; // Transformando em string\n    }\n\n    return value === inputValue;\n  }\n\n  // Método necessário para bloquear o evento default do select nativo.\n  // Ao utilizar event.preventDefault(), nos navegadores Firefox e IE o mesmo não cancela o evento.\n  private disableDefaultEventAndToggleButton() {\n    this.selectElement.nativeElement.style.display = 'none';\n\n    setTimeout(() => {\n      this.selectElement.nativeElement.style.display = 'block';\n      this.toggleButton();\n    });\n  }\n\n  private findOptionValue(value: any) {\n    return this.options.find(option => this.isEqual(option.value, value));\n  }\n\n  private getSelectItemHeight() {\n    const selectItem = this.selector('div.po-select-item');\n\n    return selectItem && selectItem.clientHeight;\n  }\n\n  private initializeListeners() {\n    this.clickoutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.eventResizeListener = this.renderer.listen('window', 'resize', () => {\n      this.hideDropDown();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.controlPosition.adjustPosition(poSelectContentPositionDefault);\n  };\n\n  private removeListeners() {\n    if (this.clickoutListener) {\n      this.clickoutListener();\n    }\n\n    this.eventResizeListener();\n    window.removeEventListener('scroll', this.onScroll, true);\n  }\n\n  private setPositionDropdown() {\n    this.controlPosition.setElements(\n      this.contentList.nativeElement,\n      poSelectContentOffset,\n      this.selectButtonElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.controlPosition.adjustPosition(poSelectContentPositionDefault);\n  }\n\n  private setScrollPosition(value: any) {\n    const ulDropdpwn = this.element.nativeElement.querySelector('ul.po-select-content');\n\n    if (value && this.options && this.options.length) {\n      const optionFound: PoSelectOption = this.findOptionValue(value);\n\n      if (optionFound) {\n        const index = this.options.indexOf(optionFound);\n        ulDropdpwn.scrollTop = this.scrollValue(index, ulDropdpwn.clientHeight);\n      }\n    }\n  }\n\n  private showDropdown() {\n    if (!this.readonly) {\n      this.selectElement.nativeElement.focus();\n      this.selectIcon = 'po-icon-arrow-up';\n      this.selector('.po-select-container').classList.add('po-select-show');\n      this.open = true;\n      this.changeDetector.markForCheck();\n      this.setPositionDropdown();\n      this.initializeListeners();\n\n      if (this.options && this.options.length) {\n        this.setScrollPosition(this.selectedValue);\n      }\n    }\n  }\n}\n","<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n  <select\n    #select\n    class=\"po-select\"\n    [attr.name]=\"name\"\n    [disabled]=\"disabled\"\n    [ngClass]=\"{ 'po-select-mobile': isMobile, 'po-invisible': isInvisibleSelectNative }\"\n    [required]=\"required\"\n    (change)=\"onSelectChange($event.target.value)\"\n    (blur)=\"onBlur()\"\n  >\n    <option *ngIf=\"isMobile\" disabled hidden selected></option>\n    <option *ngFor=\"let option of options\" [disabled]=\"readonly\" [value]=\"option.value\" (click)=\"onOptionClick(option)\">\n      {{ option?.label }}\n    </option>\n  </select>\n\n  <div class=\"po-select-container\">\n    <div\n      #selectButton\n      class=\"po-select-button\"\n      [ngClass]=\"{ 'po-select-button-disabled': disabled, 'po-select-button-readonly': readonly }\"\n      (click)=\"toggleButton()\"\n    >\n      <span>{{ displayValue || placeholder }}</span>\n\n      <div class=\"po-field-icon-container-right\">\n        <span\n          #icon\n          class=\"po-icon {{ selectIcon }} po-field-icon\"\n          [ngClass]=\"{ 'po-field-icon-disabled': disabled, 'po-field-icon-readonly': readonly }\"\n        ></span>\n      </div>\n    </div>\n\n    <ul #contentList class=\"po-select-content\" [ngClass]=\"{ 'po-invisible': isMobile }\">\n      <li\n        *ngFor=\"let option of options\"\n        [class.po-select-item-selected]=\"selectedValue === option.value\"\n        [value]=\"option.value\"\n        (click)=\"onOptionClick(option)\"\n      >\n        <div class=\"po-select-item\">\n          <ng-container *ngIf=\"selectOptionTemplate; then optionTemplate; else defaultOptionTemplate\"></ng-container>\n\n          <ng-template #defaultOptionTemplate>\n            <span>{{ option?.label }}</span>\n          </ng-template>\n\n          <ng-template\n            #optionTemplate\n            [ngTemplateOutlet]=\"selectOptionTemplate?.templateRef\"\n            [ngTemplateOutletContext]=\"{ $implicit: option }\"\n          >\n          </ng-template>\n        </div>\n      </li>\n    </ul>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}
561
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  Input,\n  IterableDiffers,\n  Output,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport {\n  isMobile,\n  removeDuplicatedOptions,\n  removeDuplicatedOptionsWithFieldValue,\n  removeUndefinedAndNullOptions,\n  removeUndefinedAndNullOptionsWithFieldValue,\n  validValue\n} from '../../../utils/util';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\n\nimport { InputBoolean } from '../../../decorators';\nimport { PoFieldValidateModel } from '../po-field-validate.model';\nimport { PoSelectOption } from './po-select-option.interface';\n\nconst poSelectContentOffset = 8;\nconst poSelectContentPositionDefault = 'bottom';\nconst PO_SELECT_FIELD_LABEL_DEFAULT = 'label';\nconst PO_SELECT_FIELD_VALUE_DEFAULT = 'value';\n\n/**\n * @docsExtends PoFieldValidateModel\n *\n * @example\n *\n * <example name=\"po-select-basic\" title=\"PO Select Basic\">\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.html\"> </file>\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-labs\" title=\"PO Select Labs\">\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.html\"> </file>\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-customer-registration\" title=\"PO Select - Customer registration\">\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.html\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.ts\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.service.ts\"> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.e2e-spec.ts'> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.po.ts'> </file>\n * </example>\n *\n * <example name=\"po-select-companies\" title=\"PO Select Companies\">\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.html\"> </file>\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.ts\"> </file>\n * </example>\n *\n * @description\n *\n * O componente po-select exibe uma lista de valores e permite que o usuário selecione um desses valores.\n * Os valores listados podem ser fixos ou dinâmicos de acordo com a necessidade do desenvolvedor, dando mais flexibilidade ao componente.\n * O po-select não permite que o usuário informe um valor diferente dos valores listados, isso garante a consistência da informação.\n * O po-select não permite que sejam passados valores duplicados, undefined e null para as opções, excluindo-os da lista.\n *\n * > Ao passar um valor para o _model_ que não está na lista de opções, o mesmo será definido como `undefined`.\n *\n * Também existe a possibilidade de utilizar um _template_ para a exibição dos itens da lista,\n * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.\n *\n * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.\n */\n@Component({\n  selector: 'po-select',\n  templateUrl: './po-select.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    PoControlPositionService\n  ]\n})\nexport class PoSelectComponent extends PoFieldValidateModel<any> implements DoCheck {\n  @ViewChild('contentList', { read: ElementRef, static: true }) contentList: ElementRef;\n  @ViewChild('icon', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('select', { read: ElementRef, static: true }) selectElement: ElementRef;\n  @ViewChild('selectButton', { read: ElementRef, static: true }) selectButtonElement: ElementRef;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Função para atualizar o ngModel do componente, necessário quando não for utilizado dentro da tag form.\n   *\n   * Na versão 12.2.0 do Angular a verificação `strictTemplates` vem true como default. Portanto, para utilizar\n   * two-way binding no componente deve se utilizar da seguinte forma:\n   *\n   * ```\n   * <po-select ... [ngModel]=\"selectModel\" (ngModelChange)=\"selectModel = $event\"> </po-select>\n   * ```\n   */\n  @Output('ngModelChange') ngModelChange: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente para leitura.\n   *\n   * @default `false`\n   */\n  @Input('p-readonly') @InputBoolean() readonly: boolean = false;\n\n  /** Mensagem que aparecerá enquanto nenhuma opção estiver selecionada. */\n  @Input('p-placeholder') placeholder?: string;\n\n  displayValue;\n  isMobile: any = isMobile();\n  modelValue: any;\n  onModelChange: any;\n  open: boolean = false;\n  selectedValue: any;\n  selectOptionTemplate: any;\n  selectIcon: string = 'po-icon-arrow-down';\n  scrollPosition: number;\n\n  eventListenerFunction: () => void;\n  eventResizeListener: () => void;\n\n  onModelTouched: any;\n  protected clickoutListener: () => void;\n  private differ: any;\n  private _fieldLabel?: string = PO_SELECT_FIELD_LABEL_DEFAULT;\n  private _fieldValue?: string = PO_SELECT_FIELD_VALUE_DEFAULT;\n  private _options: Array<PoSelectOption> | Array<any>;\n\n  /**\n   * Nesta propriedade deve ser definido uma coleção de objetos que implementam a interface `PoSelectOption`.\n   *\n   * Caso esta lista estiver vazia, o model será `undefined`.\n   *\n   * > Essa propriedade é imutável, ou seja, sempre que quiser atualizar a lista de opções disponíveis\n   * atualize a referência do objeto:\n   *\n   * ```\n   * // atualiza a referência do objeto garantindo a atualização do template\n   * this.options = [...this.options, { value: 'x', label: 'Nova opção' }];\n   *\n   * // evite, pois não atualiza a referência do objeto podendo gerar atrasos na atualização do template\n   * this.options.push({ value: 'x', label: 'Nova opção' });\n   * ```\n   */\n  @Input('p-options') set options(options: Array<any>) {\n    if (this.fieldLabel && this.fieldValue) {\n      options.map(option => {\n        option.label = option[this.fieldLabel];\n        option.value = option[this.fieldValue];\n      });\n    }\n\n    this.validateOptions([...options]);\n    this.onUpdateOptions();\n    this._options = [...options];\n  }\n\n  get options() {\n    return this._options;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.\n   *\n   * @default `label`\n   */\n  @Input('p-field-label') set fieldLabel(value: string) {\n    this._fieldLabel = value || PO_SELECT_FIELD_LABEL_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldLabel() {\n    return this._fieldLabel;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.\n   *\n   * @default `value`\n   */\n  @Input('p-field-value') set fieldValue(value: string) {\n    this._fieldValue = value || PO_SELECT_FIELD_VALUE_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldValue() {\n    return this._fieldValue;\n  }\n\n  /* istanbul ignore next */\n  constructor(\n    private element: ElementRef,\n    private changeDetector: ChangeDetectorRef,\n    differs: IterableDiffers,\n    public renderer: Renderer2,\n    private controlPosition: PoControlPositionService\n  ) {\n    super();\n    this.differ = differs.find([]).create(null);\n  }\n\n  get isInvisibleSelectNative() {\n    return this.readonly && this.isMobile;\n  }\n\n  @HostListener('keydown', ['$event']) onKeydown($event?: any) {\n    const charCode = $event.which || $event.keyCode;\n\n    // Tratamentos para quando o readonly for ativado.\n    if (this.readonly) {\n      // deve matar o evento do teclado devido a alterar o valor do model mesmo com os options fechados\n      if (charCode !== PoKeyCodeEnum.tab) {\n        this.disableDefaultEventAndToggleButton();\n        $event.preventDefault();\n      }\n      return;\n    }\n\n    // Seleciona os itens com as teclas \"up\" e \"down\"\n    if ((!this.open || $event.altKey) && (charCode === PoKeyCodeEnum.arrowDown || charCode === PoKeyCodeEnum.arrowUp)) {\n      this.disableDefaultEventAndToggleButton();\n    }\n\n    // Abre o po-select com as teclas \"enter\" e \"espaço\"\n    if (charCode === PoKeyCodeEnum.enter || charCode === PoKeyCodeEnum.space) {\n      this.disableDefaultEventAndToggleButton();\n    }\n\n    // Fecha o po-select com a tecla \"tab\"\n    if (this.open && charCode === PoKeyCodeEnum.tab) {\n      $event.preventDefault();\n      this.toggleButton();\n    }\n  }\n\n  ngDoCheck() {\n    const change = this.differ.diff(this.options);\n    if (change) {\n      removeDuplicatedOptions(this.options);\n      removeUndefinedAndNullOptions(this.options);\n      removeDuplicatedOptionsWithFieldValue(this.options, this.fieldValue);\n      removeUndefinedAndNullOptionsWithFieldValue(this.options, this.fieldValue);\n    }\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoSelectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoSelectComponent, { static: true }) select: PoSelectComponent;\n   *\n   * focusSelect() {\n   *   this.select.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.selectElement.nativeElement.focus();\n    }\n  }\n\n  hideDropDown() {\n    this.selectIcon = 'po-icon-arrow-down';\n    this.selector('.po-select-container').classList.remove('po-select-show');\n    this.open = false;\n\n    this.changeDetector.markForCheck();\n    this.selectElement.nativeElement.focus();\n\n    this.removeListeners();\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  onOptionClick(option: any) {\n    this.updateValues(option);\n    this.toggleButton();\n  }\n\n  // Altera o valor ao selecionar um item.\n  onSelectChange(value: any) {\n    if (value && this.options && this.options.length) {\n      const optionFound: any = this.findOptionValue(value);\n\n      if (optionFound) {\n        this.updateValues(optionFound);\n        this.setScrollPosition(optionFound.value);\n      }\n    }\n  }\n\n  onUpdateOptions() {\n    if (this.modelValue) {\n      this.onSelectChange(this.modelValue);\n    }\n  }\n\n  scrollValue(index, clientHeight) {\n    const heightScrollValue: number = index * this.getSelectItemHeight();\n\n    return (this.scrollPosition = heightScrollValue > clientHeight ? heightScrollValue : 0);\n  }\n\n  selector(query: string): Element {\n    return this.element.nativeElement.querySelector(query);\n  }\n\n  toggleButton(): void {\n    this.open ? this.hideDropDown() : this.showDropdown();\n  }\n\n  // Atualiza valores\n  updateValues(option: any): void {\n    if (this.selectedValue !== option[this.fieldValue]) {\n      this.selectedValue = option[this.fieldValue];\n      this.selectElement.nativeElement.value = option[this.fieldValue];\n      this.updateModel(option[this.fieldValue]);\n      this.displayValue = option[this.fieldLabel];\n      this.emitChange(option[this.fieldValue]);\n    }\n  }\n\n  // Esconde Content do Select quando for clicado fora\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      !this.selectButtonElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target)\n    ) {\n      this.hideDropDown();\n    }\n  }\n\n  // Recebe as alterações do model\n  onWriteValue(value: any) {\n    const optionFound: any = this.findOptionValue(value);\n\n    if (optionFound) {\n      this.selectElement.nativeElement.value = optionFound.value;\n      this.selectedValue = optionFound[this.fieldValue];\n      this.displayValue = optionFound[this.fieldLabel];\n      this.setScrollPosition(optionFound[this.fieldValue]);\n    } else if (validValue(this.selectedValue)) {\n      this.selectElement.nativeElement.value = undefined;\n      this.updateModel(undefined);\n      this.selectedValue = undefined;\n      this.displayValue = undefined;\n    }\n\n    this.modelValue = value;\n    this.changeDetector.detectChanges();\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  private isEqual(value: any, inputValue: any): boolean {\n    if ((value || value === 0) && inputValue) {\n      return value.toString() === inputValue.toString();\n    }\n\n    if ((value === null && inputValue !== null) || (value === undefined && inputValue !== undefined)) {\n      value = `${value}`; // Transformando em string\n    }\n\n    return value === inputValue;\n  }\n\n  // Método necessário para bloquear o evento default do select nativo.\n  // Ao utilizar event.preventDefault(), nos navegadores Firefox e IE o mesmo não cancela o evento.\n  private disableDefaultEventAndToggleButton() {\n    this.selectElement.nativeElement.style.display = 'none';\n\n    setTimeout(() => {\n      this.selectElement.nativeElement.style.display = 'block';\n      this.toggleButton();\n    });\n  }\n\n  private findOptionValue(value: any) {\n    return this.options.find(option => this.isEqual(option.value, value));\n  }\n\n  private getSelectItemHeight() {\n    const selectItem = this.selector('div.po-select-item');\n\n    return selectItem && selectItem.clientHeight;\n  }\n\n  private initializeListeners() {\n    this.clickoutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.eventResizeListener = this.renderer.listen('window', 'resize', () => {\n      this.hideDropDown();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.controlPosition.adjustPosition(poSelectContentPositionDefault);\n  };\n\n  private removeListeners() {\n    if (this.clickoutListener) {\n      this.clickoutListener();\n    }\n\n    this.eventResizeListener();\n    window.removeEventListener('scroll', this.onScroll, true);\n  }\n\n  private setPositionDropdown() {\n    this.controlPosition.setElements(\n      this.contentList.nativeElement,\n      poSelectContentOffset,\n      this.selectButtonElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.controlPosition.adjustPosition(poSelectContentPositionDefault);\n  }\n\n  private setScrollPosition(value: any) {\n    const ulDropdpwn = this.element.nativeElement.querySelector('ul.po-select-content');\n\n    if (value && this.options && this.options.length) {\n      const optionFound: any = this.findOptionValue(value);\n\n      if (optionFound) {\n        const index = this.options.indexOf(optionFound);\n        ulDropdpwn.scrollTop = this.scrollValue(index, ulDropdpwn.clientHeight);\n      }\n    }\n  }\n\n  private showDropdown() {\n    if (!this.readonly) {\n      this.selectElement.nativeElement.focus();\n      this.selectIcon = 'po-icon-arrow-up';\n      this.selector('.po-select-container').classList.add('po-select-show');\n      this.open = true;\n      this.changeDetector.markForCheck();\n      this.setPositionDropdown();\n      this.initializeListeners();\n\n      if (this.options && this.options.length) {\n        this.setScrollPosition(this.selectedValue);\n      }\n    }\n  }\n\n  private validateOptions(options: Array<any>) {\n    removeDuplicatedOptions(options);\n    removeUndefinedAndNullOptions(options);\n    removeDuplicatedOptionsWithFieldValue(options, this.fieldValue);\n    removeUndefinedAndNullOptionsWithFieldValue(options, this.fieldValue);\n  }\n}\n","<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n  <select\n    #select\n    class=\"po-select\"\n    [attr.name]=\"name\"\n    [disabled]=\"disabled\"\n    [ngClass]=\"{ 'po-select-mobile': isMobile, 'po-invisible': isInvisibleSelectNative }\"\n    [required]=\"required\"\n    (change)=\"onSelectChange($event.target.value)\"\n    (blur)=\"onBlur()\"\n  >\n    <option *ngIf=\"isMobile\" disabled hidden selected></option>\n    <option\n      *ngFor=\"let option of options\"\n      [disabled]=\"readonly\"\n      [value]=\"option?.[this.fieldValue]\"\n      (click)=\"onOptionClick(option)\"\n    >\n      {{ option?.[this.fieldLabel] }}\n    </option>\n  </select>\n\n  <div class=\"po-select-container\">\n    <div\n      #selectButton\n      class=\"po-select-button\"\n      [ngClass]=\"{ 'po-select-button-disabled': disabled, 'po-select-button-readonly': readonly }\"\n      (click)=\"toggleButton()\"\n    >\n      <span>{{ displayValue || placeholder }}</span>\n\n      <div class=\"po-field-icon-container-right\">\n        <span\n          #icon\n          class=\"po-icon {{ selectIcon }} po-field-icon\"\n          [ngClass]=\"{ 'po-field-icon-disabled': disabled, 'po-field-icon-readonly': readonly }\"\n        ></span>\n      </div>\n    </div>\n\n    <ul #contentList class=\"po-select-content\" [ngClass]=\"{ 'po-invisible': isMobile }\">\n      <li\n        *ngFor=\"let option of options\"\n        [class.po-select-item-selected]=\"selectedValue === option?.[this.fieldLabel]\"\n        [value]=\"option?.[this.fieldValue]\"\n        (click)=\"onOptionClick(option)\"\n      >\n        <div class=\"po-select-item\">\n          <ng-container *ngIf=\"selectOptionTemplate; then optionTemplate; else defaultOptionTemplate\"></ng-container>\n\n          <ng-template #defaultOptionTemplate>\n            <span>{{ option?.[this.fieldLabel] }}</span>\n          </ng-template>\n\n          <ng-template\n            #optionTemplate\n            [ngTemplateOutlet]=\"selectOptionTemplate?.templateRef\"\n            [ngTemplateOutletContext]=\"{ $implicit: option }\"\n          >\n          </ng-template>\n        </div>\n      </li>\n    </ul>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}
@@ -1,5 +1,6 @@
1
1
  import { Injectable } from '@angular/core';
2
2
  import { HttpEventType, HttpRequest, HttpResponse, HttpHeaders } from '@angular/common/http';
3
+ import { Subscription } from 'rxjs';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@angular/common/http";
5
6
  export class PoUploadBaseService {
@@ -39,7 +40,8 @@ export class PoUploadBaseService {
39
40
  }
40
41
  }
41
42
  sendFile(url, file, headers, formData, uploadCallback, successCallback, errorCallback) {
42
- const request = this.getRequest(url, headers, formData).subscribe(event => {
43
+ let request = new Subscription();
44
+ request = this.getRequest(url, headers, formData).subscribe(event => {
43
45
  if (event.type === HttpEventType.UploadProgress) {
44
46
  this.addRequest(file, request);
45
47
  const percentDone = Math.round((100 * event.loaded) / event.total);
@@ -86,4 +88,4 @@ PoUploadBaseService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: PoUp
86
88
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoUploadBaseService, [{
87
89
  type: Injectable
88
90
  }], function () { return [{ type: i1.HttpClient }]; }, null); })();
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-upload-base.service.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-upload/po-upload-base.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, EventEmitter } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEventType,\n  HttpErrorResponse,\n  HttpRequest,\n  HttpResponse,\n  HttpHeaders\n} from '@angular/common/http';\n\nimport { PoUploadFile } from './po-upload-file';\n\nimport { Observable, Subscription } from 'rxjs';\n\n@Injectable()\nexport class PoUploadBaseService {\n  formField: string = 'files';\n  requests: Array<any> = [];\n\n  constructor(private http: HttpClient) {}\n\n  /**\n   * Método responsável por enviar os arquivos ao servidor, conforme o parâmetro URL.\n   *\n   * @param url URL da requisição a ser efetuada.\n   * @param files Arquivos a serem enviados.\n   * @param tOnUpload Função a ser executada quando o arquivo for enviado ao servidor.\n   * @param uploadCallback Função que será executada enquanto os arquivos estiverem sendo enviados.\n   * @param successCallback Função a ser executada quando a requisição for efetuada com sucesso.\n   * @param errorCallback Função a ser executada quando a requisição foi efetuada com sucesso.\n   */\n  public upload(\n    url: string,\n    files: Array<PoUploadFile>,\n    headers: { [name: string]: string | Array<string> },\n    tOnUpload: EventEmitter<any>,\n    uploadCallback: (file: PoUploadFile, percent: number) => void,\n    successCallback: (file: PoUploadFile, event: any) => void,\n    errorCallback: (file: PoUploadFile, event: any) => void\n  ) {\n    const filesLength = files.length;\n    const uploadEvent: any = {\n      data: {},\n      file: null\n    };\n\n    for (let i = 0; i < filesLength; i++) {\n      const formData: FormData = new FormData();\n      const file = files[i];\n      const fileName = file.rawFile.name;\n\n      formData.append(this.formField, file.rawFile, fileName);\n\n      // Função upload, onde o desenvolvedor pode enviar dados para a requisição.\n      if (tOnUpload) {\n        uploadEvent['file'] = file;\n        tOnUpload.emit(uploadEvent);\n\n        formData.append('data', JSON.stringify(uploadEvent.data));\n      }\n\n      this.sendFile(url, file, headers, formData, uploadCallback, successCallback, errorCallback);\n    }\n  }\n\n  public sendFile(\n    url: string,\n    file: PoUploadFile,\n    headers: { [name: string]: string | Array<string> },\n    formData: FormData,\n    uploadCallback: (file: PoUploadFile, percent: number) => void,\n    successCallback: (file: PoUploadFile, event: any) => void,\n    errorCallback: (file: PoUploadFile, event: any) => void\n  ) {\n    const request = this.getRequest(url, headers, formData).subscribe(\n      event => {\n        if (event.type === HttpEventType.UploadProgress) {\n          this.addRequest(file, request);\n\n          const percentDone = Math.round((100 * event.loaded) / event.total);\n          uploadCallback(file, percentDone);\n        } else if (event instanceof HttpResponse) {\n          // Sucesso, arquivos enviados.\n          successCallback(file, event);\n        }\n      },\n      (err: HttpErrorResponse) => {\n        errorCallback(file, err);\n      }\n    );\n  }\n\n  public getRequest(\n    url: string,\n    headers: { [name: string]: string | Array<string> },\n    formData: FormData\n  ): Observable<any> {\n    const httpHeaders = new HttpHeaders(headers);\n\n    const req = new HttpRequest('POST', url, formData, {\n      reportProgress: true,\n      headers: httpHeaders\n    });\n    return this.http.request(req);\n  }\n\n  public stopRequestByFile(file: any, callback: () => void) {\n    const requestObj = this.requests.find(req => req.file.uid === file.uid);\n\n    if (requestObj) {\n      const request = requestObj.request;\n      request.unsubscribe();\n      this.removeRequest(requestObj);\n      callback();\n    }\n  }\n\n  public removeRequest(requestObj: any) {\n    const index = this.requests.indexOf(requestObj);\n    this.requests.splice(index, 1);\n  }\n\n  public addRequest(file: PoUploadFile, request: Subscription) {\n    const hasRequest = this.requests.some(req => req.file.uid === file.uid);\n\n    if (!hasRequest) {\n      this.requests.push({ file, request });\n    }\n  }\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-upload-base.service.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-upload/po-upload-base.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, EventEmitter } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEventType,\n  HttpErrorResponse,\n  HttpRequest,\n  HttpResponse,\n  HttpHeaders\n} from '@angular/common/http';\n\nimport { PoUploadFile } from './po-upload-file';\n\nimport { Observable, Subscription } from 'rxjs';\n\n@Injectable()\nexport class PoUploadBaseService {\n  formField: string = 'files';\n  requests: Array<any> = [];\n\n  constructor(private http: HttpClient) {}\n\n  /**\n   * Método responsável por enviar os arquivos ao servidor, conforme o parâmetro URL.\n   *\n   * @param url URL da requisição a ser efetuada.\n   * @param files Arquivos a serem enviados.\n   * @param tOnUpload Função a ser executada quando o arquivo for enviado ao servidor.\n   * @param uploadCallback Função que será executada enquanto os arquivos estiverem sendo enviados.\n   * @param successCallback Função a ser executada quando a requisição for efetuada com sucesso.\n   * @param errorCallback Função a ser executada quando a requisição foi efetuada com sucesso.\n   */\n  public upload(\n    url: string,\n    files: Array<PoUploadFile>,\n    headers: { [name: string]: string | Array<string> },\n    tOnUpload: EventEmitter<any>,\n    uploadCallback: (file: PoUploadFile, percent: number) => void,\n    successCallback: (file: PoUploadFile, event: any) => void,\n    errorCallback: (file: PoUploadFile, event: any) => void\n  ) {\n    const filesLength = files.length;\n    const uploadEvent: any = {\n      data: {},\n      file: null\n    };\n\n    for (let i = 0; i < filesLength; i++) {\n      const formData: FormData = new FormData();\n      const file = files[i];\n      const fileName = file.rawFile.name;\n\n      formData.append(this.formField, file.rawFile, fileName);\n\n      // Função upload, onde o desenvolvedor pode enviar dados para a requisição.\n      if (tOnUpload) {\n        uploadEvent['file'] = file;\n        tOnUpload.emit(uploadEvent);\n\n        formData.append('data', JSON.stringify(uploadEvent.data));\n      }\n\n      this.sendFile(url, file, headers, formData, uploadCallback, successCallback, errorCallback);\n    }\n  }\n\n  public sendFile(\n    url: string,\n    file: PoUploadFile,\n    headers: { [name: string]: string | Array<string> },\n    formData: FormData,\n    uploadCallback: (file: PoUploadFile, percent: number) => void,\n    successCallback: (file: PoUploadFile, event: any) => void,\n    errorCallback: (file: PoUploadFile, event: any) => void\n  ) {\n    let request: Subscription = new Subscription();\n    request = this.getRequest(url, headers, formData).subscribe(\n      event => {\n        if (event.type === HttpEventType.UploadProgress) {\n          this.addRequest(file, request);\n\n          const percentDone = Math.round((100 * event.loaded) / event.total);\n          uploadCallback(file, percentDone);\n        } else if (event instanceof HttpResponse) {\n          // Sucesso, arquivos enviados.\n          successCallback(file, event);\n        }\n      },\n      (err: HttpErrorResponse) => {\n        errorCallback(file, err);\n      }\n    );\n  }\n\n  public getRequest(\n    url: string,\n    headers: { [name: string]: string | Array<string> },\n    formData: FormData\n  ): Observable<any> {\n    const httpHeaders = new HttpHeaders(headers);\n\n    const req = new HttpRequest('POST', url, formData, {\n      reportProgress: true,\n      headers: httpHeaders\n    });\n    return this.http.request(req);\n  }\n\n  public stopRequestByFile(file: any, callback: () => void) {\n    const requestObj = this.requests.find(req => req.file.uid === file.uid);\n\n    if (requestObj) {\n      const request = requestObj.request;\n      request.unsubscribe();\n      this.removeRequest(requestObj);\n      callback();\n    }\n  }\n\n  public removeRequest(requestObj: any) {\n    const index = this.requests.indexOf(requestObj);\n    this.requests.splice(index, 1);\n  }\n\n  public addRequest(file: PoUploadFile, request: Subscription) {\n    const hasRequest = this.requests.some(req => req.file.uid === file.uid);\n\n    if (!hasRequest) {\n      this.requests.push({ file, request });\n    }\n  }\n}\n"]}