@po-ui/ng-components 17.4.0 → 17.6.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 (44) hide show
  1. package/esm2022/lib/components/po-dynamic/index.mjs +3 -1
  2. package/esm2022/lib/components/po-dynamic/po-dynamic-container/po-dynamic-container.component.mjs +56 -0
  3. package/esm2022/lib/components/po-dynamic/po-dynamic-field.interface.mjs +1 -1
  4. package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields-base.component.mjs +8 -5
  5. package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.mjs +221 -196
  6. package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.mjs +9 -2
  7. package/esm2022/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view-base.component.mjs +17 -6
  8. package/esm2022/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.mjs +68 -39
  9. package/esm2022/lib/components/po-dynamic/po-dynamic.module.mjs +20 -7
  10. package/esm2022/lib/components/po-dynamic/shared/po-dynamic-shared-base.mjs +41 -0
  11. package/esm2022/lib/components/po-field/po-combo/po-combo.component.mjs +8 -1
  12. package/esm2022/lib/components/po-search/interfaces/po-search-option.interface.mjs +2 -0
  13. package/esm2022/lib/components/po-search/po-search-base.component.mjs +27 -2
  14. package/esm2022/lib/components/po-search/po-search.component.mjs +264 -48
  15. package/esm2022/lib/components/po-search/po-search.module.mjs +25 -4
  16. package/fesm2022/po-ui-ng-components.mjs +1001 -564
  17. package/fesm2022/po-ui-ng-components.mjs.map +1 -1
  18. package/lib/components/po-dynamic/index.d.ts +2 -0
  19. package/lib/components/po-dynamic/po-dynamic-container/po-dynamic-container.component.d.ts +8 -0
  20. package/lib/components/po-dynamic/po-dynamic-field.interface.d.ts +7 -0
  21. package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields-base.component.d.ts +2 -3
  22. package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.d.ts +7 -0
  23. package/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view-base.component.d.ts +5 -3
  24. package/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.d.ts +5 -0
  25. package/lib/components/po-dynamic/po-dynamic.module.d.ts +11 -9
  26. package/lib/components/po-dynamic/shared/po-dynamic-shared-base.d.ts +18 -0
  27. package/lib/components/po-field/po-combo/po-combo.component.d.ts +1 -0
  28. package/lib/components/po-search/interfaces/po-search-option.interface.d.ts +21 -0
  29. package/lib/components/po-search/po-search-base.component.d.ts +20 -1
  30. package/lib/components/po-search/po-search.component.d.ts +53 -4
  31. package/lib/components/po-search/po-search.module.d.ts +2 -1
  32. package/package.json +4 -4
  33. package/po-ui-ng-components-17.6.0.tgz +0 -0
  34. package/schematics/ng-add/index.js +1 -1
  35. package/schematics/ng-update/v14/index.js +1 -1
  36. package/schematics/ng-update/v15/index.js +1 -1
  37. package/schematics/ng-update/v16/index.js +1 -1
  38. package/schematics/ng-update/v17/index.js +1 -1
  39. package/schematics/ng-update/v2/index.js +1 -1
  40. package/schematics/ng-update/v3/index.js +1 -1
  41. package/schematics/ng-update/v4/index.js +1 -1
  42. package/schematics/ng-update/v5/index.js +1 -1
  43. package/schematics/ng-update/v6/index.js +1 -1
  44. package/po-ui-ng-components-17.4.0.tgz +0 -0
@@ -42,6 +42,13 @@ function PoDynamicFormComponent_ng_template_3_Template(rf, ctx) { if (rf & 1) {
42
42
  * <file name="sample-po-dynamic-form-register/sample-po-dynamic-form-register.component.ts"> </file>
43
43
  * <file name="sample-po-dynamic-form-register/sample-po-dynamic-form-register.service.ts"> </file>
44
44
  * </example>
45
+ *
46
+ * <example name="po-dynamic-form-container" title="PO Dynamic Form - Container">
47
+ * <file name="sample-po-dynamic-form-container/sample-po-dynamic-form-container.component.html"> </file>
48
+ * <file name="sample-po-dynamic-form-container/sample-po-dynamic-form-container.component.ts"> </file>
49
+ * <file name="sample-po-dynamic-form-container/sample-po-dynamic-form-container.service.ts"> </file>
50
+ * </example>
51
+ *
45
52
  */
46
53
  export class PoDynamicFormComponent extends PoDynamicFormBaseComponent {
47
54
  changes;
@@ -206,5 +213,5 @@ export class PoDynamicFormComponent extends PoDynamicFormBaseComponent {
206
213
  type: ViewChild,
207
214
  args: ['dynamicForm']
208
215
  }] }); })();
