From a2cf743e07b7e20e92bd77ea49c1c93f54d58a9e Mon Sep 17 00:00:00 2001 From: ERICK Carvalho Paulette de Oliveira Date: Fri, 6 Sep 2024 11:52:28 -0300 Subject: [PATCH] =?UTF-8?q?v1.11.5-test=20|=20Commit=20autom=C3=A1tico?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Commit automático realizado via script pós build --- .../lib/widgets/lib-combobox/lib-combobox.component.mjs | 4 +++- dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs | 2 ++ dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs.map | 2 +- dist/ngx-sp-infra/package.json | 2 +- projects/ngx-sp-infra/package-lock.json | 4 ++-- projects/ngx-sp-infra/package.json | 2 +- .../src/lib/widgets/lib-combobox/lib-combobox.component.ts | 5 ++++- 7 files changed, 14 insertions(+), 7 deletions(-) diff --git a/dist/ngx-sp-infra/esm2022/lib/widgets/lib-combobox/lib-combobox.component.mjs b/dist/ngx-sp-infra/esm2022/lib/widgets/lib-combobox/lib-combobox.component.mjs index d57cdbb..7b7fe4e 100644 --- a/dist/ngx-sp-infra/esm2022/lib/widgets/lib-combobox/lib-combobox.component.mjs +++ b/dist/ngx-sp-infra/esm2022/lib/widgets/lib-combobox/lib-combobox.component.mjs @@ -151,6 +151,8 @@ export class LibComboboxComponent { this.innerControl.setValue(item.LABEL); this.ariaExpanded = false; this.setControlStatus(this.innerControl.status); + console.log("returnRecord:", this.returnRecord); + console.log("return ", this.returnRecord ? item : item.ID); this.onChange.emit(this.returnRecord ? item : item.ID); } clearValue() { @@ -253,4 +255,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo type: HostListener, args: ['window:resize', ['$event']] }] } }); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { AbstractControl, FormControl, FormControlStatus, Validators } from '@angular/forms';\r\n\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { RecordCombobox } from '../../models/combobox/record-combobox';\r\n\r\n/**\r\n * @component LibComboboxComponent\r\n * @selector lib-combobox\r\n * \r\n * @description\r\n * O componente LibComboboxComponent é projetado para fornecer aos usuários uma interface para pesquisar e selecionar itens de uma lista.\r\n * Ele suporta a filtragem de itens com base na entrada do usuário, permitindo uma seleção mais fácil em listas extensas.\r\n * \r\n * ## Funcionalidades:\r\n * - Pesquisa e filtragem de itens na lista do combobox.\r\n * - Seleção de itens com feedback visual.\r\n * - Emissão de eventos personalizados para interações do usuário, como recarregar a lista ou selecionar um item.\r\n * - Ajuste dinâmico da largura do dropdown para corresponder ao input principal.\r\n * - Inicialização de um valor selecionado, se fornecido.\r\n * \r\n * ## Inputs:\r\n * - `outerControl` (FormControl | AbstractControl): Control para seleção dos valores, atualizará automaticamente o control do componente pai também\r\n * - `comboboxList` (RecordCombobox[]): Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\r\n * - `labelText` (string): Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\r\n * - `disabled` (boolean): Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\r\n * - `libRequired` (boolean): Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\r\n * - `mainInputPlaceholder` (string): Placeholder do campo principal do combo\r\n * - `searchInputPlaceholder` (string): Placeholder do campo de pesquisa dentro do combo\r\n * - `colorTheme` (\"primary\" | \"secondary\" | \"success\" | \"danger\" | \"warning\" | \"info\" | \"light\" | \"dark\"): Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\r\n * - `returnRecord` (boolean): Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID\r\n * \r\n * ## Outputs:\r\n * - `onReloadList` (EventEmitter<string>): Evento emitido quando a lista precisa ser recarregada.\r\n */\r\n@Component({\r\n  selector: 'lib-combobox',\r\n  templateUrl: './lib-combobox.component.html',\r\n  styleUrl: './lib-combobox.component.scss'\r\n})\r\nexport class LibComboboxComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  // #region ==========> PROPERTIES <==========\r\n\r\n  // #region PROTECTED\r\n  protected textoPesquisa: string = \"\";\r\n\r\n  protected get ariaExpanded(): boolean { return this._ariaExpanded; }\r\n  protected set ariaExpanded(value: boolean) { this._ariaExpanded = value; }\r\n\r\n  protected innerControl: FormControl = new FormControl<string | number | null>(null);\r\n  protected invalidControl: boolean = false;\r\n  protected isRequired: boolean = false;\r\n\r\n  protected invalid: boolean = false;\r\n  protected dirty: boolean = false;\r\n  protected touched: boolean = false;\r\n  // #endregion PROTECTED\r\n\r\n  // #region PRIVATE\r\n  private _disabled?: boolean = false;\r\n  private _ariaExpanded: boolean = false;\r\n  private _subscription: Subscription = new Subscription();\r\n\r\n  private _outerControl: FormControl = new FormControl<string | number | null>(null);\r\n  // #endregion PRIVATE\r\n\r\n  // #region PUBLIC\r\n\r\n  /** (obrigatório) Control para seleção dos valores, atualizará automaticamente o control do componente pai também\r\n   * @alias 'control'\r\n   * @type {FormControl<any> | AbstractControl<any>} */\r\n  @Input({ alias: 'control', required: true })\r\n  public get outerControl(): FormControl<any> { return this._outerControl }\r\n  public set outerControl(value: FormControl<any> | AbstractControl<any>) {\r\n    this._outerControl = value as FormControl;\r\n\r\n    // Cancela a subscrição anterior (se houver) para evitar múltiplas subscrições\r\n    if (this._subscription) this._subscription.unsubscribe();\r\n\r\n    // Subscrição ao observável valueChanges para reagir a mudanças no valor\r\n    this._subscription = this._outerControl.valueChanges.subscribe(value => { this.updateSelectedValue(value) });\r\n    this._subscription = this._outerControl.statusChanges.subscribe(status => { this.setControlStatus(status) });\r\n  }\r\n\r\n  /** (obrigatório) Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\r\n   * @alias 'list'\r\n   * @type {RecordCombobox[]} */\r\n  @Input({ alias: 'list', required: true }) public comboboxList?: RecordCombobox[];\r\n\r\n  /** (opcional) Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\r\n   * @type {string} */\r\n  @Input() public labelText?: string;\r\n\r\n  /** (opcional) Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\r\n   * ! SERÁ DEPRECIADO EM BREVE\r\n   * @type {boolean}\r\n   * @default false */\r\n  @Input() public libRequired?: boolean = false;\r\n\r\n  /** (opcional) Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\r\n   * @type {boolean}\r\n   * @default false */\r\n  @Input()\r\n  public get disabled(): boolean { return this._disabled ?? false; }\r\n  public set disabled(value: boolean | undefined) {\r\n    if (value && value === true) this.innerControl.disable();\r\n    else this.innerControl.enable();\r\n\r\n    //this.setControlStatus();\r\n  }\r\n\r\n  /** (opcional) Placeholder do campo principal do combo\r\n   * @alias 'mainPlaceholder'\r\n   * @type {string}\r\n   * @default \"Selecione uma opção...\" */\r\n  @Input('mainPlaceholder') public mainInputPlaceholder?: string = \"Selecione uma opção...\";\r\n\r\n  /** (opcional) Placeholder do campo de pesquisa dentro do combo\r\n   * @alias 'searchPlaceholder'\r\n   * @type {string}\r\n   * @default \"Pesquisa...\" */\r\n  @Input('searchPlaceholder') public searchInputPlaceholder?: string = \"Pesquisa...\";\r\n\r\n  /** (opcional) Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\r\n   * @alias 'theme'\r\n   * @type {string}\r\n   * @default \"primary\"\r\n  */\r\n  @Input('theme') public colorTheme?: string = \"primary\";\r\n\r\n  /** (opcional) Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID.\r\n   * @type {boolean}\r\n   * @default false\r\n  */\r\n  @Input() public returnRecord?: boolean = false;\r\n\r\n  /** Evento emitido ao recarregar a lista de registros\r\n   * @example Ao ser emitido, o componente pai pode refazer o GET da lista, por exemplo.\r\n   * @emits EventEmitter<string> que leva o valor string da pesquisa feita para ser enviada para o GET\r\n   * @type {EventEmitter<string>} */\r\n  @Output() public onReloadList: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n\r\n  /** Evento emitido ao selecionar um registro da lista do combobox\r\n   * @example Ao ser emitido, o componente pai pode realizar uma validação com o valor selecionado.\r\n   * @emits EventEmitter<string|number|null> que leva o valor string da pesquisa feita para ser enviada para o GET\r\n   * @type {EventEmitter<string | number | null>} */\r\n  @Output() public onChange: EventEmitter<RecordCombobox | string | number | null> = new EventEmitter<RecordCombobox | string | number | null>();\r\n  \r\n\r\n  @ViewChild('mainInput') private _mainInput!: ElementRef;\r\n  @ViewChild('dropdownMenu') private _dropdownMenu!: ElementRef;\r\n  // #endregion PUBLIC\r\n\r\n  // #endregion ==========> PROPERTIES <==========\r\n\r\n\r\n  // #region ==========> INITIALIZATION <==========\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.adjustDropdownWidth();\r\n\r\n    this.setValidator();\r\n    this.updateSelectedValue();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.adjustDropdownWidth();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes[\"comboboxList\"]?.currentValue) this.updateSelectedValue();\r\n    if (changes[\"outerControl\"]?.currentValue) this.updateSelectedValue((changes[\"outerControl\"].currentValue as FormControl).value);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._subscription.unsubscribe();\r\n  }\r\n\r\n  // O que fazer quando o evento de redimensionamento ocorrer\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: Event): void { this.adjustDropdownWidth() }\r\n  // #endregion ==========> INITIALIZATION <==========\r\n\r\n\r\n  // #region ==========> UTILS <==========\r\n  public setValue(item: RecordCombobox): void {\r\n    this.textoPesquisa = \"\";\r\n    this.innerControl.markAsDirty();\r\n    this._outerControl.markAsDirty();\r\n    \r\n    this._outerControl.setValue(item.ID);\r\n    this.innerControl.setValue(item.LABEL);\r\n\r\n    this.ariaExpanded = false;\r\n    this.setControlStatus(this.innerControl.status);\r\n\r\n    this.onChange.emit(this.returnRecord ? item : item.ID);\r\n  }\r\n\r\n  public clearValue(): void {\r\n    this.textoPesquisa = \"\";\r\n    this.innerControl.markAsDirty();\r\n    this._outerControl.markAsDirty();\r\n\r\n    this._outerControl.setValue(null);\r\n    this.innerControl.setValue(null);\r\n\r\n    this.ariaExpanded = false;\r\n    this.setControlStatus(this.innerControl.status);\r\n\r\n    this.onChange.emit(null);\r\n  }\r\n\r\n  private updateSelectedValue(value?: string | number | null): void {\r\n    this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa\r\n    const selectedValue: string | number | null = value ?? this._outerControl.value;\r\n\r\n    if (!this.comboboxList || (selectedValue === null && selectedValue === '')) return;\r\n\r\n    const initializedValue = this.comboboxList.find(item => item.ID === selectedValue)\r\n    if (initializedValue) this.innerControl.setValue(initializedValue.LABEL);\r\n\r\n    // this.setControlStatus(this._outerControl.status);\r\n  }\r\n\r\n  private adjustDropdownWidth(): void {\r\n    if (this._mainInput && this._dropdownMenu) {\r\n      const inputWidth = this._mainInput.nativeElement.offsetWidth;\r\n      this._dropdownMenu.nativeElement.style.width = `${inputWidth}px`;\r\n    }\r\n  }\r\n\r\n  private setValidator(): void {\r\n    if (this._outerControl.hasValidator(Validators.required)) {\r\n      this.innerControl.addValidators(Validators.required);\r\n      this.isRequired = true;\r\n    }\r\n    else {\r\n      this.innerControl.removeValidators(Validators.required);\r\n      this.isRequired = false;\r\n    }\r\n  }\r\n\r\n  private setControlStatus(formStatus: FormControlStatus): void {\r\n    switch(formStatus) {\r\n      case 'VALID':\r\n        this.invalidControl = false;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'INVALID':\r\n        this.invalidControl = true;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'PENDING':\r\n        this.invalidControl = false;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'DISABLED':\r\n        this.invalidControl = false;\r\n        this.innerControl.disable();\r\n        break;\r\n\r\n    }\r\n  }\r\n\r\n  public reloadList(): void { this.onReloadList.emit(this.textoPesquisa) }\r\n  // #endregion ==========> UTILS <==========\r\n\r\n}\r\n","<label *ngIf=\"labelText && labelText != ''\" [libRequired]=\"isRequired\" class=\"form-label fw-bold\">{{ labelText }}</label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n\r\n   <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\r\n   Ao usar o atributo [btnLeft], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\r\n   <ng-content select=\"[btnLeft]\"></ng-content>\r\n\r\n   <input  #mainInput class=\"form-select text-start rounded-end\" type=\"text\" data-bs-toggle=\"dropdown\" [placeholder]=\"mainInputPlaceholder\"\r\n            [formControl]=\"innerControl\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly [class.is-invalid]=\"invalidControl\"\r\n            (click)=\"ariaExpanded = !ariaExpanded; searchInput.focus()\" (focus)=\"searchInput.focus()\">\r\n\r\n   <ul  #dropdownMenu  class=\"dropdown-menu p-2 glb-max-height-350px overflow-y-scroll z-index-1020\" [class.show]=\"ariaExpanded\">\r\n      <div class=\"input-group mb-2\">\r\n         <input #searchInput (input)=\"textoPesquisa = searchInput.value\" type=\"text\" id=\"searchInput\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchInputPlaceholder\" (keyup.enter)=\"reloadList()\">\r\n         <button class=\"btn btn-{{colorTheme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\r\n      </div>\r\n\r\n      @if (comboboxList) {\r\n         <li *ngIf=\"innerControl.value != '' && innerControl.value != null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar opção selecionada</span> </li>\r\n         @for (item of comboboxList | textFilter:textoPesquisa; track $index) {\r\n            <li class=\"dropdown-item\" (click)=\"setValue(item)\">\r\n               <span *ngIf=\"item.AdditionalStringProperty1 || item.AdditionalStringProperty1 != ''\" class=\"glb-fs-12 fw-bold d-inline-block w-125\">{{ item.AdditionalStringProperty1 }}</span> {{ item.LABEL }}\r\n            </li>\r\n         }\r\n         @empty { <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> }\r\n      }\r\n      @else { <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> }\r\n   </ul>\r\n\r\n   <!-- Este elemento ng-content com o atributo [btnRight] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado direito do combobox de pesquisa.\r\n   Ao usar o atributo [btnRight], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\r\n   <ng-content select=\"[btnRight]\"></ng-content>\r\n\r\n</div>\r\n\r\n<!-- #region MENSAGEM DE ERRO DE VALIDAÇÃO -->\r\n<app-field-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo é obrigatório.\" />\r\n<!-- #endregion MENSAGEM DE ERRO DE VALIDAÇÃO -->\r\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { AbstractControl, FormControl, FormControlStatus, Validators } from '@angular/forms';\r\n\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { RecordCombobox } from '../../models/combobox/record-combobox';\r\n\r\n/**\r\n * @component LibComboboxComponent\r\n * @selector lib-combobox\r\n * \r\n * @description\r\n * O componente LibComboboxComponent é projetado para fornecer aos usuários uma interface para pesquisar e selecionar itens de uma lista.\r\n * Ele suporta a filtragem de itens com base na entrada do usuário, permitindo uma seleção mais fácil em listas extensas.\r\n * \r\n * ## Funcionalidades:\r\n * - Pesquisa e filtragem de itens na lista do combobox.\r\n * - Seleção de itens com feedback visual.\r\n * - Emissão de eventos personalizados para interações do usuário, como recarregar a lista ou selecionar um item.\r\n * - Ajuste dinâmico da largura do dropdown para corresponder ao input principal.\r\n * - Inicialização de um valor selecionado, se fornecido.\r\n * \r\n * ## Inputs:\r\n * - `outerControl` (FormControl | AbstractControl): Control para seleção dos valores, atualizará automaticamente o control do componente pai também\r\n * - `comboboxList` (RecordCombobox[]): Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\r\n * - `labelText` (string): Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\r\n * - `disabled` (boolean): Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\r\n * - `libRequired` (boolean): Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\r\n * - `mainInputPlaceholder` (string): Placeholder do campo principal do combo\r\n * - `searchInputPlaceholder` (string): Placeholder do campo de pesquisa dentro do combo\r\n * - `colorTheme` (\"primary\" | \"secondary\" | \"success\" | \"danger\" | \"warning\" | \"info\" | \"light\" | \"dark\"): Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\r\n * - `returnRecord` (boolean): Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID\r\n * \r\n * ## Outputs:\r\n * - `onReloadList` (EventEmitter<string>): Evento emitido quando a lista precisa ser recarregada.\r\n */\r\n@Component({\r\n  selector: 'lib-combobox',\r\n  templateUrl: './lib-combobox.component.html',\r\n  styleUrl: './lib-combobox.component.scss'\r\n})\r\nexport class LibComboboxComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  // #region ==========> PROPERTIES <==========\r\n\r\n  // #region PROTECTED\r\n  protected textoPesquisa: string = \"\";\r\n\r\n  protected get ariaExpanded(): boolean { return this._ariaExpanded; }\r\n  protected set ariaExpanded(value: boolean) { this._ariaExpanded = value; }\r\n\r\n  protected innerControl: FormControl = new FormControl<string | number | null>(null);\r\n  protected invalidControl: boolean = false;\r\n  protected isRequired: boolean = false;\r\n\r\n  protected invalid: boolean = false;\r\n  protected dirty: boolean = false;\r\n  protected touched: boolean = false;\r\n  // #endregion PROTECTED\r\n\r\n  // #region PRIVATE\r\n  private _disabled?: boolean = false;\r\n  private _ariaExpanded: boolean = false;\r\n  private _subscription: Subscription = new Subscription();\r\n\r\n  private _outerControl: FormControl = new FormControl<string | number | null>(null);\r\n  // #endregion PRIVATE\r\n\r\n  // #region PUBLIC\r\n\r\n  /** (obrigatório) Control para seleção dos valores, atualizará automaticamente o control do componente pai também\r\n   * @alias 'control'\r\n   * @type {FormControl<any> | AbstractControl<any>} */\r\n  @Input({ alias: 'control', required: true })\r\n  public get outerControl(): FormControl<any> { return this._outerControl }\r\n  public set outerControl(value: FormControl<any> | AbstractControl<any>) {\r\n    this._outerControl = value as FormControl;\r\n\r\n    // Cancela a subscrição anterior (se houver) para evitar múltiplas subscrições\r\n    if (this._subscription) this._subscription.unsubscribe();\r\n\r\n    // Subscrição ao observável valueChanges para reagir a mudanças no valor\r\n    this._subscription = this._outerControl.valueChanges.subscribe(value => { this.updateSelectedValue(value) });\r\n    this._subscription = this._outerControl.statusChanges.subscribe(status => { this.setControlStatus(status) });\r\n  }\r\n\r\n  /** (obrigatório) Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\r\n   * @alias 'list'\r\n   * @type {RecordCombobox[]} */\r\n  @Input({ alias: 'list', required: true }) public comboboxList?: RecordCombobox[];\r\n\r\n  /** (opcional) Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\r\n   * @type {string} */\r\n  @Input() public labelText?: string;\r\n\r\n  /** (opcional) Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\r\n   * ! SERÁ DEPRECIADO EM BREVE\r\n   * @type {boolean}\r\n   * @default false */\r\n  @Input() public libRequired?: boolean = false;\r\n\r\n  /** (opcional) Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\r\n   * @type {boolean}\r\n   * @default false */\r\n  @Input()\r\n  public get disabled(): boolean { return this._disabled ?? false; }\r\n  public set disabled(value: boolean | undefined) {\r\n    if (value && value === true) this.innerControl.disable();\r\n    else this.innerControl.enable();\r\n\r\n    //this.setControlStatus();\r\n  }\r\n\r\n  /** (opcional) Placeholder do campo principal do combo\r\n   * @alias 'mainPlaceholder'\r\n   * @type {string}\r\n   * @default \"Selecione uma opção...\" */\r\n  @Input('mainPlaceholder') public mainInputPlaceholder?: string = \"Selecione uma opção...\";\r\n\r\n  /** (opcional) Placeholder do campo de pesquisa dentro do combo\r\n   * @alias 'searchPlaceholder'\r\n   * @type {string}\r\n   * @default \"Pesquisa...\" */\r\n  @Input('searchPlaceholder') public searchInputPlaceholder?: string = \"Pesquisa...\";\r\n\r\n  /** (opcional) Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\r\n   * @alias 'theme'\r\n   * @type {string}\r\n   * @default \"primary\"\r\n  */\r\n  @Input('theme') public colorTheme?: string = \"primary\";\r\n\r\n  /** (opcional) Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID.\r\n   * @type {boolean}\r\n   * @default false\r\n  */\r\n  @Input() public returnRecord?: boolean = false;\r\n\r\n  /** Evento emitido ao recarregar a lista de registros\r\n   * @example Ao ser emitido, o componente pai pode refazer o GET da lista, por exemplo.\r\n   * @emits EventEmitter<string> que leva o valor string da pesquisa feita para ser enviada para o GET\r\n   * @type {EventEmitter<string>} */\r\n  @Output() public onReloadList: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n\r\n  /** Evento emitido ao selecionar um registro da lista do combobox\r\n   * @example Ao ser emitido, o componente pai pode realizar uma validação com o valor selecionado.\r\n   * @emits EventEmitter<string|number|null> que leva o valor string da pesquisa feita para ser enviada para o GET\r\n   * @type {EventEmitter<string | number | null>} */\r\n  @Output() public onChange: EventEmitter<RecordCombobox | string | number | null> = new EventEmitter<RecordCombobox | string | number | null>();\r\n  \r\n\r\n  @ViewChild('mainInput') private _mainInput!: ElementRef;\r\n  @ViewChild('dropdownMenu') private _dropdownMenu!: ElementRef;\r\n  // #endregion PUBLIC\r\n\r\n  // #endregion ==========> PROPERTIES <==========\r\n\r\n\r\n  // #region ==========> INITIALIZATION <==========\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.adjustDropdownWidth();\r\n\r\n    this.setValidator();\r\n    this.updateSelectedValue();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.adjustDropdownWidth();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes[\"comboboxList\"]?.currentValue) this.updateSelectedValue();\r\n    if (changes[\"outerControl\"]?.currentValue) this.updateSelectedValue((changes[\"outerControl\"].currentValue as FormControl).value);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._subscription.unsubscribe();\r\n  }\r\n\r\n  // O que fazer quando o evento de redimensionamento ocorrer\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: Event): void { this.adjustDropdownWidth() }\r\n  // #endregion ==========> INITIALIZATION <==========\r\n\r\n\r\n  // #region ==========> UTILS <==========\r\n  public setValue(item: RecordCombobox): void {\r\n    this.textoPesquisa = \"\";\r\n    this.innerControl.markAsDirty();\r\n    this._outerControl.markAsDirty();\r\n    \r\n    this._outerControl.setValue(item.ID);\r\n    this.innerControl.setValue(item.LABEL);\r\n\r\n    this.ariaExpanded = false;\r\n    this.setControlStatus(this.innerControl.status);\r\n\r\n    console.log(\"returnRecord:\", this.returnRecord);\r\n    console.log(\"return \", this.returnRecord ? item : item.ID);\r\n    \r\n    this.onChange.emit(this.returnRecord ? item as RecordCombobox : item.ID);\r\n  }\r\n\r\n  public clearValue(): void {\r\n    this.textoPesquisa = \"\";\r\n    this.innerControl.markAsDirty();\r\n    this._outerControl.markAsDirty();\r\n\r\n    this._outerControl.setValue(null);\r\n    this.innerControl.setValue(null);\r\n\r\n    this.ariaExpanded = false;\r\n    this.setControlStatus(this.innerControl.status);\r\n\r\n    this.onChange.emit(null);\r\n  }\r\n\r\n  private updateSelectedValue(value?: string | number | null): void {\r\n    this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa\r\n    const selectedValue: string | number | null = value ?? this._outerControl.value;\r\n\r\n    if (!this.comboboxList || (selectedValue === null && selectedValue === '')) return;\r\n\r\n    const initializedValue = this.comboboxList.find(item => item.ID === selectedValue)\r\n    if (initializedValue) this.innerControl.setValue(initializedValue.LABEL);\r\n\r\n    // this.setControlStatus(this._outerControl.status);\r\n  }\r\n\r\n  private adjustDropdownWidth(): void {\r\n    if (this._mainInput && this._dropdownMenu) {\r\n      const inputWidth = this._mainInput.nativeElement.offsetWidth;\r\n      this._dropdownMenu.nativeElement.style.width = `${inputWidth}px`;\r\n    }\r\n  }\r\n\r\n  private setValidator(): void {\r\n    if (this._outerControl.hasValidator(Validators.required)) {\r\n      this.innerControl.addValidators(Validators.required);\r\n      this.isRequired = true;\r\n    }\r\n    else {\r\n      this.innerControl.removeValidators(Validators.required);\r\n      this.isRequired = false;\r\n    }\r\n  }\r\n\r\n  private setControlStatus(formStatus: FormControlStatus): void {\r\n    switch(formStatus) {\r\n      case 'VALID':\r\n        this.invalidControl = false;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'INVALID':\r\n        this.invalidControl = true;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'PENDING':\r\n        this.invalidControl = false;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'DISABLED':\r\n        this.invalidControl = false;\r\n        this.innerControl.disable();\r\n        break;\r\n\r\n    }\r\n  }\r\n\r\n  public reloadList(): void { this.onReloadList.emit(this.textoPesquisa) }\r\n  // #endregion ==========> UTILS <==========\r\n\r\n}\r\n","<label *ngIf=\"labelText && labelText != ''\" [libRequired]=\"isRequired\" class=\"form-label fw-bold\">{{ labelText }}</label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n\r\n   <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\r\n   Ao usar o atributo [btnLeft], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\r\n   <ng-content select=\"[btnLeft]\"></ng-content>\r\n\r\n   <input  #mainInput class=\"form-select text-start rounded-end\" type=\"text\" data-bs-toggle=\"dropdown\" [placeholder]=\"mainInputPlaceholder\"\r\n            [formControl]=\"innerControl\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly [class.is-invalid]=\"invalidControl\"\r\n            (click)=\"ariaExpanded = !ariaExpanded; searchInput.focus()\" (focus)=\"searchInput.focus()\">\r\n\r\n   <ul  #dropdownMenu  class=\"dropdown-menu p-2 glb-max-height-350px overflow-y-scroll z-index-1020\" [class.show]=\"ariaExpanded\">\r\n      <div class=\"input-group mb-2\">\r\n         <input #searchInput (input)=\"textoPesquisa = searchInput.value\" type=\"text\" id=\"searchInput\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchInputPlaceholder\" (keyup.enter)=\"reloadList()\">\r\n         <button class=\"btn btn-{{colorTheme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\r\n      </div>\r\n\r\n      @if (comboboxList) {\r\n         <li *ngIf=\"innerControl.value != '' && innerControl.value != null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar opção selecionada</span> </li>\r\n         @for (item of comboboxList | textFilter:textoPesquisa; track $index) {\r\n            <li class=\"dropdown-item\" (click)=\"setValue(item)\">\r\n               <span *ngIf=\"item.AdditionalStringProperty1 || item.AdditionalStringProperty1 != ''\" class=\"glb-fs-12 fw-bold d-inline-block w-125\">{{ item.AdditionalStringProperty1 }}</span> {{ item.LABEL }}\r\n            </li>\r\n         }\r\n         @empty { <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> }\r\n      }\r\n      @else { <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> }\r\n   </ul>\r\n\r\n   <!-- Este elemento ng-content com o atributo [btnRight] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado direito do combobox de pesquisa.\r\n   Ao usar o atributo [btnRight], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\r\n   <ng-content select=\"[btnRight]\"></ng-content>\r\n\r\n</div>\r\n\r\n<!-- #region MENSAGEM DE ERRO DE VALIDAÇÃO -->\r\n<app-field-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo é obrigatório.\" />\r\n<!-- #endregion MENSAGEM DE ERRO DE VALIDAÇÃO -->\r\n"]} \ No newline at end of file diff --git a/dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs b/dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs index 908b024..c7e67a5 100644 --- a/dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs +++ b/dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs @@ -4392,6 +4392,8 @@ class LibComboboxComponent { this.innerControl.setValue(item.LABEL); this.ariaExpanded = false; this.setControlStatus(this.innerControl.status); + console.log("returnRecord:", this.returnRecord); + console.log("return ", this.returnRecord ? item : item.ID); this.onChange.emit(this.returnRecord ? item : item.ID); } clearValue() { diff --git a/dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs.map b/dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs.map index ef5a5ac..f2983f8 100644 --- a/dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs.map +++ b/dist/ngx-sp-infra/fesm2022/ngx-sp-infra.mjs.map @@ -1 +1 @@ -{"version":3,"file":"ngx-sp-infra.mjs","sources":["../../../projects/ngx-sp-infra/src/lib/message/alert/alert.component.ts","../../../projects/ngx-sp-infra/src/lib/message/alert/alert.component.html","../../../projects/ngx-sp-infra/src/lib/message/confirm/confirm.component.ts","../../../projects/ngx-sp-infra/src/lib/message/confirm/confirm.component.html","../../../projects/ngx-sp-infra/src/lib/message/confirm-modal/confirm-modal.component.ts","../../../projects/ngx-sp-infra/src/lib/message/confirm-modal/confirm-modal.component.html","../../../projects/ngx-sp-infra/src/lib/message/save/save.component.ts","../../../projects/ngx-sp-infra/src/lib/message/save/save.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/breadcrumb/infra-breadcrumb-item/infra-breadcrumb-item.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/breadcrumb/infra-breadcrumb-item/infra-breadcrumb-item.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/breadcrumb/infra-breadcrumb/infra-breadcrumb.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/breadcrumb/infra-breadcrumb/infra-breadcrumb.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/breadcrumb/portalrh-breadcrumb/breadcrumb.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/breadcrumb/portalrh-breadcrumb/breadcrumb.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/combobox/pipes/filter-by.pipe.ts","../../../projects/ngx-sp-infra/src/lib/widgets/svg-storage/svg-storage.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/svg-storage/svg-storage.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/combobox/pipes/limit-to.pipe.ts","../../../projects/ngx-sp-infra/src/lib/widgets/combobox/combobox.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/combobox/combobox.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/field-control-error/field-control-error.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/field-control-error/field-control-error.component.html","../../../projects/ngx-sp-infra/src/lib/utils/form-utils.ts","../../../projects/ngx-sp-infra/src/lib/widgets/field-error-message/field-error-message.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/field-error-message/field-error-message.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/loading-button/loading-button.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/loading-button/loading-button.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/loading/loading.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/loading/loading.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/tree/pipes/search-tree.pipe.ts","../../../projects/ngx-sp-infra/src/lib/widgets/tree/tree.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/tree/tree.component.html","../../../projects/ngx-sp-infra/src/lib/pipes/to-url.pipe.ts","../../../projects/ngx-sp-infra/src/lib/pipes/cpf-cnpj.pipe.ts","../../../projects/ngx-sp-infra/src/lib/widgets/click-outside/clickoutside.directive.ts","../../../projects/ngx-sp-infra/src/lib/widgets/ordering/ordering.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/ordering/ordering.component.html","../../../projects/ngx-sp-infra/src/lib/directives/required.directive.ts","../../../projects/ngx-sp-infra/src/lib/pipes/text-filter.pipe.ts","../../../projects/ngx-sp-infra/src/lib/widgets/search-combobox/search-combobox.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/search-combobox/search-combobox.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/simple-header/simple-header.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/simple-header/simple-header.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/lib-icons/lib-icons.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/lib-icons/lib-icons.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/content-container/content-container.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/content-container/content-container.component.html","../../../projects/ngx-sp-infra/src/lib/directives/copy-clipboard.directive.ts","../../../projects/ngx-sp-infra/src/lib/widgets/table/table.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/table/table.component.html","../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.ts","../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.html","../../../projects/ngx-sp-infra/src/lib/infra.module.ts","../../../projects/ngx-sp-infra/src/lib/message/message-enum.ts","../../../projects/ngx-sp-infra/src/lib/message/message.service.ts","../../../projects/ngx-sp-infra/src/lib/models/DownloadArquivos.ts","../../../projects/ngx-sp-infra/src/lib/models/email-model.ts","../../../projects/ngx-sp-infra/src/lib/models/report-file.ts","../../../projects/ngx-sp-infra/src/lib/models/ret-error.ts","../../../projects/ngx-sp-infra/src/lib/models/ret-feedback-message.ts","../../../projects/ngx-sp-infra/src/lib/models/ret-report-file.ts","../../../projects/ngx-sp-infra/src/lib/models/combobox/record-combobox.ts","../../../projects/ngx-sp-infra/src/lib/models/combobox/ret-records-combobox.ts","../../../projects/ngx-sp-infra/src/lib/models/icons/icon.model.ts","../../../projects/ngx-sp-infra/src/lib/models/forms/custom-form-control.ts","../../../projects/ngx-sp-infra/src/lib/pipes/currency.pipe.ts","../../../projects/ngx-sp-infra/src/lib/utils/check-url-and-method.service.ts","../../../projects/ngx-sp-infra/src/lib/utils/settings.service.ts","../../../projects/ngx-sp-infra/src/lib/utils/ip-service.service.ts","../../../projects/ngx-sp-infra/src/lib/utils/utils.ts","../../../projects/ngx-sp-infra/src/lib/service/modal-utils.service.ts","../../../projects/ngx-sp-infra/src/lib/validators/cpf-cnpj.validator.ts","../../../projects/ngx-sp-infra/src/lib/validators/cpf-cnpj.validator.directive.ts","../../../projects/ngx-sp-infra/src/lib/widgets/tree/models/ret-tree.ts","../../../projects/ngx-sp-infra/src/lib/widgets/tree/models/tree-item.ts","../../../projects/ngx-sp-infra/src/public-api.ts","../../../projects/ngx-sp-infra/src/ngx-sp-infra.ts"],"sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\n\r\nimport { BsModalRef } from 'ngx-bootstrap/modal'\r\n\r\nimport { alertTypes } from '../message-enum';\r\n\r\n@Component({\r\n selector: 'app-alert',\r\n templateUrl: './alert.component.html',\r\n styleUrls: ['./alert.component.scss']\r\n})\r\nexport class AlertComponent implements OnInit {\r\n @Input() message: string;\r\n @Input() type: alertTypes;\r\n \r\n constructor(public _bsModalRef: BsModalRef) { }\r\n \r\n ngOnInit(): void {\r\n const elSpan = document.createElement('span');\r\n\r\n elSpan.classList.add('xoverflow')\r\n\r\n elSpan.innerHTML = this.message;\r\n\r\n // Caso a mensagem seja muito grande, é quebrada para a próxima linha\r\n elSpan.style.wordBreak = \"break-word\";\r\n\r\n let elDivMessage = document.getElementById( \"divMessage\" );\r\n \r\n elDivMessage?.appendChild(elSpan);\r\n }\r\n\r\n public closeAlert(): void {\r\n this.message = '';\r\n \r\n this._bsModalRef.hide();\r\n }\r\n\r\n}\r\n","
\r\n
\r\n
\r\n \r\n
\r\n
\r\n","import { Component, Input, OnInit, EventEmitter, Output } from '@angular/core';\r\n\r\nimport { Subject } from 'rxjs';\r\n\r\nimport { BsModalRef } from 'ngx-bootstrap/modal';\r\n\r\n@Component({\r\n selector: 'app-confirm',\r\n templateUrl: './confirm.component.html',\r\n styleUrls: ['./confirm.component.scss'],\r\n})\r\nexport class ConfirmComponent implements OnInit {\r\n @Input() title: string;\r\n @Input() message: string;\r\n @Input() cancelText: string = 'Cancelar';\r\n @Input() okText: string = 'Sim';\r\n @Input() okButton: Function;\r\n @Input() parametroOkButton: boolean;\r\n @Output() clickButton = new EventEmitter<'confirmado' | 'cancelado'>();\r\n\r\n confirmResult: Subject<'confirmado' | 'cancelado'>;\r\n\r\n constructor(public bsModalRef: BsModalRef) {}\r\n\r\n ngOnInit(): void {\r\n this.confirmResult = new Subject();\r\n \r\n const elSpan = document.createElement('span');\r\n\r\n elSpan.classList.add('xoverflow')\r\n\r\n elSpan.innerHTML = this.message;\r\n\r\n let elDivMessage = document.getElementById( \"divMessage\" );\r\n \r\n elDivMessage?.appendChild(elSpan);\r\n }\r\n\r\n confirm() {\r\n this.confirmAndClose('confirmado');\r\n }\r\n\r\n closeConfirm() {\r\n this.confirmAndClose('cancelado');\r\n }\r\n\r\n private confirmAndClose(value: 'confirmado' | 'cancelado') {\r\n this.bsModalRef.hide();\r\n this.confirmResult.next( value )\r\n this.clickButton.emit(value);\r\n }\r\n}\r\n","
\r\n
\r\n
{{ title }}
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n","import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'app-confirm-modal',\r\n templateUrl: './confirm-modal.component.html',\r\n styleUrls: ['./confirm-modal.component.scss']\r\n})\r\nexport class ConfirmModalComponent {\r\n\r\n constructor() { }\r\n\r\n\r\n // #region ==========> PROPERTIES <==========\r\n\r\n // #region PRIVATE\r\n @Output() public _closingModal: EventEmitter = new EventEmitter();\r\n // #endregion PRIVATE\r\n\r\n // #region PUBLIC\r\n @Input() public modalSubject: string;\r\n @Input() public modalType: 'Excluir' | 'Inativar' | 'Ativar';\r\n @Input() public genreAndPluralitySubject: 'masc singular' | 'masc plural' |\r\n 'fem singular' | 'fem plural' = 'masc singular';\r\n\r\n // Estas variáveis abaixo servem para deixar o mais genérico possível o modal de confirmalçao\r\n @Input() public customMessage: string = '';\r\n @Input() public customTitle: string = '';\r\n @Input() public customButton: string = '';\r\n @Input() public customButtonLoading: string = '';\r\n\r\n @Input() public importantMessage: boolean = false;\r\n\r\n public showSpinner: boolean = false;\r\n // #endregion PUBLIC\r\n\r\n // #endregion ==========> PROPERTIES <==========\r\n\r\n\r\n // #region ==========> UTILITIES <==========\r\n /**\r\n * Este método recebe uma palavra (podendo ser uma palavra composta), vai\r\n * separá-la em outras palavras caso ela seja uma palavra composta, irá percorrer\r\n * as palavras separadas, colocando a inicial de cada palavra em maiúsculo, e\r\n * depois vai uní-las em uma nova palavra, que terá todas as primeiras letras em\r\n * maiúsculo para mostrar no título.\r\n * @param fateWord Palavra (podendo ser ou não palavra composta) que\r\n * será alterada para ter suas iniciais maiúsculas.\r\n * @returns Palavra com iniciais maiúscula.\r\n */\r\n public firstLetterIsLowercase(fateWord: string): string {\r\n const fateWordSplit: string[] = fateWord.split(\" \");\r\n\r\n for (let i = 0; i < fateWordSplit.length; i++) {\r\n fateWordSplit[i] = fateWordSplit[i][0].toLowerCase() + fateWordSplit[i].substring(1);\r\n }\r\n\r\n return fateWordSplit.join(\" \");\r\n }\r\n // #endregion ==========> UTILITIES <==========\r\n\r\n\r\n // #region ==========> MODALS <==========\r\n /**\r\n * Função com o objetivo de mandar um evento para o componente pai para que\r\n * ele feche o modal.\r\n */\r\n public closeModal(isExecuteAction: boolean = false): void {\r\n this._closingModal.emit(isExecuteAction);\r\n }\r\n // #endregion ==========> MODALS <==========\r\n\r\n\r\n}\r\n","
\r\n

{{ customTitle === '' ? [modalType + ' ' + modalSubject] : customTitle }}

\r\n \r\n
\r\n
\r\n
\r\n Tem certeza que você quer {{ firstLetterIsLowercase(modalType) }}\r\n \r\n este \r\n estes \r\n esta \r\n estas \r\n \r\n {{ firstLetterIsLowercase(modalSubject) }}?\r\n \r\n\r\n \r\n {{ customMessage }} \r\n \r\n\r\n (esta ação é irreversível) \r\n
\r\n
\r\n
\r\n \r\n\r\n \r\n\r\n \r\n \r\n \r\n\r\n
\r\n","import { Component, Input, OnInit } from '@angular/core';\r\n\r\nimport { Subject } from 'rxjs';\r\n\r\nimport { BsModalRef } from 'ngx-bootstrap/modal';\r\n\r\n@Component({\r\n selector: 'app-save',\r\n templateUrl: './save.component.html',\r\n styleUrls: ['./save.component.scss'],\r\n})\r\nexport class SaveComponent implements OnInit {\r\n @Input() title: string;\r\n @Input() message: string;\r\n @Input() cancelText: string = 'Cancelar';\r\n @Input() okText: string = 'Sim';\r\n @Input() okButton: Function;\r\n @Input() fields: string[];\r\n\r\n confirmResult: Subject;\r\n\r\n constructor(public bsModalRef: BsModalRef) {}\r\n\r\n ngOnInit(): void {\r\n this.confirmResult = new Subject();\r\n }\r\n\r\n confirm() {\r\n \r\n\r\n this.okButton({Id: 15});\r\n this.confirmAndClose(true);\r\n }\r\n\r\n closeConfirm() {\r\n this.confirmAndClose(false);\r\n }\r\n\r\n private confirmAndClose(value: boolean) {\r\n this.confirmResult.next(value);\r\n\r\n this.bsModalRef.hide();\r\n }\r\n}\r\n","
\r\n
\r\n

{{ title }}

\r\n \r\n
\r\n
\r\n

{{ message }}

\r\n\r\n
\r\n
\r\n
\r\n dados \r\n\r\n
\r\n \r\n
\r\n \r\n \r\n \r\n \r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n","import { Component, ElementRef, OnInit } from '@angular/core';\r\n\r\n/**\r\n * Item da lista padrão da Sispro.\r\n * \r\n * Deve ser utilizado em conjunto com o InfraBreadCrumb\r\n */\r\n@Component({\r\n // eslint-disable-next-line @angular-eslint/component-selector\r\n selector: 'li[infra-breadcrumb-item]',\r\n templateUrl: './infra-breadcrumb-item.component.html',\r\n styleUrls: ['./infra-breadcrumb-item.component.css']\r\n})\r\nexport class InfraBreadcrumbItemComponent implements OnInit {\r\n\r\n constructor(private elem: ElementRef) { }\r\n \r\n ngOnInit(): void {\r\n this.elem.nativeElement.classList.add(\"breadcrumb-item\")\r\n \r\n if (this.elem.nativeElement.children.length > 0) {\r\n let isAnchor = this.elem.nativeElement.children[0] instanceof HTMLAnchorElement;\r\n \r\n if (isAnchor) {\r\n this.elem.nativeElement.classList.add(\"active\");\r\n }\r\n }\r\n }\r\n}\r\n","","import { Component } from '@angular/core';\r\n/**\r\n * Breadcrumbs padrão Sispro.\r\n * \r\n * ## Utilização\r\n * \r\n * Colocar o componente infra-breadcrumb com elementos li que possuem o seletor infra-breadcrumb-item.\r\n * Como demonstrado da seguinte forma:\r\n * \r\n * \r\n *
  • \r\n * Home\r\n *
  • \r\n *
  • \r\n * Consultar\r\n *
  • \r\n *
    \r\n * \r\n * ## Peculiaridades\r\n * \r\n * Não é necessário colocar o item como ativo pois ele verifica se algum dos filhos do elemento li é\r\n * uma âncora ()\r\n * \r\n */\r\n@Component({\r\n selector: 'infra-breadcrumb',\r\n templateUrl: './infra-breadcrumb.component.html',\r\n styleUrls: ['./infra-breadcrumb.component.css']\r\n})\r\nexport class InfraBreadcrumbComponent {\r\n\r\n constructor() { }\r\n\r\n}\r\n","
      \r\n \r\n
    ","import { Component, OnInit, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'app-breadcrumb',\r\n templateUrl: './breadcrumb.component.html',\r\n styleUrls: ['./breadcrumb.component.css']\r\n})\r\nexport class BreadcrumbComponent implements OnInit {\r\n \r\n @Input() menu: string = '';\r\n @Input() opcao: string = '';\r\n\r\n constructor() { }\r\n\r\n ngOnInit(): void {\r\n }\r\n\r\n}\r\n","\r\n
      \r\n
    1. {{ menu }}
    2. \r\n
    3. {{ opcao }}
    4. \r\n
    \r\n","import { Pipe, PipeTransform } from '@angular/core';\r\n\r\n/**\r\n * filters an array based on searctext\r\n */\r\n@Pipe({\r\n name: 'filterBy'\r\n})\r\nexport class FilterByPipe implements PipeTransform {\r\n public transform(array: any[], searchText?: string, keyName?: string) {\r\n if (!array || !searchText || !Array.isArray(array)) {\r\n return array;\r\n }\r\n if (typeof array[0] === 'string') {\r\n return array.filter((item) => item.toLowerCase().indexOf(searchText.toLowerCase()) > -1);\r\n }\r\n // filter array, items which match and return true will be\r\n // kept, false will be filtered out\r\n if (!keyName) {\r\n return array.filter((item: any) => {\r\n for (const key in item) {\r\n if (typeof item[key] !== 'object' && item[key].toString().toLowerCase().indexOf(searchText.toLowerCase()) > -1) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n });\r\n } else {\r\n return array.filter((item: any) => {\r\n if (typeof item[keyName] !== 'object' && item[keyName].toString().toLowerCase().indexOf(searchText.toLowerCase()) > -1) {\r\n return true;\r\n }\r\n return false;\r\n });\r\n }\r\n\r\n }\r\n}\r\n","import { Component, OnChanges, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'app-svg-storage',\r\n templateUrl: './svg-storage.component.html',\r\n styleUrls: ['./svg-storage.component.scss']\r\n})\r\nexport class SvgStorageComponent implements OnChanges {\r\n\r\n constructor() { }\r\n\r\n public ngOnChanges(): void {\r\n switch (this.svgSize) {\r\n case \"default\": this.svgName == 'edit' ? this.size = 20 : this.size = 24; break;\r\n\r\n case \"medium-small\": this.svgName == 'edit' ? this.size = 16 : this.size = 20; break;\r\n\r\n case \"small\": this.svgName == 'edit' ? this.size = 12 : this.size = 16; break;\r\n\r\n default: this.size = this.svgSize; break;\r\n }\r\n\r\n this.color = this.svgColor;\r\n\r\n switch (this.svgColor) {\r\n case \"white\": this.color = \"#FFFFFF\"; break;\r\n\r\n case \"blue\": this.color = \"#2847A0\"; break;\r\n\r\n case \"gray\": this.color = \"#6C757D\"; break;\r\n\r\n case \"lightgray\": this.color = \"#bfbfbf\"; break;\r\n\r\n case \"green\": this.color = \"#198754\"; break;\r\n\r\n case \"light-blue\": this.color = \"#0dcaf0\"; break;\r\n\r\n case \"yellow\": this.color = \"#ffc107\"; break;\r\n\r\n case \"red\": this.color = \"#dc3545\"; break;\r\n\r\n case \"currentColor\": this.color = \"currentColor\"; break;\r\n }\r\n\r\n switch (this.svgStrokeWidth) {\r\n case \"super-lighter\": this.strokeWidth = 0.5; break;\r\n\r\n case \"lighter\": this.strokeWidth = 1; break;\r\n\r\n case \"light\": this.strokeWidth = 1.5; break;\r\n\r\n case \"default\": this.strokeWidth = 2; break;\r\n\r\n case \"bold\": this.strokeWidth = 2.5; break;\r\n\r\n case \"bolder\": this.strokeWidth = 3; break\r\n }\r\n }\r\n\r\n // #region PROPERTIES\r\n\r\n // #region PRIVATE\r\n // #endregion PRIVATE\r\n\r\n // #region PUBLIC\r\n @Input({ required: true }) public svgName: 'arrow-up' | 'arrow-down' | 'copy' | 'chevron-left' | 'cloud' | 'duplicate' | 'eye'\r\n | 'eye-off' | 'more-vertical' | 'plus' | 'save' | 'inativar' | 'trash' | 'edit' | 'ativar' | 'search' | 'cancel'\r\n | 'info' | 'rocket' | 'plus-circle' | 'menu' | 'building' | 'star' | 'star-outline' | 'file-download'\r\n | 'file-download-alt' | 'flag' | 'cancel-circle' | 'warning' | 'gavel' | 'chevron-right' | 'chevron-up'\r\n | 'chevron-down' | 'code' | 'square-pencil' | 'document' | 'document-sign' | 'timer-clock' | 'download-doc'\r\n | 'file-alt' | 'file-upload-alt' | 'file-upload' | 'file-blank' | 'refresh' | 'send' | 'arrow-left-right'\r\n | 'exclamation-circle' | 'camera' | 'user' | 'user-iconscout' | 'angry' | 'frown' | 'meh' | 'smile' | 'grin-tongue'\r\n | 'fases' | 'list-ul' | 'list-ol' | 'file-docx' | 'file-pdf' | 'table' | 'dash-circle' | 'file-slash'\r\n | 'file-info-alt' | 'signout' | 'calculator-alt' | 'prancheta-icon' | 'minus' | 'esfera-cheia'\r\n | string\r\n | 'folha' | 'folha-linhas' | 'folha-upload' | 'folha-lapis' | 'folha-mais' | 'folha-check' | 'folha-marcador'\r\n | 'prancheta' | 'folha-dupla' | 'folha-dupla-linhas' | 'seta-baixo' | 'seta-cima' | 'seta-esquerda' | 'seta-direita'\r\n | 'upload' | 'download' | 'login' | 'logout' | 'fechar' | 'mais' | 'check' | 'aspas' | 'cubo' | 'caixa'\r\n | 'engrenagem' | 'editar' | 'escrita-linha' | 'janelas' | 'atencao' | 'pare' | 'cronometro' | 'olho' | 'sino' | 'estrela'\r\n | 'lupa' | 'usuarios' | 'usuario-quadro' | 'adicionar-usuario' | 'foguete' | 'predio' | 'casa' | 'monitor'\r\n | 'monitor-painel' | 'calendario' | 'fluxo' | 'nuvem' | 'aviao-papel' | 'disquete' | 'lixeira' | 'atualizar'\r\n | 'menu-hamburguer' | 'menu-pontos' | 'linkedin' | 'facebook' | 'instagram' | 'auditoria' | 'cifrao' | 'moedas'\r\n | 'reajuste' | 'cimabaixo' | 'toggle-on' | 'toggle-off' | 'folha-pdf' | 'folha-docx' | 'download-docx'\r\n | 'download-pdf' | 'link' | 'iniciar' | 'timeline' | 'acessoexterno' | 'olho-fechado' | 'tabela-fixa'\r\n | 'eventos-tabela' | 'eventos-nao-periodicos' | 'eventos-periodicos' | 'eventos-saude' | 'eventos-de-fechamento'\r\n | 'evento-tabela' | 'testes' | 'log' | 'eventos-p' | 'eventos-np' | 'contraparte' | 'copiar' | 'logs'\r\n | 'ver-assinaturas' | 'configurar-assinaturas' | 'recalcular' | 'estornar' | 'solicitacao' | 'perguntas' | 'centraldeajuda'\r\n | 'sorriso' | 'lampada' | 'sol' | 'seta-grande-cima' | 'seta-grande-baixo' | 'historico' | 'verificado' | 'logo-contratos'\r\n | 'reverter-reajuste' | 'transporte-caminhao' | 'meia-lua' | 'retornar-workflow' | 'ger-nota-fiscal' | 'prod-financeiro-icone'\r\n | 'certificado' | 'relatorio' | 'relatorio-nucleo' | 'relatorio-contrato' | 'relatorio-condicao-pagamento' | 'relatorio-objeto'\r\n | 'relatorio-reajuste' | 'relatorio-vencido-vincendo' | 'alarme' | 'gestor' | 'consulta' | 'cadeado' | 'cadeado-outline' | 'cadeado-semiaberto-outline'\r\n | 'cadeado-aberto-outline' | 'chave' | 'notificacoes';\r\n\r\n @Input() public svgColor: 'white' | 'blue' | 'gray' | 'green' | 'light-blue' | 'yellow' | 'red' | 'currentColor' | string = 'currentColor';\r\n\r\n @Input() public svgFill: string = 'none';\r\n\r\n @Input() public svgSize: 'default' | 'medium-small' | 'small' | number = 'default';\r\n\r\n @Input() public svgStrokeWidth: 'super-lighter' | 'lighter' | 'light' | 'default' | 'bold' | 'bolder' = 'default';\r\n\r\n public size: number;\r\n public color: string;\r\n public strokeWidth: number;\r\n // #endregion PUBLIC\r\n\r\n // #endregion PROPERTIES\r\n\r\n}\r\n","\r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n\r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n\r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n\r\n\r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n\r\n\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\n\r\n@Pipe({\r\n name: 'limitTo'\r\n})\r\nexport class LimitToPipe implements PipeTransform {\r\n public transform(array: any[], itemsCount: number, startIndex: number = 0) {\r\n if (!Array.isArray(array) || itemsCount === 0) {\r\n return array;\r\n }\r\n return array.slice(startIndex, startIndex + itemsCount);\r\n }\r\n}\r\n","import {\r\n Component, OnInit, Input,\r\n EventEmitter,\r\n Output,\r\n HostListener,\r\n OnChanges,\r\n SimpleChanges,\r\n ViewChildren,\r\n ElementRef,\r\n QueryList,\r\n AfterViewInit,\r\n ChangeDetectorRef,\r\n forwardRef\r\n} from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { FilterByPipe } from './pipes/filter-by.pipe';\r\n\r\n\r\n@Component({\r\n selector: 'app-combobox',\r\n templateUrl: './combobox.component.html',\r\n styleUrls: ['./combobox.component.scss'],\r\n providers: [\r\n {\r\n provide: NG_VALUE_ACCESSOR,\r\n useExisting: forwardRef(() => ComboboxComponent),\r\n multi: true,\r\n },\r\n ]\r\n})\r\nexport class ComboboxComponent implements OnInit, OnChanges, AfterViewInit {\r\n\r\n /** value of the dropdown */\r\n @Input() public _value: any;\r\n\r\n /**\r\n * Get the required inputs\r\n */\r\n @Input() public options: any = [];\r\n\r\n /**\r\n * configuration options\r\n */\r\n @Input() public config: any = {};\r\n\r\n /**\r\n * Whether multiple selection or single selection allowed\r\n */\r\n @Input() public multiple = false;\r\n\r\n /**\r\n * Value\r\n */\r\n @Input() public disabled: boolean;\r\n\r\n /**\r\n * change event when value changes to provide user to handle things in change event\r\n */\r\n @Output() public change: EventEmitter = new EventEmitter();\r\n\r\n /**\r\n * The search text change event emitter emitted when user type in the search input\r\n */\r\n @Output() public searchChange: EventEmitter = new EventEmitter();\r\n\r\n /**\r\n * Event emitted when dropdown is open.\r\n */\r\n @Output() public open: EventEmitter = new EventEmitter();\r\n\r\n /**\r\n * Event emitted when dropdown is open.\r\n */\r\n @Output() public close: EventEmitter = new EventEmitter();\r\n\r\n /**\r\n * Toogle the dropdown list\r\n */\r\n public toggleDropdown = false;\r\n\r\n /**\r\n * Available items for selection\r\n */\r\n public availableItems: any = [];\r\n\r\n /**\r\n * Selected Items\r\n */\r\n public selectedItems: any = [];\r\n\r\n /**\r\n * Selection text to be Displayed\r\n */\r\n public selectedDisplayText = '-';\r\n\r\n /**\r\n * Search text\r\n */\r\n public searchText: string | undefined;\r\n\r\n /**\r\n * variable to track if clicked inside or outside of component\r\n */\r\n public clickedInside = false;\r\n\r\n /**\r\n * variable to track keypress event inside and outsid of component\r\n */\r\n public insideKeyPress = false;\r\n\r\n /**\r\n * variable to track the focused item whenuser uses arrow keys to select item\r\n */\r\n public focusedItemIndex: number | null;\r\n\r\n /**\r\n * element to show not found text when not itmes match the search\r\n */\r\n\r\n public showNotFound = false;\r\n /**\r\n * Hold the reference to available items in the list to focus on the item when scrolling\r\n */\r\n @ViewChildren('availableOption')\r\n public availableOptions: QueryList;\r\n\r\n get value() {\r\n return this._value;\r\n }\r\n set value(val) {\r\n this._value = val;\r\n this.onChange(val);\r\n this.onTouched();\r\n }\r\n\r\n constructor(\r\n private cdref: ChangeDetectorRef,\r\n public _elementRef: ElementRef\r\n ) {\r\n this.multiple = false;\r\n }\r\n\r\n public onChange: any = () => {\r\n // empty\r\n }\r\n public onTouched: any = () => {\r\n // empty\r\n }\r\n\r\n /**\r\n * click listener for host inside this component i.e\r\n * if many instances are there, this detects if clicked inside\r\n * this instance\r\n */\r\n @HostListener('click')\r\n public clickInsideComponent() {\r\n this.clickedInside = true;\r\n }\r\n\r\n @HostListener('blur') public blur() {\r\n this.toggleDropdown = false;\r\n }\r\n\r\n @HostListener('focus') public focus() {\r\n /* istanbul ignore else */\r\n if (!this.disabled) {\r\n this.toggleSelectDropdown();\r\n }\r\n }\r\n /**\r\n * click handler on documnent to hide the open dropdown if clicked outside\r\n */\r\n @HostListener('document:click')\r\n public clickOutsideComponent() {\r\n /* istanbul ignore else */\r\n if (!this.clickedInside) {\r\n this.toggleDropdown = false;\r\n this.resetArrowKeyActiveElement();\r\n // clear searh on close\r\n this.searchText = undefined;\r\n this.close.emit();\r\n }\r\n this.clickedInside = false;\r\n }\r\n\r\n /**\r\n * click handler on documnent to hide the open dropdown if clicked outside\r\n */\r\n @HostListener('document:keydown')\r\n public KeyPressOutsideComponent() {\r\n /* istanbul ignore else */\r\n if (!this.insideKeyPress) {\r\n this.toggleDropdown = false;\r\n this.resetArrowKeyActiveElement();\r\n }\r\n this.insideKeyPress = false;\r\n }\r\n /**\r\n * Event handler for key up and down event and enter press for selecting element\r\n */\r\n @HostListener('keydown', ['$event'])\r\n public handleKeyboardEvent($event: KeyboardEvent) {\r\n this.insideKeyPress = true;\r\n /* istanbul ignore else */\r\n if ($event.keyCode === 27 || this.disabled) {\r\n this.toggleDropdown = false;\r\n this.insideKeyPress = false;\r\n return;\r\n }\r\n const avaOpts = this.availableOptions.toArray();\r\n /* istanbul ignore else */\r\n if ($event.keyCode !== 9 && avaOpts.length === 0 && !this.toggleDropdown) {\r\n this.toggleDropdown = true;\r\n }\r\n // Arrow Down\r\n /* istanbul ignore else */\r\n if ($event.keyCode === 40 && avaOpts.length > 0) {\r\n this.onArrowKeyDown();\r\n /* istanbul ignore else */\r\n if (this.focusedItemIndex! >= avaOpts.length) {\r\n this.focusedItemIndex = 0;\r\n }\r\n avaOpts[this.focusedItemIndex!].nativeElement.focus();\r\n $event.preventDefault();\r\n }\r\n // Arrow Up\r\n /* istanbul ignore else */\r\n if ($event.keyCode === 38 && avaOpts.length) {\r\n this.onArrowKeyUp();\r\n /* istanbul ignore else */\r\n if (this.focusedItemIndex! >= avaOpts.length) {\r\n this.focusedItemIndex = avaOpts.length - 1;\r\n }\r\n avaOpts[this.focusedItemIndex!].nativeElement.focus();\r\n $event.preventDefault();\r\n }\r\n // Enter\r\n /* istanbul ignore else */\r\n if ($event.keyCode === 13 && this.focusedItemIndex !== null) {\r\n const filteredItems = new FilterByPipe().transform(\r\n this.availableItems,\r\n this.searchText!,\r\n this.config.searchOnKey\r\n );\r\n this.selectItem(\r\n filteredItems[this.focusedItemIndex],\r\n this.availableItems.indexOf(filteredItems[this.focusedItemIndex])\r\n );\r\n return false;\r\n }\r\n\r\n return $event.key\r\n\r\n }\r\n\r\n /**\r\n * Component onInit\r\n */\r\n public ngOnInit() {\r\n /* istanbul ignore else */\r\n if (typeof this.options !== 'undefined' && Array.isArray(this.options)) {\r\n if (!this.config.isNotSort) this.availableItems = [...this.options.sort(this.config.customComparator)];\r\n else this.availableItems = [...this.options];\r\n this.initDropdownValuesAndOptions();\r\n }\r\n }\r\n\r\n /**\r\n * after view init to subscribe to available option changes\r\n */\r\n public ngAfterViewInit() {\r\n this.availableOptions.changes.subscribe(this.setNotFoundState.bind(this));\r\n }\r\n\r\n public registerOnChange(fn: any) {\r\n this.onChange = fn;\r\n }\r\n\r\n public registerOnTouched(fn: any) {\r\n this.onTouched = fn;\r\n }\r\n\r\n public setDisabledState(isDisabled: boolean) {\r\n this.disabled = isDisabled;\r\n }\r\n\r\n public writeValue(value: any, internal?: boolean) {\r\n if (value) {\r\n if (Array.isArray(value)) {\r\n if (this.multiple) {\r\n this.value = value;\r\n } else if (value.length > 0) {\r\n this.value = value[0];\r\n }\r\n } else {\r\n this.value = value;\r\n }\r\n /* istanbul ignore else */\r\n if (this.selectedItems.length === 0) {\r\n if (Array.isArray(value)) {\r\n this.selectedItems = value;\r\n } else {\r\n this.selectedItems.push(value);\r\n }\r\n this.initDropdownValuesAndOptions();\r\n }\r\n } else {\r\n this.value = [];\r\n /* istanbul ignore else */\r\n if (!internal) {\r\n this.reset();\r\n }\r\n }\r\n /* istanbul ignore else */\r\n if (!internal) {\r\n this.reset();\r\n }\r\n }\r\n\r\n public reset() {\r\n this.selectedItems = [];\r\n if (!this.config.isNotSort) this.availableItems = [...this.options.sort(this.config.customComparator)];\r\n else this.availableItems = [...this.options]\r\n this.initDropdownValuesAndOptions();\r\n }\r\n /**\r\n * function sets whether to show items not found text or not\r\n */\r\n public setNotFoundState() {\r\n if (this.availableOptions.length === 0) {\r\n this.showNotFound = true;\r\n } else {\r\n this.showNotFound = false;\r\n }\r\n this.cdref.detectChanges();\r\n }\r\n /**\r\n * Component onchage i.e when any of the input properties change\r\n */\r\n public ngOnChanges(changes: SimpleChanges) {\r\n this.selectedItems = [];\r\n // this.searchText = null;\r\n this.options = this.options || [];\r\n /* istanbul ignore else */\r\n if (changes['options']) {\r\n if (!this.config.isNotSort) this.availableItems = [...this.options.sort(this.config.customComparator)];\r\n else this.availableItems = [...this.options];\r\n }\r\n /* istanbul ignore else */\r\n if (changes['value']) {\r\n /* istanbul ignore else */\r\n if (\r\n JSON.stringify(changes['value'].currentValue) === JSON.stringify([]) ||\r\n changes['value'].currentValue === '' ||\r\n changes['value'].currentValue === null\r\n ) {\r\n if (!this.config.isNotSort) this.availableItems = [...this.options.sort(this.config.customComparator)];\r\n else this.availableItems = [...this.options];\r\n }\r\n }\r\n this.initDropdownValuesAndOptions();\r\n }\r\n\r\n /**\r\n * Deselct a selected items\r\n * @param item: item to be deselected\r\n * @param index: index of the item\r\n */\r\n public deselectItem(item: any, index: number) {\r\n this.selectedItems.forEach((element: any, i: number) => {\r\n /* istanbul ignore else */\r\n if (item === element) {\r\n this.selectedItems.splice(i, 1);\r\n }\r\n });\r\n let sortedItems = [...this.availableItems];\r\n /* istanbul ignore else */\r\n if (!this.availableItems.includes(item)) {\r\n this.availableItems.push(item);\r\n if (!this.config.isNotSort) sortedItems = this.availableItems.sort(this.config.customComparator);\r\n else sortedItems = this.availableItems;\r\n }\r\n this.selectedItems = [...this.selectedItems];\r\n this.availableItems = [...sortedItems];\r\n /* istanbul ignore else */\r\n if (!Array.isArray(this.value)) {\r\n this.value = [];\r\n }\r\n\r\n if (this.config.defaultSort) {\r\n const set1: Set = new Set(this.selectedItems);\r\n this.selectedItems = (this.config.defaultSort as [number, string][]).sort((a, b) => a[0] - b[0]).map(e => e[1]).filter(e => set1.has(e))\r\n\r\n const set2: Set = new Set(this.availableItems);\r\n this.availableItems = (this.config.defaultSort as [number, string][]).sort((a, b) => a[0] - b[0]).map(e => e[1]).filter(e => set2.has(e))\r\n }\r\n\r\n this.valueChanged();\r\n this.resetArrowKeyActiveElement();\r\n }\r\n\r\n /**\r\n * Select an item\r\n * @param item: item to be selected\r\n * @param index: index of the item\r\n */\r\n public selectItem(item: string, index?: number) {\r\n /* istanbul ignore else */\r\n if (!this.multiple) {\r\n /* istanbul ignore else */\r\n if (this.selectedItems.length > 0) {\r\n this.availableItems.push(this.selectedItems[0]);\r\n }\r\n this.selectedItems = [];\r\n this.toggleDropdown = false;\r\n }\r\n\r\n this.availableItems.forEach((element: any, i: number) => {\r\n /* istanbul ignore else */\r\n if (item === element) {\r\n this.selectedItems.push(item);\r\n this.availableItems.splice(i, 1);\r\n }\r\n });\r\n\r\n /* istanbul ignore else */\r\n if (this.config.clearOnSelection) {\r\n this.searchText = undefined;\r\n }\r\n\r\n this.selectedItems = [...this.selectedItems];\r\n this.availableItems = [...this.availableItems];\r\n\r\n if (!this.config.isNotSort) {\r\n this.selectedItems.sort(this.config.customComparator);\r\n this.availableItems.sort(this.config.customComparator);\r\n }\r\n\r\n if (this.config.defaultSort) {\r\n const set1: Set = new Set(this.selectedItems);\r\n this.selectedItems = (this.config.defaultSort as [number, string][]).sort((a, b) => a[0] - b[0]).map(e => e[1]).filter(e => set1.has(e))\r\n\r\n const set2: Set = new Set(this.availableItems);\r\n this.availableItems = (this.config.defaultSort as [number, string][]).sort((a, b) => a[0] - b[0]).map(e => e[1]).filter(e => set2.has(e))\r\n }\r\n\r\n // this.searchText = null;\r\n this.valueChanged();\r\n this.resetArrowKeyActiveElement();\r\n }\r\n\r\n /**\r\n * When selected items changes trigger the chaange back to parent\r\n */\r\n public valueChanged() {\r\n this.writeValue(this.selectedItems, true);\r\n // this.valueChange.emit(this.value);\r\n this.change.emit({ value: this.value });\r\n this.setSelectedDisplayText();\r\n }\r\n\r\n /**\r\n * Toggle the dropdownlist on/off\r\n */\r\n public toggleSelectDropdown() {\r\n this.toggleDropdown = !this.toggleDropdown;\r\n if (this.toggleDropdown) {\r\n this.open.emit();\r\n } else {\r\n this.searchText = undefined;\r\n this.close.emit();\r\n }\r\n this.resetArrowKeyActiveElement();\r\n }\r\n\r\n /**\r\n * The change handler for search text\r\n */\r\n public searchTextChanged() {\r\n this.searchChange.emit(this.searchText);\r\n }\r\n\r\n public changeSearchText($event: any) {\r\n $event.stopPropagation();\r\n }\r\n\r\n /**\r\n * initialize the config and other properties\r\n */\r\n private initDropdownValuesAndOptions() {\r\n const config: any = {\r\n displayKey: 'description',\r\n height: 'auto',\r\n search: false,\r\n placeholder: '-',\r\n searchPlaceholder: 'Pesquisar ',\r\n limitTo: 0,\r\n customComparator: undefined,\r\n noResultsFound: 'Nada encontrado!',\r\n moreText: 'Selecionados',\r\n searchOnKey: null,\r\n clearOnSelection: false,\r\n inputDirection: 'ltr',\r\n };\r\n /* istanbul ignore else */\r\n if (this.config === 'undefined' || Object.keys(this.config).length === 0) {\r\n this.config = { ...config };\r\n }\r\n for (const key of Object.keys(config)) {\r\n this.config[key] = this.config[key] ? this.config[key] : config[key];\r\n }\r\n this.config = { ...this.config };\r\n // Adding placeholder in config as default param\r\n this.selectedDisplayText = this.config['placeholder'];\r\n /* istanbul ignore else */\r\n if (this.value !== '' && typeof this.value !== 'undefined') {\r\n if (Array.isArray(this.value)) {\r\n this.selectedItems = this.value;\r\n } else if (this.value !== '' && this.value !== null) {\r\n this.selectedItems[0] = this.value;\r\n } else {\r\n this.selectedItems = [];\r\n this.value = [];\r\n }\r\n\r\n this.selectedItems.forEach((item: any) => {\r\n const ind = this.availableItems.findIndex(\r\n (aItem: any) => JSON.stringify(item) === JSON.stringify(aItem)\r\n );\r\n if (ind !== -1) {\r\n this.availableItems.splice(ind, 1);\r\n }\r\n });\r\n }\r\n this.setSelectedDisplayText();\r\n }\r\n\r\n /**\r\n * set the text to be displayed\r\n */\r\n private setSelectedDisplayText() {\r\n let text: string = this.selectedItems[0];\r\n /* istanbul ignore else */\r\n if (typeof this.selectedItems[0] === 'object') {\r\n text = this.config.displayFn\r\n ? this.config.displayFn(this.selectedItems[0])\r\n : this.selectedItems[0][this.config.displayKey];\r\n }\r\n if (this.multiple && this.selectedItems.length > 0) {\r\n this.selectedDisplayText =\r\n this.selectedItems.length === 1\r\n ? text\r\n : text +\r\n ` + ${this.selectedItems.length - 1} ${this.config.moreText}`;\r\n } else {\r\n this.selectedDisplayText =\r\n this.selectedItems.length === 0 ? this.config.placeholder : text;\r\n }\r\n }\r\n\r\n /**\r\n * Event handler for arrow key up event thats focuses on a item\r\n */\r\n private onArrowKeyUp() {\r\n /* istanbul ignore else */\r\n if (this.focusedItemIndex === 0) {\r\n this.focusedItemIndex = this.availableItems.length - 1;\r\n return;\r\n }\r\n /* istanbul ignore else */\r\n if (this.onArrowKey()) {\r\n this.focusedItemIndex!;\r\n }\r\n }\r\n\r\n /**\r\n * Event handler for arrow key down event thats focuses on a item\r\n */\r\n private onArrowKeyDown() {\r\n /* istanbul ignore else */\r\n if (this.focusedItemIndex === this.availableItems.length - 1) {\r\n this.focusedItemIndex = 0;\r\n return;\r\n }\r\n /* istanbul ignore else */\r\n if (this.onArrowKey()) {\r\n this.focusedItemIndex!++;\r\n }\r\n }\r\n\r\n private onArrowKey() {\r\n /* istanbul ignore else */\r\n if (this.focusedItemIndex === null) {\r\n this.focusedItemIndex = 0;\r\n return false;\r\n }\r\n return true;\r\n }\r\n\r\n /**\r\n * will reset the element that is marked active using arrow keys\r\n */\r\n private resetArrowKeyActiveElement() {\r\n this.focusedItemIndex = null;\r\n }\r\n}\r\n","
    \r\n \r\n
    \r\n
    \r\n \r\n \r\n
    \r\n
      \r\n
    • \r\n \r\n
      {{\r\n config.displayFn\r\n ? config.displayFn(selected)\r\n : selected[config.displayKey] || selected\r\n }}
      \r\n
    • \r\n
    \r\n
    0 && availableItems.length > 0\" />\r\n
      \r\n
    • \r\n \r\n
      \r\n {{ config.displayFn ? config.displayFn(item) : item[config.displayKey] || item }}\r\n
      \r\n
    • \r\n
    • {{ config.noResultsFound }}
    • \r\n
    \r\n
    \r\n
    \r\n","import { Component, Input, OnInit, ElementRef, Renderer2 } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'app-field-control-error',\r\n templateUrl: './field-control-error.component.html',\r\n styleUrls: ['./field-control-error.component.css']\r\n})\r\nexport class FieldControlErrorComponent implements OnInit {\r\n @Input() showError: boolean;\r\n @Input() errorMessage: string;\r\n\r\n constructor(private renderer: Renderer2, private elementRef: ElementRef) { }\r\n\r\n ngOnInit(): void {\r\n this.renderer.setStyle(this.elementRef.nativeElement, 'width', '100%');\r\n }\r\n\r\n}\r\n","
    \r\n {{ errorMessage }}\r\n
    ","import { AbstractControl, NgControl, UntypedFormGroup, UntypedFormArray, FormGroup } from '@angular/forms';\r\n\r\n\r\n/**\r\n * @summary Contém diversos métodos de utilidade para formulários\r\n */\r\nexport class FormUtils {\r\n\r\n /** Verifica se um campo é inválido (Template Driven) */\r\n static isInvalidFieldTemplate(control: NgControl): boolean {\r\n const ret: any = !control.valid && (control.dirty || control.touched);\r\n \r\n return (ret ? ret : false)\r\n }\r\n \r\n /** Verifica se um campo é inválido (Data Driven) */\r\n static isInvalidField(control: AbstractControl | null): boolean {\r\n return (control ? !control.valid && (control.dirty || control.touched) : false);\r\n }\r\n\r\n /** Verifica se um campo é inválido ou se possui algum erro customizado (Data Driven) */\r\n static isInvalidFieldError(control: AbstractControl | null): boolean {\r\n if (control) {\r\n if (!control.valid && (control.dirty || control.touched)) { return true }\r\n else { return false }\r\n }\r\n else { return false }\r\n }\r\n\r\n /** Valida todos os campos do formulário */\r\n static validateFields(formGroup: UntypedFormGroup | UntypedFormArray): void {\r\n Object.keys(formGroup.controls).forEach(field => {\r\n const control = formGroup.get(field);\r\n \r\n let currentValue = control?.value;\r\n\r\n control?.reset();\r\n\r\n control?.markAsDirty();\r\n control?.markAsTouched();\r\n\r\n control?.setValue(currentValue);\r\n \r\n if (control instanceof UntypedFormGroup || control instanceof UntypedFormArray) {\r\n this.validateFields(control);\r\n }\r\n \r\n });\r\n \r\n } \r\n \r\n /** Obtém a mensagem de erro conforme o validador utilizado */\r\n static getErrorMessage(fieldName: string, validatorName: string, validatorValue?: any, customErrorMessage?: string): string {\r\n const config : any = {\r\n 'required': `Este campo é obrigatório.`,\r\n 'minlength': `Este campo deve possuir no mínimo ${validatorValue.requiredLength} caracteres.`,\r\n 'maxlength': `Este campo deve possuir no máximo ${validatorValue.requiredLength} caracteres.`,\r\n 'min': `Este campo deve ser no mínimo ${validatorValue.min}.`,\r\n 'max': `Este campo deve ser no máximo ${validatorValue.max}.`,\r\n 'cpcnpjInvalid': `Este ${fieldName} está inválido.`,\r\n 'cpcnpjInvalidDigit': `Este ${fieldName} tem um dígito inválido.`,\r\n 'incorrect': `Este campo está inválido.`,\r\n 'email': `Este e-mail está inválido.`\r\n };\r\n\r\n return (customErrorMessage\r\n ? customErrorMessage\r\n : config[validatorName]\r\n ? config[validatorName]\r\n : `Este validador - ${validatorName} - não foi implementado`);\r\n }\r\n\r\n\r\n\r\n /**\r\n * @summary Mapeia os valores de um formulário reativo para um objeto de modelo.\r\n *\r\n * @description\r\n * O método `mapFormToModel` recebe um objeto de modelo e um `FormGroup` do Angular, \r\n * e retorna um novo objeto que combina as propriedades do modelo original com os valores \r\n * atuais do formulário. Este método é útil para atualizar dinamicamente as propriedades \r\n * de um modelo com base nos valores inseridos pelo usuário em um formulário.\r\n * \r\n * Se o objeto `record` ou o `formGroup` forem nulos ou indefinidos, o método retornará `null`.\r\n * Caso contrário, o método retorna um novo objeto que inclui todas as propriedades \r\n * do objeto original, sobrescrevendo-as com os valores atuais do formulário, se disponíveis.\r\n *\r\n * @param {object} record - O objeto de modelo original que será atualizado com os valores do formulário.\r\n * @param {FormGroup} formGroup - O `FormGroup` contendo os valores inseridos pelo usuário.\r\n * @returns {object | null} - Um novo objeto combinando o modelo original e os valores do formulário, ou `null` se `record` ou `formGroup` forem nulos ou indefinidos.\r\n *\r\n * @example\r\n * // Suponha que você tenha um objeto de modelo `person` e um `FormGroup` chamado `personForm`.\r\n * const person = {\r\n * name: 'John Doe',\r\n * age: 30,\r\n * email: 'john.doe@example.com'\r\n * };\r\n * \r\n * const personForm: FormGroup = this.formBuilder.group({\r\n * name: ['Jane Doe'],\r\n * age: [25],\r\n * email: ['jane.doe@example.com']\r\n * });\r\n * \r\n * const updatedPerson = this.mapFormToModel(person, personForm);\r\n * // `updatedPerson` agora contém:\r\n * // {\r\n * // name: 'Jane Doe',\r\n * // age: 25,\r\n * // email: 'jane.doe@example.com'\r\n * // }\r\n */\r\n static mapFormToModel(record: object, formGroup: FormGroup): object | null {\r\n if ((record === null || record === undefined) || (formGroup === null || formGroup === undefined)) { return null; }\r\n \r\n return {\r\n ...record,\r\n ...formGroup.value\r\n };\r\n }\r\n\r\n}\r\n","import { AbstractControl, FormControl } from '@angular/forms';\r\nimport { Component, Input, OnInit, ElementRef, Renderer2 } from '@angular/core';\r\n\r\nimport { FormUtils } from '../../utils/form-utils';\r\n\r\n@Component({\r\n selector: 'app-field-error-message',\r\n templateUrl: './field-error-message.component.html',\r\n styleUrls: ['./field-error-message.component.css']\r\n})\r\nexport class FieldErrorMessageComponent implements OnInit {\r\n @Input('customMessage') public customErrorMessage: string;\r\n @Input() control: AbstractControl | null;\r\n @Input() label: string;\r\n\r\n\r\n constructor(\r\n private _renderer: Renderer2,\r\n private _elementRef: ElementRef\r\n ) { }\r\n\r\n\r\n public get errorMessage() {\r\n for (let propertyName in this.control?.errors) {\r\n if (this.control?.errors.hasOwnProperty(propertyName) &&\r\n (this.control?.dirty || this.control?.touched)) {\r\n return FormUtils.getErrorMessage(this.label, propertyName, this.control?.errors[propertyName], this.customErrorMessage);\r\n }\r\n }\r\n\r\n return null;\r\n }\r\n \r\n\r\n ngOnInit(): void {\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'width', '100%');\r\n }\r\n\r\n}\r\n","@if (customErrorMessage && customErrorMessage != \"\") {\r\n
    {{ customErrorMessage }}
    \r\n} @else {\r\n
    {{ errorMessage }}
    \r\n}","import { Component, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'app-loading-button',\r\n templateUrl: './loading-button.component.html',\r\n styleUrls: ['./loading-button.component.css']\r\n})\r\nexport class LoadingButtonComponent {\r\n @Input() isLoading: boolean;\r\n\r\n constructor() { }\r\n\r\n}\r\n","","import { Component } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'app-loading',\r\n templateUrl: './loading.component.html',\r\n styleUrls: ['./loading.component.css']\r\n})\r\nexport class LoadingComponent {\r\n\r\n constructor() { }\r\n\r\n}\r\n","\r\n
    \r\n \"Carregando\"\r\n
    \r\n","import { TreeItem } from '../models/tree-item';\r\nimport { Pipe, PipeTransform } from '@angular/core';\r\n\r\n@Pipe({\r\n name: 'TreeFilter',\r\n pure: true,\r\n})\r\n\r\nexport class SearchTreePipe implements PipeTransform {\r\n\r\n public transform(items: TreeItem[], search: string): TreeItem[] {\r\n return items.filter(node => node.label.toLocaleLowerCase().includes(search.toLocaleLowerCase()));\r\n }\r\n\r\n}\r\n","import { Component, EventEmitter, Input, OnInit, Output } from \"@angular/core\";\r\nimport { TreeItem } from \"./models/tree-item\";\r\n\r\n@Component({\r\n selector: \"app-tree\",\r\n templateUrl: \"./tree.component.html\",\r\n styleUrls: [\"./tree.component.scss\"]\r\n})\r\nexport class TreeComponent implements OnInit {\r\n constructor() {}\r\n\r\n ngOnInit(): void {}\r\n\r\n // #region ==========> PROPERTIES <==========\r\n\r\n // #region PUBLIC\r\n @Input() public items: TreeItem[] | any = [];\r\n @Input() public checkbox: boolean = false;\r\n @Input() public filter: boolean = false;\r\n\r\n @Output() public onSelect: EventEmitter = new EventEmitter();\r\n @Output() public onEvent: EventEmitter = new EventEmitter();\r\n\r\n public checked = (item: TreeItem) => item.is_selected == true;\r\n\r\n public search: string = \"\";\r\n // #endregion PUBLIC\r\n\r\n // #endregion ==========> PROPERTIES <==========\r\n\r\n // #region ==========> PUBLIC METHODS <==========\r\n public onExpand(item: TreeItem): void {\r\n if (item.expanded) {\r\n item.expanded = !item.expanded;\r\n return;\r\n } else {\r\n if (item.children) {\r\n if (item.children.length > 0) {\r\n item.expanded = true;\r\n } else {\r\n item.expanded = false;\r\n }\r\n }\r\n }\r\n }\r\n\r\n public onCheck(items: TreeItem[], item: TreeItem): void {\r\n if (item.has_children) {\r\n item.children.forEach((firstNode) => {\r\n if (firstNode.is_selected != item.is_selected) {\r\n firstNode.is_selected = !firstNode.is_selected;\r\n }\r\n if (firstNode.has_children) {\r\n firstNode.children.forEach((secondNode) => {\r\n if (secondNode.is_selected != firstNode.is_selected) {\r\n secondNode.is_selected = !secondNode.is_selected;\r\n }\r\n });\r\n }\r\n });\r\n }\r\n if (this.indeterminateCheck(items)) {\r\n this.onSelect.emit(true);\r\n } else if (!this.indeterminateCheck(items)) {\r\n this.onSelect.emit(false);\r\n }\r\n }\r\n\r\n public onCheckEvent(items: TreeItem[]) {\r\n if (this.indeterminateCheck(items)) {\r\n this.onEvent.emit(true);\r\n } else {\r\n this.onEvent.emit(false);\r\n }\r\n }\r\n // #endregion ==========> PUBLIC METHODS <==========\r\n\r\n // #region ==========> PRIVATE METHODS <==========\r\n\r\n private indeterminateCheck(list: TreeItem[]): boolean {\r\n return list.some(this.checked);\r\n }\r\n\r\n // private allCheck(list: TreeItem[]): boolean {\r\n // return list.every(this.checked);\r\n // }\r\n // #endregion ==========> PRIVATE METHODS <==========\r\n}\r\n","\r\n\r\n \r\n\r\n
    \r\n \r\n \r\n \r\n \r\n
    \r\n \r\n
    \r\n\r\n
      \r\n \r\n
      \r\n \r\n \r\n \r\n \r\n \r\n \r\n
      \r\n \r\n
        \r\n \r\n
      \r\n
      \r\n
    ","import { Pipe, PipeTransform } from '@angular/core';\r\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\r\n\r\n/**\r\n * @description\r\n * Transforma um Blob ou MediaSource em uma URL para ser utilizada em imagens.\r\n * \r\n * Ela aceita valors não definidos em casos onde o valor vai ser trazido em outro momento.\r\n */\r\n@Pipe(\r\n { name: 'toUrl' }\r\n)\r\nexport class ToUrlPipe implements PipeTransform {\r\n\r\n constructor(\r\n private sanitizer: DomSanitizer\r\n ) {}\r\n\r\n transform(value: Blob | MediaSource | undefined, ...args: unknown[]): SafeUrl {\r\n\r\n if (value) {\r\n let url: string = URL.createObjectURL(value);\r\n // Devemos dizer que a URL passada é segura e pode ser usada.\r\n // Se não limpada a url vai estar da seguinte forma: [unsafe][blob] ao invés de [blob]\r\n let safeUrl: SafeUrl = this.sanitizer.bypassSecurityTrustUrl(url);\r\n return safeUrl;\r\n }\r\n\r\n // Se não estiver definida, retorna nada.\r\n return \"\";\r\n }\r\n\r\n}\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\n\r\n@Pipe({\r\n name: 'cpfCnpj'\r\n})\r\nexport class CpfCnpjPipe implements PipeTransform {\r\n\r\n public transform(value: string): string {\r\n\r\n switch (value.length) {\r\n case 11: return `${value.substring(0, 3)}.${value.substring(3, 6)}.${value.substring(6, 9)}-${value.substring(9)}`;\r\n\r\n case 14: return `${value.substring(0, 2)}.${value.substring(2, 5)}.${value.substring(5, 8)}/${value.substring(8, 12)}-${value.substring(12)}`;\r\n\r\n default: return value;\r\n }\r\n }\r\n}\r\n","import {\r\n\tDirective,\r\n\tElementRef,\r\n\tEventEmitter,\r\n\tInject,\r\n\tInput,\r\n\tNgZone,\r\n\tOnChanges,\r\n\tOnDestroy,\r\n\tOnInit,\r\n\tOutput,\r\n\tSimpleChanges,\r\n } from '@angular/core';\r\n import {DOCUMENT} from '@angular/common';\r\n \r\n @Directive({selector: '[clickOutside]'})\r\n export class ClickOutsideDirective implements OnInit, OnChanges, OnDestroy {\r\n \r\n\t@Input() clickOutsideEnabled = true;\r\n \r\n\t@Input() attachOutsideOnClick = false;\r\n\t@Input() delayClickOutsideInit = false;\r\n\t@Input() emitOnBlur = false;\r\n \r\n\t@Input() exclude = '';\r\n\t@Input() excludeBeforeClick = false;\r\n \r\n\t@Input() clickOutsideEvents = '';\r\n \r\n\t@Output() clickOutside: EventEmitter = new EventEmitter();\r\n \r\n\tprivate _nodesExcluded: Array = [];\r\n\tprivate _events: Array = ['click'];\r\n \r\n\tconstructor(\r\n\t private _el: ElementRef,\r\n\t private _ngZone: NgZone,\r\n\t @Inject(DOCUMENT) private document: Document) {\r\n\t this._initOnClickBody = this._initOnClickBody.bind(this);\r\n\t this._onClickBody = this._onClickBody.bind(this);\r\n\t this._onWindowBlur = this._onWindowBlur.bind(this);\r\n\t}\r\n \r\n\tngOnInit() {\r\n\t this._init();\r\n\t}\r\n \r\n\tngOnDestroy() {\r\n\t this._removeClickOutsideListener();\r\n\t this._removeAttachOutsideOnClickListener();\r\n\t this._removeWindowBlurListener();\r\n\t}\r\n \r\n\tngOnChanges(changes: SimpleChanges) {\r\n\t if (changes['attachOutsideOnClick'] || changes['exclude'] || changes['emitOnBlur']) {\r\n\t this._init();\r\n\t }\r\n\t}\r\n \r\n\tprivate _init() {\r\n\t if (this.clickOutsideEvents !== '') {\r\n\t this._events = this.clickOutsideEvents.split(',').map(e => e.trim());\r\n\t }\r\n \r\n\t this._excludeCheck();\r\n \r\n\t if (this.attachOutsideOnClick) {\r\n\t this._initAttachOutsideOnClickListener();\r\n\t } else {\r\n\t this._initOnClickBody();\r\n\t }\r\n \r\n\t if (this.emitOnBlur) {\r\n\t this._initWindowBlurListener();\r\n\t }\r\n\t}\r\n \r\n\tprivate _initOnClickBody() {\r\n\t if (this.delayClickOutsideInit) {\r\n\t setTimeout(this._initClickOutsideListener.bind(this));\r\n\t } else {\r\n\t this._initClickOutsideListener();\r\n\t }\r\n\t}\r\n \r\n\tprivate _excludeCheck() {\r\n\t if (this.exclude) {\r\n\t try {\r\n\t\tconst nodes = Array.from(this.document.querySelectorAll(this.exclude)) as Array;\r\n\t\tif (nodes) {\r\n\t\t this._nodesExcluded = nodes;\r\n\t\t}\r\n\t } catch (err) {\r\n\t\tconsole.error('[ng-click-outside] Check your exclude selector syntax.', err);\r\n\t }\r\n\t }\r\n\t}\r\n \r\n\tprivate _onClickBody(ev: Event) {\r\n\t if (!this.clickOutsideEnabled) {\r\n\t return;\r\n\t }\r\n \r\n\t if (this.excludeBeforeClick) {\r\n\t this._excludeCheck();\r\n\t }\r\n \r\n\t if (!this._el.nativeElement.contains(ev.target) && !this._shouldExclude(ev.target)) {\r\n\t this._emit(ev);\r\n \r\n\t if (this.attachOutsideOnClick) {\r\n\t\tthis._removeClickOutsideListener();\r\n\t }\r\n\t }\r\n\t}\r\n \r\n\t/**\r\n\t * Resolves problem with outside click on iframe\r\n\t * @see https://github.com/arkon/ng-click-outside/issues/32\r\n\t */\r\n\tprivate _onWindowBlur(ev: Event) {\r\n\t setTimeout(() => {\r\n\t if (!this.document.hidden) {\r\n\t\tthis._emit(ev);\r\n\t }\r\n\t });\r\n\t}\r\n \r\n\tprivate _emit(ev: Event) {\r\n\t if (!this.clickOutsideEnabled) {\r\n\t return;\r\n\t }\r\n \r\n\t this._ngZone.run(() => this.clickOutside.emit(ev));\r\n\t}\r\n \r\n\tprivate _shouldExclude(target: any): boolean {\r\n\t for (let excludedNode of this._nodesExcluded) {\r\n\t if (excludedNode.contains(target)) {\r\n\t\treturn true;\r\n\t }\r\n\t }\r\n \r\n\t return false;\r\n\t}\r\n \r\n\tprivate _initClickOutsideListener() {\r\n\t this._ngZone.runOutsideAngular(() => {\r\n\t this._events.forEach(e => this.document.addEventListener(e, this._onClickBody));\r\n\t });\r\n\t}\r\n \r\n\tprivate _removeClickOutsideListener() {\r\n\t this._ngZone.runOutsideAngular(() => {\r\n\t this._events.forEach(e => this.document.removeEventListener(e, this._onClickBody));\r\n\t });\r\n\t}\r\n \r\n\tprivate _initAttachOutsideOnClickListener() {\r\n\t this._ngZone.runOutsideAngular(() => {\r\n\t this._events.forEach(e => this._el.nativeElement.addEventListener(e, this._initOnClickBody));\r\n\t });\r\n\t}\r\n \r\n\tprivate _removeAttachOutsideOnClickListener() {\r\n\t this._ngZone.runOutsideAngular(() => {\r\n\t this._events.forEach(e => this._el.nativeElement.removeEventListener(e, this._initOnClickBody));\r\n\t });\r\n\t}\r\n \r\n\tprivate _initWindowBlurListener() {\r\n\t this._ngZone.runOutsideAngular(() => {\r\n\t window.addEventListener('blur', this._onWindowBlur);\r\n\t });\r\n\t}\r\n \r\n\tprivate _removeWindowBlurListener() {\r\n\t this._ngZone.runOutsideAngular(() => {\r\n\t window.removeEventListener('blur', this._onWindowBlur);\r\n\t });\r\n\t}\r\n \r\n }","import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'app-ordering',\r\n templateUrl: './ordering.component.html',\r\n styleUrls: ['./ordering.component.scss']\r\n})\r\nexport class OrderingComponent implements OnInit {\r\n\r\n @Input() isColumnClicked: boolean = false;\r\n // Direção atual da ordenação ('asc', 'desc' ou vazio)\r\n @Input() sortDirection: string = '';\r\n\r\n // Atributos de ordenação\r\n @Input() sortAttributes: string | string[] = [];\r\n\r\n // Evento emitido quando a direção de ordenação é alterada\r\n @Output() sortDirectionChange = new EventEmitter();\r\n\r\n // Evento emitido quando ocorre uma mudança na ordenação\r\n @Output() sortChange = new EventEmitter<{ direction: string, column: string | string[] }>();\r\n\r\n // Função chamada quando o botão de ordenação é clicado\r\n sort() {\r\n // Inverte a direção de ordenação atual\r\n if (this.sortDirection === 'asc') {\r\n this.sortDirection = 'desc';\r\n } else {\r\n this.sortDirection = 'asc';\r\n }\r\n\r\n // Emite o evento com a nova direção de ordenação\r\n this.sortDirectionChange.emit(this.sortDirection);\r\n\r\n // Emite o evento de mudança na ordenação com a direção e os atributos de ordenação\r\n this.sortChange.emit({ direction: this.sortDirection, column: this.sortAttributes });\r\n }\r\n\r\n // Obtém a cor do ícone com base na direção de ordenação atual\r\n getSvgColor(): string {\r\n return this.sortDirection === 'asc' ? 'blue' : 'lightgray';\r\n }\r\n\r\n constructor() {}\r\n\r\n ngOnInit(): void {\r\n // Define a direção de ordenação inicial como vazio\r\n this.sortDirection = '';\r\n }\r\n}\r\n","\r\n \r\n \r\n\r\n\r\n\r\n \r\n \r\n\r\n","import { Directive, ElementRef, Input, OnChanges, OnInit, Renderer2, SimpleChanges } from \"@angular/core\";\r\n\r\n/**\r\n * Diretiva que adiciona um asterisco vermelho (*) ao lado de um elemento