@po-ui/ng-templates 16.1.0 → 16.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.
@@ -332,6 +332,7 @@ export class PoPageDynamicEditComponent {
332
332
  // afterRemove
333
333
  // beforeInsert: : return boolean
334
334
  detailActions = {};
335
+ indexFocus = 0;
335
336
  language;
336
337
  subscriptions = [];
337
338
  _actions = {};
@@ -562,6 +563,44 @@ export class PoPageDynamicEditComponent {
562
563
  }
563
564
  return EMPTY;
564
565
  }
566
+ focusCheckboxInput(control) {
567
+ const checkboxGroup = document.querySelector(`po-checkbox-group[ng-reflect-name=${control}]`);
568
+ if (checkboxGroup) {
569
+ const checkBoxComponent = checkboxGroup.querySelector('po-checkbox[ng-reflect-disabled=false]');
570
+ const labelInput = checkBoxComponent?.querySelector('.po-checkbox-outline');
571
+ if (labelInput) {
572
+ labelInput.focus();
573
+ }
574
+ else {
575
+ this.indexFocus--;
576
+ }
577
+ }
578
+ }
579
+ focusControl(control) {
580
+ const inputElement = document.querySelector(`[name=${control}]`);
581
+ if (inputElement) {
582
+ if (inputElement.tagName === 'INPUT') {
583
+ inputElement.focus();
584
+ }
585
+ else {
586
+ this.focusRadioInput(inputElement, control);
587
+ }
588
+ }
589
+ else {
590
+ this.focusCheckboxInput(control);
591
+ }
592
+ }
593
+ focusRadioInput(inputElement, control) {
594
+ const radioComponent = inputElement.querySelector(`po-radio[ng-reflect-name=${control}][ng-reflect-disabled=false]`);
595
+ if (radioComponent) {
596
+ const radioInput = radioComponent.querySelector('input');
597
+ radioInput.focus();
598
+ radioInput.parentElement.parentElement.classList.add('po-radio-focus');
599
+ }
600
+ else {
601
+ this.indexFocus--;
602
+ }
603
+ }
565
604
  getPoDynamicPageOptions(onLoad) {
566
605
  const originalOption = {
567
606
  fields: this.fields,
@@ -603,6 +642,17 @@ export class PoPageDynamicEditComponent {
603
642
  }
604
643
  return this.loadOptionsOnInitialize(onLoad);
605
644
  }
645
+ markControlsAsDirtyAndFocusFirstInvalid() {
646
+ this.indexFocus = 0;
647
+ const controls = Object.keys(this.dynamicForm.form.controls);
648
+ controls.forEach(control => {
649
+ this.dynamicForm.form.controls[control].markAsDirty();
650
+ if (this.dynamicForm.form.controls[control].hasError('required') && this.indexFocus === 0) {
651
+ this.focusControl(control);
652
+ this.indexFocus++;
653
+ }
654
+ });
655
+ }
606
656
  navigateTo(path) {
607
657
  if (path) {
608
658
  const url = this.resolveUrl(this.model, path);
@@ -634,6 +684,7 @@ export class PoPageDynamicEditComponent {
634
684
  }
635
685
  saveOperation() {
636
686
  if (this.dynamicForm.form.invalid) {
687
+ this.markControlsAsDirtyAndFocusFirstInvalid();
637
688
  this.poNotification.warning(this.literals.saveNotificationWarning);
638
689
  return EMPTY;
639
690
  }
@@ -775,4 +826,4 @@ export class PoPageDynamicEditComponent {
775
826
  type: Input,
776
827
  args: ['p-fields']
777
828
  }] }); })();