209
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoDynamicFormComponent, { className: "PoDynamicFormComponent", filePath: "lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.ts", lineNumber: 34 }); })();
210
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.ts","../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectorRef, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { NgForm } from '@angular/forms';\n\nimport { Observable, Subject, Subscription } from 'rxjs';\n\nimport { PoDynamicFormBaseComponent } from './po-dynamic-form-base.component';\nimport { PoDynamicFormField } from './po-dynamic-form-field.interface';\nimport { PoDynamicFormLoad } from './po-dynamic-form-load/po-dynamic-form-load.interface';\nimport { PoDynamicFormLoadService } from './po-dynamic-form-load/po-dynamic-form-load.service';\nimport { PoDynamicFormValidation } from './po-dynamic-form-validation/po-dynamic-form-validation.interface';\nimport { PoDynamicFormValidationService } from './po-dynamic-form-validation/po-dynamic-form-validation.service';\n\n/**\n * @docsExtends PoDynamicFormBaseComponent\n *\n * @example\n *\n * <example name=\"po-dynamic-form-basic\" title=\"PO Dynamic Form Basic\">\n *  <file name=\"sample-po-dynamic-form-basic/sample-po-dynamic-form-basic.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-form-basic/sample-po-dynamic-form-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dynamic-form-register\" title=\"PO Dynamic Form - Register\">\n *  <file name=\"sample-po-dynamic-form-register/sample-po-dynamic-form-register.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-form-register/sample-po-dynamic-form-register.component.ts\"> </file>\n *  <file name=\"sample-po-dynamic-form-register/sample-po-dynamic-form-register.service.ts\"> </file>\n * </example>\n */\n\n@Component({\n  selector: 'po-dynamic-form',\n  templateUrl: './po-dynamic-form.component.html'\n})\nexport class PoDynamicFormComponent extends PoDynamicFormBaseComponent implements OnInit, OnDestroy {\n  @ViewChild('fieldsComponent') fieldsComponent: { focus: (property: string) => void; updatePreviousValue: () => void };\n\n  disabledForm: boolean;\n\n  private _form: NgForm;\n\n  private onLoadSubscription: Subscription;\n  private sendFormSubscription: Subscription;\n  private comboOptionSubject = new Subject<any>();\n\n  @ViewChild('dynamicForm') set form(value: NgForm) {\n    // necessario para nao ocorrer o ExpressionChangedAfterItHasBeenCheckedError\n    setTimeout(() => {\n      this._form = value;\n\n      this.emitForm();\n    });\n  }\n\n  get form() {\n    return this._form || <any>{};\n  }\n\n  constructor(\n    private changes: ChangeDetectorRef,\n    private loadService: PoDynamicFormLoadService,\n    private validationService: PoDynamicFormValidationService\n  ) {\n    super();\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n  }\n\n  ngOnInit() {\n    if (this.load) {\n      this.loadDataOnInitialize();\n    }\n  }\n\n  /**\n   * Função que atribui foco ao campo desejado.\n   *\n   * Para utilizá-la é necessário capturar a instância do `dynamic form`, como por exemplo:\n   *\n   * ``` html\n   * <po-dynamic-form #dynamicForm [p-fields]=\"fields\"></po-dynamic-form>\n   * ```\n   *\n   * ``` javascript\n   * import { PoDynamicFormComponent, PoDynamicFormField } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild('dynamicForm', { static: true }) dynamicForm: PoDynamicFormComponent;\n   *\n   * fields: Array<PoDynamicFormField> = [\n   *   { property: 'fieldOne' },\n   *   { property: 'fieldTwo' }\n   * ];\n   *\n   * fieldFocus() {\n   *   this.dynamicForm.focus('fieldTwo');\n   * }\n   * ```\n   *\n   * @param {string} property Nome da propriedade atribuída ao `PoDynamicFormField.property`.\n   */\n  focus(property: string) {\n    this.fieldsComponent.focus(property);\n  }\n\n  getObjectValue(): Observable<any> {\n    return this.comboOptionSubject.asObservable();\n  }\n\n  sendObjectValue(objectValue: any) {\n    this.comboOptionSubject.next(objectValue);\n  }\n\n  validateForm(field: PoDynamicFormField) {\n    const previousFocusElement = document.activeElement;\n\n    this.disableForm(true);\n    const errorOnValidation = () => this.disableForm(false);\n\n    this.sendFormSubscription = this.validationService\n      .sendFormChange(this.validate, field, this.value)\n      .subscribe(this.applyFormValidation(previousFocusElement), errorOnValidation);\n  }\n\n  private applyFormUpdatesOnLoad(previousFocusElement: Element): (dynamicFormData: PoDynamicFormLoad) => void {\n    return dynamicFormData => {\n      this.updateModelOnLoad(dynamicFormData);\n      this.disableForm(false);\n      this.setFocusOnFieldByProperty(dynamicFormData.focus, previousFocusElement);\n    };\n  }\n\n  private applyFormValidation(previousFocusElement: Element): (dynamicFormData: PoDynamicFormValidation) => void {\n    return dynamicFormData => {\n      this.updateModelWithValidation(dynamicFormData);\n      this.disableForm(false);\n      this.setFocusOnFieldByProperty(dynamicFormData.focus, previousFocusElement);\n    };\n  }\n\n  private disableForm(value: boolean) {\n    this.disabledForm = value;\n    this.changes.detectChanges();\n  }\n\n  private emitForm() {\n    if (!this.groupForm && this.formOutput.observers.length) {\n      this.formOutput.emit(this.form);\n    }\n  }\n\n  private loadDataOnInitialize() {\n    const previousFocusElement = document.activeElement;\n\n    this.disabledForm = true;\n    const errorOnLoad = () => (this.disabledForm = false);\n\n    this.onLoadSubscription = this.loadService\n      .executeLoad(this.load, this.value)\n      .subscribe(this.applyFormUpdatesOnLoad(previousFocusElement), errorOnLoad);\n  }\n\n  private removeListeners() {\n    if (this.onLoadSubscription) {\n      this.onLoadSubscription.unsubscribe();\n    }\n\n    if (this.sendFormSubscription) {\n      this.sendFormSubscription.unsubscribe();\n    }\n  }\n\n  private setFocusOnFieldByProperty(property: string, previousFocusElement: Element) {\n    if (property) {\n      // precisa do timeout para que o valor seja atribuido no campo antes de setar o focus,\n      // para nao disparar a mudança posteriormente. Situação ocorre quando retornar campo com valor e focus atribuido a ele.\n      setTimeout(() => this.focus(property));\n    } else {\n      previousFocusElement['focus']();\n    }\n  }\n\n  private updateModelOnLoad(loadedFormData: PoDynamicFormLoad) {\n    Object.assign(this.value, loadedFormData.value);\n    this.fields = this.loadService.createAndUpdateFieldsForm(loadedFormData.fields, this.fields);\n  }\n\n  private updateModelWithValidation(formData: PoDynamicFormValidation) {\n    Object.assign(this.value, formData.value);\n    this.fieldsComponent.updatePreviousValue();\n    this.fields = this.validationService.updateFieldsForm(formData.fields, this.fields);\n  }\n}\n","<ng-container *ngIf=\"groupForm; then reuseFormTemplate; else uniqueFormTemplate\"></ng-container>\n\n<ng-template #reuseFormTemplate>\n  <po-dynamic-form-fields #fieldsComponent [p-auto-focus]=\"autoFocus\" [p-fields]=\"fields\" [p-value]=\"value\">\n  </po-dynamic-form-fields>\n</ng-template>\n\n<ng-template #uniqueFormTemplate>\n  <form #dynamicForm=\"ngForm\">\n    <po-dynamic-form-fields\n      #fieldsComponent\n      [(p-fields)]=\"fields\"\n      [p-auto-focus]=\"autoFocus\"\n      [p-disabled-form]=\"disabledForm\"\n      [p-validate]=\"validate\"\n      [p-validate-fields]=\"validateFields\"\n      [p-validate-on-input]=\"validateOnInput\"\n      [p-value]=\"value\"\n      (p-object-value)=\"sendObjectValue($event)\"\n      (p-form-validate)=\"validateForm($event)\"\n    >\n    </po-dynamic-form-fields>\n  </form>\n</ng-template>\n"]}
216
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoDynamicFormComponent, { className: "PoDynamicFormComponent", filePath: "lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.ts", lineNumber: 41 }); })();
217
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.ts","../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectorRef, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { NgForm } from '@angular/forms';\n\nimport { Observable, Subject, Subscription } from 'rxjs';\n\nimport { PoDynamicFormBaseComponent } from './po-dynamic-form-base.component';\nimport { PoDynamicFormField } from './po-dynamic-form-field.interface';\nimport { PoDynamicFormLoad } from './po-dynamic-form-load/po-dynamic-form-load.interface';\nimport { PoDynamicFormLoadService } from './po-dynamic-form-load/po-dynamic-form-load.service';\nimport { PoDynamicFormValidation } from './po-dynamic-form-validation/po-dynamic-form-validation.interface';\nimport { PoDynamicFormValidationService } from './po-dynamic-form-validation/po-dynamic-form-validation.service';\n\n/**\n * @docsExtends PoDynamicFormBaseComponent\n *\n * @example\n *\n * <example name=\"po-dynamic-form-basic\" title=\"PO Dynamic Form Basic\">\n *  <file name=\"sample-po-dynamic-form-basic/sample-po-dynamic-form-basic.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-form-basic/sample-po-dynamic-form-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dynamic-form-register\" title=\"PO Dynamic Form - Register\">\n *  <file name=\"sample-po-dynamic-form-register/sample-po-dynamic-form-register.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-form-register/sample-po-dynamic-form-register.component.ts\"> </file>\n *  <file name=\"sample-po-dynamic-form-register/sample-po-dynamic-form-register.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dynamic-form-container\" title=\"PO Dynamic Form - Container\">\n *  <file name=\"sample-po-dynamic-form-container/sample-po-dynamic-form-container.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-form-container/sample-po-dynamic-form-container.component.ts\"> </file>\n *  <file name=\"sample-po-dynamic-form-container/sample-po-dynamic-form-container.service.ts\"> </file>\n * </example>\n *\n */\n\n@Component({\n  selector: 'po-dynamic-form',\n  templateUrl: './po-dynamic-form.component.html'\n})\nexport class PoDynamicFormComponent extends PoDynamicFormBaseComponent implements OnInit, OnDestroy {\n  @ViewChild('fieldsComponent') fieldsComponent: { focus: (property: string) => void; updatePreviousValue: () => void };\n\n  disabledForm: boolean;\n\n  private _form: NgForm;\n\n  private onLoadSubscription: Subscription;\n  private sendFormSubscription: Subscription;\n  private comboOptionSubject = new Subject<any>();\n\n  @ViewChild('dynamicForm') set form(value: NgForm) {\n    // necessario para nao ocorrer o ExpressionChangedAfterItHasBeenCheckedError\n    setTimeout(() => {\n      this._form = value;\n\n      this.emitForm();\n    });\n  }\n\n  get form() {\n    return this._form || <any>{};\n  }\n\n  constructor(\n    private changes: ChangeDetectorRef,\n    private loadService: PoDynamicFormLoadService,\n    private validationService: PoDynamicFormValidationService\n  ) {\n    super();\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n  }\n\n  ngOnInit() {\n    if (this.load) {\n      this.loadDataOnInitialize();\n    }\n  }\n\n  /**\n   * Função que atribui foco ao campo desejado.\n   *\n   * Para utilizá-la é necessário capturar a instância do `dynamic form`, como por exemplo:\n   *\n   * ``` html\n   * <po-dynamic-form #dynamicForm [p-fields]=\"fields\"></po-dynamic-form>\n   * ```\n   *\n   * ``` javascript\n   * import { PoDynamicFormComponent, PoDynamicFormField } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild('dynamicForm', { static: true }) dynamicForm: PoDynamicFormComponent;\n   *\n   * fields: Array<PoDynamicFormField> = [\n   *   { property: 'fieldOne' },\n   *   { property: 'fieldTwo' }\n   * ];\n   *\n   * fieldFocus() {\n   *   this.dynamicForm.focus('fieldTwo');\n   * }\n   * ```\n   *\n   * @param {string} property Nome da propriedade atribuída ao `PoDynamicFormField.property`.\n   */\n  focus(property: string) {\n    this.fieldsComponent.focus(property);\n  }\n\n  getObjectValue(): Observable<any> {\n    return this.comboOptionSubject.asObservable();\n  }\n\n  sendObjectValue(objectValue: any) {\n    this.comboOptionSubject.next(objectValue);\n  }\n\n  validateForm(field: PoDynamicFormField) {\n    const previousFocusElement = document.activeElement;\n\n    this.disableForm(true);\n    const errorOnValidation = () => this.disableForm(false);\n\n    this.sendFormSubscription = this.validationService\n      .sendFormChange(this.validate, field, this.value)\n      .subscribe(this.applyFormValidation(previousFocusElement), errorOnValidation);\n  }\n\n  private applyFormUpdatesOnLoad(previousFocusElement: Element): (dynamicFormData: PoDynamicFormLoad) => void {\n    return dynamicFormData => {\n      this.updateModelOnLoad(dynamicFormData);\n      this.disableForm(false);\n      this.setFocusOnFieldByProperty(dynamicFormData.focus, previousFocusElement);\n    };\n  }\n\n  private applyFormValidation(previousFocusElement: Element): (dynamicFormData: PoDynamicFormValidation) => void {\n    return dynamicFormData => {\n      this.updateModelWithValidation(dynamicFormData);\n      this.disableForm(false);\n      this.setFocusOnFieldByProperty(dynamicFormData.focus, previousFocusElement);\n    };\n  }\n\n  private disableForm(value: boolean) {\n    this.disabledForm = value;\n    this.changes.detectChanges();\n  }\n\n  private emitForm() {\n    if (!this.groupForm && this.formOutput.observers.length) {\n      this.formOutput.emit(this.form);\n    }\n  }\n\n  private loadDataOnInitialize() {\n    const previousFocusElement = document.activeElement;\n\n    this.disabledForm = true;\n    const errorOnLoad = () => (this.disabledForm = false);\n\n    this.onLoadSubscription = this.loadService\n      .executeLoad(this.load, this.value)\n      .subscribe(this.applyFormUpdatesOnLoad(previousFocusElement), errorOnLoad);\n  }\n\n  private removeListeners() {\n    if (this.onLoadSubscription) {\n      this.onLoadSubscription.unsubscribe();\n    }\n\n    if (this.sendFormSubscription) {\n      this.sendFormSubscription.unsubscribe();\n    }\n  }\n\n  private setFocusOnFieldByProperty(property: string, previousFocusElement: Element) {\n    if (property) {\n      // precisa do timeout para que o valor seja atribuido no campo antes de setar o focus,\n      // para nao disparar a mudança posteriormente. Situação ocorre quando retornar campo com valor e focus atribuido a ele.\n      setTimeout(() => this.focus(property));\n    } else {\n      previousFocusElement['focus']();\n    }\n  }\n\n  private updateModelOnLoad(loadedFormData: PoDynamicFormLoad) {\n    Object.assign(this.value, loadedFormData.value);\n    this.fields = this.loadService.createAndUpdateFieldsForm(loadedFormData.fields, this.fields);\n  }\n\n  private updateModelWithValidation(formData: PoDynamicFormValidation) {\n    Object.assign(this.value, formData.value);\n    this.fieldsComponent.updatePreviousValue();\n    this.fields = this.validationService.updateFieldsForm(formData.fields, this.fields);\n  }\n}\n","<ng-container *ngIf=\"groupForm; then reuseFormTemplate; else uniqueFormTemplate\"></ng-container>\n\n<ng-template #reuseFormTemplate>\n  <po-dynamic-form-fields #fieldsComponent [p-auto-focus]=\"autoFocus\" [p-fields]=\"fields\" [p-value]=\"value\">\n  </po-dynamic-form-fields>\n</ng-template>\n\n<ng-template #uniqueFormTemplate>\n  <form #dynamicForm=\"ngForm\">\n    <po-dynamic-form-fields\n      #fieldsComponent\n      [(p-fields)]=\"fields\"\n      [p-auto-focus]=\"autoFocus\"\n      [p-disabled-form]=\"disabledForm\"\n      [p-validate]=\"validate\"\n      [p-validate-fields]=\"validateFields\"\n      [p-validate-on-input]=\"validateOnInput\"\n      [p-value]=\"value\"\n      (p-object-value)=\"sendObjectValue($event)\"\n      (p-form-validate)=\"validateForm($event)\"\n    >\n    </po-dynamic-form-fields>\n  </form>\n</ng-template>\n"]}
@@ -2,6 +2,7 @@ import { Directive, Input } from '@angular/core';
2
2
  import { convertToBoolean, isTypeof, sortFields } from '../../../utils/util';
3
3
  import { catchError, map, of } from 'rxjs';
4
4
  import { getGridColumnsClasses, isVisibleField } from '../po-dynamic.util';
5
+ import { PoDynamicSharedBase } from '../shared/po-dynamic-shared-base';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@angular/common";
7
8
  import * as i2 from "../../../pipes/po-time/po-time.pipe";
@@ -17,7 +18,7 @@ import * as i5 from "../../po-field/po-multiselect/po-multiselect-filter.service
17
18
  * > Por padrão esse componente cria `po-info` para exibição, é possível criar `po-tag` passando a propriedade { tag: true }.
18
19
  *
19
20
  */
20
- export class PoDynamicViewBaseComponent {
21
+ export class PoDynamicViewBaseComponent extends PoDynamicSharedBase {
21
22
  currencyPipe;
22
23
  datePipe;
23
24
  decimalPipe;
@@ -60,7 +61,6 @@ export class PoDynamicViewBaseComponent {
60
61
  *
61
62
  */
62
63
  load;
63
- visibleFields = [];
64
64
  service;
65
65
  _fields = [];
66
66
  _showAllValue = false;
@@ -123,6 +123,7 @@ export class PoDynamicViewBaseComponent {
123
123
  return this._value;
124
124
  }
125
125
  constructor(currencyPipe, datePipe, decimalPipe, timePipe, titleCasePipe, dynamicViewService, comboFilterService, multiselectFilterService) {
126
+ super();
126
127
  this.currencyPipe = currencyPipe;
127
128
  this.datePipe = datePipe;
128
129
  this.decimalPipe = decimalPipe;
@@ -132,8 +133,16 @@ export class PoDynamicViewBaseComponent {
132
133
  this.comboFilterService = comboFilterService;
133
134
  this.multiselectFilterService = multiselectFilterService;
134
135
  }
136
+ getFieldOrderRetroactive(position, index = 1) {
137
+ if (position === index) {
138
+ return position;
139
+ }
140
+ return this.fields.findIndex(field => field.order === index) > -1
141
+ ? this.getFieldOrderRetroactive(position, index + 1)
142
+ : index;
143
+ }
135
144
  getFieldOrder(field, index) {
136
- const position = index + 1;
145
+ const position = this.getFieldOrderRetroactive(index + 1);
137
146
  return this.fields.findIndex(e => e.order === position) > -1 ? this.getFieldOrder(field, position) : position;
138
147
  }
139
148
  getConfiguredFields(useSearchService = true) {
@@ -184,7 +193,9 @@ export class PoDynamicViewBaseComponent {
184
193
  this.createFieldWithService(field, newFields, _field);
185
194
  }
186
195
  });
187
- return sortFields(newFields);
196
+ const _sortedField = sortFields(newFields);
197
+ this.ensureFieldHasContainer(_sortedField);
198
+ return _sortedField;
188
199
  }
189
200
  // retorna fields ligado ao value mais os atributos do value que não possuiam fields.
190
201
  getMergedFields() {
@@ -353,7 +364,7 @@ export class PoDynamicViewBaseComponent {
353
364
  return formattedField;
354
365
  }
355
366
  static ɵfac = function PoDynamicViewBaseComponent_Factory(t) { return new (t || PoDynamicViewBaseComponent)(i0.ɵɵdirectiveInject(i1.CurrencyPipe), i0.ɵɵdirectiveInject(i1.DatePipe), i0.ɵɵdirectiveInject(i1.DecimalPipe), i0.ɵɵdirectiveInject(i2.PoTimePipe), i0.ɵɵdirectiveInject(i1.TitleCasePipe), i0.ɵɵdirectiveInject(i3.PoDynamicViewService), i0.ɵɵdirectiveInject(i4.PoComboFilterService), i0.ɵɵdirectiveInject(i5.PoMultiselectFilterService)); };
356
- static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoDynamicViewBaseComponent, inputs: { load: [i0.ɵɵInputFlags.None, "p-load", "load"], fields: [i0.ɵɵInputFlags.None, "p-fields", "fields"], showAllValue: [i0.ɵɵInputFlags.None, "p-show-all-value", "showAllValue"], value: [i0.ɵɵInputFlags.None, "p-value", "value"] } });
367
+ static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoDynamicViewBaseComponent, inputs: { load: [i0.ɵɵInputFlags.None, "p-load", "load"], fields: [i0.ɵɵInputFlags.None, "p-fields", "fields"], showAllValue: [i0.ɵɵInputFlags.None, "p-show-all-value", "showAllValue"], value: [i0.ɵɵInputFlags.None, "p-value", "value"] }, features: [i0.ɵɵInheritDefinitionFeature] });
357
368
  }
