@po-ui/ng-components 17.1.0 → 17.2.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.
@@ -132,18 +132,14 @@ export class PoDynamicViewBaseComponent {
132
132
  this.comboFilterService = comboFilterService;
133
133
  this.multiselectFilterService = multiselectFilterService;
134
134
  }
135
- /**
136
- * Verifica se já existe algum outro campo com a order da posição dele no array,
137
- * se houver ele adiciona +1 até achar uma proxima posição
138
- */
139
- getOrdertoField(field, index) {
135
+ getFieldOrder(field, index) {
140
136
  const position = index + 1;
141
- return this.fields.findIndex(e => e.order === position) > -1 ? this.getOrdertoField(field, position) : position;
137
+ return this.fields.findIndex(e => e.order === position) > -1 ? this.getFieldOrder(field, position) : position;
142
138
  }
143
139
  getConfiguredFields(useSearchService = true) {
144
140
  const newFields = [];
145
141
  this.fields.forEach((field, index) => {
146
- field.order = field.order || this.getOrdertoField(field, index);
142
+ field.order = field.order || this.getFieldOrder(field, index);
147
143
  if (!isVisibleField(field)) {
148
144
  return;
149
145
  }
@@ -154,8 +150,8 @@ export class PoDynamicViewBaseComponent {
154
150
  const hasValue = this.value[field.property]?.length ||
155
151
  (!Array.isArray(this.value[field.property]) && this.value[field.property] && useSearchService);
156
152
  if (hasValue) {
157
- const tempField = this.returnValues({ ...field }, '');
158
- newFields.push(this.createField(tempField));
153
+ const _field = this.returnValues({ ...field }, '');
154
+ newFields.push(_field);
159
155
  if (field.searchService) {
160
156
  if (typeof field.searchService === 'object') {
161
157
  this.service = field.searchService;
@@ -185,8 +181,7 @@ export class PoDynamicViewBaseComponent {
185
181
  }
186
182
  }
187
183
  }
188
- const indexUpdated = field.order;
189
- this.createFieldWithService(field, newFields, indexUpdated);
184
+ this.createFieldWithService(field, newFields, _field);
190
185
  }
191
186
  });
192
187
  return sortFields(newFields);
@@ -221,12 +216,13 @@ export class PoDynamicViewBaseComponent {
221
216
  }
222
217
  return this.returnValues(field, value);
223
218
  }
224
- createFieldWithService(field, newFields, index) {
219
+ createFieldWithService(field, newFields, oldField) {
225
220
  const property = field.property;
226
221
  this.searchById(this.value[property], field).subscribe(response => {
227
222
  const value = response;
228
223
  const allValues = this.returnValues(field, value);
229
- newFields.splice(index - 1, 1, allValues);
224
+ const oldFieldIndex = newFields.indexOf(newFields.find(field => field === oldField));
225
+ newFields.splice(oldFieldIndex, 1, allValues);
230
226
  sortFields(newFields);
231
227
  });
232
228
  }
@@ -374,4 +370,4 @@ export class PoDynamicViewBaseComponent {
374
370
  type: Input,
375
371
  args: ['p-value']
376
372
  }] }); })();
377
- //# 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  /**\n   * Verifica se já existe algum outro campo com a order da posição dele no array,\n   * se houver ele adiciona +1 até achar uma proxima posição\n   */\n  protected getOrdertoField(field: PoDynamicViewField, index: number) {\n    const position = index + 1;\n    return this.fields.findIndex(e => e.order === position) > -1 ? this.getOrdertoField(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.getOrdertoField(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 tempField = this.returnValues({ ...field }, '');\n        newFields.push(this.createField(tempField));\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        const indexUpdated = field.order;\n        this.createFieldWithService(field, newFields, indexUpdated);\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?, index?) {\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      newFields.splice(index - 1, 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"]}
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"]}
@@ -131,7 +131,7 @@ export class PoPageSlideComponent extends PoPageSlideBaseComponent {
131
131
  }
132
132
  else {
133
133
  const elements = getFocusableElements(this.pageContent.nativeElement);
134
- const element = elements[1] || this.pageContent.nativeElement;
134
+ const element = elements[0] || this.pageContent.nativeElement;
135
135
  element.focus();
136
136
  }