778
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-dynamic-edit.component.js","sourceRoot":"","sources":["../../../../../../projects/templates/src/lib/components/po-page-dynamic-edit/po-page-dynamic-edit.component.ts","../../../../../../projects/templates/src/lib/components/po-page-dynamic-edit/po-page-dynamic-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ViewChild, OnDestroy } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\n\nimport { Observable, concat, of, Subscription, EMPTY, throwError } from 'rxjs';\nimport { tap, catchError, map, switchMap } from 'rxjs/operators';\n\nimport {\n  PoBreadcrumb,\n  PoDialogService,\n  PoDynamicFormComponent,\n  PoGridComponent,\n  PoGridRowActions,\n  PoLanguageService,\n  PoNotificationService,\n  PoPageAction,\n  poLocaleDefault\n} from '@po-ui/ng-components';\n\nimport { convertToBoolean, mapObjectByProperties, valuesFromObject, removeKeysProperties } from './../../utils/util';\n\nimport { PoPageDynamicEditActions } from './interfaces/po-page-dynamic-edit-actions.interface';\nimport { PoPageDynamicEditField } from './interfaces/po-page-dynamic-edit-field.interface';\nimport { PoPageDynamicService } from '../../services/po-page-dynamic/po-page-dynamic.service';\nimport { PoPageDynamicEditOptions } from './interfaces/po-page-dynamic-edit-options.interface';\nimport { PoPageCustomizationService } from '../../services/po-page-customization/po-page-customization.service';\nimport { PoPageDynamicEditMetadata } from './interfaces/po-page-dynamic-edit-metadata.interface';\nimport { PoPageDynamicOptionsSchema } from '../../services/po-page-customization/po-page-dynamic-options.interface';\nimport { PoPageDynamicEditActionsService } from './po-page-dynamic-edit-actions.service';\nimport { PoPageDynamicEditBeforeCancel } from './interfaces/po-page-dynamic-edit-before-cancel.interface';\nimport { PoPageDynamicEditLiterals } from './interfaces/po-page-dynamic-edit-literals.interface';\n\ntype UrlOrPoCustomizationFunction = string | (() => PoPageDynamicEditOptions);\ntype SaveAction = PoPageDynamicEditActions['save'] | PoPageDynamicEditActions['saveNew'];\n\nexport const poPageDynamicEditLiteralsDefault = {\n  en: <PoPageDynamicEditLiterals>{\n    cancelConfirmMessage: 'Are you sure you want to cancel this operation?',\n    detailActionNew: 'New',\n    pageActionCancel: 'Cancel',\n    pageActionSave: 'Save',\n    pageActionSaveNew: 'Save and new',\n    registerNotFound: 'Register not found.',\n    saveNotificationSuccessSave: 'Resource successfully saved.',\n    saveNotificationSuccessUpdate: 'Resource successfully updated.',\n    saveNotificationWarning: 'Form must be filled out correctly.'\n  },\n  es: <PoPageDynamicEditLiterals>{\n    cancelConfirmMessage: 'Está seguro de que desea cancelar esta operación?',\n    detailActionNew: 'Nuevo',\n    pageActionCancel: 'Cancelar',\n    pageActionSave: 'Guardar',\n    pageActionSaveNew: 'Guardar y nuevo',\n    registerNotFound: 'Registro no encontrado.',\n    saveNotificationSuccessSave: 'Recurso salvo con éxito.',\n    saveNotificationSuccessUpdate: 'Recurso actualizado con éxito.',\n    saveNotificationWarning: 'El formulario debe llenarse correctamente.'\n  },\n  pt: <PoPageDynamicEditLiterals>{\n    cancelConfirmMessage: 'Tem certeza que deseja cancelar esta operação?',\n    detailActionNew: 'Novo',\n    pageActionCancel: 'Cancelar',\n    pageActionSave: 'Salvar',\n    pageActionSaveNew: 'Salvar e novo',\n    registerNotFound: 'Registro não encontrado.',\n    saveNotificationSuccessSave: 'Recurso salvo com sucesso.',\n    saveNotificationSuccessUpdate: 'Recurso atualizado com sucesso.',\n    saveNotificationWarning: 'Formulário precisa ser preenchido corretamente.'\n  },\n  ru: <PoPageDynamicEditLiterals>{\n    cancelConfirmMessage: 'Вы уверены, что хотите отменить эту операцию?',\n    detailActionNew: 'Новый',\n    pageActionCancel: 'Отменить',\n    pageActionSave: 'Сохранить',\n    pageActionSaveNew: 'Сохранить и создать',\n    registerNotFound: 'Запись не найдена.',\n    saveNotificationSuccessSave: 'Ресурс успешно сохранен.',\n    saveNotificationSuccessUpdate: 'Ресурс успешно обновлен.',\n    saveNotificationWarning: 'Форма должна быть заполнена правильно.'\n  }\n};\n\n/**\n * @description\n *\n * O `po-page-dynamic-edit` é uma página que pode servir para editar ou criar novos registros,\n * o mesmo também suporta metadados conforme especificado na documentação.\n *\n * ### Utilização via rota\n *\n * Ao utilizar as rotas para carregar o template, o `page-dynamic-edit` disponibiliza propriedades para\n * poder especificar o endpoint dos dados e dos metadados. Exemplo de utilização:\n *\n * O componente primeiro irá carregar o metadado da rota definida na propriedade serviceMetadataApi\n * e depois irá buscar da rota definida na propriedade serviceLoadApi\n *\n * > Caso o servidor retornar um erro ao recuperar o metadados, será repassado o metadados salvo em cache,\n * se o cache não existe será disparado uma notificação.\n *\n * ```\n * {\n *   path: 'people',\n *   component: PoPageDynamicEditComponent,\n *   data: {\n *     serviceApi: 'http://localhost:3000/v1/people', // endpoint dos dados\n *     serviceMetadataApi: 'http://localhost:3000/v1/metadata', // endpoint dos metadados utilizando o método HTTP Get\n *     serviceLoadApi: 'http://localhost:3000/load-metadata' // endpoint de customizações dos metadados utilizando o método HTTP Post\n *   }\n * }\n *\n * ```\n *\n * Para carregar com um recurso já existente, deve-se ser incluído um parâmetro na rota chamado `id`:\n *\n * ```\n * {\n *   path: 'people/:id',\n *   component: PoPageDynamicEditComponent,\n *   data: {\n *     serviceApi: 'http://localhost:3000/v1/people', // endpoint dos dados\n *     serviceMetadataApi: 'http://localhost:3000/v1/metadata', // endpoint dos metadados\n *     serviceLoadApi: 'http://localhost:3000/load-metadata' // endpoint de customizações dos metadados\n *   }\n * }\n * ```\n *\n * A requisição dos metadados é feita na inicialização do template para buscar os metadados da página passando o\n * tipo do metadado esperado e a versão cacheada pelo browser.\n *\n * O formato esperado na resposta da requisição está especificado na interface\n * [PoPageDynamicEditMetadata](/documentation/po-page-dynamic-edit#po-page-dynamic-edit-metadata). Por exemplo:\n *\n * ```\n *  {\n *   version: 1,\n *   title: 'Person edit',\n *   fields: [\n *     { property: 'id', key: true, disabled: true },\n *     { property: 'status' },\n *     { property: 'name' },\n *     { property: 'nickname' },\n *     { property: 'birthdate', label: 'Birth date' },\n *     { property: 'genre' },\n *     { property: 'city' },\n *     { property: 'country' }\n *   ]\n * }\n * ```\n *\n * > Caso o endpoint dos metadados não seja especificado, será feito uma requisição utilizando o `serviceApi` da seguinte forma:\n * ```\n * GET {end-point}/metadata?type=edit&version={version}\n * ```\n *\n * @example\n *\n * <example name=\"po-page-dynamic-edit-basic\" title=\"PO Page Dynamic Edit Basic\">\n *  <file name=\"sample-po-page-dynamic-edit-basic/sample-po-page-dynamic-edit-basic.component.html\"> </file>\n *  <file name=\"sample-po-page-dynamic-edit-basic/sample-po-page-dynamic-edit-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-dynamic-edit-user\" title=\"PO Page Dynamic Edit - User\">\n *  <file name=\"sample-po-page-dynamic-edit-user/sample-po-page-dynamic-edit-user.component.html\"> </file>\n *  <file name=\"sample-po-page-dynamic-edit-user/sample-po-page-dynamic-edit-user.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-page-dynamic-edit',\n  templateUrl: './po-page-dynamic-edit.component.html',\n  providers: [PoPageDynamicService]\n})\nexport class PoPageDynamicEditComponent implements OnInit, OnDestroy {\n  @ViewChild('dynamicForm') dynamicForm: PoDynamicFormComponent;\n  @ViewChild('gridDetail') gridDetail: PoGridComponent;\n\n  /** Objeto com propriedades do breadcrumb. */\n  @Input('p-breadcrumb') breadcrumb?: PoBreadcrumb = { items: [] };\n\n  /**\n   * @description\n   *\n   * Endpoint usado pelo template para requisição do recurso que será exibido para edição.\n   *\n   * Para as ações de `save` e `saveNew`, será feito uma requisição de criação nesse mesmo endpoint passando os valores\n   * preenchidos pelo usuário via payload.\n   *\n   * > `POST {end-point}`\n   *\n   * ```\n   *  <po-page-dynamic-edit\n   *    [p-actions]=\"{ save: '/', saveNew: 'new' }\"\n   *    [p-fields]=\"[ { property: 'name' }, { property: 'city' } ]\"\n   *    p-service=\"/api/po-samples/v1/people\"\n   *    ...>\n   *  </po-page-dynamic-edit>\n   * ```\n   *\n   * Resquisição disparada, onde a propriedade `name` e `city` foram preenchidas:\n   *\n   * ```\n   *  POST /api/po-samples/v1/people HTTP/1.1\n   *  Host: localhost:4000\n   *  Connection: keep-alive\n   *  Accept: application/json, text/plain\n   *  ...\n   * ```\n   *\n   * Request payload:\n   *\n   * ```\n   * { \"name\": \"Fulano\", \"city\": \"Smallville\" }\n   * ```\n   *\n   * Caso queira que o template carregue um recurso já existente, deve-se ser incluído um parametro na rota chamado `id`.\n   *\n   * Exemplo de configuração de rota:\n   *\n   * ```\n   *  RouterModule.forRoot([\n   *    ...\n   *    { path: 'edit/:id', component: PersonEditComponent },\n   *    ...\n   *  ],\n   * ```\n   *\n   * Baseado nisso, na inicialização do template, será disparado uma requisição para buscar o recurso que será editado.\n   *\n   * > `GET {end-point}/{id}`\n   *\n   * Nos métodos de `save` e `saveNew`, ao invés de um `POST`, será disparado um `PUT`.\n   *\n   * Resquisição disparada, onde a propriedade `name` e `city` foram preenchidas / atualizadas, e o `id` da url é 2:\n   *\n   * ```\n   *  PUT /api/po-samples/v1/people/2 HTTP/1.1\n   *  Host: localhost:4000\n   *  Connection: keep-alive\n   *  Accept: application/json, text/plain\n   *  ...\n   * ```\n   *\n   * Request payload:\n   *\n   * ```\n   * { \"name\": \"Fulano\", \"city\": \"Metropolis\" }\n   * ```\n   */\n  @Input('p-service-api') serviceApi: string;\n\n  /** Título da página. */\n  @Input('p-title') title: string;\n\n  /**\n   * Função ou serviço que será executado na inicialização do componente.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * O retorno desta função deve ser do tipo `PoPageDynamicEditOptions`,\n   * onde o usuário poderá customizar novos campos, breadcrumb, title e actions\n   *\n   * Por exemplo:\n   *\n   * ```\n   * getPageOptions(): PoPageDynamicEditOptions {\n   * return {\n   *   actions:\n   *     { cancel: false, save: 'save/:id', saveNew: 'saveNew' },\n   *   fields: [\n   *     { property: 'idCard', gridColumns: 6 }\n   *   ]\n   * };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-load]=\"onLoadOptions.bind(this)\"\n   * ```\n   */\n  @Input('p-load') onLoad: string | (() => PoPageDynamicEditOptions);\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Função que será executada após ser realizada a busca dos dados.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `function`: Método que será executado.\n   *\n   * Esta função passa por parâmetro o model e deve recebê-lo de volta com as alterações.\n   * Também aceita o retorno de um Observable com o novo model.\n   *\n   * Por exemplo:\n   *\n   * ```\n   * onLoadCustom(model) {\n   *  return { ...model, customField: 'newValue' };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-load-data]=\"onLoadCustom.bind(this)\"\n   * ```\n   */\n  @Input('p-load-data') onLoadData: ((model: any) => any) | ((model: any) => Observable<any>);\n\n  model: any = {};\n\n  // beforeSave: return boolean\n  // afterSave\n  // beforeRemove: return boolean\n  // afterRemove\n  // beforeInsert: : return boolean\n  readonly detailActions: PoGridRowActions = {};\n\n  private language: string;\n  private subscriptions: Array<Subscription> = [];\n  private _actions: PoPageDynamicEditActions = {};\n  private _literals: PoPageDynamicEditLiterals;\n  private _autoRouter: boolean = false;\n  private _controlFields: Array<any> = [];\n  private _detailFields: Array<any> = [];\n  private _duplicates: Array<any> = [];\n  private _fields: Array<any> = [];\n  private _keys: Array<any> = [];\n  private _pageActions: Array<PoPageAction> = [];\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ações da página.\n   */\n  @Input('p-actions') set actions(value: PoPageDynamicEditActions) {\n    this._actions = this.isObject(value) ? value : {};\n\n    this._pageActions = this.getPageActions(this._actions);\n  }\n\n  get actions() {\n    return { ...this._actions };\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Objeto com as literais usadas no `po-page-dynamic-edit`.\n   *\n   * É possivel customizar passando um objeto com todas as literais disponíveis\n   * ou passando apenas as literais que deseja customizar\n   *\n   * ```\n   *  const customLiterals: PoPageDynamicEditLiterals = {\n   *    detailActionNew: 'Incluir',\n   *    pageActionCancel: 'Descartar',\n   *    pageActionSave: 'Gravar',\n   *    pageActionSaveNew: 'Gravar e incluir',\n   *    registerNotFound: 'Nenhum registro encontrado.',\n   *    saveNotificationSuccessSave: 'Item salvo com sucesso.',\n   *    saveNotificationSuccessUpdate: 'Item atualizado com sucesso.',\n   *    saveNotificationWarning: 'Necessário preencher o formulário corretamente.'\n   *  };\n   * ```\n   *\n   * E para carregar as literais customizadas, basta apenas passar o objeto para o componente.\n   *\n   * ```\n   * <po-page-dynamic-edit\n   *   [p-literals]=\"customLiterals\">\n   * </po-page-dynamic-edit>\n   * ```\n   *\n   * > O valor padrão será traduzido de acordo com o idioma configurado no [`PoI18nService`](/documentation/po-i18n) ou *browser*.\n   */\n  @Input('p-literals') set literals(value: PoPageDynamicEditLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poPageDynamicEditLiteralsDefault[poLocaleDefault],\n        ...poPageDynamicEditLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poPageDynamicEditLiteralsDefault[this.language];\n    }\n\n    this._pageActions = this.getPageActions(this._actions);\n  }\n\n  get literals() {\n    return this._literals || poPageDynamicEditLiteralsDefault[this.language];\n  }\n\n  /**\n   * @todo Validar rotas na mão pois se existir uma rota '**' o catch do navigation não funciona.\n   *\n   * @optional\n   *\n   * @description\n   *\n   * Cria automaticamente as rotas de edição (novo/duplicate) e detalhes caso as ações\n   * estejam definidas nas ações.\n   *\n   * > Para o correto funcionamento não pode haver nenhum rota coringa (`**`) especificada.\n   *\n   * @default false\n   */\n  @Input('p-auto-router') set autoRouter(value: boolean) {\n    this._autoRouter = convertToBoolean(value);\n  }\n\n  get autoRouter(): boolean {\n    return this._autoRouter;\n  }\n\n  /** Lista dos campos usados na tabela e busca avançada. */\n  @Input('p-fields') set fields(value: Array<PoPageDynamicEditField>) {\n    this._fields = Array.isArray(value) ? [...value] : [];\n\n    this._keys = this.getKeysByFields(this._fields);\n    this._duplicates = this.getDuplicatesByFields(this._fields);\n\n    this._controlFields = this.getControlFields(this._fields);\n    this._detailFields = this.getDetailFields(this._fields);\n  }\n\n  get fields(): Array<PoPageDynamicEditField> {\n    return this._fields;\n  }\n\n  constructor(\n    private router: Router,\n    private activatedRoute: ActivatedRoute,\n    private poNotification: PoNotificationService,\n    private poDialogService: PoDialogService,\n    private poPageDynamicService: PoPageDynamicService,\n    private poPageCustomizationService: PoPageCustomizationService,\n    private poPageDynamicEditActionsService: PoPageDynamicEditActionsService,\n    languageService: PoLanguageService\n  ) {\n    this.language = languageService.getShortLanguage();\n  }\n\n  ngOnInit(): void {\n    this.loadDataFromAPI();\n  }\n\n  ngOnDestroy() {\n    if (this.subscriptions) {\n      this.subscriptions.forEach(subscription => {\n        subscription.unsubscribe();\n      });\n    }\n  }\n\n  detailActionNew() {\n    this.gridDetail.insertRow();\n  }\n\n  get duplicates() {\n    return [...this._duplicates];\n  }\n\n  get keys() {\n    return [...this._keys];\n  }\n\n  get pageActions() {\n    return [...this._pageActions];\n  }\n\n  get controlFields() {\n    return this._controlFields;\n  }\n\n  get detailFields() {\n    return this._detailFields;\n  }\n\n  private loadDataFromAPI() {\n    const { serviceApi: serviceApiFromRoute, serviceMetadataApi, serviceLoadApi } = this.activatedRoute.snapshot.data;\n    const { id } = this.activatedRoute.snapshot.params;\n    const { duplicate } = this.activatedRoute.snapshot.queryParams;\n\n    const onLoad = serviceLoadApi || this.onLoad;\n    this.serviceApi = serviceApiFromRoute || this.serviceApi;\n\n    this.poPageDynamicService.configServiceApi({ endpoint: this.serviceApi, metadata: serviceMetadataApi });\n\n    const metadata$ = this.getMetadata(serviceApiFromRoute, id, onLoad);\n    const data$ = this.loadData(id, duplicate);\n\n    this.subscriptions.push(concat(metadata$, data$).subscribe());\n  }\n\n  private cancel(\n    actionCancel: PoPageDynamicEditActions['cancel'],\n    actionBeforeCancel: PoPageDynamicEditActions['beforeCancel']\n  ) {\n    if (this.dynamicForm && this.dynamicForm.form.dirty) {\n      this.poDialogService.confirm({\n        message: this.literals.cancelConfirmMessage,\n        title: this.literals.pageActionCancel,\n        confirm: this.goBack.bind(this, actionCancel, actionBeforeCancel)\n      });\n    } else {\n      this.goBack(actionCancel, actionBeforeCancel);\n    }\n  }\n\n  private formatUniqueKey(item) {\n    const keys = mapObjectByProperties(item, this.keys);\n\n    return valuesFromObject(keys).join('|');\n  }\n\n  private goBack(\n    actionCancel: PoPageDynamicEditActions['cancel'],\n    actionBeforeCancel: PoPageDynamicEditActions['beforeCancel']\n  ) {\n    this.subscriptions.push(\n      this.poPageDynamicEditActionsService\n        .beforeCancel(actionBeforeCancel)\n        .subscribe((beforeCancelResult: PoPageDynamicEditBeforeCancel) => {\n          this.executeBackAction(actionCancel, beforeCancelResult?.allowAction, beforeCancelResult?.newUrl);\n        })\n    );\n  }\n\n  private executeBackAction(\n    actionCancel: PoPageDynamicEditActions['cancel'],\n    allowAction?: PoPageDynamicEditBeforeCancel['allowAction'],\n    newUrl?: PoPageDynamicEditBeforeCancel['newUrl']\n  ) {\n    const isAllowedAction = typeof allowAction === 'boolean' ? allowAction : true;\n\n    if (isAllowedAction) {\n      if (actionCancel === undefined || typeof actionCancel === 'boolean') {\n        return window.history.back();\n      }\n\n      if (typeof actionCancel === 'string' || newUrl) {\n        return this.router.navigate([newUrl || actionCancel]);\n      }\n\n      return actionCancel();\n    }\n  }\n\n  private loadData(id, duplicate?) {\n    if (!id) {\n      try {\n        this.model = duplicate ? JSON.parse(duplicate) : {};\n      } catch {\n        this.model = {};\n      }\n\n      return EMPTY;\n    }\n\n    return this.poPageDynamicService.getResource(id).pipe(\n      tap(response => {\n        this.beforeSetModel(response);\n      }),\n      catchError(error => {\n        this.model = undefined;\n        this.actions = undefined;\n        this._pageActions = [];\n        return throwError(error);\n      })\n    );\n  }\n\n  private beforeSetModel(response: any) {\n    if (!this.onLoadData) {\n      this.model = response;\n      return;\n    }\n\n    const onLoadDataExecution = this.onLoadData(response);\n    const onLoadData$ = onLoadDataExecution instanceof Observable ? onLoadDataExecution : of(onLoadDataExecution);\n\n    onLoadData$.subscribe({\n      next: customModel => {\n        this.model = customModel;\n      },\n      error: () => {\n        this.model = response;\n      }\n    });\n  }\n\n  private loadOptionsOnInitialize(onLoad: UrlOrPoCustomizationFunction) {\n    if (onLoad) {\n      return this.getPoDynamicPageOptions(onLoad).pipe(\n        tap(responsePoOption =>\n          this.poPageCustomizationService.changeOriginalOptionsToNewOptions(this, responsePoOption)\n        )\n      );\n    }\n\n    return EMPTY;\n  }\n\n  private getPoDynamicPageOptions(onLoad: UrlOrPoCustomizationFunction): Observable<PoPageDynamicEditOptions> {\n    const originalOption: PoPageDynamicEditOptions = {\n      fields: this.fields,\n      actions: this.actions,\n      breadcrumb: this.breadcrumb,\n      title: this.title\n    };\n\n    const pageOptionSchema: PoPageDynamicOptionsSchema<PoPageDynamicEditOptions> = {\n      schema: [\n        {\n          nameProp: 'fields',\n          merge: true,\n          keyForMerge: 'property'\n        },\n        {\n          nameProp: 'actions',\n          merge: true\n        },\n        {\n          nameProp: 'breadcrumb'\n        },\n        {\n          nameProp: 'title'\n        }\n      ]\n    };\n\n    return this.poPageCustomizationService.getCustomOptions(onLoad, originalOption, pageOptionSchema);\n  }\n\n  private getMetadata(serviceApiFromRoute: string, paramId: string | number, onLoad: UrlOrPoCustomizationFunction) {\n    const typeMetadata = paramId ? 'edit' : 'create';\n\n    if (serviceApiFromRoute) {\n      return this.poPageDynamicService.getMetadata<PoPageDynamicEditMetadata>(typeMetadata).pipe(\n        tap(response => {\n          this.autoRouter = response.autoRouter || this.autoRouter;\n          this.actions = response.actions || this.actions;\n          this.breadcrumb = response.breadcrumb || this.breadcrumb;\n          this.fields = response.fields || this.fields;\n          this.title = response.title || this.title;\n        }),\n        switchMap(() => this.loadOptionsOnInitialize(onLoad))\n      );\n    }\n\n    return this.loadOptionsOnInitialize(onLoad);\n  }\n\n  private navigateTo(path: string) {\n    if (path) {\n      const url = this.resolveUrl(this.model, path);\n\n      this.router.navigate([url]);\n    } else {\n      window.history.back();\n    }\n  }\n\n  private resolveUniqueKey(item: any) {\n    return this.activatedRoute.snapshot.params['id'] ? this.formatUniqueKey(item) : undefined;\n  }\n\n  private resolveUrl(item: any, path: string) {\n    const uniqueKey = this.formatUniqueKey(item);\n\n    return path.replace(/:id/g, uniqueKey);\n  }\n\n  private executeSave(saveRedirectPath: string) {\n    const saveOperation$ = this.saveOperation();\n\n    return saveOperation$.pipe(\n      tap(message => {\n        this.poNotification.success(message);\n        this.navigateTo(saveRedirectPath);\n      })\n    );\n  }\n\n  private updateModel(newResource: any = {}) {\n    const dynamicNgForm = this.dynamicForm.form;\n\n    removeKeysProperties(this.keys, newResource);\n\n    this.model = { ...this.model, ...newResource };\n\n    dynamicNgForm.form.patchValue(this.model);\n  }\n\n  private saveOperation() {\n    if (this.dynamicForm.form.invalid) {\n      this.poNotification.warning(this.literals.saveNotificationWarning);\n      return EMPTY;\n    }\n\n    const paramId = this.activatedRoute.snapshot.params['id'];\n    const successMsg = paramId\n      ? this.literals.saveNotificationSuccessUpdate\n      : this.literals.saveNotificationSuccessSave;\n\n    const saveOperation$ = paramId\n      ? this.poPageDynamicService.updateResource(paramId, this.model)\n      : this.poPageDynamicService.createResource(this.model);\n\n    return saveOperation$.pipe(map(() => successMsg));\n  }\n\n  private save(action: SaveAction, before: 'beforeSave' | 'beforeSaveNew' = 'beforeSave') {\n    const executeOperation = {\n      beforeSave: this.executeSave.bind(this),\n      beforeSaveNew: this.executeSaveNew.bind(this)\n    };\n\n    const uniqueKey = this.resolveUniqueKey(this.model);\n\n    this.subscriptions.push(\n      this.poPageDynamicEditActionsService[before](this.actions[before], uniqueKey, { ...this.model })\n        .pipe(\n          switchMap(returnBefore => {\n            const newAction = returnBefore?.newUrl ?? action;\n            const allowAction = returnBefore?.allowAction ?? true;\n\n            this.updateModel(returnBefore?.resource);\n\n            if (!allowAction) {\n              return of({});\n            }\n\n            if (typeof newAction === 'string') {\n              return executeOperation[before](newAction);\n            } else {\n              newAction({ ...this.model }, uniqueKey);\n              return EMPTY;\n            }\n          })\n        )\n        .subscribe()\n    );\n  }\n\n  private executeSaveNew(path: string) {\n    const paramId = this.activatedRoute.snapshot.params['id'];\n    const saveOperation$ = this.saveOperation();\n\n    return saveOperation$.pipe(\n      tap(message => {\n        if (paramId) {\n          this.poNotification.success(message);\n\n          this.navigateTo(path);\n        } else {\n          this.poNotification.success(message);\n\n          this.model = {};\n          this.dynamicForm.form.reset();\n        }\n      })\n    );\n  }\n\n  private getKeysByFields(fields: Array<any> = []) {\n    return fields.filter(field => field.key === true).map(field => field.property);\n  }\n\n  private getControlFields(fields: Array<any> = []) {\n    return fields.filter(field => field.type !== 'detail');\n  }\n\n  private getDetailFields(fields: Array<any> = []) {\n    return fields.filter(field => field.type === 'detail');\n  }\n\n  private getDuplicatesByFields(fields: Array<any> = []) {\n    return fields.filter(field => field.duplicate === true).map(field => field.property);\n  }\n\n  private getPageActions(actions: PoPageDynamicEditActions = {}): Array<PoPageAction> {\n    const pageActions = [{ label: this.literals.pageActionSave, action: this.save.bind(this, actions.save) }];\n\n    if (actions.saveNew) {\n      pageActions.push({\n        label: this.literals.pageActionSaveNew,\n        action: this.save.bind(this, actions.saveNew, 'beforeSaveNew')\n      });\n    }\n\n    if (actions.cancel === undefined || actions.cancel) {\n      pageActions.push({\n        label: this.literals.pageActionCancel,\n        action: this.cancel.bind(this, actions.cancel, this.actions.beforeCancel)\n      });\n    }\n\n    return pageActions;\n  }\n\n  private isObject(value: any): boolean {\n    return !!value && typeof value === 'object' && !Array.isArray(value);\n  }\n}\n","<po-page-default [p-actions]=\"pageActions\" [p-breadcrumb]=\"breadcrumb\" [p-title]=\"title\">\n  <ng-container *ngIf=\"model; then formFieldsTemplate; else registerNotFoundTemplate\"> </ng-container>\n</po-page-default>\n\n<ng-template #registerNotFoundTemplate>\n  <po-widget>\n    <span class=\"po-icon po-icon-info\"></span>\n    <span class=\"po-font-text-large\">\n      {{ literals.registerNotFound }}\n    </span>\n  </po-widget>\n</ng-template>\n\n<ng-template #formFieldsTemplate>\n  <po-dynamic-form #dynamicForm [p-fields]=\"controlFields\" [p-value]=\"model\"> </po-dynamic-form>\n\n  <div *ngIf=\"detailFields.length > 0\" class=\"po-sm-12\">\n    <po-divider [p-label]=\"detailFields[0].divider\"></po-divider>\n\n    <div class=\"po-row po-mb-2\">\n      <po-button [p-label]=\"literals.detailActionNew\" (p-click)=\"detailActionNew()\"></po-button>\n    </div>\n\n    <po-grid\n      #gridDetail\n      [p-row-actions]=\"detailActions\"\n      [p-columns]=\"detailFields[0].detail.columns\"\n      [p-data]=\"model[detailFields[0].property]\"\n    >\n    </po-grid>\n  </div>\n</ng-template>\n"]}
829
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-page-dynamic-edit.component.js","sourceRoot":"","sources":["../../../../../../projects/templates/src/lib/components/po-page-dynamic-edit/po-page-dynamic-edit.component.ts","../../../../../../projects/templates/src/lib/components/po-page-dynamic-edit/po-page-dynamic-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ViewChild, OnDestroy } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\n\nimport { Observable, concat, of, Subscription, EMPTY, throwError } from 'rxjs';\nimport { tap, catchError, map, switchMap } from 'rxjs/operators';\n\nimport {\n  PoBreadcrumb,\n  PoDialogService,\n  PoDynamicFormComponent,\n  PoGridComponent,\n  PoGridRowActions,\n  PoLanguageService,\n  PoNotificationService,\n  PoPageAction,\n  poLocaleDefault\n} from '@po-ui/ng-components';\n\nimport { convertToBoolean, mapObjectByProperties, valuesFromObject, removeKeysProperties } from './../../utils/util';\n\nimport { PoPageDynamicEditActions } from './interfaces/po-page-dynamic-edit-actions.interface';\nimport { PoPageDynamicEditField } from './interfaces/po-page-dynamic-edit-field.interface';\nimport { PoPageDynamicService } from '../../services/po-page-dynamic/po-page-dynamic.service';\nimport { PoPageDynamicEditOptions } from './interfaces/po-page-dynamic-edit-options.interface';\nimport { PoPageCustomizationService } from '../../services/po-page-customization/po-page-customization.service';\nimport { PoPageDynamicEditMetadata } from './interfaces/po-page-dynamic-edit-metadata.interface';\nimport { PoPageDynamicOptionsSchema } from '../../services/po-page-customization/po-page-dynamic-options.interface';\nimport { PoPageDynamicEditActionsService } from './po-page-dynamic-edit-actions.service';\nimport { PoPageDynamicEditBeforeCancel } from './interfaces/po-page-dynamic-edit-before-cancel.interface';\nimport { PoPageDynamicEditLiterals } from './interfaces/po-page-dynamic-edit-literals.interface';\n\ntype UrlOrPoCustomizationFunction = string | (() => PoPageDynamicEditOptions);\ntype SaveAction = PoPageDynamicEditActions['save'] | PoPageDynamicEditActions['saveNew'];\n\nexport const poPageDynamicEditLiteralsDefault = {\n  en: <PoPageDynamicEditLiterals>{\n    cancelConfirmMessage: 'Are you sure you want to cancel this operation?',\n    detailActionNew: 'New',\n    pageActionCancel: 'Cancel',\n    pageActionSave: 'Save',\n    pageActionSaveNew: 'Save and new',\n    registerNotFound: 'Register not found.',\n    saveNotificationSuccessSave: 'Resource successfully saved.',\n    saveNotificationSuccessUpdate: 'Resource successfully updated.',\n    saveNotificationWarning: 'Form must be filled out correctly.'\n  },\n  es: <PoPageDynamicEditLiterals>{\n    cancelConfirmMessage: 'Está seguro de que desea cancelar esta operación?',\n    detailActionNew: 'Nuevo',\n    pageActionCancel: 'Cancelar',\n    pageActionSave: 'Guardar',\n    pageActionSaveNew: 'Guardar y nuevo',\n    registerNotFound: 'Registro no encontrado.',\n    saveNotificationSuccessSave: 'Recurso salvo con éxito.',\n    saveNotificationSuccessUpdate: 'Recurso actualizado con éxito.',\n    saveNotificationWarning: 'El formulario debe llenarse correctamente.'\n  },\n  pt: <PoPageDynamicEditLiterals>{\n    cancelConfirmMessage: 'Tem certeza que deseja cancelar esta operação?',\n    detailActionNew: 'Novo',\n    pageActionCancel: 'Cancelar',\n    pageActionSave: 'Salvar',\n    pageActionSaveNew: 'Salvar e novo',\n    registerNotFound: 'Registro não encontrado.',\n    saveNotificationSuccessSave: 'Recurso salvo com sucesso.',\n    saveNotificationSuccessUpdate: 'Recurso atualizado com sucesso.',\n    saveNotificationWarning: 'Formulário precisa ser preenchido corretamente.'\n  },\n  ru: <PoPageDynamicEditLiterals>{\n    cancelConfirmMessage: 'Вы уверены, что хотите отменить эту операцию?',\n    detailActionNew: 'Новый',\n    pageActionCancel: 'Отменить',\n    pageActionSave: 'Сохранить',\n    pageActionSaveNew: 'Сохранить и создать',\n    registerNotFound: 'Запись не найдена.',\n    saveNotificationSuccessSave: 'Ресурс успешно сохранен.',\n    saveNotificationSuccessUpdate: 'Ресурс успешно обновлен.',\n    saveNotificationWarning: 'Форма должна быть заполнена правильно.'\n  }\n};\n\n/**\n * @description\n *\n * O `po-page-dynamic-edit` é uma página que pode servir para editar ou criar novos registros,\n * o mesmo também suporta metadados conforme especificado na documentação.\n *\n * ### Utilização via rota\n *\n * Ao utilizar as rotas para carregar o template, o `page-dynamic-edit` disponibiliza propriedades para\n * poder especificar o endpoint dos dados e dos metadados. Exemplo de utilização:\n *\n * O componente primeiro irá carregar o metadado da rota definida na propriedade serviceMetadataApi\n * e depois irá buscar da rota definida na propriedade serviceLoadApi\n *\n * > Caso o servidor retornar um erro ao recuperar o metadados, será repassado o metadados salvo em cache,\n * se o cache não existe será disparado uma notificação.\n *\n * ```\n * {\n *   path: 'people',\n *   component: PoPageDynamicEditComponent,\n *   data: {\n *     serviceApi: 'http://localhost:3000/v1/people', // endpoint dos dados\n *     serviceMetadataApi: 'http://localhost:3000/v1/metadata', // endpoint dos metadados utilizando o método HTTP Get\n *     serviceLoadApi: 'http://localhost:3000/load-metadata' // endpoint de customizações dos metadados utilizando o método HTTP Post\n *   }\n * }\n *\n * ```\n *\n * Para carregar com um recurso já existente, deve-se ser incluído um parâmetro na rota chamado `id`:\n *\n * ```\n * {\n *   path: 'people/:id',\n *   component: PoPageDynamicEditComponent,\n *   data: {\n *     serviceApi: 'http://localhost:3000/v1/people', // endpoint dos dados\n *     serviceMetadataApi: 'http://localhost:3000/v1/metadata', // endpoint dos metadados\n *     serviceLoadApi: 'http://localhost:3000/load-metadata' // endpoint de customizações dos metadados\n *   }\n * }\n * ```\n *\n * A requisição dos metadados é feita na inicialização do template para buscar os metadados da página passando o\n * tipo do metadado esperado e a versão cacheada pelo browser.\n *\n * O formato esperado na resposta da requisição está especificado na interface\n * [PoPageDynamicEditMetadata](/documentation/po-page-dynamic-edit#po-page-dynamic-edit-metadata). Por exemplo:\n *\n * ```\n *  {\n *   version: 1,\n *   title: 'Person edit',\n *   fields: [\n *     { property: 'id', key: true, disabled: true },\n *     { property: 'status' },\n *     { property: 'name' },\n *     { property: 'nickname' },\n *     { property: 'birthdate', label: 'Birth date' },\n *     { property: 'genre' },\n *     { property: 'city' },\n *     { property: 'country' }\n *   ]\n * }\n * ```\n *\n * > Caso o endpoint dos metadados não seja especificado, será feito uma requisição utilizando o `serviceApi` da seguinte forma:\n * ```\n * GET {end-point}/metadata?type=edit&version={version}\n * ```\n *\n * @example\n *\n * <example name=\"po-page-dynamic-edit-basic\" title=\"PO Page Dynamic Edit Basic\">\n *  <file name=\"sample-po-page-dynamic-edit-basic/sample-po-page-dynamic-edit-basic.component.html\"> </file>\n *  <file name=\"sample-po-page-dynamic-edit-basic/sample-po-page-dynamic-edit-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-page-dynamic-edit-user\" title=\"PO Page Dynamic Edit - User\">\n *  <file name=\"sample-po-page-dynamic-edit-user/sample-po-page-dynamic-edit-user.component.html\"> </file>\n *  <file name=\"sample-po-page-dynamic-edit-user/sample-po-page-dynamic-edit-user.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-page-dynamic-edit',\n  templateUrl: './po-page-dynamic-edit.component.html',\n  providers: [PoPageDynamicService]\n})\nexport class PoPageDynamicEditComponent implements OnInit, OnDestroy {\n  @ViewChild('dynamicForm') dynamicForm: PoDynamicFormComponent;\n  @ViewChild('gridDetail') gridDetail: PoGridComponent;\n\n  /** Objeto com propriedades do breadcrumb. */\n  @Input('p-breadcrumb') breadcrumb?: PoBreadcrumb = { items: [] };\n\n  /**\n   * @description\n   *\n   * Endpoint usado pelo template para requisição do recurso que será exibido para edição.\n   *\n   * Para as ações de `save` e `saveNew`, será feito uma requisição de criação nesse mesmo endpoint passando os valores\n   * preenchidos pelo usuário via payload.\n   *\n   * > `POST {end-point}`\n   *\n   * ```\n   *  <po-page-dynamic-edit\n   *    [p-actions]=\"{ save: '/', saveNew: 'new' }\"\n   *    [p-fields]=\"[ { property: 'name' }, { property: 'city' } ]\"\n   *    p-service=\"/api/po-samples/v1/people\"\n   *    ...>\n   *  </po-page-dynamic-edit>\n   * ```\n   *\n   * Resquisição disparada, onde a propriedade `name` e `city` foram preenchidas:\n   *\n   * ```\n   *  POST /api/po-samples/v1/people HTTP/1.1\n   *  Host: localhost:4000\n   *  Connection: keep-alive\n   *  Accept: application/json, text/plain\n   *  ...\n   * ```\n   *\n   * Request payload:\n   *\n   * ```\n   * { \"name\": \"Fulano\", \"city\": \"Smallville\" }\n   * ```\n   *\n   * Caso queira que o template carregue um recurso já existente, deve-se ser incluído um parametro na rota chamado `id`.\n   *\n   * Exemplo de configuração de rota:\n   *\n   * ```\n   *  RouterModule.forRoot([\n   *    ...\n   *    { path: 'edit/:id', component: PersonEditComponent },\n   *    ...\n   *  ],\n   * ```\n   *\n   * Baseado nisso, na inicialização do template, será disparado uma requisição para buscar o recurso que será editado.\n   *\n   * > `GET {end-point}/{id}`\n   *\n   * Nos métodos de `save` e `saveNew`, ao invés de um `POST`, será disparado um `PUT`.\n   *\n   * Resquisição disparada, onde a propriedade `name` e `city` foram preenchidas / atualizadas, e o `id` da url é 2:\n   *\n   * ```\n   *  PUT /api/po-samples/v1/people/2 HTTP/1.1\n   *  Host: localhost:4000\n   *  Connection: keep-alive\n   *  Accept: application/json, text/plain\n   *  ...\n   * ```\n   *\n   * Request payload:\n   *\n   * ```\n   * { \"name\": \"Fulano\", \"city\": \"Metropolis\" }\n   * ```\n   */\n  @Input('p-service-api') serviceApi: string;\n\n  /** Título da página. */\n  @Input('p-title') title: string;\n\n  /**\n   * Função ou serviço que será executado na inicialização do componente.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * O retorno desta função deve ser do tipo `PoPageDynamicEditOptions`,\n   * onde o usuário poderá customizar novos campos, breadcrumb, title e actions\n   *\n   * Por exemplo:\n   *\n   * ```\n   * getPageOptions(): PoPageDynamicEditOptions {\n   * return {\n   *   actions:\n   *     { cancel: false, save: 'save/:id', saveNew: 'saveNew' },\n   *   fields: [\n   *     { property: 'idCard', gridColumns: 6 }\n   *   ]\n   * };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-load]=\"onLoadOptions.bind(this)\"\n   * ```\n   */\n  @Input('p-load') onLoad: string | (() => PoPageDynamicEditOptions);\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Função que será executada após ser realizada a busca dos dados.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `function`: Método que será executado.\n   *\n   * Esta função passa por parâmetro o model e deve recebê-lo de volta com as alterações.\n   * Também aceita o retorno de um Observable com o novo model.\n   *\n   * Por exemplo:\n   *\n   * ```\n   * onLoadCustom(model) {\n   *  return { ...model, customField: 'newValue' };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-load-data]=\"onLoadCustom.bind(this)\"\n   * ```\n   */\n  @Input('p-load-data') onLoadData: ((model: any) => any) | ((model: any) => Observable<any>);\n\n  model: any = {};\n\n  // beforeSave: return boolean\n  // afterSave\n  // beforeRemove: return boolean\n  // afterRemove\n  // beforeInsert: : return boolean\n  readonly detailActions: PoGridRowActions = {};\n\n  private indexFocus = 0;\n  private language: string;\n  private subscriptions: Array<Subscription> = [];\n  private _actions: PoPageDynamicEditActions = {};\n  private _literals: PoPageDynamicEditLiterals;\n  private _autoRouter: boolean = false;\n  private _controlFields: Array<any> = [];\n  private _detailFields: Array<any> = [];\n  private _duplicates: Array<any> = [];\n  private _fields: Array<any> = [];\n  private _keys: Array<any> = [];\n  private _pageActions: Array<PoPageAction> = [];\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ações da página.\n   */\n  @Input('p-actions') set actions(value: PoPageDynamicEditActions) {\n    this._actions = this.isObject(value) ? value : {};\n\n    this._pageActions = this.getPageActions(this._actions);\n  }\n\n  get actions() {\n    return { ...this._actions };\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Objeto com as literais usadas no `po-page-dynamic-edit`.\n   *\n   * É possivel customizar passando um objeto com todas as literais disponíveis\n   * ou passando apenas as literais que deseja customizar\n   *\n   * ```\n   *  const customLiterals: PoPageDynamicEditLiterals = {\n   *    detailActionNew: 'Incluir',\n   *    pageActionCancel: 'Descartar',\n   *    pageActionSave: 'Gravar',\n   *    pageActionSaveNew: 'Gravar e incluir',\n   *    registerNotFound: 'Nenhum registro encontrado.',\n   *    saveNotificationSuccessSave: 'Item salvo com sucesso.',\n   *    saveNotificationSuccessUpdate: 'Item atualizado com sucesso.',\n   *    saveNotificationWarning: 'Necessário preencher o formulário corretamente.'\n   *  };\n   * ```\n   *\n   * E para carregar as literais customizadas, basta apenas passar o objeto para o componente.\n   *\n   * ```\n   * <po-page-dynamic-edit\n   *   [p-literals]=\"customLiterals\">\n   * </po-page-dynamic-edit>\n   * ```\n   *\n   * > O valor padrão será traduzido de acordo com o idioma configurado no [`PoI18nService`](/documentation/po-i18n) ou *browser*.\n   */\n  @Input('p-literals') set literals(value: PoPageDynamicEditLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poPageDynamicEditLiteralsDefault[poLocaleDefault],\n        ...poPageDynamicEditLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poPageDynamicEditLiteralsDefault[this.language];\n    }\n\n    this._pageActions = this.getPageActions(this._actions);\n  }\n\n  get literals() {\n    return this._literals || poPageDynamicEditLiteralsDefault[this.language];\n  }\n\n  /**\n   * @todo Validar rotas na mão pois se existir uma rota '**' o catch do navigation não funciona.\n   *\n   * @optional\n   *\n   * @description\n   *\n   * Cria automaticamente as rotas de edição (novo/duplicate) e detalhes caso as ações\n   * estejam definidas nas ações.\n   *\n   * > Para o correto funcionamento não pode haver nenhum rota coringa (`**`) especificada.\n   *\n   * @default false\n   */\n  @Input('p-auto-router') set autoRouter(value: boolean) {\n    this._autoRouter = convertToBoolean(value);\n  }\n\n  get autoRouter(): boolean {\n    return this._autoRouter;\n  }\n\n  /** Lista dos campos usados na tabela e busca avançada. */\n  @Input('p-fields') set fields(value: Array<PoPageDynamicEditField>) {\n    this._fields = Array.isArray(value) ? [...value] : [];\n\n    this._keys = this.getKeysByFields(this._fields);\n    this._duplicates = this.getDuplicatesByFields(this._fields);\n\n    this._controlFields = this.getControlFields(this._fields);\n    this._detailFields = this.getDetailFields(this._fields);\n  }\n\n  get fields(): Array<PoPageDynamicEditField> {\n    return this._fields;\n  }\n\n  constructor(\n    private router: Router,\n    private activatedRoute: ActivatedRoute,\n    private poNotification: PoNotificationService,\n    private poDialogService: PoDialogService,\n    private poPageDynamicService: PoPageDynamicService,\n    private poPageCustomizationService: PoPageCustomizationService,\n    private poPageDynamicEditActionsService: PoPageDynamicEditActionsService,\n    languageService: PoLanguageService\n  ) {\n    this.language = languageService.getShortLanguage();\n  }\n\n  ngOnInit(): void {\n    this.loadDataFromAPI();\n  }\n\n  ngOnDestroy() {\n    if (this.subscriptions) {\n      this.subscriptions.forEach(subscription => {\n        subscription.unsubscribe();\n      });\n    }\n  }\n\n  detailActionNew() {\n    this.gridDetail.insertRow();\n  }\n\n  get duplicates() {\n    return [...this._duplicates];\n  }\n\n  get keys() {\n    return [...this._keys];\n  }\n\n  get pageActions() {\n    return [...this._pageActions];\n  }\n\n  get controlFields() {\n    return this._controlFields;\n  }\n\n  get detailFields() {\n    return this._detailFields;\n  }\n\n  private loadDataFromAPI() {\n    const { serviceApi: serviceApiFromRoute, serviceMetadataApi, serviceLoadApi } = this.activatedRoute.snapshot.data;\n    const { id } = this.activatedRoute.snapshot.params;\n    const { duplicate } = this.activatedRoute.snapshot.queryParams;\n\n    const onLoad = serviceLoadApi || this.onLoad;\n    this.serviceApi = serviceApiFromRoute || this.serviceApi;\n\n    this.poPageDynamicService.configServiceApi({ endpoint: this.serviceApi, metadata: serviceMetadataApi });\n\n    const metadata$ = this.getMetadata(serviceApiFromRoute, id, onLoad);\n    const data$ = this.loadData(id, duplicate);\n\n    this.subscriptions.push(concat(metadata$, data$).subscribe());\n  }\n\n  private cancel(\n    actionCancel: PoPageDynamicEditActions['cancel'],\n    actionBeforeCancel: PoPageDynamicEditActions['beforeCancel']\n  ) {\n    if (this.dynamicForm && this.dynamicForm.form.dirty) {\n      this.poDialogService.confirm({\n        message: this.literals.cancelConfirmMessage,\n        title: this.literals.pageActionCancel,\n        confirm: this.goBack.bind(this, actionCancel, actionBeforeCancel)\n      });\n    } else {\n      this.goBack(actionCancel, actionBeforeCancel);\n    }\n  }\n\n  private formatUniqueKey(item) {\n    const keys = mapObjectByProperties(item, this.keys);\n\n    return valuesFromObject(keys).join('|');\n  }\n\n  private goBack(\n    actionCancel: PoPageDynamicEditActions['cancel'],\n    actionBeforeCancel: PoPageDynamicEditActions['beforeCancel']\n  ) {\n    this.subscriptions.push(\n      this.poPageDynamicEditActionsService\n        .beforeCancel(actionBeforeCancel)\n        .subscribe((beforeCancelResult: PoPageDynamicEditBeforeCancel) => {\n          this.executeBackAction(actionCancel, beforeCancelResult?.allowAction, beforeCancelResult?.newUrl);\n        })\n    );\n  }\n\n  private executeBackAction(\n    actionCancel: PoPageDynamicEditActions['cancel'],\n    allowAction?: PoPageDynamicEditBeforeCancel['allowAction'],\n    newUrl?: PoPageDynamicEditBeforeCancel['newUrl']\n  ) {\n    const isAllowedAction = typeof allowAction === 'boolean' ? allowAction : true;\n\n    if (isAllowedAction) {\n      if (actionCancel === undefined || typeof actionCancel === 'boolean') {\n        return window.history.back();\n      }\n\n      if (typeof actionCancel === 'string' || newUrl) {\n        return this.router.navigate([newUrl || actionCancel]);\n      }\n\n      return actionCancel();\n    }\n  }\n\n  private loadData(id, duplicate?) {\n    if (!id) {\n      try {\n        this.model = duplicate ? JSON.parse(duplicate) : {};\n      } catch {\n        this.model = {};\n      }\n\n      return EMPTY;\n    }\n\n    return this.poPageDynamicService.getResource(id).pipe(\n      tap(response => {\n        this.beforeSetModel(response);\n      }),\n      catchError(error => {\n        this.model = undefined;\n        this.actions = undefined;\n        this._pageActions = [];\n        return throwError(error);\n      })\n    );\n  }\n\n  private beforeSetModel(response: any) {\n    if (!this.onLoadData) {\n      this.model = response;\n      return;\n    }\n\n    const onLoadDataExecution = this.onLoadData(response);\n    const onLoadData$ = onLoadDataExecution instanceof Observable ? onLoadDataExecution : of(onLoadDataExecution);\n\n    onLoadData$.subscribe({\n      next: customModel => {\n        this.model = customModel;\n      },\n      error: () => {\n        this.model = response;\n      }\n    });\n  }\n\n  private loadOptionsOnInitialize(onLoad: UrlOrPoCustomizationFunction) {\n    if (onLoad) {\n      return this.getPoDynamicPageOptions(onLoad).pipe(\n        tap(responsePoOption =>\n          this.poPageCustomizationService.changeOriginalOptionsToNewOptions(this, responsePoOption)\n        )\n      );\n    }\n\n    return EMPTY;\n  }\n\n  private focusCheckboxInput(control: string): void {\n    const checkboxGroup = document.querySelector(`po-checkbox-group[ng-reflect-name=${control}]`);\n    if (checkboxGroup) {\n      const checkBoxComponent = checkboxGroup.querySelector('po-checkbox[ng-reflect-disabled=false]');\n      const labelInput: HTMLInputElement = checkBoxComponent?.querySelector('.po-checkbox-outline');\n      if (labelInput) {\n        labelInput.focus();\n      } else {\n        this.indexFocus--;\n      }\n    }\n  }\n\n  private focusControl(control: string): void {\n    const inputElement: HTMLInputElement = document.querySelector(`[name=${control}]`);\n    if (inputElement) {\n      if (inputElement.tagName === 'INPUT') {\n        inputElement.focus();\n      } else {\n        this.focusRadioInput(inputElement, control);\n      }\n    } else {\n      this.focusCheckboxInput(control);\n    }\n  }\n\n  private focusRadioInput(inputElement: Element, control: string): void {\n    const radioComponent = inputElement.querySelector(\n      `po-radio[ng-reflect-name=${control}][ng-reflect-disabled=false]`\n    );\n    if (radioComponent) {\n      const radioInput = radioComponent.querySelector('input');\n      radioInput.focus();\n      radioInput.parentElement.parentElement.classList.add('po-radio-focus');\n    } else {\n      this.indexFocus--;\n    }\n  }\n\n  private getPoDynamicPageOptions(onLoad: UrlOrPoCustomizationFunction): Observable<PoPageDynamicEditOptions> {\n    const originalOption: PoPageDynamicEditOptions = {\n      fields: this.fields,\n      actions: this.actions,\n      breadcrumb: this.breadcrumb,\n      title: this.title\n    };\n\n    const pageOptionSchema: PoPageDynamicOptionsSchema<PoPageDynamicEditOptions> = {\n      schema: [\n        {\n          nameProp: 'fields',\n          merge: true,\n          keyForMerge: 'property'\n        },\n        {\n          nameProp: 'actions',\n          merge: true\n        },\n        {\n          nameProp: 'breadcrumb'\n        },\n        {\n          nameProp: 'title'\n        }\n      ]\n    };\n\n    return this.poPageCustomizationService.getCustomOptions(onLoad, originalOption, pageOptionSchema);\n  }\n\n  private getMetadata(serviceApiFromRoute: string, paramId: string | number, onLoad: UrlOrPoCustomizationFunction) {\n    const typeMetadata = paramId ? 'edit' : 'create';\n\n    if (serviceApiFromRoute) {\n      return this.poPageDynamicService.getMetadata<PoPageDynamicEditMetadata>(typeMetadata).pipe(\n        tap(response => {\n          this.autoRouter = response.autoRouter || this.autoRouter;\n          this.actions = response.actions || this.actions;\n          this.breadcrumb = response.breadcrumb || this.breadcrumb;\n          this.fields = response.fields || this.fields;\n          this.title = response.title || this.title;\n        }),\n        switchMap(() => this.loadOptionsOnInitialize(onLoad))\n      );\n    }\n\n    return this.loadOptionsOnInitialize(onLoad);\n  }\n\n  private markControlsAsDirtyAndFocusFirstInvalid(): void {\n    this.indexFocus = 0;\n    const controls = Object.keys(this.dynamicForm.form.controls);\n\n    controls.forEach(control => {\n      this.dynamicForm.form.controls[control].markAsDirty();\n      if (this.dynamicForm.form.controls[control].hasError('required') && this.indexFocus === 0) {\n        this.focusControl(control);\n        this.indexFocus++;\n      }\n    });\n  }\n\n  private navigateTo(path: string) {\n    if (path) {\n      const url = this.resolveUrl(this.model, path);\n\n      this.router.navigate([url]);\n    } else {\n      window.history.back();\n    }\n  }\n\n  private resolveUniqueKey(item: any) {\n    return this.activatedRoute.snapshot.params['id'] ? this.formatUniqueKey(item) : undefined;\n  }\n\n  private resolveUrl(item: any, path: string) {\n    const uniqueKey = this.formatUniqueKey(item);\n\n    return path.replace(/:id/g, uniqueKey);\n  }\n\n  private executeSave(saveRedirectPath: string) {\n    const saveOperation$ = this.saveOperation();\n\n    return saveOperation$.pipe(\n      tap(message => {\n        this.poNotification.success(message);\n        this.navigateTo(saveRedirectPath);\n      })\n    );\n  }\n\n  private updateModel(newResource: any = {}) {\n    const dynamicNgForm = this.dynamicForm.form;\n\n    removeKeysProperties(this.keys, newResource);\n\n    this.model = { ...this.model, ...newResource };\n\n    dynamicNgForm.form.patchValue(this.model);\n  }\n\n  private saveOperation() {\n    if (this.dynamicForm.form.invalid) {\n      this.markControlsAsDirtyAndFocusFirstInvalid();\n      this.poNotification.warning(this.literals.saveNotificationWarning);\n      return EMPTY;\n    }\n\n    const paramId = this.activatedRoute.snapshot.params['id'];\n    const successMsg = paramId\n      ? this.literals.saveNotificationSuccessUpdate\n      : this.literals.saveNotificationSuccessSave;\n\n    const saveOperation$ = paramId\n      ? this.poPageDynamicService.updateResource(paramId, this.model)\n      : this.poPageDynamicService.createResource(this.model);\n\n    return saveOperation$.pipe(map(() => successMsg));\n  }\n\n  private save(action: SaveAction, before: 'beforeSave' | 'beforeSaveNew' = 'beforeSave') {\n    const executeOperation = {\n      beforeSave: this.executeSave.bind(this),\n      beforeSaveNew: this.executeSaveNew.bind(this)\n    };\n\n    const uniqueKey = this.resolveUniqueKey(this.model);\n\n    this.subscriptions.push(\n      this.poPageDynamicEditActionsService[before](this.actions[before], uniqueKey, { ...this.model })\n        .pipe(\n          switchMap(returnBefore => {\n            const newAction = returnBefore?.newUrl ?? action;\n            const allowAction = returnBefore?.allowAction ?? true;\n\n            this.updateModel(returnBefore?.resource);\n\n            if (!allowAction) {\n              return of({});\n            }\n\n            if (typeof newAction === 'string') {\n              return executeOperation[before](newAction);\n            } else {\n              newAction({ ...this.model }, uniqueKey);\n              return EMPTY;\n            }\n          })\n        )\n        .subscribe()\n    );\n  }\n\n  private executeSaveNew(path: string) {\n    const paramId = this.activatedRoute.snapshot.params['id'];\n    const saveOperation$ = this.saveOperation();\n\n    return saveOperation$.pipe(\n      tap(message => {\n        if (paramId) {\n          this.poNotification.success(message);\n\n          this.navigateTo(path);\n        } else {\n          this.poNotification.success(message);\n\n          this.model = {};\n          this.dynamicForm.form.reset();\n        }\n      })\n    );\n  }\n\n  private getKeysByFields(fields: Array<any> = []) {\n    return fields.filter(field => field.key === true).map(field => field.property);\n  }\n\n  private getControlFields(fields: Array<any> = []) {\n    return fields.filter(field => field.type !== 'detail');\n  }\n\n  private getDetailFields(fields: Array<any> = []) {\n    return fields.filter(field => field.type === 'detail');\n  }\n\n  private getDuplicatesByFields(fields: Array<any> = []) {\n    return fields.filter(field => field.duplicate === true).map(field => field.property);\n  }\n\n  private getPageActions(actions: PoPageDynamicEditActions = {}): Array<PoPageAction> {\n    const pageActions = [{ label: this.literals.pageActionSave, action: this.save.bind(this, actions.save) }];\n\n    if (actions.saveNew) {\n      pageActions.push({\n        label: this.literals.pageActionSaveNew,\n        action: this.save.bind(this, actions.saveNew, 'beforeSaveNew')\n      });\n    }\n\n    if (actions.cancel === undefined || actions.cancel) {\n      pageActions.push({\n        label: this.literals.pageActionCancel,\n        action: this.cancel.bind(this, actions.cancel, this.actions.beforeCancel)\n      });\n    }\n\n    return pageActions;\n  }\n\n  private isObject(value: any): boolean {\n    return !!value && typeof value === 'object' && !Array.isArray(value);\n  }\n}\n","<po-page-default [p-actions]=\"pageActions\" [p-breadcrumb]=\"breadcrumb\" [p-title]=\"title\">\n  <ng-container *ngIf=\"model; then formFieldsTemplate; else registerNotFoundTemplate\"> </ng-container>\n</po-page-default>\n\n<ng-template #registerNotFoundTemplate>\n  <po-widget>\n    <span class=\"po-icon po-icon-info\"></span>\n    <span class=\"po-font-text-large\">\n      {{ literals.registerNotFound }}\n    </span>\n  </po-widget>\n</ng-template>\n\n<ng-template #formFieldsTemplate>\n  <po-dynamic-form #dynamicForm [p-fields]=\"controlFields\" [p-value]=\"model\"> </po-dynamic-form>\n\n  <div *ngIf=\"detailFields.length > 0\" class=\"po-sm-12\">\n    <po-divider [p-label]=\"detailFields[0].divider\"></po-divider>\n\n    <div class=\"po-row po-mb-2\">\n      <po-button [p-label]=\"literals.detailActionNew\" (p-click)=\"detailActionNew()\"></po-button>\n    </div>\n\n    <po-grid\n      #gridDetail\n      [p-row-actions]=\"detailActions\"\n      [p-columns]=\"detailFields[0].detail.columns\"\n      [p-data]=\"model[detailFields[0].property]\"\n    >\n    </po-grid>\n  </div>\n</ng-template>\n"]}
@@ -4129,6 +4129,7 @@ class PoPageDynamicEditComponent {
4129
4129
  // afterRemove
4130
4130
  // beforeInsert: : return boolean
4131
4131
  detailActions = {};
4132
+ indexFocus = 0;
4132
4133
  language;
4133
4134
  subscriptions = [];
4134
4135
  _actions = {};
@@ -4359,6 +4360,44 @@ class PoPageDynamicEditComponent {
4359
4360
  }
4360
4361
  return EMPTY;
4361
4362
  }