358
369
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoDynamicViewBaseComponent, [{
359
370
  type: Directive
@@ -370,4 +381,4 @@ export class PoDynamicViewBaseComponent {
370
381
  type: Input,
371
382
  args: ['p-value']
372
383
  }] }); })();
373
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-view-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe, DatePipe, DecimalPipe, TitleCasePipe } from '@angular/common';\nimport { Directive, Input } from '@angular/core';\n\nimport { PoTimePipe } from '../../../pipes/po-time/po-time.pipe';\nimport { convertToBoolean, isTypeof, sortFields } from '../../../utils/util';\n\nimport { Observable, catchError, map, of } from 'rxjs';\nimport { getGridColumnsClasses, isVisibleField } from '../po-dynamic.util';\nimport { PoDynamicViewField } from './po-dynamic-view-field.interface';\nimport { PoDynamicViewService } from './services/po-dynamic-view.service';\nimport { PoComboFilterService } from '../../po-field/po-combo/po-combo-filter.service';\nimport { PoMultiselectFilterService } from '../../po-field/po-multiselect/po-multiselect-filter.service';\n\n/**\n *\n * @description\n *\n * Componente para listar dados dinamicamente a partir de uma lista de objetos.\n *\n * > Por padrão esse componente cria `po-info` para exibição, é possível criar `po-tag` passando a propriedade { tag: true }.\n *\n */\n@Directive()\nexport class PoDynamicViewBaseComponent {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Possibilita executar uma função quando o componente é inicializado.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - **String**: Endpoint usado pelo componente para requisição via `POST`.\n   * - **Function**: Método que será executado na inicialização do componente.\n   *\n   * Para os dois tipos de utilização da propriedade espera-se o seguinte retorno:\n   *\n   * ```\n   * {\n   *   value: {\n   *     cnpj: '**************', // altera valor do campo\n   *     updated: (new Date()).toString() // atribui valor ao campo novo\n   *   },\n   *   fields: [\n   *     { property: 'cnpj', tag: true, inverse: true }, // atribui novas propriedades ao field\n   *     { property: 'updated', tag: true } // inclui campo novo\n   *   ]\n   * }\n   * ```\n   * > **value**: any = atribui novo valor do model.\n   *\n   * > **fields**: `Array<PoDynamicViewField>` = Lista de campos que deseja alterar as propriedades,\n   * caso enviar um campo a mais será criado um novo campo.\n   *\n   * - Para esconder/remover campos precisa informar no field a propriedade `visible = false`.\n   *\n   */\n  @Input('p-load') load: string | Function;\n\n  visibleFields = [];\n  service: any;\n\n  private _fields: Array<PoDynamicViewField> = [];\n  private _showAllValue: boolean = false;\n  private _value = {};\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista de objetos que implementam a interface `PoDynamicView`.\n   *\n   * > Ex: `[ { property: 'age' } ]`\n   *\n   * Regras de tipagem e formatação dos valores exibidos:\n   *\n   * - Caso o *type* informado seja *currency* e não seja informado o *format* o mesmo recebe \"'BRL', 'symbol', '1.2-2'\"\n   * como formato padrão.\n   * - Caso o *type* informado seja *date* e não seja informado o *format* o mesmo recebe 'dd/MM/yyyy' como formato padrão.\n   * - Caso o *type* informado seja *dateTime* e não seja informado o *format* o mesmo recebe 'dd/MM/yyyy HH:mm:ss' como formato padrão.\n   * - Caso o *type* informado seja *number* e não seja informado o *format* o mesmo não será formatado.\n   * - Caso o *type* informado seja *time* e não seja informado o *format* o mesmo recebe 'HH:mm:ss.ffffff' como formato padrão.\n   *\n   * > As propriedades informadas serão exibidas mesmo não contendo valor de referência no objeto da propriedade `p-value`.\n   *\n   * @default `[]`\n   */\n  @Input('p-fields') set fields(fields: Array<PoDynamicViewField>) {\n    this._fields = Array.isArray(fields) ? [...fields] : [];\n  }\n\n  get fields() {\n    return this._fields;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica se exibirá todas as informações contidas dentro do objeto informado na propriedade `p-value`.\n   *\n   * @default `false`\n   */\n  @Input('p-show-all-value') set showAllValue(value: boolean) {\n    this._showAllValue = convertToBoolean(value);\n  }\n\n  get showAllValue() {\n    return this._showAllValue;\n  }\n\n  /**\n   * @description\n   *\n   * Objeto que será utilizado para exibir as informações dinâmicas, o valor será recuperado através do atributo *property*\n   * dos objetos contidos na propridade `p-fields`.\n   *\n   * > Ex: `{ age: '35' }`\n   */\n  @Input('p-value') set value(value: object) {\n    this._value = value && isTypeof(value, 'object') ? value : {};\n  }\n\n  get value() {\n    return this._value;\n  }\n\n  constructor(\n    private currencyPipe: CurrencyPipe,\n    private datePipe: DatePipe,\n    private decimalPipe: DecimalPipe,\n    private timePipe: PoTimePipe,\n    private titleCasePipe: TitleCasePipe,\n    protected dynamicViewService: PoDynamicViewService,\n    protected comboFilterService: PoComboFilterService,\n    protected multiselectFilterService: PoMultiselectFilterService\n  ) {}\n\n  protected getFieldOrder(field: PoDynamicViewField, index: number) {\n    const position = index + 1;\n    return this.fields.findIndex(e => e.order === position) > -1 ? this.getFieldOrder(field, position) : position;\n  }\n\n  protected getConfiguredFields(useSearchService = true) {\n    const newFields = [];\n\n    this.fields.forEach((field, index) => {\n      field.order = field.order || this.getFieldOrder(field, index);\n\n      if (!isVisibleField(field)) {\n        return;\n      }\n\n      if (!field.searchService && !field.optionsService) {\n        newFields.push(this.createField(field));\n        return;\n      }\n\n      const hasValue =\n        this.value[field.property]?.length ||\n        (!Array.isArray(this.value[field.property]) && this.value[field.property] && useSearchService);\n\n      if (hasValue) {\n        const _field = this.returnValues({ ...field }, '');\n        newFields.push(_field);\n\n        if (field.searchService) {\n          if (typeof field.searchService === 'object') {\n            this.service = field.searchService as PoDynamicViewService;\n          } else if (typeof field.searchService === 'string') {\n            this.service = this.dynamicViewService;\n            this.service.setConfig(field.searchService);\n          }\n        } else if (field.optionsService) {\n          if (field.optionsMulti) {\n            if (typeof field.optionsService === 'object') {\n              this.service = field.optionsService as PoMultiselectFilterService;\n            } else {\n              this.service = this.multiselectFilterService;\n              this.service.configProperties(field.optionsService, field.fieldLabel, field.fieldValue);\n            }\n          } else {\n            if (typeof field.optionsService === 'object') {\n              this.service = field.optionsService as PoComboFilterService;\n            } else {\n              this.service = this.comboFilterService;\n              this.service.configProperties(field.optionsService, field.fieldLabel, field.fieldValue);\n            }\n          }\n        }\n\n        this.createFieldWithService(field, newFields, _field);\n      }\n    });\n\n    return sortFields(newFields);\n  }\n\n  // retorna fields ligado ao value mais os atributos do value que não possuiam fields.\n  protected getMergedFields() {\n    const mergedFields = [...this.getConfiguredFields()];\n\n    this.getValueFields().forEach(valueField => {\n      const fieldIndex = mergedFields.findIndex(field => field.property === valueField.property);\n      const property = valueField.property;\n\n      if (fieldIndex === -1) {\n        mergedFields.push(this.createField({ property }));\n      }\n    });\n\n    return mergedFields;\n  }\n\n  // retorna o objeto value como fields.\n  protected getValueFields() {\n    return Object.keys(this.value).map(property => this.createField({ property }));\n  }\n\n  private createField(field: PoDynamicViewField) {\n    const property = field.property;\n    let value;\n    if (field.isArrayOrObject && this.value[property]) {\n      value = this.transformArrayValue(this.value[property], field);\n    } else if (field.fieldLabel) {\n      value = this.transformFieldLabel(property, field);\n    }\n\n    if (!value) {\n      value = this.transformValue(field.type, this.value[property], field.format);\n    }\n\n    return this.returnValues(field, value);\n  }\n\n  private createFieldWithService(field: PoDynamicViewField, newFields?, oldField?) {\n    const property = field.property;\n\n    this.searchById(this.value[property], field).subscribe(response => {\n      const value = response;\n      const allValues = this.returnValues(field, value);\n      const oldFieldIndex = newFields.indexOf(newFields.find(field => field === oldField));\n      newFields.splice(oldFieldIndex, 1, allValues);\n      sortFields(newFields);\n    });\n  }\n\n  private returnValues(field: PoDynamicViewField, value: any) {\n    const property = field.property;\n    const classesGridColumns = getGridColumnsClasses(\n      field.gridColumns,\n      field.offsetColumns,\n      {\n        smGrid: field.gridSmColumns,\n        mdGrid: field.gridMdColumns,\n        lgGrid: field.gridLgColumns,\n        xlGrid: field.gridXlColumns\n      },\n      {\n        smOffset: field.offsetSmColumns,\n        mdOffset: field.offsetMdColumns,\n        lgOffset: field.offsetLgColumns,\n        xlOffset: field.offsetXlColumns\n      },\n      {\n        smPull: field.gridSmPull,\n        mdPull: field.gridMdPull,\n        lgPull: field.gridLgPull,\n        xlPull: field.gridXlPull\n      }\n    );\n\n    return {\n      property,\n      value,\n      label: this.titleCasePipe.transform(property),\n      cssClass: classesGridColumns,\n      ...field\n    };\n  }\n\n  private searchById(value: any, field: PoDynamicViewField): Observable<any> {\n    if (typeof value === 'string') {\n      value = value.trim();\n    }\n\n    if (value !== '') {\n      if (field.optionsMulti) {\n        return this.service\n          .getObjectsByValues(value, field.params)\n          .pipe(map(res => this.transformArrayValue(res, field)))\n          .pipe(catchError(() => of(null)));\n      } else {\n        return this.service\n          .getObjectByValue(value, field.params)\n          .pipe(map(res => this.transformArrayValue(res, field)))\n          .pipe(catchError(() => of(null)));\n      }\n    } else {\n      return of(null);\n    }\n  }\n\n  private transformArrayValue(valueProperty: any, field: PoDynamicViewField) {\n    const valueArray = Array.isArray(valueProperty) ? valueProperty : [valueProperty];\n    let labels: Array<string>;\n\n    if (Array.isArray(field.format)) {\n      labels = valueArray.map(objectData => this.formatField(objectData, field.format));\n    } else {\n      const arrayWithLabel = valueArray.map(item => ({\n        value: item[field.fieldValue] || item.value,\n        label: item[field.fieldLabel] || item.label\n      }));\n\n      labels = arrayWithLabel.map(optionValue => {\n        if (optionValue.label) {\n          const labelTranformed = this.transformValue(field.type, optionValue.label, field.format);\n          if (field.concatLabelValue && optionValue.value) {\n            return `${labelTranformed} - ${optionValue.value}`;\n          } else {\n            return labelTranformed;\n          }\n        }\n      });\n    }\n\n    if (labels[0] !== undefined && labels.join()) {\n      return labels.join(', ');\n    } else {\n      valueProperty = '';\n      return undefined;\n    }\n  }\n\n  private transformFieldLabel(property: string, field: PoDynamicViewField) {\n    if (field.concatLabelValue && field.fieldLabel && field.fieldValue && !field.isArrayOrObject) {\n      const transformedValue = this.transformValue(field.type, this.value[field.fieldLabel], field.format);\n      return `${transformedValue} - ${this.value[field.fieldValue]}`;\n    }\n\n    if (field.fieldLabel && !field.concatLabelValue && !field.isArrayOrObject) {\n      this.value[property] = this.value[field.fieldLabel];\n    }\n    return undefined;\n  }\n\n  private transformValue(type: string, value, format) {\n    let transformedValue = value;\n\n    switch (type) {\n      case 'currency':\n        transformedValue = this.currencyPipe.transform(value, format || 'BRL', 'symbol', '1.2-2');\n        break;\n      case 'date':\n        transformedValue = this.datePipe.transform(value, format || 'dd/MM/yyyy');\n        break;\n      case 'dateTime':\n        transformedValue = this.datePipe.transform(value, format || 'dd/MM/yyyy HH:mm:ss');\n        break;\n      case 'number':\n        transformedValue = this.decimalPipe.transform(value, format);\n        break;\n      case 'time':\n        transformedValue = this.timePipe.transform(value, format || 'HH:mm:ss.ffffff');\n        break;\n    }\n\n    return transformedValue;\n  }\n\n  private formatField(objectSelected, properties) {\n    let formattedField;\n    if (Array.isArray(properties)) {\n      for (const property of properties) {\n        if (objectSelected && objectSelected[property]) {\n          if (!formattedField) {\n            formattedField = objectSelected[property];\n          } else {\n            formattedField += ' - ' + objectSelected[property];\n          }\n        }\n      }\n    }\n    return formattedField;\n  }\n}\n"]}
384
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-view-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe, DatePipe, DecimalPipe, TitleCasePipe } from '@angular/common';\nimport { Directive, Input } from '@angular/core';\n\nimport { PoTimePipe } from '../../../pipes/po-time/po-time.pipe';\nimport { convertToBoolean, isTypeof, sortFields } from '../../../utils/util';\n\nimport { Observable, catchError, map, of } from 'rxjs';\nimport { getGridColumnsClasses, isVisibleField } from '../po-dynamic.util';\nimport { PoDynamicViewField } from './po-dynamic-view-field.interface';\nimport { PoDynamicViewService } from './services/po-dynamic-view.service';\nimport { PoComboFilterService } from '../../po-field/po-combo/po-combo-filter.service';\nimport { PoMultiselectFilterService } from '../../po-field/po-multiselect/po-multiselect-filter.service';\nimport { PoDynamicSharedBase } from '../shared/po-dynamic-shared-base';\n\n/**\n *\n * @description\n *\n * Componente para listar dados dinamicamente a partir de uma lista de objetos.\n *\n * > Por padrão esse componente cria `po-info` para exibição, é possível criar `po-tag` passando a propriedade { tag: true }.\n *\n */\n@Directive()\nexport class PoDynamicViewBaseComponent extends PoDynamicSharedBase {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Possibilita executar uma função quando o componente é inicializado.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - **String**: Endpoint usado pelo componente para requisição via `POST`.\n   * - **Function**: Método que será executado na inicialização do componente.\n   *\n   * Para os dois tipos de utilização da propriedade espera-se o seguinte retorno:\n   *\n   * ```\n   * {\n   *   value: {\n   *     cnpj: '**************', // altera valor do campo\n   *     updated: (new Date()).toString() // atribui valor ao campo novo\n   *   },\n   *   fields: [\n   *     { property: 'cnpj', tag: true, inverse: true }, // atribui novas propriedades ao field\n   *     { property: 'updated', tag: true } // inclui campo novo\n   *   ]\n   * }\n   * ```\n   * > **value**: any = atribui novo valor do model.\n   *\n   * > **fields**: `Array<PoDynamicViewField>` = Lista de campos que deseja alterar as propriedades,\n   * caso enviar um campo a mais será criado um novo campo.\n   *\n   * - Para esconder/remover campos precisa informar no field a propriedade `visible = false`.\n   *\n   */\n  @Input('p-load') load: string | Function;\n\n  service: any;\n\n  private _fields: Array<PoDynamicViewField> = [];\n  private _showAllValue: boolean = false;\n  private _value = {};\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista de objetos que implementam a interface `PoDynamicView`.\n   *\n   * > Ex: `[ { property: 'age' } ]`\n   *\n   * Regras de tipagem e formatação dos valores exibidos:\n   *\n   * - Caso o *type* informado seja *currency* e não seja informado o *format* o mesmo recebe \"'BRL', 'symbol', '1.2-2'\"\n   * como formato padrão.\n   * - Caso o *type* informado seja *date* e não seja informado o *format* o mesmo recebe 'dd/MM/yyyy' como formato padrão.\n   * - Caso o *type* informado seja *dateTime* e não seja informado o *format* o mesmo recebe 'dd/MM/yyyy HH:mm:ss' como formato padrão.\n   * - Caso o *type* informado seja *number* e não seja informado o *format* o mesmo não será formatado.\n   * - Caso o *type* informado seja *time* e não seja informado o *format* o mesmo recebe 'HH:mm:ss.ffffff' como formato padrão.\n   *\n   * > As propriedades informadas serão exibidas mesmo não contendo valor de referência no objeto da propriedade `p-value`.\n   *\n   * @default `[]`\n   */\n  @Input('p-fields') set fields(fields: Array<PoDynamicViewField>) {\n    this._fields = Array.isArray(fields) ? [...fields] : [];\n  }\n\n  get fields() {\n    return this._fields;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica se exibirá todas as informações contidas dentro do objeto informado na propriedade `p-value`.\n   *\n   * @default `false`\n   */\n  @Input('p-show-all-value') set showAllValue(value: boolean) {\n    this._showAllValue = convertToBoolean(value);\n  }\n\n  get showAllValue() {\n    return this._showAllValue;\n  }\n\n  /**\n   * @description\n   *\n   * Objeto que será utilizado para exibir as informações dinâmicas, o valor será recuperado através do atributo *property*\n   * dos objetos contidos na propridade `p-fields`.\n   *\n   * > Ex: `{ age: '35' }`\n   */\n  @Input('p-value') set value(value: object) {\n    this._value = value && isTypeof(value, 'object') ? value : {};\n  }\n\n  get value() {\n    return this._value;\n  }\n\n  constructor(\n    private currencyPipe: CurrencyPipe,\n    private datePipe: DatePipe,\n    private decimalPipe: DecimalPipe,\n    private timePipe: PoTimePipe,\n    private titleCasePipe: TitleCasePipe,\n    protected dynamicViewService: PoDynamicViewService,\n    protected comboFilterService: PoComboFilterService,\n    protected multiselectFilterService: PoMultiselectFilterService\n  ) {\n    super();\n  }\n\n  protected getFieldOrderRetroactive(position: number, index: number = 1): number {\n    if (position === index) {\n      return position;\n    }\n    return this.fields.findIndex(field => field.order === index) > -1\n      ? this.getFieldOrderRetroactive(position, index + 1)\n      : index;\n  }\n\n  protected getFieldOrder(field: PoDynamicViewField, index: number): number {\n    const position = this.getFieldOrderRetroactive(index + 1);\n    return this.fields.findIndex(e => e.order === position) > -1 ? this.getFieldOrder(field, position) : position;\n  }\n\n  protected getConfiguredFields(useSearchService = true) {\n    const newFields = [];\n\n    this.fields.forEach((field, index) => {\n      field.order = field.order || this.getFieldOrder(field, index);\n\n      if (!isVisibleField(field)) {\n        return;\n      }\n\n      if (!field.searchService && !field.optionsService) {\n        newFields.push(this.createField(field));\n        return;\n      }\n\n      const hasValue =\n        this.value[field.property]?.length ||\n        (!Array.isArray(this.value[field.property]) && this.value[field.property] && useSearchService);\n\n      if (hasValue) {\n        const _field = this.returnValues({ ...field }, '');\n        newFields.push(_field);\n\n        if (field.searchService) {\n          if (typeof field.searchService === 'object') {\n            this.service = field.searchService as PoDynamicViewService;\n          } else if (typeof field.searchService === 'string') {\n            this.service = this.dynamicViewService;\n            this.service.setConfig(field.searchService);\n          }\n        } else if (field.optionsService) {\n          if (field.optionsMulti) {\n            if (typeof field.optionsService === 'object') {\n              this.service = field.optionsService as PoMultiselectFilterService;\n            } else {\n              this.service = this.multiselectFilterService;\n              this.service.configProperties(field.optionsService, field.fieldLabel, field.fieldValue);\n            }\n          } else {\n            if (typeof field.optionsService === 'object') {\n              this.service = field.optionsService as PoComboFilterService;\n            } else {\n              this.service = this.comboFilterService;\n              this.service.configProperties(field.optionsService, field.fieldLabel, field.fieldValue);\n            }\n          }\n        }\n\n        this.createFieldWithService(field, newFields, _field);\n      }\n    });\n\n    const _sortedField = sortFields(newFields);\n    this.ensureFieldHasContainer(_sortedField);\n\n    return _sortedField;\n  }\n\n  // retorna fields ligado ao value mais os atributos do value que não possuiam fields.\n  protected getMergedFields() {\n    const mergedFields = [...this.getConfiguredFields()];\n\n    this.getValueFields().forEach(valueField => {\n      const fieldIndex = mergedFields.findIndex(field => field.property === valueField.property);\n      const property = valueField.property;\n\n      if (fieldIndex === -1) {\n        mergedFields.push(this.createField({ property }));\n      }\n    });\n\n    return mergedFields;\n  }\n\n  // retorna o objeto value como fields.\n  protected getValueFields() {\n    return Object.keys(this.value).map(property => this.createField({ property }));\n  }\n\n  private createField(field: PoDynamicViewField) {\n    const property = field.property;\n    let value;\n    if (field.isArrayOrObject && this.value[property]) {\n      value = this.transformArrayValue(this.value[property], field);\n    } else if (field.fieldLabel) {\n      value = this.transformFieldLabel(property, field);\n    }\n\n    if (!value) {\n      value = this.transformValue(field.type, this.value[property], field.format);\n    }\n\n    return this.returnValues(field, value);\n  }\n\n  private createFieldWithService(field: PoDynamicViewField, newFields?, oldField?) {\n    const property = field.property;\n\n    this.searchById(this.value[property], field).subscribe(response => {\n      const value = response;\n      const allValues = this.returnValues(field, value);\n      const oldFieldIndex = newFields.indexOf(newFields.find(field => field === oldField));\n      newFields.splice(oldFieldIndex, 1, allValues);\n      sortFields(newFields);\n    });\n  }\n\n  private returnValues(field: PoDynamicViewField, value: any) {\n    const property = field.property;\n    const classesGridColumns = getGridColumnsClasses(\n      field.gridColumns,\n      field.offsetColumns,\n      {\n        smGrid: field.gridSmColumns,\n        mdGrid: field.gridMdColumns,\n        lgGrid: field.gridLgColumns,\n        xlGrid: field.gridXlColumns\n      },\n      {\n        smOffset: field.offsetSmColumns,\n        mdOffset: field.offsetMdColumns,\n        lgOffset: field.offsetLgColumns,\n        xlOffset: field.offsetXlColumns\n      },\n      {\n        smPull: field.gridSmPull,\n        mdPull: field.gridMdPull,\n        lgPull: field.gridLgPull,\n        xlPull: field.gridXlPull\n      }\n    );\n\n    return {\n      property,\n      value,\n      label: this.titleCasePipe.transform(property),\n      cssClass: classesGridColumns,\n      ...field\n    };\n  }\n\n  private searchById(value: any, field: PoDynamicViewField): Observable<any> {\n    if (typeof value === 'string') {\n      value = value.trim();\n    }\n\n    if (value !== '') {\n      if (field.optionsMulti) {\n        return this.service\n          .getObjectsByValues(value, field.params)\n          .pipe(map(res => this.transformArrayValue(res, field)))\n          .pipe(catchError(() => of(null)));\n      } else {\n        return this.service\n          .getObjectByValue(value, field.params)\n          .pipe(map(res => this.transformArrayValue(res, field)))\n          .pipe(catchError(() => of(null)));\n      }\n    } else {\n      return of(null);\n    }\n  }\n\n  private transformArrayValue(valueProperty: any, field: PoDynamicViewField) {\n    const valueArray = Array.isArray(valueProperty) ? valueProperty : [valueProperty];\n    let labels: Array<string>;\n\n    if (Array.isArray(field.format)) {\n      labels = valueArray.map(objectData => this.formatField(objectData, field.format));\n    } else {\n      const arrayWithLabel = valueArray.map(item => ({\n        value: item[field.fieldValue] || item.value,\n        label: item[field.fieldLabel] || item.label\n      }));\n\n      labels = arrayWithLabel.map(optionValue => {\n        if (optionValue.label) {\n          const labelTranformed = this.transformValue(field.type, optionValue.label, field.format);\n          if (field.concatLabelValue && optionValue.value) {\n            return `${labelTranformed} - ${optionValue.value}`;\n          } else {\n            return labelTranformed;\n          }\n        }\n      });\n    }\n\n    if (labels[0] !== undefined && labels.join()) {\n      return labels.join(', ');\n    } else {\n      valueProperty = '';\n      return undefined;\n    }\n  }\n\n  private transformFieldLabel(property: string, field: PoDynamicViewField) {\n    if (field.concatLabelValue && field.fieldLabel && field.fieldValue && !field.isArrayOrObject) {\n      const transformedValue = this.transformValue(field.type, this.value[field.fieldLabel], field.format);\n      return `${transformedValue} - ${this.value[field.fieldValue]}`;\n    }\n\n    if (field.fieldLabel && !field.concatLabelValue && !field.isArrayOrObject) {\n      this.value[property] = this.value[field.fieldLabel];\n    }\n    return undefined;\n  }\n\n  private transformValue(type: string, value, format) {\n    let transformedValue = value;\n\n    switch (type) {\n      case 'currency':\n        transformedValue = this.currencyPipe.transform(value, format || 'BRL', 'symbol', '1.2-2');\n        break;\n      case 'date':\n        transformedValue = this.datePipe.transform(value, format || 'dd/MM/yyyy');\n        break;\n      case 'dateTime':\n        transformedValue = this.datePipe.transform(value, format || 'dd/MM/yyyy HH:mm:ss');\n        break;\n      case 'number':\n        transformedValue = this.decimalPipe.transform(value, format);\n        break;\n      case 'time':\n        transformedValue = this.timePipe.transform(value, format || 'HH:mm:ss.ffffff');\n        break;\n    }\n\n    return transformedValue;\n  }\n\n  private formatField(objectSelected, properties) {\n    let formattedField;\n    if (Array.isArray(properties)) {\n      for (const property of properties) {\n        if (objectSelected && objectSelected[property]) {\n          if (!formattedField) {\n            formattedField = objectSelected[property];\n          } else {\n            formattedField += ' - ' + objectSelected[property];\n          }\n        }\n      }\n    }\n    return formattedField;\n  }\n}\n"]}
@@ -10,56 +10,77 @@ import * as i6 from "../../po-divider/po-divider.component";
10
10
  import * as i7 from "../../po-info/po-info.component";