137
137
  }
@@ -193,4 +193,4 @@ export class PoPageSlideComponent extends PoPageSlideBaseComponent {
193
193
  args: ['pageContent', { read: ElementRef }]
194
194
  }] }); })();
195
195
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoPageSlideComponent, { className: "PoPageSlideComponent", filePath: "lib/components/po-page/po-page-slide/po-page-slide.component.ts", lineNumber: 52 }); })();
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-slide.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide.component.ts","../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACtG,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,oBAAoB,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAGjE,OAAO,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;;;;;;;ICGhE,+BAAqD;IAAA,YAAc;IAAA,iBAAM;;;IAApB,cAAc;IAAd,qCAAc;;;;IAErE,qCAA2F;IAApB,sLAAW,eAAA,cAAO,CAAA,IAAC;IAAE,iBAAY;;;;;IAbhH,8BAAgE,aAAA;IAC3B,4KAAa,eAAA,yBAAkB,CAAA,IAAC;IAAC,iBAAM;IAC1E,8BAIC,gBAAA,aAAA,aAAA,WAAA;IAIa,YAAW;IAAA,iBAAO;IACxB,2EAAyE;IAC3E,iBAAM;IACN,yFAAwG;IAC1G,iBAAM;IACN,gCAAgC;IAC9B,mBAAyB;IAC3B,iBAAM,EAAA,EAAA,EAAA;;;IAjB4C,iCAAO;IAG3D,eAA4E;IAA5E,wGAA4E;IAC5E,kCAAQ,yGAAA;IAMI,eAAW;IAAX,kCAAW;IACoB,cAAc;IAAd,sCAAc;IAEzC,cAAgB;IAAhB,wCAAgB;;;ADHpC;;;;;;;;;;;;;;;;;;;GAmBG;AAsBH,MAAM,OAAO,oBAAqB,SAAQ,wBAAwB;IAqB5C;IApBZ,YAAY,CAAa;IAEzB,YAAY,CAAM;IAClB,EAAE,GAAW,IAAI,EAAE,CAAC;IACpB,gBAAgB,GAAG,IAAI,aAAa,EAAQ,CAAC;IAC7C,aAAa,CAAM;IAEnB,UAAU,CAAgB;IAElC,IAAoD,WAAW,CAAC,WAAuB;QACrF,IAAI,WAAW,EAAE;YACf,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;YAChC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;SAC9B;IACH,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,YAAoB,sBAA8C;QAChE,KAAK,EAAE,CAAC;QADU,2BAAsB,GAAtB,sBAAsB,CAAwB;IAElE,CAAC;IAEM,IAAI;QACT,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;QAC5C,KAAK,CAAC,IAAI,EAAE,CAAC;QACb,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC5F,CAAC;IAEM,KAAK;QACV,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC;QAChD,KAAK,CAAC,KAAK,EAAE,CAAC;QAEd,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC7B,CAAC;IAEM,UAAU,CAAC,KAAiB;QACjC,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAC3E,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACxD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjB,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;IAC5D,CAAC;IAEO,SAAS;QACf,kCAAkC;QAClC,IAAI,CAAC,UAAU,GAAG,CAAC,KAAY,EAAE,EAAE;YACjC,IACE,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC;gBACtD,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE,EAC3G;gBACA,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;aAC3B;QACH,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;SAC3B;aAAM;YACL,MAAM,QAAQ,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;YACtE,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;YAC9D,OAAO,CAAC,KAAK,EAAE,CAAC;SACjB;IACH,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,YAAY,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;IAChH,CAAC;IAEO,oBAAoB;QAC1B,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QAC7D,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;8EAjFU,oBAAoB;6DAApB,oBAAoB;mCAUG,UAAU;;;;8CA5BjC,EAAE;;YCjCf,uEAoBM;;YApBmC,kCAAa;6GDkCxC;gBACV,OAAO,CAAC,MAAM,EAAE;oBACd,UAAU,CAAC,QAAQ,EAAE;wBACnB,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;wBACrB,KAAK,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;qBAClF,CAAC;oBACF,UAAU,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;iBACxG,CAAC;gBACF,OAAO,CAAC,OAAO,EAAE;oBACf,UAAU,CAAC,QAAQ,EAAE;wBACnB,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC;wBACxC,OAAO,CAAC,mBAAmB,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;qBAC3D,CAAC;oBACF,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC,CAAC,CAAC,CAAC;iBACnF,CAAC;aACH;;iFAEU,oBAAoB;cArBhC,SAAS;2BACE,eAAe,aAEd,EAAE,cACD;oBACV,OAAO,CAAC,MAAM,EAAE;wBACd,UAAU,CAAC,QAAQ,EAAE;4BACnB,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;4BACrB,KAAK,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;yBAClF,CAAC;wBACF,UAAU,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;qBACxG,CAAC;oBACF,OAAO,CAAC,OAAO,EAAE;wBACf,UAAU,CAAC,QAAQ,EAAE;4BACnB,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC;4BACxC,OAAO,CAAC,mBAAmB,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;yBAC3D,CAAC;wBACF,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC,CAAC,CAAC,CAAC;qBACnF,CAAC;iBACH;uDAYmD,WAAW;kBAA9D,SAAS;mBAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;;kFAVnC,oBAAoB","sourcesContent":["import { animate, animateChild, group, query, style, transition, trigger } from '@angular/animations';\nimport { Component, ElementRef, ViewChild } from '@angular/core';\nimport { ReplaySubject } from 'rxjs';\nimport { delay, take } from 'rxjs/operators';\n\nimport { getFocusableElements, uuid } from '../../../utils/util';\n\nimport { PoActiveOverlayService } from '../../../services/po-active-overlay/po-active-overlay.service';\nimport { PoPageSlideBaseComponent } from './po-page-slide-base.component';\n\n/**\n * @docsExtends PoPageSlideBaseComponent\n *\n * @example\n *\n * <example name=\"po-page-slide-basic\" title=\"PO Page Slide Basic\">\n *  <file name=\"sample-po-page-slide-basic/sample-po-page-slide-basic.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-basic/sample-po-page-slide-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-slide-labs\" title=\"PO Page Slide Labs\">\n *  <file name=\"sample-po-page-slide-labs/sample-po-page-slide-labs.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-labs/sample-po-page-slide-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-slide-configuration\" title=\"PO Page Slide - Configuration\">\n *  <file name=\"sample-po-page-slide-configuration/sample-po-page-slide-configuration.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-configuration/sample-po-page-slide-configuration.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-page-slide',\n  templateUrl: './po-page-slide.component.html',\n  providers: [],\n  animations: [\n    trigger('fade', [\n      transition(':enter', [\n        style({ opacity: 0 }),\n        group([animate('150ms', style({ opacity: 1 })), query('@slide', animateChild())])\n      ]),\n      transition(':leave', group([query('@slide', animateChild()), animate('150ms', style({ opacity: 0 }))]))\n    ]),\n    trigger('slide', [\n      transition(':enter', [\n        style({ transform: 'translateX(50px)' }),\n        animate('691ms ease-in-out', style({ transform: 'none' }))\n      ]),\n      transition(':leave', [animate('150ms', style({ transform: 'translateX(50px)' }))])\n    ])\n  ]\n})\nexport class PoPageSlideComponent extends PoPageSlideBaseComponent {\n  private _pageContent: ElementRef;\n\n  private firstElement: any;\n  private id: string = uuid();\n  private loadingCompleted = new ReplaySubject<void>();\n  private sourceElement: any;\n\n  private focusEvent: EventListener;\n\n  @ViewChild('pageContent', { read: ElementRef }) set pageContent(pageContent: ElementRef) {\n    if (pageContent) {\n      this._pageContent = pageContent;\n      this.loadingCompleted.next();\n    }\n  }\n\n  get pageContent(): ElementRef {\n    return this._pageContent;\n  }\n\n  constructor(private poActiveOverlayService: PoActiveOverlayService) {\n    super();\n  }\n\n  public open(): void {\n    this.sourceElement = document.activeElement;\n    super.open();\n    this.loadingCompleted.pipe(take(1)).pipe(delay(0)).subscribe(this.handleFocus.bind(this));\n  }\n\n  public close(): void {\n    this.poActiveOverlayService.activeOverlay.pop();\n    super.close();\n\n    this.removeEventListeners();\n    this.sourceElement.focus();\n  }\n\n  public onClickOut(event: MouseEvent): void {\n    if (this.clickOut && !this.pageContent.nativeElement.contains(event.target)) {\n      this.close();\n    }\n  }\n\n  private handleFocus(): void {\n    this.poActiveOverlayService.activeOverlay.push(this.id);\n    this.loadFirstElement();\n    this.initFocus();\n\n    document.addEventListener('focus', this.focusEvent, true);\n  }\n\n  private initFocus() {\n    // O foco não pode sair da página.\n    this.focusEvent = (event: Event) => {\n      if (\n        !this.pageContent.nativeElement.contains(event.target) &&\n        this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id\n      ) {\n        event.stopPropagation();\n        this.firstElement.focus();\n      }\n    };\n\n    if (this.hideClose) {\n      this.firstElement.focus();\n    } else {\n      const elements = getFocusableElements(this.pageContent.nativeElement);\n      const element = elements[1] || this.pageContent.nativeElement;\n      element.focus();\n    }\n  }\n\n  private loadFirstElement(): void {\n    this.firstElement = getFocusableElements(this.pageContent.nativeElement)[0] || this.pageContent.nativeElement;\n  }\n\n  private removeEventListeners(): void {\n    document.removeEventListener('focus', this.focusEvent, true);\n    this.loadingCompleted.complete();\n  }\n}\n","<div class=\"po-page-slide\" tabindex=\"0\" *ngIf=\"!hidden\" [@fade]>\n  <div class=\"po-page-slide-overlay\" (mousedown)=\"onClickOut($event)\"></div>\n  <div\n    class=\"po-page-slide-container po-page-slide-right po-page-slide-{{ size }}\"\n    [@slide]\n    [ngStyle]=\"{ 'width': flexibleWidth ? '' : size === 'auto' ? 'auto' : '' }\"\n  >\n    <div class=\"po-page-slide-content\" tabindex=\"-1\" #pageContent>\n      <div class=\"po-page-slide-header\">\n        <div class=\"po-page-slide-title\">\n          <span>{{ title }}</span>\n          <div class=\"po-page-slide-subtitle\" *ngIf=\"subtitle\">{{ subtitle }}</div>\n        </div>\n        <po-button *ngIf=\"!hideClose\" p-icon=\"po-icon-close\" p-kind=\"tertiary\" (p-click)=\"close()\"> </po-button>\n      </div>\n      <div class=\"po-page-slide-body\">\n        <ng-content></ng-content>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-slide.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide.component.ts","../../../../../../../projects/ui/src/lib/components/po-page/po-page-slide/po-page-slide.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, animateChild, group, query, style, transition, trigger } from '@angular/animations';\nimport { Component, ElementRef, ViewChild } from '@angular/core';\nimport { ReplaySubject } from 'rxjs';\nimport { delay, take } from 'rxjs/operators';\n\nimport { getFocusableElements, uuid } from '../../../utils/util';\n\nimport { PoActiveOverlayService } from '../../../services/po-active-overlay/po-active-overlay.service';\nimport { PoPageSlideBaseComponent } from './po-page-slide-base.component';\n\n/**\n * @docsExtends PoPageSlideBaseComponent\n *\n * @example\n *\n * <example name=\"po-page-slide-basic\" title=\"PO Page Slide Basic\">\n *  <file name=\"sample-po-page-slide-basic/sample-po-page-slide-basic.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-basic/sample-po-page-slide-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-slide-labs\" title=\"PO Page Slide Labs\">\n *  <file name=\"sample-po-page-slide-labs/sample-po-page-slide-labs.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-labs/sample-po-page-slide-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-slide-configuration\" title=\"PO Page Slide - Configuration\">\n *  <file name=\"sample-po-page-slide-configuration/sample-po-page-slide-configuration.component.html\"> </file>\n *  <file name=\"sample-po-page-slide-configuration/sample-po-page-slide-configuration.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-page-slide',\n  templateUrl: './po-page-slide.component.html',\n  providers: [],\n  animations: [\n    trigger('fade', [\n      transition(':enter', [\n        style({ opacity: 0 }),\n        group([animate('150ms', style({ opacity: 1 })), query('@slide', animateChild())])\n      ]),\n      transition(':leave', group([query('@slide', animateChild()), animate('150ms', style({ opacity: 0 }))]))\n    ]),\n    trigger('slide', [\n      transition(':enter', [\n        style({ transform: 'translateX(50px)' }),\n        animate('691ms ease-in-out', style({ transform: 'none' }))\n      ]),\n      transition(':leave', [animate('150ms', style({ transform: 'translateX(50px)' }))])\n    ])\n  ]\n})\nexport class PoPageSlideComponent extends PoPageSlideBaseComponent {\n  private _pageContent: ElementRef;\n\n  private firstElement: any;\n  private id: string = uuid();\n  private loadingCompleted = new ReplaySubject<void>();\n  private sourceElement: any;\n\n  private focusEvent: EventListener;\n\n  @ViewChild('pageContent', { read: ElementRef }) set pageContent(pageContent: ElementRef) {\n    if (pageContent) {\n      this._pageContent = pageContent;\n      this.loadingCompleted.next();\n    }\n  }\n\n  get pageContent(): ElementRef {\n    return this._pageContent;\n  }\n\n  constructor(private poActiveOverlayService: PoActiveOverlayService) {\n    super();\n  }\n\n  public open(): void {\n    this.sourceElement = document.activeElement;\n    super.open();\n    this.loadingCompleted.pipe(take(1)).pipe(delay(0)).subscribe(this.handleFocus.bind(this));\n  }\n\n  public close(): void {\n    this.poActiveOverlayService.activeOverlay.pop();\n    super.close();\n\n    this.removeEventListeners();\n    this.sourceElement.focus();\n  }\n\n  public onClickOut(event: MouseEvent): void {\n    if (this.clickOut && !this.pageContent.nativeElement.contains(event.target)) {\n      this.close();\n    }\n  }\n\n  private handleFocus(): void {\n    this.poActiveOverlayService.activeOverlay.push(this.id);\n    this.loadFirstElement();\n    this.initFocus();\n\n    document.addEventListener('focus', this.focusEvent, true);\n  }\n\n  private initFocus() {\n    // O foco não pode sair da página.\n    this.focusEvent = (event: Event) => {\n      if (\n        !this.pageContent.nativeElement.contains(event.target) &&\n        this.poActiveOverlayService.activeOverlay[this.poActiveOverlayService.activeOverlay.length - 1] === this.id\n      ) {\n        event.stopPropagation();\n        this.firstElement.focus();\n      }\n    };\n\n    if (this.hideClose) {\n      this.firstElement.focus();\n    } else {\n      const elements = getFocusableElements(this.pageContent.nativeElement);\n      const element = elements[0] || this.pageContent.nativeElement;\n      element.focus();\n    }\n  }\n\n  private loadFirstElement(): void {\n    this.firstElement = getFocusableElements(this.pageContent.nativeElement)[0] || this.pageContent.nativeElement;\n  }\n\n  private removeEventListeners(): void {\n    document.removeEventListener('focus', this.focusEvent, true);\n    this.loadingCompleted.complete();\n  }\n}\n","<div class=\"po-page-slide\" tabindex=\"0\" *ngIf=\"!hidden\" [@fade]>\n  <div class=\"po-page-slide-overlay\" (mousedown)=\"onClickOut($event)\"></div>\n  <div\n    class=\"po-page-slide-container po-page-slide-right po-page-slide-{{ size }}\"\n    [@slide]\n    [ngStyle]=\"{ 'width': flexibleWidth ? '' : size === 'auto' ? 'auto' : '' }\"\n  >\n    <div class=\"po-page-slide-content\" tabindex=\"-1\" #pageContent>\n      <div class=\"po-page-slide-header\">\n        <div class=\"po-page-slide-title\">\n          <span>{{ title }}</span>\n          <div class=\"po-page-slide-subtitle\" *ngIf=\"subtitle\">{{ subtitle }}</div>\n        </div>\n        <po-button *ngIf=\"!hideClose\" p-icon=\"po-icon-close\" p-kind=\"tertiary\" (p-click)=\"close()\"> </po-button>\n      </div>\n      <div class=\"po-page-slide-body\">\n        <ng-content></ng-content>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -18766,7 +18766,7 @@ class PoPageSlideComponent extends PoPageSlideBaseComponent {
18766
18766
  }
18767
18767
  else {
18768
18768
  const elements = getFocusableElements(this.pageContent.nativeElement);
18769
- const element = elements[1] || this.pageContent.nativeElement;
18769
+ const element = elements[0] || this.pageContent.nativeElement;
18770
18770
  element.focus();
18771
18771
  }
18772
18772
  }
@@ -40812,18 +40812,14 @@ class PoDynamicViewBaseComponent {
40812
40812
  this.comboFilterService = comboFilterService;
40813
40813
  this.multiselectFilterService = multiselectFilterService;
40814
40814
  }
40815
- /**
40816
- * Verifica se já existe algum outro campo com a order da posição dele no array,
40817
- * se houver ele adiciona +1 até achar uma proxima posição
40818
- */
40819
- getOrdertoField(field, index) {
40815
+ getFieldOrder(field, index) {
40820
40816
  const position = index + 1;
40821
- return this.fields.findIndex(e => e.order === position) > -1 ? this.getOrdertoField(field, position) : position;
40817
+ return this.fields.findIndex(e => e.order === position) > -1 ? this.getFieldOrder(field, position) : position;
40822
40818
  }
40823
40819
  getConfiguredFields(useSearchService = true) {
40824
40820
  const newFields = [];
40825
40821
  this.fields.forEach((field, index) => {
40826
- field.order = field.order || this.getOrdertoField(field, index);
40822
+ field.order = field.order || this.getFieldOrder(field, index);
40827
40823
  if (!isVisibleField(field)) {
40828
40824
  return;
40829
40825
  }
@@ -40834,8 +40830,8 @@ class PoDynamicViewBaseComponent {
40834
40830
  const hasValue = this.value[field.property]?.length ||
40835
40831
  (!Array.isArray(this.value[field.property]) && this.value[field.property] && useSearchService);
40836
40832
  if (hasValue) {
40837
- const tempField = this.returnValues({ ...field }, '');
40838
- newFields.push(this.createField(tempField));
40833
+ const _field = this.returnValues({ ...field }, '');
40834
+ newFields.push(_field);
40839
40835
  if (field.searchService) {
40840
40836
  if (typeof field.searchService === 'object') {
40841
40837
  this.service = field.searchService;
@@ -40865,8 +40861,7 @@ class PoDynamicViewBaseComponent {
40865
40861
  }
40866
40862
  }
40867
40863
  }
40868
- const indexUpdated = field.order;
40869
- this.createFieldWithService(field, newFields, indexUpdated);
40864
+ this.createFieldWithService(field, newFields, _field);
40870
40865
  }
40871
40866
  });
40872
40867
  return sortFields(newFields);
@@ -40901,12 +40896,13 @@ class PoDynamicViewBaseComponent {
40901
40896
  }
40902
40897
  return this.returnValues(field, value);
40903
40898
  }
40904
- createFieldWithService(field, newFields, index) {
40899
+ createFieldWithService(field, newFields, oldField) {
40905
40900
  const property = field.property;
40906
40901
  this.searchById(this.value[property], field).subscribe(response => {
40907
40902
  const value = response;
40908
40903
  const allValues = this.returnValues(field, value);
40909
- newFields.splice(index - 1, 1, allValues);
40904
+ const oldFieldIndex = newFields.indexOf(newFields.find(field => field === oldField));
40905
+ newFields.splice(oldFieldIndex, 1, allValues);
40910
40906
  sortFields(newFields);
40911
40907
  });
40912
40908
  }