4363
+ focusCheckboxInput(control) {
4364
+ const checkboxGroup = document.querySelector(`po-checkbox-group[ng-reflect-name=${control}]`);
4365
+ if (checkboxGroup) {
4366
+ const checkBoxComponent = checkboxGroup.querySelector('po-checkbox[ng-reflect-disabled=false]');
4367
+ const labelInput = checkBoxComponent?.querySelector('.po-checkbox-outline');
4368
+ if (labelInput) {
4369
+ labelInput.focus();
4370
+ }
4371
+ else {
4372
+ this.indexFocus--;
4373
+ }
4374
+ }
4375
+ }
4376
+ focusControl(control) {
4377
+ const inputElement = document.querySelector(`[name=${control}]`);
4378
+ if (inputElement) {
4379
+ if (inputElement.tagName === 'INPUT') {
4380
+ inputElement.focus();
4381
+ }
4382
+ else {
4383
+ this.focusRadioInput(inputElement, control);
4384
+ }
4385
+ }
4386
+ else {
4387
+ this.focusCheckboxInput(control);
4388
+ }
4389
+ }
4390
+ focusRadioInput(inputElement, control) {
4391
+ const radioComponent = inputElement.querySelector(`po-radio[ng-reflect-name=${control}][ng-reflect-disabled=false]`);
4392
+ if (radioComponent) {
4393
+ const radioInput = radioComponent.querySelector('input');
4394
+ radioInput.focus();
4395
+ radioInput.parentElement.parentElement.classList.add('po-radio-focus');
4396
+ }
4397
+ else {
4398
+ this.indexFocus--;
4399
+ }
4400
+ }
4362
4401
  getPoDynamicPageOptions(onLoad) {
4363
4402
  const originalOption = {
4364
4403
  fields: this.fields,
@@ -4400,6 +4439,17 @@ class PoPageDynamicEditComponent {
4400
4439
  }
4401
4440
  return this.loadOptionsOnInitialize(onLoad);
4402
4441
  }
4442
+ markControlsAsDirtyAndFocusFirstInvalid() {
4443
+ this.indexFocus = 0;
4444
+ const controls = Object.keys(this.dynamicForm.form.controls);
4445
+ controls.forEach(control => {
4446
+ this.dynamicForm.form.controls[control].markAsDirty();
4447
+ if (this.dynamicForm.form.controls[control].hasError('required') && this.indexFocus === 0) {
4448
+ this.focusControl(control);
4449
+ this.indexFocus++;
4450
+ }
4451
+ });
4452
+ }
4403
4453
  navigateTo(path) {
4404
4454
  if (path) {
4405
4455
  const url = this.resolveUrl(this.model, path);
@@ -4431,6 +4481,7 @@ class PoPageDynamicEditComponent {
4431
4481
  }
4432
4482
  saveOperation() {
4433
4483
  if (this.dynamicForm.form.invalid) {
4484
+ this.markControlsAsDirtyAndFocusFirstInvalid();
4434
4485
  this.poNotification.warning(this.literals.saveNotificationWarning);
4435
4486
  return EMPTY;
4436
4487
  }