11
11
  import * as i8 from "../../po-tag/po-tag.component";
12
12
  import * as i9 from "../../po-image/po-image.component";
13
- function PoDynamicViewComponent_div_0_ng_template_1_po_divider_0_Template(rf, ctx) { if (rf & 1) {
14
- i0.ɵɵelement(0, "po-divider", 8);
15
- } if (rf & 2) {
16
- const field_r8 = i0.ɵɵnextContext().$implicit;
17
- i0.ɵɵproperty("p-label", field_r8.divider);
18
- } }
19
- function PoDynamicViewComponent_div_0_ng_template_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
13
+ import * as i10 from "../po-dynamic-container/po-dynamic-container.component";
14
+ function PoDynamicViewComponent_div_0_ng_container_1_Template(rf, ctx) { if (rf & 1) {
20
15
  i0.ɵɵelementContainer(0);
21
16
  } }
22
17
  const _c0 = a0 => ({ $implicit: a0 });
23
- function PoDynamicViewComponent_div_0_ng_template_1_Template(rf, ctx) { if (rf & 1) {
24
- i0.ɵɵtemplate(0, PoDynamicViewComponent_div_0_ng_template_1_po_divider_0_Template, 1, 1, "po-divider", 6)(1, PoDynamicViewComponent_div_0_ng_template_1_ng_container_1_Template, 1, 0, "ng-container", 7);
18
+ function PoDynamicViewComponent_div_0_Template(rf, ctx) { if (rf & 1) {
19
+ i0.ɵɵelementStart(0, "div", 6);
20
+ i0.ɵɵtemplate(1, PoDynamicViewComponent_div_0_ng_container_1_Template, 1, 0, "ng-container", 7);
21
+ i0.ɵɵelementEnd();
25
22
  } if (rf & 2) {
26
- const field_r8 = ctx.$implicit;
27
- i0.ɵɵnextContext(2);
28
- const _r2 = i0.ɵɵreference(2);
23
+ const ctx_r0 = i0.ɵɵnextContext();
29
24
  const _r4 = i0.ɵɵreference(4);
30
- const _r6 = i0.ɵɵreference(6);
31
- i0.ɵɵproperty("ngIf", field_r8 == null ? null : field_r8.divider == null ? null : field_r8.divider.trim());
25
+ const _r2 = i0.ɵɵreference(2);
26
+ i0.ɵɵclassProp("po-dynamic", ctx_r0.hasContainers);
32
27
  i0.ɵɵadvance();
33
- i0.ɵɵproperty("ngTemplateOutlet", !field_r8.tag && !field_r8.image ? _r2 : !field_r8.image ? _r4 : _r6)("ngTemplateOutletContext", i0.ɵɵpureFunction1(3, _c0, field_r8));
28
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.hasContainers ? _r4 : _r2)("ngTemplateOutletContext", i0.ɵɵpureFunction1(4, _c0, ctx_r0.hasContainers ? ctx_r0.containerFields : ctx_r0.visibleFields));
34
29
  } }
35
- function PoDynamicViewComponent_div_0_Template(rf, ctx) { if (rf & 1) {
36
- i0.ɵɵelementStart(0, "div", 4);
37
- i0.ɵɵtemplate(1, PoDynamicViewComponent_div_0_ng_template_1_Template, 2, 5, "ng-template", 5);
38
- i0.ɵɵelementEnd();
30
+ function PoDynamicViewComponent_ng_template_1_ng_template_0_po_divider_0_Template(rf, ctx) { if (rf & 1) {
31
+ i0.ɵɵelement(0, "po-divider", 10);
39
32
  } if (rf & 2) {
40
- const ctx_r0 = i0.ɵɵnextContext();
33
+ const field_r14 = i0.ɵɵnextContext().$implicit;
34
+ i0.ɵɵproperty("p-label", field_r14.divider);
35
+ } }
36
+ function PoDynamicViewComponent_ng_template_1_ng_template_0_ng_container_1_Template(rf, ctx) { if (rf & 1) {
37
+ i0.ɵɵelementContainer(0);
38
+ } }
39
+ function PoDynamicViewComponent_ng_template_1_ng_template_0_Template(rf, ctx) { if (rf & 1) {
40
+ i0.ɵɵtemplate(0, PoDynamicViewComponent_ng_template_1_ng_template_0_po_divider_0_Template, 1, 1, "po-divider", 9)(1, PoDynamicViewComponent_ng_template_1_ng_template_0_ng_container_1_Template, 1, 0, "ng-container", 7);
41
+ } if (rf & 2) {
42
+ const field_r14 = ctx.$implicit;
43
+ i0.ɵɵnextContext(2);
44
+ const _r6 = i0.ɵɵreference(6);
45
+ const _r8 = i0.ɵɵreference(8);
46
+ const _r10 = i0.ɵɵreference(10);
47
+ i0.ɵɵproperty("ngIf", field_r14 == null ? null : field_r14.divider == null ? null : field_r14.divider.trim());
41
48
  i0.ɵɵadvance();
42
- i0.ɵɵproperty("ngForOf", ctx_r0.visibleFields);
49
+ i0.ɵɵproperty("ngTemplateOutlet", !field_r14.tag && !field_r14.image ? _r6 : !field_r14.image ? _r8 : _r10)("ngTemplateOutletContext", i0.ɵɵpureFunction1(3, _c0, field_r14));
43
50
  } }
44
51
  function PoDynamicViewComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
45
- i0.ɵɵelement(0, "po-info", 9);
52
+ i0.ɵɵtemplate(0, PoDynamicViewComponent_ng_template_1_ng_template_0_Template, 2, 5, "ng-template", 8);
46
53
  } if (rf & 2) {
47
- const field_r12 = ctx.$implicit;
48
- const ctx_r1 = i0.ɵɵnextContext();
49
- i0.ɵɵproperty("ngClass", field_r12.cssClass)("p-label", field_r12.label)("p-value", ctx_r1.setFieldValue(field_r12));
54
+ const fields_r12 = ctx.$implicit;
55
+ i0.ɵɵproperty("ngForOf", fields_r12);
50
56
  } }
51
57
  function PoDynamicViewComponent_ng_template_3_Template(rf, ctx) { if (rf & 1) {
52
- i0.ɵɵelement(0, "po-tag", 10);
58
+ i0.ɵɵelement(0, "po-dynamic-container", 11);
53
59
  } if (rf & 2) {
54
- const field_r13 = ctx.$implicit;
55
- const ctx_r3 = i0.ɵɵnextContext();
56
- i0.ɵɵproperty("ngClass", field_r13.cssClass)("p-color", field_r13.color)("p-icon", field_r13.icon)("p-inverse", field_r13.inverse)("p-label", field_r13.label)("p-value", ctx_r3.setFieldValue(field_r13));
60
+ const fields_r18 = ctx.$implicit;
61
+ i0.ɵɵnextContext();
62
+ const _r2 = i0.ɵɵreference(2);
63
+ i0.ɵɵproperty("p-fields", fields_r18)("p-content", _r2);
57
64
  } }
58
65
  function PoDynamicViewComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
59
- i0.ɵɵelement(0, "po-image", 11);
66
+ i0.ɵɵelement(0, "po-info", 12);
60
67
  } if (rf & 2) {
61
- const field_r14 = ctx.$implicit;
62
- i0.ɵɵproperty("p-alt", field_r14.alt)("p-height", field_r14.height)("p-src", field_r14.value);
68
+ const field_r19 = ctx.$implicit;
69
+ const ctx_r5 = i0.ɵɵnextContext();
70
+ i0.ɵɵproperty("ngClass", field_r19.cssClass)("p-label", field_r19.label)("p-value", ctx_r5.setFieldValue(field_r19));
71
+ } }
72
+ function PoDynamicViewComponent_ng_template_7_Template(rf, ctx) { if (rf & 1) {
73
+ i0.ɵɵelement(0, "po-tag", 13);
74
+ } if (rf & 2) {
75
+ const field_r20 = ctx.$implicit;
76
+ const ctx_r7 = i0.ɵɵnextContext();
77
+ i0.ɵɵproperty("ngClass", field_r20.cssClass)("p-color", field_r20.color)("p-icon", field_r20.icon)("p-inverse", field_r20.inverse)("p-label", field_r20.label)("p-value", ctx_r7.setFieldValue(field_r20));
78
+ } }
79
+ function PoDynamicViewComponent_ng_template_9_Template(rf, ctx) { if (rf & 1) {
80
+ i0.ɵɵelement(0, "po-image", 14);
81
+ } if (rf & 2) {
82
+ const field_r21 = ctx.$implicit;
83
+ i0.ɵɵproperty("p-alt", field_r21.alt)("p-height", field_r21.height)("p-src", field_r21.value);
63
84
  } }
64
85
  /**
65
86
  * @docsExtends PoDynamicViewBaseComponent
@@ -81,6 +102,11 @@ function PoDynamicViewComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
81
102
  * <file name="sample-po-dynamic-view-employee-on-load/sample-po-dynamic-view-employee-on-load.component.ts"> </file>
82
103
  * <file name="sample-po-dynamic-view-employee-on-load/sample-po-dynamic-view-employee-on-load.service.ts"> </file>
83
104
  * </example>
105
+ *
106
+ * <example name="po-dynamic-view-container" title="PO Dynamic View - Employee on load">
107
+ * <file name="sample-po-dynamic-view-container/sample-po-dynamic-view-container.component.html"> </file>
108
+ * <file name="sample-po-dynamic-view-container/sample-po-dynamic-view-container.component.ts"> </file>
109
+ * </example>
84
110
  */
85
111
  export class PoDynamicViewComponent extends PoDynamicViewBaseComponent {
86
112
  initChanges;
@@ -96,11 +122,14 @@ export class PoDynamicViewComponent extends PoDynamicViewBaseComponent {
96
122
  }
97
123
  if ((changes.fields || changes.value || changes.showAllValue) && this.initChanges) {
98
124
  this.visibleFields = this.getVisibleFields();
125
+ this.setContainerFields();
99
126
  }
100
127
  }
101
128
  ngOnInit() {
102
129
  if (this.load) {
103
- this.updateValuesAndFieldsOnLoad();
130
+ this.updateValuesAndFieldsOnLoad().finally(() => {
131
+ this.setContainerFields();
132
+ });
104
133
  }
105
134
  }
106
135
  setFieldValue(field) {
@@ -158,15 +187,15 @@ export class PoDynamicViewComponent extends PoDynamicViewBaseComponent {
158
187
  this.initChanges = true;
159
188
  }
160
189
  static ɵfac = function PoDynamicViewComponent_Factory(t) { return new (t || PoDynamicViewComponent)(i0.ɵɵdirectiveInject(i1.CurrencyPipe), i0.ɵɵdirectiveInject(i1.DatePipe), i0.ɵɵdirectiveInject(i1.DecimalPipe), i0.ɵɵdirectiveInject(i2.PoTimePipe), i0.ɵɵdirectiveInject(i1.TitleCasePipe), i0.ɵɵdirectiveInject(i3.PoDynamicViewService), i0.ɵɵdirectiveInject(i4.PoComboFilterService), i0.ɵɵdirectiveInject(i5.PoMultiselectFilterService)); };
161
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoDynamicViewComponent, selectors: [["po-dynamic-view"]], features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], decls: 7, vars: 1, consts: [["class", "po-dynamic-view po-row", 4, "ngIf"], ["poInfo", ""], ["poTag", ""], ["poImage", ""], [1, "po-dynamic-view", "po-row"], ["ngFor", "", 3, "ngForOf"], ["class", "po-sm-12", 3, "p-label", 4, "ngIf"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], [1, "po-sm-12", 3, "p-label"], [3, "ngClass", "p-label", "p-value"], [3, "ngClass", "p-color", "p-icon", "p-inverse", "p-label", "p-value"], [3, "p-alt", "p-height", "p-src"]], template: function PoDynamicViewComponent_Template(rf, ctx) { if (rf & 1) {
162
- i0.ɵɵtemplate(0, PoDynamicViewComponent_div_0_Template, 2, 1, "div", 0)(1, PoDynamicViewComponent_ng_template_1_Template, 1, 3, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor)(3, PoDynamicViewComponent_ng_template_3_Template, 1, 6, "ng-template", null, 2, i0.ɵɵtemplateRefExtractor)(5, PoDynamicViewComponent_ng_template_5_Template, 1, 3, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
190
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoDynamicViewComponent, selectors: [["po-dynamic-view"]], features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], decls: 11, vars: 1, consts: [["class", "po-row", 3, "po-dynamic", 4, "ngIf"], ["poContent", ""], ["poContentContainer", ""], ["poInfo", ""], ["poTag", ""], ["poImage", ""], [1, "po-row"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], ["ngFor", "", 3, "ngForOf"], ["class", "po-sm-12", 3, "p-label", 4, "ngIf"], [1, "po-sm-12", 3, "p-label"], [3, "p-fields", "p-content"], [3, "ngClass", "p-label", "p-value"], [3, "ngClass", "p-color", "p-icon", "p-inverse", "p-label", "p-value"], [3, "p-alt", "p-height", "p-src"]], template: function PoDynamicViewComponent_Template(rf, ctx) { if (rf & 1) {
191
+ i0.ɵɵtemplate(0, PoDynamicViewComponent_div_0_Template, 2, 6, "div", 0)(1, PoDynamicViewComponent_ng_template_1_Template, 1, 1, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor)(3, PoDynamicViewComponent_ng_template_3_Template, 1, 2, "ng-template", null, 2, i0.ɵɵtemplateRefExtractor)(5, PoDynamicViewComponent_ng_template_5_Template, 1, 3, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor)(7, PoDynamicViewComponent_ng_template_7_Template, 1, 6, "ng-template", null, 4, i0.ɵɵtemplateRefExtractor)(9, PoDynamicViewComponent_ng_template_9_Template, 1, 3, "ng-template", null, 5, i0.ɵɵtemplateRefExtractor);
163
192
  } if (rf & 2) {
164
193
  i0.ɵɵproperty("ngIf", ctx.visibleFields.length);
165
- } }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i1.NgTemplateOutlet, i6.PoDividerComponent, i7.PoInfoComponent, i8.PoTagComponent, i9.PoImageComponent], encapsulation: 2 });
194
+ } }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i1.NgTemplateOutlet, i6.PoDividerComponent, i7.PoInfoComponent, i8.PoTagComponent, i9.PoImageComponent, i10.PoDynamicContainerComponent], encapsulation: 2 });
166
195
  }
167
196
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoDynamicViewComponent, [{
168
197
  type: Component,
169
- args: [{ selector: 'po-dynamic-view', template: "<div class=\"po-dynamic-view po-row\" *ngIf=\"visibleFields.length\">\n <ng-template ngFor let-field [ngForOf]=\"visibleFields\">\n <po-divider *ngIf=\"field?.divider?.trim()\" class=\"po-sm-12\" [p-label]=\"field.divider\"> </po-divider>\n\n <ng-container\n *ngTemplateOutlet=\"\n !field.tag && !field.image ? poInfo : !field.image ? poTag : poImage;\n context: { $implicit: field }\n \"\n >\n </ng-container>\n </ng-template>\n</div>\n\n<ng-template #poInfo let-field>\n <po-info [ngClass]=\"field.cssClass\" [p-label]=\"field.label\" [p-value]=\"setFieldValue(field)\"> </po-info>\n</ng-template>\n\n<ng-template #poTag let-field>\n <po-tag\n [ngClass]=\"field.cssClass\"\n [p-color]=\"field.color\"\n [p-icon]=\"field.icon\"\n [p-inverse]=\"field.inverse\"\n [p-label]=\"field.label\"\n [p-value]=\"setFieldValue(field)\"\n >\n </po-tag>\n</ng-template>\n\n<ng-template #poImage let-field>\n <po-image [p-alt]=\"field.alt\" [p-height]=\"field.height\" [p-src]=\"field.value\"> </po-image>\n</ng-template>\n" }]
198
+ args: [{ selector: 'po-dynamic-view', template: "<div class=\"po-row\" [class.po-dynamic]=\"hasContainers\" *ngIf=\"visibleFields.length\">\n <ng-container\n *ngTemplateOutlet=\"\n hasContainers ? poContentContainer : poContent;\n context: { $implicit: hasContainers ? containerFields : visibleFields }\n \"\n ></ng-container>\n</div>\n\n<ng-template #poContent let-fields>\n <ng-template ngFor let-field [ngForOf]=\"fields\">\n <po-divider *ngIf=\"field?.divider?.trim()\" class=\"po-sm-12\" [p-label]=\"field.divider\"> </po-divider>\n <ng-container\n *ngTemplateOutlet=\"\n !field.tag && !field.image ? poInfo : !field.image ? poTag : poImage;\n context: { $implicit: field }\n \"\n >\n </ng-container>\n </ng-template>\n</ng-template>\n\n<ng-template #poContentContainer let-fields>\n <po-dynamic-container [p-fields]=\"fields\" [p-content]=\"poContent\"></po-dynamic-container>\n</ng-template>\n\n<ng-template #poInfo let-field>\n <po-info [ngClass]=\"field.cssClass\" [p-label]=\"field.label\" [p-value]=\"setFieldValue(field)\"> </po-info>\n</ng-template>\n\n<ng-template #poTag let-field>\n <po-tag\n [ngClass]=\"field.cssClass\"\n [p-color]=\"field.color\"\n [p-icon]=\"field.icon\"\n [p-inverse]=\"field.inverse\"\n [p-label]=\"field.label\"\n [p-value]=\"setFieldValue(field)\"\n >\n </po-tag>\n</ng-template>\n\n<ng-template #poImage let-field>\n <po-image [p-alt]=\"field.alt\" [p-height]=\"field.height\" [p-src]=\"field.value\"> </po-image>\n</ng-template>\n" }]
170
199
  }], () => [{ type: i1.CurrencyPipe }, { type: i1.DatePipe }, { type: i1.DecimalPipe }, { type: i2.PoTimePipe }, { type: i1.TitleCasePipe }, { type: i3.PoDynamicViewService }, { type: i4.PoComboFilterService }, { type: i5.PoMultiselectFilterService }], null); })();
171
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoDynamicViewComponent, { className: "PoDynamicViewComponent", filePath: "lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.ts", lineNumber: 37 }); })();
172
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.ts","../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe, DatePipe, DecimalPipe, TitleCasePipe } from '@angular/common';\nimport { Component, OnChanges, OnInit, SimpleChanges } from '@angular/core';\n\nimport { PoTimePipe } from '../../../pipes/po-time/po-time.pipe';\n\nimport { PoDynamicViewField } from './../po-dynamic-view/po-dynamic-view-field.interface';\nimport { PoDynamicViewBaseComponent } from './po-dynamic-view-base.component';\nimport { PoDynamicViewService } from './services/po-dynamic-view.service';\nimport { PoComboFilterService } from '../../po-field/po-combo/po-combo-filter.service';\nimport { PoMultiselectFilterService } from '../../po-field/po-multiselect/po-multiselect-filter.service';\n\n/**\n * @docsExtends PoDynamicViewBaseComponent\n *\n * @example\n *\n * <example name=\"po-dynamic-view-basic\" title=\"PO Dynamic View Basic\">\n *  <file name=\"sample-po-dynamic-view-basic/sample-po-dynamic-view-basic.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-view-basic/sample-po-dynamic-view-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dynamic-view-employee\" title=\"PO Dynamic View - Employee\">\n *  <file name=\"sample-po-dynamic-view-employee/sample-po-dynamic-view-employee.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-view-employee/sample-po-dynamic-view-employee.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dynamic-view-employee-on-load\" title=\"PO Dynamic View - Employee on load\">\n *  <file name=\"sample-po-dynamic-view-employee-on-load/sample-po-dynamic-view-employee-on-load.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-view-employee-on-load/sample-po-dynamic-view-employee-on-load.component.ts\"> </file>\n *  <file name=\"sample-po-dynamic-view-employee-on-load/sample-po-dynamic-view-employee-on-load.service.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-dynamic-view',\n  templateUrl: './po-dynamic-view.component.html'\n})\nexport class PoDynamicViewComponent extends PoDynamicViewBaseComponent implements OnChanges, OnInit {\n  initChanges;\n  constructor(\n    currencyPipe: CurrencyPipe,\n    datePipe: DatePipe,\n    decimalPipe: DecimalPipe,\n    timePipe: PoTimePipe,\n    titleCasePipe: TitleCasePipe,\n    dynamicViewService: PoDynamicViewService,\n    comboFilterService: PoComboFilterService,\n    multiselectFilterService: PoMultiselectFilterService\n  ) {\n    super(\n      currencyPipe,\n      datePipe,\n      decimalPipe,\n      timePipe,\n      titleCasePipe,\n      dynamicViewService,\n      comboFilterService,\n      multiselectFilterService\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.load && !this.initChanges) {\n      this.initChanges = false;\n    } else {\n      this.initChanges = true;\n    }\n    if ((changes.fields || changes.value || changes.showAllValue) && this.initChanges) {\n      this.visibleFields = this.getVisibleFields();\n    }\n  }\n\n  ngOnInit() {\n    if (this.load) {\n      this.updateValuesAndFieldsOnLoad();\n    }\n  }\n\n  setFieldValue(field) {\n    if (field.options) {\n      const selectedOption = field.options.find(option => option.value === field.value);\n      return selectedOption ? selectedOption.label : field.value;\n    } else if (field.type === 'boolean' && 'booleanTrue' in field && 'booleanFalse' in field) {\n      return field.value ? field.booleanTrue : field.booleanFalse;\n    } else {\n      return field.value;\n    }\n  }\n\n  private async getValuesAndFieldsFromLoad(): Promise<{ value?: any; fields?: Array<PoDynamicViewField> }> {\n    let valueAndFieldsFromLoad;\n\n    if (typeof this.load === 'string') {\n      valueAndFieldsFromLoad = await this.dynamicViewService.onLoad(this.load, this.value);\n    } else if (typeof this.load === 'function') {\n      valueAndFieldsFromLoad = this.load();\n    }\n\n    return valueAndFieldsFromLoad || {};\n  }\n\n  private getVisibleFields() {\n    if (this.showAllValue) {\n      return this.getMergedFields();\n    }\n\n    return this.value && this.fields.length ? this.getConfiguredFields() : this.getValueFields();\n  }\n\n  private setFieldOnLoad(fieldOnLoad: PoDynamicViewField) {\n    const index = this.fields.findIndex(field => field.property === fieldOnLoad.property);\n\n    if (index >= 0) {\n      this.fields[index] = { ...this.fields[index], ...fieldOnLoad };\n    } else {\n      this.fields.push({ ...fieldOnLoad });\n    }\n  }\n\n  private setFieldsOnLoad(fields: Array<PoDynamicViewField>) {\n    if (fields) {\n      fields.forEach(fieldOnLoad => {\n        this.setFieldOnLoad(fieldOnLoad);\n      });\n    }\n  }\n\n  private setValueOnLoad(newValue: any) {\n    Object.assign(this.value, newValue);\n  }\n\n  private async updateValuesAndFieldsOnLoad() {\n    const { value, fields } = await this.getValuesAndFieldsFromLoad();\n\n    this.setValueOnLoad(value);\n    this.setFieldsOnLoad(fields);\n\n    this.visibleFields = this.getVisibleFields();\n    this.initChanges = true;\n  }\n}\n","<div class=\"po-dynamic-view po-row\" *ngIf=\"visibleFields.length\">\n  <ng-template ngFor let-field [ngForOf]=\"visibleFields\">\n    <po-divider *ngIf=\"field?.divider?.trim()\" class=\"po-sm-12\" [p-label]=\"field.divider\"> </po-divider>\n\n    <ng-container\n      *ngTemplateOutlet=\"\n        !field.tag && !field.image ? poInfo : !field.image ? poTag : poImage;\n        context: { $implicit: field }\n      \"\n    >\n    </ng-container>\n  </ng-template>\n</div>\n\n<ng-template #poInfo let-field>\n  <po-info [ngClass]=\"field.cssClass\" [p-label]=\"field.label\" [p-value]=\"setFieldValue(field)\"> </po-info>\n</ng-template>\n\n<ng-template #poTag let-field>\n  <po-tag\n    [ngClass]=\"field.cssClass\"\n    [p-color]=\"field.color\"\n    [p-icon]=\"field.icon\"\n    [p-inverse]=\"field.inverse\"\n    [p-label]=\"field.label\"\n    [p-value]=\"setFieldValue(field)\"\n  >\n  </po-tag>\n</ng-template>\n\n<ng-template #poImage let-field>\n  <po-image [p-alt]=\"field.alt\" [p-height]=\"field.height\" [p-src]=\"field.value\"> </po-image>\n</ng-template>\n"]}
200
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoDynamicViewComponent, { className: "PoDynamicViewComponent", filePath: "lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.ts", lineNumber: 42 }); })();
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.ts","../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe, DatePipe, DecimalPipe, TitleCasePipe } from '@angular/common';\nimport { Component, OnChanges, OnInit, SimpleChanges } from '@angular/core';\n\nimport { PoTimePipe } from '../../../pipes/po-time/po-time.pipe';\n\nimport { PoDynamicViewField } from './../po-dynamic-view/po-dynamic-view-field.interface';\nimport { PoDynamicViewBaseComponent } from './po-dynamic-view-base.component';\nimport { PoDynamicViewService } from './services/po-dynamic-view.service';\nimport { PoComboFilterService } from '../../po-field/po-combo/po-combo-filter.service';\nimport { PoMultiselectFilterService } from '../../po-field/po-multiselect/po-multiselect-filter.service';\n\n/**\n * @docsExtends PoDynamicViewBaseComponent\n *\n * @example\n *\n * <example name=\"po-dynamic-view-basic\" title=\"PO Dynamic View Basic\">\n *  <file name=\"sample-po-dynamic-view-basic/sample-po-dynamic-view-basic.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-view-basic/sample-po-dynamic-view-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dynamic-view-employee\" title=\"PO Dynamic View - Employee\">\n *  <file name=\"sample-po-dynamic-view-employee/sample-po-dynamic-view-employee.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-view-employee/sample-po-dynamic-view-employee.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dynamic-view-employee-on-load\" title=\"PO Dynamic View - Employee on load\">\n *  <file name=\"sample-po-dynamic-view-employee-on-load/sample-po-dynamic-view-employee-on-load.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-view-employee-on-load/sample-po-dynamic-view-employee-on-load.component.ts\"> </file>\n *  <file name=\"sample-po-dynamic-view-employee-on-load/sample-po-dynamic-view-employee-on-load.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-dynamic-view-container\" title=\"PO Dynamic View - Employee on load\">\n *  <file name=\"sample-po-dynamic-view-container/sample-po-dynamic-view-container.component.html\"> </file>\n *  <file name=\"sample-po-dynamic-view-container/sample-po-dynamic-view-container.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-dynamic-view',\n  templateUrl: './po-dynamic-view.component.html'\n})\nexport class PoDynamicViewComponent extends PoDynamicViewBaseComponent implements OnChanges, OnInit {\n  initChanges;\n  constructor(\n    currencyPipe: CurrencyPipe,\n    datePipe: DatePipe,\n    decimalPipe: DecimalPipe,\n    timePipe: PoTimePipe,\n    titleCasePipe: TitleCasePipe,\n    dynamicViewService: PoDynamicViewService,\n    comboFilterService: PoComboFilterService,\n    multiselectFilterService: PoMultiselectFilterService\n  ) {\n    super(\n      currencyPipe,\n      datePipe,\n      decimalPipe,\n      timePipe,\n      titleCasePipe,\n      dynamicViewService,\n      comboFilterService,\n      multiselectFilterService\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.load && !this.initChanges) {\n      this.initChanges = false;\n    } else {\n      this.initChanges = true;\n    }\n    if ((changes.fields || changes.value || changes.showAllValue) && this.initChanges) {\n      this.visibleFields = this.getVisibleFields();\n      this.setContainerFields();\n    }\n  }\n\n  ngOnInit() {\n    if (this.load) {\n      this.updateValuesAndFieldsOnLoad().finally(() => {\n        this.setContainerFields();\n      });\n    }\n  }\n\n  setFieldValue(field) {\n    if (field.options) {\n      const selectedOption = field.options.find(option => option.value === field.value);\n      return selectedOption ? selectedOption.label : field.value;\n    } else if (field.type === 'boolean' && 'booleanTrue' in field && 'booleanFalse' in field) {\n      return field.value ? field.booleanTrue : field.booleanFalse;\n    } else {\n      return field.value;\n    }\n  }\n\n  private async getValuesAndFieldsFromLoad(): Promise<{ value?: any; fields?: Array<PoDynamicViewField> }> {\n    let valueAndFieldsFromLoad;\n\n    if (typeof this.load === 'string') {\n      valueAndFieldsFromLoad = await this.dynamicViewService.onLoad(this.load, this.value);\n    } else if (typeof this.load === 'function') {\n      valueAndFieldsFromLoad = this.load();\n    }\n\n    return valueAndFieldsFromLoad || {};\n  }\n\n  private getVisibleFields() {\n    if (this.showAllValue) {\n      return this.getMergedFields();\n    }\n\n    return this.value && this.fields.length ? this.getConfiguredFields() : this.getValueFields();\n  }\n\n  private setFieldOnLoad(fieldOnLoad: PoDynamicViewField) {\n    const index = this.fields.findIndex(field => field.property === fieldOnLoad.property);\n\n    if (index >= 0) {\n      this.fields[index] = { ...this.fields[index], ...fieldOnLoad };\n    } else {\n      this.fields.push({ ...fieldOnLoad });\n    }\n  }\n\n  private setFieldsOnLoad(fields: Array<PoDynamicViewField>) {\n    if (fields) {\n      fields.forEach(fieldOnLoad => {\n        this.setFieldOnLoad(fieldOnLoad);\n      });\n    }\n  }\n\n  private setValueOnLoad(newValue: any) {\n    Object.assign(this.value, newValue);\n  }\n\n  private async updateValuesAndFieldsOnLoad() {\n    const { value, fields } = await this.getValuesAndFieldsFromLoad();\n\n    this.setValueOnLoad(value);\n    this.setFieldsOnLoad(fields);\n\n    this.visibleFields = this.getVisibleFields();\n    this.initChanges = true;\n  }\n}\n","<div class=\"po-row\" [class.po-dynamic]=\"hasContainers\" *ngIf=\"visibleFields.length\">\n  <ng-container\n    *ngTemplateOutlet=\"\n      hasContainers ? poContentContainer : poContent;\n      context: { $implicit: hasContainers ? containerFields : visibleFields }\n    \"\n  ></ng-container>\n</div>\n\n<ng-template #poContent let-fields>\n  <ng-template ngFor let-field [ngForOf]=\"fields\">\n    <po-divider *ngIf=\"field?.divider?.trim()\" class=\"po-sm-12\" [p-label]=\"field.divider\"> </po-divider>\n    <ng-container\n      *ngTemplateOutlet=\"\n        !field.tag && !field.image ? poInfo : !field.image ? poTag : poImage;\n        context: { $implicit: field }\n      \"\n    >\n    </ng-container>\n  </ng-template>\n</ng-template>\n\n<ng-template #poContentContainer let-fields>\n  <po-dynamic-container [p-fields]=\"fields\" [p-content]=\"poContent\"></po-dynamic-container>\n</ng-template>\n\n<ng-template #poInfo let-field>\n  <po-info [ngClass]=\"field.cssClass\" [p-label]=\"field.label\" [p-value]=\"setFieldValue(field)\"> </po-info>\n</ng-template>\n\n<ng-template #poTag let-field>\n  <po-tag\n    [ngClass]=\"field.cssClass\"\n    [p-color]=\"field.color\"\n    [p-icon]=\"field.icon\"\n    [p-inverse]=\"field.inverse\"\n    [p-label]=\"field.label\"\n    [p-value]=\"setFieldValue(field)\"\n  >\n  </po-tag>\n</ng-template>\n\n<ng-template #poImage let-field>\n  <po-image [p-alt]=\"field.alt\" [p-height]=\"field.height\" [p-src]=\"field.value\"> </po-image>\n</ng-template>\n"]}