@po-ui/ng-components 5.10.0 → 5.13.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/po-ui-ng-components.umd.js +326 -137
- package/bundles/po-ui-ng-components.umd.js.map +1 -1
- package/esm2015/lib/components/po-calendar/po-calendar-base.component.js +14 -3
- package/esm2015/lib/components/po-calendar/po-calendar-wrapper/po-calendar-wrapper.component.js +18 -7
- package/esm2015/lib/components/po-calendar/po-calendar.component.js +10 -2
- package/esm2015/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.js +3 -2
- package/esm2015/lib/components/po-field/po-multiselect/po-multiselect-base.component.js +88 -10
- package/esm2015/lib/components/po-field/po-multiselect/po-multiselect-filter.service.js +50 -0
- package/esm2015/lib/components/po-field/po-multiselect/po-multiselect.component.js +17 -5
- package/esm2015/lib/components/po-page/po-page-action.interface.js +1 -1
- package/esm2015/lib/components/po-table/interfaces/po-table-column.interface.js +1 -1
- package/esm2015/lib/components/po-table/po-table-base.component.js +2 -2
- package/esm2015/lib/components/po-table/po-table.component.js +2 -2
- package/esm2015/lib/interceptors/po-http-interceptor/po-http-interceptor-base.service.js +2 -1
- package/esm2015/lib/interceptors/po-http-interceptor/po-http-interceptor-detail/po-http-interceptor-detail.component.js +16 -6
- package/esm2015/lib/interceptors/po-http-interceptor/po-http-interceptor-detail/po-http-interceptor-detail.interface.js +1 -1
- package/esm2015/lib/interceptors/po-http-request/po-http-request-interceptor.service.js +3 -11
- package/esm2015/lib/services/po-date/po-date.service.js +1 -1
- package/esm2015/po-ui-ng-components.js +104 -103
- package/fesm2015/po-ui-ng-components.js +207 -36
- package/fesm2015/po-ui-ng-components.js.map +1 -1
- package/lib/components/po-calendar/po-calendar-base.component.d.ts +1 -0
- package/lib/components/po-calendar/po-calendar-wrapper/po-calendar-wrapper.component.d.ts +5 -3
- package/lib/components/po-calendar/po-calendar.component.d.ts +5 -2
- package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +57 -4
- package/lib/components/po-field/po-multiselect/po-multiselect-filter.service.d.ts +18 -0
- package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +6 -3
- package/lib/components/po-page/po-page-action.interface.d.ts +2 -0
- package/lib/components/po-table/interfaces/po-table-column.interface.d.ts +11 -0
- package/lib/interceptors/po-http-interceptor/po-http-interceptor-base.service.d.ts +1 -0
- package/lib/interceptors/po-http-interceptor/po-http-interceptor-detail/po-http-interceptor-detail.interface.d.ts +2 -0
- package/lib/interceptors/po-http-request/po-http-request-interceptor.service.d.ts +2 -2
- package/lib/services/po-date/po-date.service.d.ts +1 -1
- package/package.json +4 -4
- package/po-ui-ng-components-5.13.1.tgz +0 -0
- package/po-ui-ng-components.d.ts +103 -102
- package/po-ui-ng-components.metadata.json +1 -1
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/po-ui-ng-components-5.10.0.tgz +0 -0
|
@@ -2,13 +2,15 @@ import { __decorate } from "tslib";
|
|
|
2
2
|
import { EventEmitter, Input, Output, Directive } from '@angular/core';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
4
|
import { debounceTime, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';
|
|
5
|
-
import { convertToBoolean, removeDuplicatedOptions, removeUndefinedAndNullOptions, sortOptionsByProperty } from '../../../utils/util';
|
|
5
|
+
import { convertToBoolean, isTypeof, removeDuplicatedOptions, removeUndefinedAndNullOptions, sortOptionsByProperty } from '../../../utils/util';
|
|
6
6
|
import { requiredFailed } from './../validators';
|
|
7
7
|
import { PoLanguageService } from '../../../services/po-language/po-language.service';
|
|
8
8
|
import { poLocaleDefault } from '../../../services/po-language/po-language.constant';
|
|
9
9
|
import { PoMultiselectFilterMode } from './po-multiselect-filter-mode.enum';
|
|
10
10
|
import { InputBoolean } from '../../../decorators';
|
|
11
11
|
const PO_MULTISELECT_DEBOUNCE_TIME_DEFAULT = 400;
|
|
12
|
+
const PO_MULTISELECT_FIELD_LABEL_DEFAULT = 'label';
|
|
13
|
+
const PO_MULTISELECT_FIELD_VALUE_DEFAULT = 'value';
|
|
12
14
|
export const poMultiselectLiteralsDefault = {
|
|
13
15
|
en: {
|
|
14
16
|
noData: 'No data found',
|
|
@@ -90,15 +92,36 @@ export class PoMultiselectBaseComponent {
|
|
|
90
92
|
this._required = false;
|
|
91
93
|
this._sort = false;
|
|
92
94
|
this._autoHeight = false;
|
|
95
|
+
this._fieldLabel = PO_MULTISELECT_FIELD_LABEL_DEFAULT;
|
|
96
|
+
this._fieldValue = PO_MULTISELECT_FIELD_VALUE_DEFAULT;
|
|
93
97
|
this.language = languageService.getShortLanguage();
|
|
94
98
|
}
|
|
95
99
|
/**
|
|
96
100
|
* @optional
|
|
97
101
|
*
|
|
98
102
|
* @description
|
|
99
|
-
* Nesta propriedade
|
|
103
|
+
* Nesta propriedade pode ser informada a URL do serviço em que será realizado o filtro para carregamento da lista de itens no componente.
|
|
104
|
+
*
|
|
105
|
+
*Também existe a possibilidade de informar um serviço implementando a interface `PoMultiselectFilter`.
|
|
106
|
+
*
|
|
107
|
+
*Caso utilizado uma URL, o serviço deve ser retornado no padrão [API PO UI](https://po-ui.io/guides/api) e utilizar as propriedades `p-field-label` e `p-field-value` para a construção da lista de itens.
|
|
108
|
+
*
|
|
109
|
+
*Quando utilizada uma URL de serviço, então será concatenada nesta URL o valor que deseja-se filtrar da seguinte forma:
|
|
110
|
+
*
|
|
111
|
+
*```
|
|
112
|
+
* // caso filtrar por "Peter"
|
|
113
|
+
* https://localhost:8080/api/heroes?filter=Peter
|
|
114
|
+
*```
|
|
115
|
+
*
|
|
116
|
+
*E caso iniciar o campo com valor, os itens serão buscados da seguinte forma:
|
|
117
|
+
*
|
|
118
|
+
*```
|
|
119
|
+
* // caso o valor do campo for [1234, 5678];
|
|
120
|
+
* https://localhost:8080/api/heroes?value=1234,5678
|
|
121
|
+
*
|
|
122
|
+
* //O *value* é referente ao `fieldValue`.
|
|
123
|
+
*```
|
|
100
124
|
*
|
|
101
|
-
* > Definirá por padrão a propriedade `p-auto-height` como `true`, mas a mesma pode ser redefinida caso necessário.
|
|
102
125
|
*/
|
|
103
126
|
set filterService(value) {
|
|
104
127
|
this._filterService = value;
|
|
@@ -306,14 +329,67 @@ export class PoMultiselectBaseComponent {
|
|
|
306
329
|
get filterMode() {
|
|
307
330
|
return this._filterMode;
|
|
308
331
|
}
|
|
332
|
+
/**
|
|
333
|
+
* @optional
|
|
334
|
+
*
|
|
335
|
+
* @description
|
|
336
|
+
* Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente
|
|
337
|
+
* (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.
|
|
338
|
+
*
|
|
339
|
+
* Necessário quando informar o serviço como URL e o mesmo não estiver retornando uma lista de objetos no padrão da interface
|
|
340
|
+
* `PoMultiSelectOption`.
|
|
341
|
+
*
|
|
342
|
+
* @default `label`
|
|
343
|
+
*/
|
|
344
|
+
set fieldLabel(value) {
|
|
345
|
+
this._fieldLabel = value || PO_MULTISELECT_FIELD_LABEL_DEFAULT;
|
|
346
|
+
if (isTypeof(this.filterService, 'string') && this.service) {
|
|
347
|
+
this.service.fieldLabel = this._fieldLabel;
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
get fieldLabel() {
|
|
351
|
+
return this._fieldLabel;
|
|
352
|
+
}
|
|
353
|
+
/**
|
|
354
|
+
* @optional
|
|
355
|
+
*
|
|
356
|
+
* @description
|
|
357
|
+
* Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente
|
|
358
|
+
* (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.
|
|
359
|
+
*
|
|
360
|
+
* Necessário quando informar o serviço como URL e o mesmo não estiver retornando uma lista de objetos no padrão da interface
|
|
361
|
+
* `PoMultiSelectOption`.
|
|
362
|
+
*
|
|
363
|
+
* @default `value`
|
|
364
|
+
*/
|
|
365
|
+
set fieldValue(value) {
|
|
366
|
+
this._fieldValue = value || PO_MULTISELECT_FIELD_VALUE_DEFAULT;
|
|
367
|
+
if (isTypeof(this.filterService, 'string') && this.service) {
|
|
368
|
+
this.service.fieldValue = this._fieldValue;
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
get fieldValue() {
|
|
372
|
+
return this._fieldValue;
|
|
373
|
+
}
|
|
309
374
|
ngOnInit() {
|
|
310
375
|
if (this.filterService) {
|
|
311
|
-
this.
|
|
312
|
-
.pipe(debounceTime(this.debounceTime), distinctUntilChanged(), tap(() => (this.isServerSearching = true)), switchMap((search) => this.applyFilter(search)), tap(() => (this.isServerSearching = false)))
|
|
313
|
-
.subscribe();
|
|
376
|
+
this.setService(this.filterService);
|
|
314
377
|
}
|
|
378
|
+
this.filterSubject
|
|
379
|
+
.pipe(debounceTime(this.debounceTime), distinctUntilChanged(), tap(() => (this.isServerSearching = true)), switchMap((search) => this.applyFilter(search)), tap(() => (this.isServerSearching = false)))
|
|
380
|
+
.subscribe();
|
|
315
381
|
this.updateList(this.options);
|
|
316
382
|
}
|
|
383
|
+
setService(service) {
|
|
384
|
+
if (isTypeof(service, 'object')) {
|
|
385
|
+
this.service = service;
|
|
386
|
+
}
|
|
387
|
+
else {
|
|
388
|
+
this.service = this.defaultService;
|
|
389
|
+
this.service.configProperties(service, this.fieldLabel, this.fieldValue);
|
|
390
|
+
}
|
|
391
|
+
this.isFirstFilter = true;
|
|
392
|
+
}
|
|
317
393
|
validAndSortOptions() {
|
|
318
394
|
if (this.options && this.options.length) {
|
|
319
395
|
removeUndefinedAndNullOptions(this.options);
|
|
@@ -413,8 +489,8 @@ export class PoMultiselectBaseComponent {
|
|
|
413
489
|
}
|
|
414
490
|
writeValue(values) {
|
|
415
491
|
values = values || [];
|
|
416
|
-
if (this.
|
|
417
|
-
this.getObjectsByValuesSubscription = this.
|
|
492
|
+
if (this.service && values.length) {
|
|
493
|
+
this.getObjectsByValuesSubscription = this.service.getObjectsByValues(values).subscribe(options => {
|
|
418
494
|
this.updateSelectedOptions(options);
|
|
419
495
|
this.callOnChange(this.selectedOptions);
|
|
420
496
|
});
|
|
@@ -471,7 +547,9 @@ PoMultiselectBaseComponent.propDecorators = {
|
|
|
471
547
|
hideSearch: [{ type: Input, args: ['p-hide-search',] }],
|
|
472
548
|
options: [{ type: Input, args: ['p-options',] }],
|
|
473
549
|
sort: [{ type: Input, args: ['p-sort',] }],
|
|
474
|
-
filterMode: [{ type: Input, args: ['p-filter-mode',] }]
|
|
550
|
+
filterMode: [{ type: Input, args: ['p-filter-mode',] }],
|
|
551
|
+
fieldLabel: [{ type: Input, args: ['p-field-label',] }],
|
|
552
|
+
fieldValue: [{ type: Input, args: ['p-field-value',] }]
|
|
475
553
|
};
|
|
476
554
|
__decorate([
|
|
477
555
|
InputBoolean()
|
|
@@ -479,4 +557,4 @@ __decorate([
|
|
|
479
557
|
__decorate([
|
|
480
558
|
InputBoolean()
|
|
481
559
|
], PoMultiselectBaseComponent.prototype, "autoHeight", null);
|
|
482
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-multiselect-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Input, OnInit, Output, Directive } from '@angular/core';\nimport { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\n\nimport { Observable, Subject, Subscription } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';\n\nimport {\n  convertToBoolean,\n  removeDuplicatedOptions,\n  removeUndefinedAndNullOptions,\n  sortOptionsByProperty\n} from '../../../utils/util';\nimport { requiredFailed } from './../validators';\nimport { PoLanguageService } from '../../../services/po-language/po-language.service';\nimport { poLocaleDefault } from '../../../services/po-language/po-language.constant';\n\nimport { PoMultiselectFilterMode } from './po-multiselect-filter-mode.enum';\nimport { PoMultiselectLiterals } from './po-multiselect-literals.interface';\nimport { PoMultiselectOption } from './po-multiselect-option.interface';\nimport { InputBoolean } from '../../../decorators';\nimport { PoMultiselectFilter } from './po-multiselect-filter.interface';\n\nconst PO_MULTISELECT_DEBOUNCE_TIME_DEFAULT = 400;\n\nexport const poMultiselectLiteralsDefault = {\n  en: <PoMultiselectLiterals>{\n    noData: 'No data found',\n    placeholderSearch: 'Search'\n  },\n  es: <PoMultiselectLiterals>{\n    noData: 'Datos no encontrados',\n    placeholderSearch: 'Busca'\n  },\n  pt: <PoMultiselectLiterals>{\n    noData: 'Nenhum dado encontrado',\n    placeholderSearch: 'Buscar'\n  },\n  ru: <PoMultiselectLiterals>{\n    noData: 'Данные не найдены',\n    placeholderSearch: 'искать'\n  }\n};\n\n/**\n * @description\n *\n * O po-multiselect é um componente de múltipla seleção.\n * Este componente é recomendado para dar ao usuário a opção de selecionar vários itens em uma lista.\n *\n * Quando a lista possuir poucos itens, deve-se dar preferência para o uso do po-checkbox-group, por ser mais simples\n * e mais rápido para a seleção do usuário.\n *\n * Este componente também não deve ser utilizado em casos onde a seleção seja única. Nesses casos, deve-se utilizar o\n * po-select, po-combo ou po-radio-group.\n *\n * Com ele também é possível definir uma lista à partir da requisição de um serviço definido em `p-filter-service`.\n */\n@Directive()\nexport abstract class PoMultiselectBaseComponent implements ControlValueAccessor, OnInit, Validator {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Aplica foco no elemento ao ser iniciado.\n   *\n   * > Caso mais de um elemento seja configurado com essa propriedade, apenas o último elemento declarado com ela terá o foco.\n   *\n   * @default `false`\n   */\n  @Input('p-auto-focus') @InputBoolean() autoFocus: boolean = false;\n\n  /** Label no componente. */\n  @Input('p-label') label?: string;\n\n  /** Texto de apoio para o campo. */\n  @Input('p-help') help?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se a indicação de campo opcional será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - O campo conter `p-required`;\n   * - Não possuir `p-help` e/ou `p-label`.\n   *\n   * @default `false`\n   */\n  @Input('p-optional') optional: boolean;\n\n  /** Mensagem apresentada enquanto o campo estiver vazio. */\n  @Input('p-placeholder') placeholder?: string = '';\n\n  /**\n   * @description\n   *\n   * Placeholder do campo de pesquisa.\n   *\n   * > Caso o mesmo não seja informado, o valor padrão será traduzido com base no idioma do navegador (pt, es e en).\n   *\n   * @default `Buscar`\n   */\n  @Input('p-placeholder-search') placeholderSearch?: string = '';\n\n  /** Nome do componente. */\n  @Input('name') name: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Pode ser informada uma função que será disparada quando houver alterações no ngModel.\n   */\n  @Output('p-change') change: EventEmitter<any> = new EventEmitter<any>();\n\n  selectedOptions: Array<PoMultiselectOption> = [];\n  visibleOptionsDropdown: Array<PoMultiselectOption> = [];\n  visibleDisclaimers = [];\n  isServerSearching = false;\n  isFirstFilter: boolean = true;\n  filterSubject = new Subject();\n\n  // eslint-disable-next-line\n  protected onModelTouched: any = null;\n\n  protected clickOutListener: () => void;\n  protected resizeListener: () => void;\n  protected getObjectsByValuesSubscription: Subscription;\n\n  private _filterService?: PoMultiselectFilter;\n  private _debounceTime?: number = 400;\n  private _disabled?: boolean = false;\n  private _filterMode?: PoMultiselectFilterMode = PoMultiselectFilterMode.startsWith;\n  private _hideSearch?: boolean = false;\n  private _literals: PoMultiselectLiterals;\n  private _options: Array<PoMultiselectOption>;\n  private _required?: boolean = false;\n  private _sort?: boolean = false;\n  private _autoHeight: boolean = false;\n  private language: string;\n\n  private lastLengthModel;\n  private onModelChange: any;\n  private validatorChange: any;\n  private autoHeightInitialValue: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   * Nesta propriedade deve ser informado um serviço implementando a interface PoMultiselectFilter.\n   *\n   * > Definirá por padrão a propriedade `p-auto-height` como `true`, mas a mesma pode ser redefinida caso necessário.\n   */\n  @Input('p-filter-service') set filterService(value: PoMultiselectFilter) {\n    this._filterService = value;\n    this.autoHeight = this.autoHeightInitialValue !== undefined ? this.autoHeightInitialValue : true;\n    this.options = [];\n  }\n\n  get filterService() {\n    return this._filterService;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define que a altura do componente será auto ajustável, possuindo uma altura minima porém a altura máxima será de acordo\n   * com o número de itens selecionados e a extensão dos mesmos, mantendo-os sempre visíveis.\n   *\n   * > O valor padrão será `true` quando houver serviço (`p-filter-service`).\n   *\n   * @default `false`\n   */\n  @Input('p-auto-height') @InputBoolean() set autoHeight(value: boolean) {\n    this._autoHeight = value;\n    this.autoHeightInitialValue = value;\n  }\n\n  get autoHeight(): boolean {\n    return this._autoHeight;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Esta propriedade define em quanto tempo (em milissegundos), aguarda para acionar o evento de filtro após cada pressionamento de tecla.\n   *\n   * > Será utilizada apenas quando houver serviço (`p-filter-service`) e somente será aceito valor maior do que *zero*.\n   *\n   * @default `400`\n   */\n  @Input('p-debounce-time') set debounceTime(value: number) {\n    const parsedValue = parseInt(<any>value, 10);\n\n    this._debounceTime = !isNaN(parsedValue) && parsedValue > 0 ? parsedValue : PO_MULTISELECT_DEBOUNCE_TIME_DEFAULT;\n  }\n\n  get debounceTime(): number {\n    return this._debounceTime;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Objeto com as literais usadas no `po-multiselect`.\n   *\n   * Existem duas maneiras de customizar o componente, passando um objeto com todas as literais disponíveis:\n   *\n   * ```\n   *  const customLiterals: PoMultiselectLiterals = {\n   *    noData: 'Nenhum dado encontrado',\n   *    placeholderSearch: 'Buscar'\n   *  };\n   * ```\n   *\n   * Ou passando apenas as literais que deseja customizar:\n   *\n   * ```\n   *  const customLiterals: PoMultiselectLiterals = {\n   *    noData: 'Sem dados'\n   *  };\n   * ```\n   *\n   * E para carregar as literais customizadas, basta apenas passar o objeto para o componente:\n   *\n   * ```\n   * <po-multiselect\n   *   [p-literals]=\"customLiterals\">\n   * </po-po-multiselect>\n   * ```\n   *\n   * > O objeto padrão de literais será traduzido de acordo com o idioma do\n   * [`PoI18nService`](/documentation/po-i18n) ou do browser.\n   */\n  @Input('p-literals') set literals(value: PoMultiselectLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poMultiselectLiteralsDefault[poLocaleDefault],\n        ...poMultiselectLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poMultiselectLiteralsDefault[this.language];\n    }\n  }\n  get literals() {\n    return this._literals || poMultiselectLiteralsDefault[this.language];\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será obrigatório. Esta propriedade é desconsiderada quando o campo está desabilitado (p-disabled).\n   *\n   * @default `false`\n   */\n  @Input('p-required') set required(required: boolean) {\n    this._required = <any>required === '' ? true : convertToBoolean(required);\n    this.validateModel();\n  }\n\n  get required() {\n    return this._required;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será desabilitado.\n   *\n   * @default `false`\n   */\n  @Input('p-disabled') set disabled(disabled: boolean) {\n    this._disabled = <any>disabled === '' ? true : convertToBoolean(disabled);\n    this.validateModel();\n\n    this.updateVisibleItems();\n  }\n\n  get disabled() {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Esconde o campo de pesquisa existente dentro do dropdown do po-multiselect.\n   *\n   * @default `false`\n   */\n  @Input('p-hide-search') set hideSearch(hideSearch: boolean) {\n    this._hideSearch = <any>hideSearch === '' ? true : convertToBoolean(hideSearch);\n  }\n\n  get hideSearch() {\n    return this._hideSearch;\n  }\n\n  /**\n   * @description\n   *\n   * Nesta propriedade deve ser definida uma lista de objetos que implementam a interface PoMultiselectOption.\n   * Esta lista deve conter os valores e os labels que serão apresentados na tela.\n   *\n   * > Essa propriedade é imutável, ou seja, sempre que quiser atualizar a lista de opções disponíveis\n   * atualize a referência do objeto:\n   *\n   * ```\n   * // atualiza a referência do objeto garantindo a atualização do template\n   * this.options = [...this.options, { value: 'x', label: 'Nova opção' }];\n   *\n   * // evite, pois não atualiza a referência do objeto podendo gerar atrasos na atualização do template\n   * this.options.push({ value: 'x', label: 'Nova opção' });\n   * ```\n   */\n  @Input('p-options') set options(options: Array<PoMultiselectOption>) {\n    this._options = options;\n\n    this.validAndSortOptions();\n  }\n\n  get options() {\n    return this._options;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que a lista definida na propriedade p-options será ordenada pelo label antes de ser apresentada no\n   * dropdown.\n   *\n   * @default `false`\n   */\n  @Input('p-sort') set sort(sort: boolean) {\n    this._sort = <any>sort === '' ? true : convertToBoolean(sort);\n\n    this.validAndSortOptions();\n  }\n\n  get sort() {\n    return this._sort;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o modo de pesquisa utilizado no campo de busca, quando habilitado.\n   * Valores definidos no enum: PoMultiselectFilterMode\n   *\n   * @default `startsWith`\n   */\n  @Input('p-filter-mode') set filterMode(filterMode: PoMultiselectFilterMode) {\n    this._filterMode = filterMode in PoMultiselectFilterMode ? filterMode : PoMultiselectFilterMode.startsWith;\n    switch (this._filterMode.toString()) {\n      case 'startsWith':\n        this._filterMode = PoMultiselectFilterMode.startsWith;\n        break;\n      case 'contains':\n        this._filterMode = PoMultiselectFilterMode.contains;\n        break;\n      case 'endsWith':\n        this._filterMode = PoMultiselectFilterMode.endsWith;\n        break;\n    }\n  }\n\n  get filterMode() {\n    return this._filterMode;\n  }\n\n  constructor(languageService: PoLanguageService) {\n    this.language = languageService.getShortLanguage();\n  }\n\n  ngOnInit() {\n    if (this.filterService) {\n      this.filterSubject\n        .pipe(\n          debounceTime(this.debounceTime),\n          distinctUntilChanged(),\n          tap(() => (this.isServerSearching = true)),\n          switchMap((search: string) => this.applyFilter(search)),\n          tap(() => (this.isServerSearching = false))\n        )\n        .subscribe();\n    }\n\n    this.updateList(this.options);\n  }\n\n  validAndSortOptions() {\n    if (this.options && this.options.length) {\n      removeUndefinedAndNullOptions(this.options);\n      removeDuplicatedOptions(this.options);\n      this.setUndefinedLabels(this.options);\n\n      if (this.sort) {\n        sortOptionsByProperty(this.options, 'label');\n      }\n    }\n  }\n\n  setUndefinedLabels(options) {\n    options.forEach(option => {\n      if (!option['label']) {\n        option.label = option.value;\n      }\n    });\n  }\n\n  updateList(options: Array<PoMultiselectOption>) {\n    if (options) {\n      this.visibleOptionsDropdown = options;\n    }\n  }\n\n  callOnChange(selectedOptions: Array<PoMultiselectOption>) {\n    if (this.onModelChange) {\n      this.onModelChange(this.getValuesFromOptions(selectedOptions));\n      this.eventChange(selectedOptions);\n    }\n  }\n\n  eventChange(selectedOptions) {\n    if (selectedOptions && this.lastLengthModel !== selectedOptions.length) {\n      this.change.emit(selectedOptions);\n    }\n    this.lastLengthModel = selectedOptions ? selectedOptions.length : null;\n  }\n\n  getValuesFromOptions(selectedOptions: Array<PoMultiselectOption>) {\n    return selectedOptions && selectedOptions.length ? selectedOptions.map(option => option.value) : [];\n  }\n\n  getLabelByValue(value) {\n    const index = this.options.findIndex(option => option.value === value);\n    return this.options[index].label;\n  }\n\n  searchByLabel(search: string, options: Array<PoMultiselectOption>, filterMode: PoMultiselectFilterMode) {\n    if (search && options && options.length) {\n      const newOptions: Array<PoMultiselectOption> = [];\n      options.forEach(option => {\n        if (option.label && this.compareMethod(search, option, filterMode)) {\n          newOptions.push(option);\n        }\n      });\n      this.visibleOptionsDropdown = newOptions;\n    }\n  }\n\n  compareMethod(search: string, option: PoMultiselectOption, filterMode: PoMultiselectFilterMode) {\n    switch (filterMode) {\n      case PoMultiselectFilterMode.startsWith:\n        return this.startsWith(search, option);\n      case PoMultiselectFilterMode.contains:\n        return this.contains(search, option);\n      case PoMultiselectFilterMode.endsWith:\n        return this.endsWith(search, option);\n    }\n  }\n\n  startsWith(search: string, option: PoMultiselectOption) {\n    return option.label.toLowerCase().startsWith(search.toLowerCase());\n  }\n\n  contains(search: string, option: PoMultiselectOption) {\n    return option.label.toLowerCase().indexOf(search.toLowerCase()) > -1;\n  }\n\n  endsWith(search: string, option: PoMultiselectOption) {\n    return option.label.toLowerCase().endsWith(search.toLowerCase());\n  }\n\n  validate(c: AbstractControl): { [key: string]: any } {\n    if (requiredFailed(this.required, this.disabled, c.value)) {\n      return {\n        required: {\n          valid: false\n        }\n      };\n    }\n\n    return null;\n  }\n\n  updateSelectedOptions(newOptions: Array<any>, options = this.options) {\n    this.selectedOptions = [];\n\n    if (this.filterService) {\n      this.selectedOptions = newOptions;\n    } else {\n      newOptions.forEach(newOption => {\n        options.forEach(option => {\n          if (option.value === newOption.value) {\n            this.selectedOptions.push(option);\n          }\n        });\n      });\n    }\n\n    this.updateVisibleItems();\n  }\n\n  writeValue(values: any): void {\n    values = values || [];\n\n    if (this.filterService && values.length) {\n      this.getObjectsByValuesSubscription = this.filterService.getObjectsByValues(values).subscribe(options => {\n        this.updateSelectedOptions(options);\n        this.callOnChange(this.selectedOptions);\n      });\n    } else {\n      // Validar se todos os items existem entre os options, senão atualizar o model\n      this.updateSelectedOptions(values.map(value => ({ value })));\n\n      if (this.selectedOptions && this.selectedOptions.length < values.length) {\n        this.callOnChange(this.selectedOptions);\n      }\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  // Usada para interceptar os estados de habilitado via forms api\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onModelChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onModelTouched = fn;\n  }\n\n  registerOnValidatorChange(fn: () => void) {\n    this.validatorChange = fn;\n  }\n\n  private validateModel() {\n    if (this.validatorChange) {\n      this.validatorChange();\n    }\n  }\n\n  abstract applyFilter(value?: string): Observable<Array<PoMultiselectOption>>;\n  abstract updateVisibleItems(): void;\n}\n"]}
|
|
560
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-multiselect-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Input, OnInit, Output, Directive } from '@angular/core';\nimport { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\n\nimport { Observable, Subject, Subscription } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';\n\nimport {\n  convertToBoolean,\n  isTypeof,\n  removeDuplicatedOptions,\n  removeUndefinedAndNullOptions,\n  sortOptionsByProperty\n} from '../../../utils/util';\nimport { requiredFailed } from './../validators';\nimport { PoLanguageService } from '../../../services/po-language/po-language.service';\nimport { poLocaleDefault } from '../../../services/po-language/po-language.constant';\n\nimport { PoMultiselectFilterMode } from './po-multiselect-filter-mode.enum';\nimport { PoMultiselectLiterals } from './po-multiselect-literals.interface';\nimport { PoMultiselectOption } from './po-multiselect-option.interface';\nimport { InputBoolean } from '../../../decorators';\nimport { PoMultiselectFilter } from './po-multiselect-filter.interface';\nimport { PoMultiselectFilterService } from './po-multiselect-filter.service';\n\nconst PO_MULTISELECT_DEBOUNCE_TIME_DEFAULT = 400;\nconst PO_MULTISELECT_FIELD_LABEL_DEFAULT = 'label';\nconst PO_MULTISELECT_FIELD_VALUE_DEFAULT = 'value';\n\nexport const poMultiselectLiteralsDefault = {\n  en: <PoMultiselectLiterals>{\n    noData: 'No data found',\n    placeholderSearch: 'Search'\n  },\n  es: <PoMultiselectLiterals>{\n    noData: 'Datos no encontrados',\n    placeholderSearch: 'Busca'\n  },\n  pt: <PoMultiselectLiterals>{\n    noData: 'Nenhum dado encontrado',\n    placeholderSearch: 'Buscar'\n  },\n  ru: <PoMultiselectLiterals>{\n    noData: 'Данные не найдены',\n    placeholderSearch: 'искать'\n  }\n};\n\n/**\n * @description\n *\n * O po-multiselect é um componente de múltipla seleção.\n * Este componente é recomendado para dar ao usuário a opção de selecionar vários itens em uma lista.\n *\n * Quando a lista possuir poucos itens, deve-se dar preferência para o uso do po-checkbox-group, por ser mais simples\n * e mais rápido para a seleção do usuário.\n *\n * Este componente também não deve ser utilizado em casos onde a seleção seja única. Nesses casos, deve-se utilizar o\n * po-select, po-combo ou po-radio-group.\n *\n * Com ele também é possível definir uma lista à partir da requisição de um serviço definido em `p-filter-service`.\n */\n@Directive()\nexport abstract class PoMultiselectBaseComponent implements ControlValueAccessor, OnInit, Validator {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Aplica foco no elemento ao ser iniciado.\n   *\n   * > Caso mais de um elemento seja configurado com essa propriedade, apenas o último elemento declarado com ela terá o foco.\n   *\n   * @default `false`\n   */\n  @Input('p-auto-focus') @InputBoolean() autoFocus: boolean = false;\n\n  /** Label no componente. */\n  @Input('p-label') label?: string;\n\n  /** Texto de apoio para o campo. */\n  @Input('p-help') help?: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se a indicação de campo opcional será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - O campo conter `p-required`;\n   * - Não possuir `p-help` e/ou `p-label`.\n   *\n   * @default `false`\n   */\n  @Input('p-optional') optional: boolean;\n\n  /** Mensagem apresentada enquanto o campo estiver vazio. */\n  @Input('p-placeholder') placeholder?: string = '';\n\n  /**\n   * @description\n   *\n   * Placeholder do campo de pesquisa.\n   *\n   * > Caso o mesmo não seja informado, o valor padrão será traduzido com base no idioma do navegador (pt, es e en).\n   *\n   * @default `Buscar`\n   */\n  @Input('p-placeholder-search') placeholderSearch?: string = '';\n\n  /** Nome do componente. */\n  @Input('name') name: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Pode ser informada uma função que será disparada quando houver alterações no ngModel.\n   */\n  @Output('p-change') change: EventEmitter<any> = new EventEmitter<any>();\n\n  selectedOptions: Array<PoMultiselectOption> = [];\n  visibleOptionsDropdown: Array<PoMultiselectOption> = [];\n  visibleDisclaimers = [];\n  isServerSearching = false;\n  isFirstFilter: boolean = true;\n  filterSubject = new Subject();\n  service: PoMultiselectFilterService;\n  defaultService: PoMultiselectFilterService;\n\n  // eslint-disable-next-line\n  protected onModelTouched: any = null;\n\n  protected clickOutListener: () => void;\n  protected resizeListener: () => void;\n  protected getObjectsByValuesSubscription: Subscription;\n\n  private _filterService?: PoMultiselectFilter | string;\n  private _debounceTime?: number = 400;\n  private _disabled?: boolean = false;\n  private _filterMode?: PoMultiselectFilterMode = PoMultiselectFilterMode.startsWith;\n  private _hideSearch?: boolean = false;\n  private _literals: PoMultiselectLiterals;\n  private _options: Array<PoMultiselectOption>;\n  private _required?: boolean = false;\n  private _sort?: boolean = false;\n  private _autoHeight: boolean = false;\n  private _fieldLabel?: string = PO_MULTISELECT_FIELD_LABEL_DEFAULT;\n  private _fieldValue?: string = PO_MULTISELECT_FIELD_VALUE_DEFAULT;\n  private language: string;\n\n  private lastLengthModel;\n  private onModelChange: any;\n  private validatorChange: any;\n  private autoHeightInitialValue: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   * Nesta propriedade pode ser informada a URL do serviço em que será realizado o filtro para carregamento da lista de itens no componente.\n   *\n   *Também existe a possibilidade de informar um serviço implementando a interface `PoMultiselectFilter`.\n   *\n   *Caso utilizado uma URL, o serviço deve ser retornado no padrão [API PO UI](https://po-ui.io/guides/api) e utilizar as propriedades `p-field-label` e `p-field-value` para a construção da lista de itens.\n   *\n   *Quando utilizada uma URL de serviço, então será concatenada nesta URL o valor que deseja-se filtrar da seguinte forma:\n   *\n   *```\n   * // caso filtrar por \"Peter\"\n   *  https://localhost:8080/api/heroes?filter=Peter\n   *```\n   *\n   *E caso iniciar o campo com valor, os itens serão buscados da seguinte forma:\n   *\n   *```\n   * // caso o valor do campo for [1234, 5678];\n   *  https://localhost:8080/api/heroes?value=1234,5678\n   *\n   * //O *value* é referente ao `fieldValue`.\n   *```\n   *\n   */\n  @Input('p-filter-service') set filterService(value: PoMultiselectFilter | string) {\n    this._filterService = value;\n    this.autoHeight = this.autoHeightInitialValue !== undefined ? this.autoHeightInitialValue : true;\n    this.options = [];\n  }\n\n  get filterService() {\n    return this._filterService;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define que a altura do componente será auto ajustável, possuindo uma altura minima porém a altura máxima será de acordo\n   * com o número de itens selecionados e a extensão dos mesmos, mantendo-os sempre visíveis.\n   *\n   * > O valor padrão será `true` quando houver serviço (`p-filter-service`).\n   *\n   * @default `false`\n   */\n  @Input('p-auto-height') @InputBoolean() set autoHeight(value: boolean) {\n    this._autoHeight = value;\n    this.autoHeightInitialValue = value;\n  }\n\n  get autoHeight(): boolean {\n    return this._autoHeight;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Esta propriedade define em quanto tempo (em milissegundos), aguarda para acionar o evento de filtro após cada pressionamento de tecla.\n   *\n   * > Será utilizada apenas quando houver serviço (`p-filter-service`) e somente será aceito valor maior do que *zero*.\n   *\n   * @default `400`\n   */\n  @Input('p-debounce-time') set debounceTime(value: number) {\n    const parsedValue = parseInt(<any>value, 10);\n\n    this._debounceTime = !isNaN(parsedValue) && parsedValue > 0 ? parsedValue : PO_MULTISELECT_DEBOUNCE_TIME_DEFAULT;\n  }\n\n  get debounceTime(): number {\n    return this._debounceTime;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Objeto com as literais usadas no `po-multiselect`.\n   *\n   * Existem duas maneiras de customizar o componente, passando um objeto com todas as literais disponíveis:\n   *\n   * ```\n   *  const customLiterals: PoMultiselectLiterals = {\n   *    noData: 'Nenhum dado encontrado',\n   *    placeholderSearch: 'Buscar'\n   *  };\n   * ```\n   *\n   * Ou passando apenas as literais que deseja customizar:\n   *\n   * ```\n   *  const customLiterals: PoMultiselectLiterals = {\n   *    noData: 'Sem dados'\n   *  };\n   * ```\n   *\n   * E para carregar as literais customizadas, basta apenas passar o objeto para o componente:\n   *\n   * ```\n   * <po-multiselect\n   *   [p-literals]=\"customLiterals\">\n   * </po-po-multiselect>\n   * ```\n   *\n   * > O objeto padrão de literais será traduzido de acordo com o idioma do\n   * [`PoI18nService`](/documentation/po-i18n) ou do browser.\n   */\n  @Input('p-literals') set literals(value: PoMultiselectLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poMultiselectLiteralsDefault[poLocaleDefault],\n        ...poMultiselectLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poMultiselectLiteralsDefault[this.language];\n    }\n  }\n  get literals() {\n    return this._literals || poMultiselectLiteralsDefault[this.language];\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será obrigatório. Esta propriedade é desconsiderada quando o campo está desabilitado (p-disabled).\n   *\n   * @default `false`\n   */\n  @Input('p-required') set required(required: boolean) {\n    this._required = <any>required === '' ? true : convertToBoolean(required);\n    this.validateModel();\n  }\n\n  get required() {\n    return this._required;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será desabilitado.\n   *\n   * @default `false`\n   */\n  @Input('p-disabled') set disabled(disabled: boolean) {\n    this._disabled = <any>disabled === '' ? true : convertToBoolean(disabled);\n    this.validateModel();\n\n    this.updateVisibleItems();\n  }\n\n  get disabled() {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Esconde o campo de pesquisa existente dentro do dropdown do po-multiselect.\n   *\n   * @default `false`\n   */\n  @Input('p-hide-search') set hideSearch(hideSearch: boolean) {\n    this._hideSearch = <any>hideSearch === '' ? true : convertToBoolean(hideSearch);\n  }\n\n  get hideSearch() {\n    return this._hideSearch;\n  }\n\n  /**\n   * @description\n   *\n   * Nesta propriedade deve ser definida uma lista de objetos que implementam a interface PoMultiselectOption.\n   * Esta lista deve conter os valores e os labels que serão apresentados na tela.\n   *\n   * > Essa propriedade é imutável, ou seja, sempre que quiser atualizar a lista de opções disponíveis\n   * atualize a referência do objeto:\n   *\n   * ```\n   * // atualiza a referência do objeto garantindo a atualização do template\n   * this.options = [...this.options, { value: 'x', label: 'Nova opção' }];\n   *\n   * // evite, pois não atualiza a referência do objeto podendo gerar atrasos na atualização do template\n   * this.options.push({ value: 'x', label: 'Nova opção' });\n   * ```\n   */\n  @Input('p-options') set options(options: Array<PoMultiselectOption>) {\n    this._options = options;\n\n    this.validAndSortOptions();\n  }\n\n  get options() {\n    return this._options;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que a lista definida na propriedade p-options será ordenada pelo label antes de ser apresentada no\n   * dropdown.\n   *\n   * @default `false`\n   */\n  @Input('p-sort') set sort(sort: boolean) {\n    this._sort = <any>sort === '' ? true : convertToBoolean(sort);\n\n    this.validAndSortOptions();\n  }\n\n  get sort() {\n    return this._sort;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o modo de pesquisa utilizado no campo de busca, quando habilitado.\n   * Valores definidos no enum: PoMultiselectFilterMode\n   *\n   * @default `startsWith`\n   */\n  @Input('p-filter-mode') set filterMode(filterMode: PoMultiselectFilterMode) {\n    this._filterMode = filterMode in PoMultiselectFilterMode ? filterMode : PoMultiselectFilterMode.startsWith;\n    switch (this._filterMode.toString()) {\n      case 'startsWith':\n        this._filterMode = PoMultiselectFilterMode.startsWith;\n        break;\n      case 'contains':\n        this._filterMode = PoMultiselectFilterMode.contains;\n        break;\n      case 'endsWith':\n        this._filterMode = PoMultiselectFilterMode.endsWith;\n        break;\n    }\n  }\n\n  get filterMode() {\n    return this._filterMode;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.\n   *\n   * Necessário quando informar o serviço como URL e o mesmo não estiver retornando uma lista de objetos no padrão da interface\n   * `PoMultiSelectOption`.\n   *\n   * @default `label`\n   */\n  @Input('p-field-label') set fieldLabel(value: string) {\n    this._fieldLabel = value || PO_MULTISELECT_FIELD_LABEL_DEFAULT;\n\n    if (isTypeof(this.filterService, 'string') && this.service) {\n      this.service.fieldLabel = this._fieldLabel;\n    }\n  }\n\n  get fieldLabel() {\n    return this._fieldLabel;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.\n   *\n   * Necessário quando informar o serviço como URL e o mesmo não estiver retornando uma lista de objetos no padrão da interface\n   * `PoMultiSelectOption`.\n   *\n   * @default `value`\n   */\n  @Input('p-field-value') set fieldValue(value: string) {\n    this._fieldValue = value || PO_MULTISELECT_FIELD_VALUE_DEFAULT;\n\n    if (isTypeof(this.filterService, 'string') && this.service) {\n      this.service.fieldValue = this._fieldValue;\n    }\n  }\n\n  get fieldValue() {\n    return this._fieldValue;\n  }\n\n  constructor(languageService: PoLanguageService) {\n    this.language = languageService.getShortLanguage();\n  }\n\n  ngOnInit() {\n    if (this.filterService) {\n      this.setService(this.filterService);\n    }\n\n    this.filterSubject\n      .pipe(\n        debounceTime(this.debounceTime),\n        distinctUntilChanged(),\n        tap(() => (this.isServerSearching = true)),\n        switchMap((search: string) => this.applyFilter(search)),\n        tap(() => (this.isServerSearching = false))\n      )\n      .subscribe();\n\n    this.updateList(this.options);\n  }\n\n  setService(service: PoMultiselectFilter | string) {\n    if (isTypeof(service, 'object')) {\n      this.service = <PoMultiselectFilterService>service;\n    } else {\n      this.service = this.defaultService;\n      this.service.configProperties(<string>service, this.fieldLabel, this.fieldValue);\n    }\n\n    this.isFirstFilter = true;\n  }\n\n  validAndSortOptions() {\n    if (this.options && this.options.length) {\n      removeUndefinedAndNullOptions(this.options);\n      removeDuplicatedOptions(this.options);\n      this.setUndefinedLabels(this.options);\n\n      if (this.sort) {\n        sortOptionsByProperty(this.options, 'label');\n      }\n    }\n  }\n\n  setUndefinedLabels(options) {\n    options.forEach(option => {\n      if (!option['label']) {\n        option.label = option.value;\n      }\n    });\n  }\n\n  updateList(options: Array<PoMultiselectOption>) {\n    if (options) {\n      this.visibleOptionsDropdown = options;\n    }\n  }\n\n  callOnChange(selectedOptions: Array<PoMultiselectOption>) {\n    if (this.onModelChange) {\n      this.onModelChange(this.getValuesFromOptions(selectedOptions));\n      this.eventChange(selectedOptions);\n    }\n  }\n\n  eventChange(selectedOptions) {\n    if (selectedOptions && this.lastLengthModel !== selectedOptions.length) {\n      this.change.emit(selectedOptions);\n    }\n    this.lastLengthModel = selectedOptions ? selectedOptions.length : null;\n  }\n\n  getValuesFromOptions(selectedOptions: Array<PoMultiselectOption>) {\n    return selectedOptions && selectedOptions.length ? selectedOptions.map(option => option.value) : [];\n  }\n\n  getLabelByValue(value) {\n    const index = this.options.findIndex(option => option.value === value);\n    return this.options[index].label;\n  }\n\n  searchByLabel(search: string, options: Array<PoMultiselectOption>, filterMode: PoMultiselectFilterMode) {\n    if (search && options && options.length) {\n      const newOptions: Array<PoMultiselectOption> = [];\n      options.forEach(option => {\n        if (option.label && this.compareMethod(search, option, filterMode)) {\n          newOptions.push(option);\n        }\n      });\n      this.visibleOptionsDropdown = newOptions;\n    }\n  }\n\n  compareMethod(search: string, option: PoMultiselectOption, filterMode: PoMultiselectFilterMode) {\n    switch (filterMode) {\n      case PoMultiselectFilterMode.startsWith:\n        return this.startsWith(search, option);\n      case PoMultiselectFilterMode.contains:\n        return this.contains(search, option);\n      case PoMultiselectFilterMode.endsWith:\n        return this.endsWith(search, option);\n    }\n  }\n\n  startsWith(search: string, option: PoMultiselectOption) {\n    return option.label.toLowerCase().startsWith(search.toLowerCase());\n  }\n\n  contains(search: string, option: PoMultiselectOption) {\n    return option.label.toLowerCase().indexOf(search.toLowerCase()) > -1;\n  }\n\n  endsWith(search: string, option: PoMultiselectOption) {\n    return option.label.toLowerCase().endsWith(search.toLowerCase());\n  }\n\n  validate(c: AbstractControl): { [key: string]: any } {\n    if (requiredFailed(this.required, this.disabled, c.value)) {\n      return {\n        required: {\n          valid: false\n        }\n      };\n    }\n\n    return null;\n  }\n\n  updateSelectedOptions(newOptions: Array<any>, options = this.options) {\n    this.selectedOptions = [];\n\n    if (this.filterService) {\n      this.selectedOptions = newOptions;\n    } else {\n      newOptions.forEach(newOption => {\n        options.forEach(option => {\n          if (option.value === newOption.value) {\n            this.selectedOptions.push(option);\n          }\n        });\n      });\n    }\n\n    this.updateVisibleItems();\n  }\n\n  writeValue(values: any): void {\n    values = values || [];\n\n    if (this.service && values.length) {\n      this.getObjectsByValuesSubscription = this.service.getObjectsByValues(values).subscribe(options => {\n        this.updateSelectedOptions(options);\n        this.callOnChange(this.selectedOptions);\n      });\n    } else {\n      // Validar se todos os items existem entre os options, senão atualizar o model\n      this.updateSelectedOptions(values.map(value => ({ value })));\n\n      if (this.selectedOptions && this.selectedOptions.length < values.length) {\n        this.callOnChange(this.selectedOptions);\n      }\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  // Usada para interceptar os estados de habilitado via forms api\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onModelChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onModelTouched = fn;\n  }\n\n  registerOnValidatorChange(fn: () => void) {\n    this.validatorChange = fn;\n  }\n\n  private validateModel() {\n    if (this.validatorChange) {\n      this.validatorChange();\n    }\n  }\n\n  abstract applyFilter(value?: string): Observable<Array<PoMultiselectOption>>;\n  abstract updateVisibleItems(): void;\n}\n"]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { HttpClient } from '@angular/common/http';
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { map } from 'rxjs/operators';
|
|
4
|
+
export class PoMultiselectFilterService {
|
|
5
|
+
constructor(http) {
|
|
6
|
+
this.http = http;
|
|
7
|
+
this.fieldLabel = 'label';
|
|
8
|
+
this.fieldValue = 'value';
|
|
9
|
+
this.messages = [];
|
|
10
|
+
}
|
|
11
|
+
get url() {
|
|
12
|
+
return this._url;
|
|
13
|
+
}
|
|
14
|
+
getFilteredData({ value }) {
|
|
15
|
+
const params = value ? { filter: value } : {};
|
|
16
|
+
return this.http
|
|
17
|
+
.get(this.url, {
|
|
18
|
+
params
|
|
19
|
+
})
|
|
20
|
+
.pipe(map(response => this.parseToArrayMultiselectOptions(response['items'])));
|
|
21
|
+
}
|
|
22
|
+
getObjectsByValues(value) {
|
|
23
|
+
return this.http
|
|
24
|
+
.get(`${this.url}?${this.fieldValue}=${value.toString()}`)
|
|
25
|
+
.pipe(map(response => this.parseToArrayMultiselectOptions(response['items'])));
|
|
26
|
+
}
|
|
27
|
+
configProperties(url, fieldLabel, fieldValue) {
|
|
28
|
+
this._url = url;
|
|
29
|
+
this.fieldLabel = fieldLabel;
|
|
30
|
+
this.fieldValue = fieldValue;
|
|
31
|
+
}
|
|
32
|
+
parseToArrayMultiselectOptions(items) {
|
|
33
|
+
if (items && items.length > 0) {
|
|
34
|
+
return items.map(item => this.parseToMultiselectOption(item));
|
|
35
|
+
}
|
|
36
|
+
return [];
|
|
37
|
+
}
|
|
38
|
+
parseToMultiselectOption(item) {
|
|
39
|
+
const label = item[this.fieldLabel];
|
|
40
|
+
const value = item[this.fieldValue];
|
|
41
|
+
return { label, value };
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
PoMultiselectFilterService.decorators = [
|
|
45
|
+
{ type: Injectable }
|
|
46
|
+
];
|
|
47
|
+
PoMultiselectFilterService.ctorParameters = () => [
|
|
48
|
+
{ type: HttpClient }
|
|
49
|
+
];
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tbXVsdGlzZWxlY3QtZmlsdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2NvbXBvbmVudHMvcG8tZmllbGQvcG8tbXVsdGlzZWxlY3QvcG8tbXVsdGlzZWxlY3QtZmlsdGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBZSxNQUFNLHNCQUFzQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHM0MsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBS3JDLE1BQU0sT0FBTywwQkFBMEI7SUFXckMsWUFBb0IsSUFBZ0I7UUFBaEIsU0FBSSxHQUFKLElBQUksQ0FBWTtRQVZwQyxlQUFVLEdBQVcsT0FBTyxDQUFDO1FBQzdCLGVBQVUsR0FBVyxPQUFPLENBQUM7UUFHckIsYUFBUSxHQUFHLEVBQUUsQ0FBQztJQU1pQixDQUFDO0lBSnhDLElBQUksR0FBRztRQUNMLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDO0lBSUQsZUFBZSxDQUFDLEVBQUUsS0FBSyxFQUFPO1FBQzVCLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUM5QyxPQUFPLElBQUksQ0FBQyxJQUFJO2FBQ2IsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUU7WUFDYixNQUFNO1NBQ1AsQ0FBQzthQUNELElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsOEJBQThCLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxrQkFBa0IsQ0FBQyxLQUE2QjtRQUM5QyxPQUFPLElBQUksQ0FBQyxJQUFJO2FBQ2IsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLENBQUMsVUFBVSxJQUFJLEtBQUssQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO2FBQ3pELElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsOEJBQThCLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxHQUFXLEVBQUUsVUFBa0IsRUFBRSxVQUFrQjtRQUNsRSxJQUFJLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztRQUNoQixJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztRQUM3QixJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztJQUMvQixDQUFDO0lBRU8sOEJBQThCLENBQUMsS0FBaUI7UUFDdEQsSUFBSSxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDN0IsT0FBTyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7U0FDL0Q7UUFFRCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFTyx3QkFBd0IsQ0FBQyxJQUFTO1FBQ3hDLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDcEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUVwQyxPQUFPLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxDQUFDO0lBQzFCLENBQUM7OztZQWhERixVQUFVOzs7WUFSRixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cEhlYWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IFBvTXVsdGlzZWxlY3RGaWx0ZXIgfSBmcm9tICcuL3BvLW11bHRpc2VsZWN0LWZpbHRlci5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgUG9NdWx0aXNlbGVjdE9wdGlvbiB9IGZyb20gJy4vcG8tbXVsdGlzZWxlY3Qtb3B0aW9uLmludGVyZmFjZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBQb011bHRpc2VsZWN0RmlsdGVyU2VydmljZSBpbXBsZW1lbnRzIFBvTXVsdGlzZWxlY3RGaWx0ZXIge1xuICBmaWVsZExhYmVsOiBzdHJpbmcgPSAnbGFiZWwnO1xuICBmaWVsZFZhbHVlOiBzdHJpbmcgPSAndmFsdWUnO1xuXG4gIHByaXZhdGUgX3VybDogc3RyaW5nO1xuICBwcml2YXRlIG1lc3NhZ2VzID0gW107XG5cbiAgZ2V0IHVybCgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLl91cmw7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQpIHt9XG5cbiAgZ2V0RmlsdGVyZWREYXRhKHsgdmFsdWUgfTogYW55KTogT2JzZXJ2YWJsZTxBcnJheTxQb011bHRpc2VsZWN0T3B0aW9uPj4ge1xuICAgIGNvbnN0IHBhcmFtcyA9IHZhbHVlID8geyBmaWx0ZXI6IHZhbHVlIH0gOiB7fTtcbiAgICByZXR1cm4gdGhpcy5odHRwXG4gICAgICAuZ2V0KHRoaXMudXJsLCB7XG4gICAgICAgIHBhcmFtc1xuICAgICAgfSlcbiAgICAgIC5waXBlKG1hcChyZXNwb25zZSA9PiB0aGlzLnBhcnNlVG9BcnJheU11bHRpc2VsZWN0T3B0aW9ucyhyZXNwb25zZVsnaXRlbXMnXSkpKTtcbiAgfVxuXG4gIGdldE9iamVjdHNCeVZhbHVlcyh2YWx1ZTogQXJyYXk8c3RyaW5nIHwgbnVtYmVyPik6IE9ic2VydmFibGU8QXJyYXk8UG9NdWx0aXNlbGVjdE9wdGlvbj4+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwXG4gICAgICAuZ2V0KGAke3RoaXMudXJsfT8ke3RoaXMuZmllbGRWYWx1ZX09JHt2YWx1ZS50b1N0cmluZygpfWApXG4gICAgICAucGlwZShtYXAocmVzcG9uc2UgPT4gdGhpcy5wYXJzZVRvQXJyYXlNdWx0aXNlbGVjdE9wdGlvbnMocmVzcG9uc2VbJ2l0ZW1zJ10pKSk7XG4gIH1cblxuICBjb25maWdQcm9wZXJ0aWVzKHVybDogc3RyaW5nLCBmaWVsZExhYmVsOiBzdHJpbmcsIGZpZWxkVmFsdWU6IHN0cmluZykge1xuICAgIHRoaXMuX3VybCA9IHVybDtcbiAgICB0aGlzLmZpZWxkTGFiZWwgPSBmaWVsZExhYmVsO1xuICAgIHRoaXMuZmllbGRWYWx1ZSA9IGZpZWxkVmFsdWU7XG4gIH1cblxuICBwcml2YXRlIHBhcnNlVG9BcnJheU11bHRpc2VsZWN0T3B0aW9ucyhpdGVtczogQXJyYXk8YW55Pik6IEFycmF5PFBvTXVsdGlzZWxlY3RPcHRpb24+IHtcbiAgICBpZiAoaXRlbXMgJiYgaXRlbXMubGVuZ3RoID4gMCkge1xuICAgICAgcmV0dXJuIGl0ZW1zLm1hcChpdGVtID0+IHRoaXMucGFyc2VUb011bHRpc2VsZWN0T3B0aW9uKGl0ZW0pKTtcbiAgICB9XG5cbiAgICByZXR1cm4gW107XG4gIH1cblxuICBwcml2YXRlIHBhcnNlVG9NdWx0aXNlbGVjdE9wdGlvbihpdGVtOiBhbnkpOiBQb011bHRpc2VsZWN0T3B0aW9uIHtcbiAgICBjb25zdCBsYWJlbCA9IGl0ZW1bdGhpcy5maWVsZExhYmVsXTtcbiAgICBjb25zdCB2YWx1ZSA9IGl0ZW1bdGhpcy5maWVsZFZhbHVlXTtcblxuICAgIHJldHVybiB7IGxhYmVsLCB2YWx1ZSB9O1xuICB9XG59XG4iXX0=
|
|
@@ -7,10 +7,12 @@ import { PoControlPositionService } from './../../../services/po-control-positio
|
|
|
7
7
|
import { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';
|
|
8
8
|
import { PoLanguageService } from '../../../services/po-language/po-language.service';
|
|
9
9
|
import { PoMultiselectBaseComponent } from './po-multiselect-base.component';
|
|
10
|
+
import { PoMultiselectFilterService } from './po-multiselect-filter.service';
|
|
10
11
|
const poMultiselectContainerOffset = 8;
|
|
11
12
|
const poMultiselectContainerPositionDefault = 'bottom';
|
|
12
13
|
/* istanbul ignore next */
|
|
13
14
|
const providers = [
|
|
15
|
+
PoMultiselectFilterService,
|
|
14
16
|
PoControlPositionService,
|
|
15
17
|
{
|
|
16
18
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -57,12 +59,13 @@ const providers = [
|
|
|
57
59
|
* </example>
|
|
58
60
|
*/
|
|
59
61
|
export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
60
|
-
constructor(renderer, changeDetector, el, controlPosition, languageService) {
|
|
62
|
+
constructor(renderer, changeDetector, el, controlPosition, defaultService, languageService) {
|
|
61
63
|
super(languageService);
|
|
62
64
|
this.renderer = renderer;
|
|
63
65
|
this.changeDetector = changeDetector;
|
|
64
66
|
this.el = el;
|
|
65
67
|
this.controlPosition = controlPosition;
|
|
68
|
+
this.defaultService = defaultService;
|
|
66
69
|
this.disclaimerOffset = 0;
|
|
67
70
|
this.dropdownIcon = 'po-icon-arrow-down';
|
|
68
71
|
this.dropdownOpen = false;
|
|
@@ -79,6 +82,11 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
79
82
|
}
|
|
80
83
|
this.initialized = true;
|
|
81
84
|
}
|
|
85
|
+
ngOnChanges(changes) {
|
|
86
|
+
if (changes.filterService || changes.fieldValue || changes.fieldLabel) {
|
|
87
|
+
this.setService(this.filterService);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
82
90
|
ngDoCheck() {
|
|
83
91
|
const inputWidth = this.inputElement.nativeElement.offsetWidth;
|
|
84
92
|
// Permite que os disclaimers sejam calculados na primeira vez que o componente torna-se visível,
|
|
@@ -255,8 +263,8 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
255
263
|
}
|
|
256
264
|
}
|
|
257
265
|
applyFilter(value = '') {
|
|
258
|
-
const param = { property: 'label', value };
|
|
259
|
-
return this.
|
|
266
|
+
const param = { property: 'label', value: value };
|
|
267
|
+
return this.service.getFilteredData(param).pipe(catchError(err => {
|
|
260
268
|
this.isServerSearching = false;
|
|
261
269
|
return of([]);
|
|
262
270
|
}), tap((options) => {
|
|
@@ -266,7 +274,10 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
266
274
|
applyFilterInFirstClick() {
|
|
267
275
|
if (this.isFirstFilter) {
|
|
268
276
|
this.isServerSearching = true;
|
|
269
|
-
|
|
277
|
+
// necessario enviar um objeto string vazia para refazer a busca, quando alterar filterService, fieldValue e fieldLabel
|
|
278
|
+
// pois temos o distinctUntilChange no pipe do filterSubject
|
|
279
|
+
/* eslint-disable no-new-wrappers */
|
|
280
|
+
this.filterSubject.next(new String());
|
|
270
281
|
}
|
|
271
282
|
else {
|
|
272
283
|
this.options = [...this.cacheOptions];
|
|
@@ -336,6 +347,7 @@ PoMultiselectComponent.ctorParameters = () => [
|
|
|
336
347
|
{ type: ChangeDetectorRef },
|
|
337
348
|
{ type: ElementRef },
|
|
338
349
|
{ type: PoControlPositionService },
|
|
350
|
+
{ type: PoMultiselectFilterService },
|
|
339
351
|
{ type: PoLanguageService }
|
|
340
352
|
];
|
|
341
353
|
PoMultiselectComponent.propDecorators = {
|
|
@@ -344,4 +356,4 @@ PoMultiselectComponent.propDecorators = {
|
|
|
344
356
|
iconElement: [{ type: ViewChild, args: ['iconElement', { read: ElementRef, static: true },] }],
|
|
345
357
|
inputElement: [{ type: ViewChild, args: ['inputElement', { read: ElementRef, static: true },] }]
|
|
346
358
|
};
|
|
347
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  forwardRef,\n  OnDestroy,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { Observable, of } from 'rxjs';\nimport { tap, catchError } from 'rxjs/operators';\n\nimport { isMobile } from './../../../utils/util';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\nimport { PoLanguageService } from '../../../services/po-language/po-language.service';\n\nimport { PoMultiselectBaseComponent } from './po-multiselect-base.component';\nimport { PoMultiselectOption } from './po-multiselect-option.interface';\n\nconst poMultiselectContainerOffset = 8;\nconst poMultiselectContainerPositionDefault = 'bottom';\n\n/* istanbul ignore next */\nconst providers = [\n  PoControlPositionService,\n  {\n    provide: NG_VALUE_ACCESSOR,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  },\n  {\n    provide: NG_VALIDATORS,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  }\n];\n\n/**\n * @docsExtends PoMultiselectBaseComponent\n *\n * @example\n *\n * <example name=\"po-multiselect-basic\" title=\"PO Multiselect Basic\">\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-labs\" title=\"PO Multiselect Labs\">\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation\" title=\"PO Multiselect - Vacation\">\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation-reactive-form\" title=\"PO Multiselect - Vacation Reactive Form\">\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-heroes\" title=\"PO Multiselect - Heroes - using API\">\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.ts\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.service.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-multiselect',\n  templateUrl: './po-multiselect.component.html',\n  providers\n})\nexport class PoMultiselectComponent extends PoMultiselectBaseComponent implements AfterViewInit, DoCheck, OnDestroy {\n  @ViewChild('dropdownElement', { read: ElementRef, static: true }) dropdownElement: ElementRef;\n  @ViewChild('dropdownElement', { static: true }) dropdown;\n  @ViewChild('iconElement', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('inputElement', { read: ElementRef, static: true }) inputElement: ElementRef;\n\n  disclaimerOffset = 0;\n  dropdownIcon: string = 'po-icon-arrow-down';\n  dropdownOpen: boolean = false;\n  initialized = false;\n  positionDisclaimerExtra;\n  timeoutResize;\n  visibleElement = false;\n\n  private isCalculateVisibleItems: boolean = true;\n  private cacheOptions: Array<PoMultiselectOption>;\n\n  constructor(\n    private renderer: Renderer2,\n    private changeDetector: ChangeDetectorRef,\n    private el: ElementRef,\n    private controlPosition: PoControlPositionService,\n    languageService: PoLanguageService\n  ) {\n    super(languageService);\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n    this.initialized = true;\n  }\n\n  ngDoCheck() {\n    const inputWidth = this.inputElement.nativeElement.offsetWidth;\n    // Permite que os disclaimers sejam calculados na primeira vez que o componente torna-se visível,\n    // evitando com isso, problemas com Tabs ou Divs que iniciem escondidas.\n    if ((inputWidth && !this.visibleElement && this.initialized) || (inputWidth && this.isCalculateVisibleItems)) {\n      this.debounceResize();\n      this.visibleElement = true;\n    }\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n    this.getObjectsByValuesSubscription?.unsubscribe();\n    this.filterSubject?.unsubscribe();\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoMultiselectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoMultiselectComponent, { static: true }) multiselect: PoMultiselectComponent;\n   *\n   * focusMultiselect() {\n   *   this.multiselect.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  getInputWidth() {\n    return this.el.nativeElement.querySelector('.po-input').offsetWidth - 40;\n  }\n\n  getDisclaimersWidth() {\n    const disclaimers = this.el.nativeElement.querySelectorAll('po-disclaimer');\n    return Array.from(disclaimers).map(disclaimer => disclaimer['offsetWidth']);\n  }\n\n  calculateVisibleItems() {\n    const disclaimersWidth = this.getDisclaimersWidth();\n    const inputWidth = this.getInputWidth();\n    const extraDisclaimerSize = 38;\n    const disclaimersVisible = disclaimersWidth[0];\n\n    this.visibleDisclaimers = [];\n\n    if (inputWidth > 0) {\n      let sum = 0;\n      let i = 0;\n      for (i = 0; i < this.selectedOptions.length; i++) {\n        sum += disclaimersWidth[i];\n        this.visibleDisclaimers.push(this.selectedOptions[i]);\n\n        if (sum > inputWidth) {\n          sum -= disclaimersWidth[i];\n          this.isCalculateVisibleItems = false;\n          break;\n        }\n      }\n\n      if (disclaimersVisible || !this.selectedOptions.length) {\n        if (i === this.selectedOptions.length) {\n          this.isCalculateVisibleItems = false;\n          return;\n        }\n\n        if (sum + extraDisclaimerSize > inputWidth) {\n          this.visibleDisclaimers.splice(-2, 2);\n          const label = '+' + (this.selectedOptions.length + 1 - i).toString();\n          this.visibleDisclaimers.push({ value: '', label: label });\n        } else {\n          this.visibleDisclaimers.splice(-1, 1);\n          const label = '+' + (this.selectedOptions.length - i).toString();\n          this.visibleDisclaimers.push({ value: '', label: label });\n        }\n      }\n    }\n  }\n\n  changeItems(changedItems) {\n    this.updateSelectedOptions(changedItems);\n    this.callOnChange(this.selectedOptions);\n\n    if (this.autoHeight && this.dropdownOpen) {\n      this.changeDetector.detectChanges();\n      this.adjustContainerPosition();\n    }\n  }\n\n  updateVisibleItems() {\n    if (this.selectedOptions) {\n      this.visibleDisclaimers = [].concat(this.selectedOptions);\n    }\n\n    this.debounceResize();\n\n    // quando estiver dentro de modal\n    if (!this.inputElement.nativeElement.offsetWidth) {\n      this.isCalculateVisibleItems = true;\n    }\n  }\n\n  debounceResize() {\n    if (!this.autoHeight) {\n      clearTimeout(this.timeoutResize);\n      this.timeoutResize = setTimeout(() => {\n        this.calculateVisibleItems();\n      }, 200);\n    }\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  onKeyDown(event?: any) {\n    if (event.keyCode === PoKeyCodeEnum.arrowUp || event.keyCode === PoKeyCodeEnum.arrowDown) {\n      event.preventDefault();\n      this.controlDropdownVisibility(true);\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.tab) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  toggleDropdownVisibility() {\n    if (this.disabled) {\n      return;\n    }\n\n    if (this.filterService) {\n      this.applyFilterInFirstClick();\n    }\n\n    this.controlDropdownVisibility(!this.dropdownOpen);\n  }\n\n  openDropdown(toOpen) {\n    if (toOpen && !this.disabled) {\n      this.controlDropdownVisibility(true);\n    }\n  }\n\n  controlDropdownVisibility(toOpen: boolean) {\n    toOpen ? this.open() : this.close();\n  }\n\n  scrollToSelectedOptions() {\n    if (this.selectedOptions && this.selectedOptions.length) {\n      const index = this.options.findIndex(option => option.value === this.selectedOptions[0].value);\n      this.dropdown.scrollTo(index);\n    }\n  }\n\n  setVisibleOptionsDropdown(options) {\n    this.visibleOptionsDropdown = options;\n  }\n\n  changeSearch(event) {\n    if (event && event.value !== undefined) {\n      if (this.filterService) {\n        this.filterSubject.next(event.value);\n      } else {\n        this.searchByLabel(event.value, this.options, this.filterMode);\n      }\n    } else {\n      this.setVisibleOptionsDropdown(this.options);\n    }\n\n    // timeout necessário para reposicionar corretamente quando dropdown estiver pra cima do input e realizar busca no input\n    setTimeout(() => this.adjustContainerPosition());\n  }\n\n  closeDisclaimer(value) {\n    const index = this.selectedOptions.findIndex(option => option.value === value);\n    this.selectedOptions.splice(index, 1);\n\n    this.updateVisibleItems();\n    this.callOnChange(this.selectedOptions);\n  }\n\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      this.dropdownOpen &&\n      !this.inputElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target) &&\n      !this.dropdownElement.nativeElement.contains(event.target)\n    ) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  applyFilter(value: string = ''): Observable<Array<PoMultiselectOption>> {\n    const param = { property: 'label', value };\n\n    return this.filterService.getFilteredData(param).pipe(\n      catchError(err => {\n        this.isServerSearching = false;\n        return of([]);\n      }),\n      tap((options: Array<PoMultiselectOption>) => {\n        this.setOptionsByApplyFilter(options);\n      })\n    );\n  }\n\n  private applyFilterInFirstClick() {\n    if (this.isFirstFilter) {\n      this.isServerSearching = true;\n\n      this.filterSubject.next();\n    } else {\n      this.options = [...this.cacheOptions];\n    }\n  }\n\n  private setOptionsByApplyFilter(items: Array<PoMultiselectOption>) {\n    if (this.isFirstFilter) {\n      this.cacheOptions = [...items];\n      this.isFirstFilter = false;\n    }\n\n    this.options = [...items];\n    this.setVisibleOptionsDropdown(this.options);\n  }\n\n  private adjustContainerPosition(): void {\n    this.controlPosition.adjustPosition(poMultiselectContainerPositionDefault);\n  }\n\n  private close(): void {\n    this.dropdownIcon = 'po-icon-arrow-down';\n    this.dropdownOpen = false;\n\n    this.dropdown.controlVisibility(false);\n    this.setVisibleOptionsDropdown(this.options);\n\n    this.removeListeners();\n  }\n\n  private initializeListeners(): void {\n    this.clickOutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.resizeListener = this.renderer.listen('window', 'resize', () => {\n      this.updateVisibleItems();\n\n      isMobile() ? this.adjustContainerPosition() : this.close();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.adjustContainerPosition();\n  };\n\n  private open(): void {\n    this.dropdownIcon = 'po-icon-arrow-up';\n    this.dropdownOpen = true;\n\n    this.dropdown.controlVisibility(true);\n    this.setVisibleOptionsDropdown(this.options);\n    this.initializeListeners();\n    this.scrollToSelectedOptions();\n\n    this.changeDetector.detectChanges();\n    this.setPositionDropdown();\n  }\n\n  private removeListeners(): void {\n    if (this.clickOutListener) {\n      this.clickOutListener();\n    }\n\n    if (this.resizeListener) {\n      this.resizeListener();\n    }\n\n    window.removeEventListener('scroll', this.onScroll, true);\n  }\n\n  private setPositionDropdown(): void {\n    this.controlPosition.setElements(\n      this.dropdown.container.nativeElement,\n      poMultiselectContainerOffset,\n      this.inputElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.adjustContainerPosition();\n  }\n}\n"]}
|
|
359
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  forwardRef,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { Observable, of } from 'rxjs';\nimport { tap, catchError } from 'rxjs/operators';\n\nimport { isMobile } from './../../../utils/util';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\nimport { PoLanguageService } from '../../../services/po-language/po-language.service';\n\nimport { PoMultiselectBaseComponent } from './po-multiselect-base.component';\nimport { PoMultiselectOption } from './po-multiselect-option.interface';\nimport { PoMultiselectFilterService } from './po-multiselect-filter.service';\n\nconst poMultiselectContainerOffset = 8;\nconst poMultiselectContainerPositionDefault = 'bottom';\n\n/* istanbul ignore next */\nconst providers = [\n  PoMultiselectFilterService,\n  PoControlPositionService,\n  {\n    provide: NG_VALUE_ACCESSOR,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  },\n  {\n    provide: NG_VALIDATORS,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  }\n];\n\n/**\n * @docsExtends PoMultiselectBaseComponent\n *\n * @example\n *\n * <example name=\"po-multiselect-basic\" title=\"PO Multiselect Basic\">\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-labs\" title=\"PO Multiselect Labs\">\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation\" title=\"PO Multiselect - Vacation\">\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation-reactive-form\" title=\"PO Multiselect - Vacation Reactive Form\">\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-heroes\" title=\"PO Multiselect - Heroes - using API\">\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.ts\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.service.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-multiselect',\n  templateUrl: './po-multiselect.component.html',\n  providers\n})\nexport class PoMultiselectComponent\n  extends PoMultiselectBaseComponent\n  implements AfterViewInit, DoCheck, OnDestroy, OnChanges {\n  @ViewChild('dropdownElement', { read: ElementRef, static: true }) dropdownElement: ElementRef;\n  @ViewChild('dropdownElement', { static: true }) dropdown;\n  @ViewChild('iconElement', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('inputElement', { read: ElementRef, static: true }) inputElement: ElementRef;\n\n  disclaimerOffset = 0;\n  dropdownIcon: string = 'po-icon-arrow-down';\n  dropdownOpen: boolean = false;\n  initialized = false;\n  positionDisclaimerExtra;\n  timeoutResize;\n  visibleElement = false;\n\n  private isCalculateVisibleItems: boolean = true;\n  private cacheOptions: Array<PoMultiselectOption>;\n\n  constructor(\n    private renderer: Renderer2,\n    private changeDetector: ChangeDetectorRef,\n    private el: ElementRef,\n    private controlPosition: PoControlPositionService,\n    public defaultService: PoMultiselectFilterService,\n    languageService: PoLanguageService\n  ) {\n    super(languageService);\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n    this.initialized = true;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.filterService || changes.fieldValue || changes.fieldLabel) {\n      this.setService(this.filterService);\n    }\n  }\n\n  ngDoCheck() {\n    const inputWidth = this.inputElement.nativeElement.offsetWidth;\n    // Permite que os disclaimers sejam calculados na primeira vez que o componente torna-se visível,\n    // evitando com isso, problemas com Tabs ou Divs que iniciem escondidas.\n    if ((inputWidth && !this.visibleElement && this.initialized) || (inputWidth && this.isCalculateVisibleItems)) {\n      this.debounceResize();\n      this.visibleElement = true;\n    }\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n    this.getObjectsByValuesSubscription?.unsubscribe();\n    this.filterSubject?.unsubscribe();\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoMultiselectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoMultiselectComponent, { static: true }) multiselect: PoMultiselectComponent;\n   *\n   * focusMultiselect() {\n   *   this.multiselect.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  getInputWidth() {\n    return this.el.nativeElement.querySelector('.po-input').offsetWidth - 40;\n  }\n\n  getDisclaimersWidth() {\n    const disclaimers = this.el.nativeElement.querySelectorAll('po-disclaimer');\n    return Array.from(disclaimers).map(disclaimer => disclaimer['offsetWidth']);\n  }\n\n  calculateVisibleItems() {\n    const disclaimersWidth = this.getDisclaimersWidth();\n    const inputWidth = this.getInputWidth();\n    const extraDisclaimerSize = 38;\n    const disclaimersVisible = disclaimersWidth[0];\n\n    this.visibleDisclaimers = [];\n\n    if (inputWidth > 0) {\n      let sum = 0;\n      let i = 0;\n      for (i = 0; i < this.selectedOptions.length; i++) {\n        sum += disclaimersWidth[i];\n        this.visibleDisclaimers.push(this.selectedOptions[i]);\n\n        if (sum > inputWidth) {\n          sum -= disclaimersWidth[i];\n          this.isCalculateVisibleItems = false;\n          break;\n        }\n      }\n\n      if (disclaimersVisible || !this.selectedOptions.length) {\n        if (i === this.selectedOptions.length) {\n          this.isCalculateVisibleItems = false;\n          return;\n        }\n\n        if (sum + extraDisclaimerSize > inputWidth) {\n          this.visibleDisclaimers.splice(-2, 2);\n          const label = '+' + (this.selectedOptions.length + 1 - i).toString();\n          this.visibleDisclaimers.push({ value: '', label: label });\n        } else {\n          this.visibleDisclaimers.splice(-1, 1);\n          const label = '+' + (this.selectedOptions.length - i).toString();\n          this.visibleDisclaimers.push({ value: '', label: label });\n        }\n      }\n    }\n  }\n\n  changeItems(changedItems) {\n    this.updateSelectedOptions(changedItems);\n    this.callOnChange(this.selectedOptions);\n\n    if (this.autoHeight && this.dropdownOpen) {\n      this.changeDetector.detectChanges();\n      this.adjustContainerPosition();\n    }\n  }\n\n  updateVisibleItems() {\n    if (this.selectedOptions) {\n      this.visibleDisclaimers = [].concat(this.selectedOptions);\n    }\n\n    this.debounceResize();\n\n    // quando estiver dentro de modal\n    if (!this.inputElement.nativeElement.offsetWidth) {\n      this.isCalculateVisibleItems = true;\n    }\n  }\n\n  debounceResize() {\n    if (!this.autoHeight) {\n      clearTimeout(this.timeoutResize);\n      this.timeoutResize = setTimeout(() => {\n        this.calculateVisibleItems();\n      }, 200);\n    }\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  onKeyDown(event?: any) {\n    if (event.keyCode === PoKeyCodeEnum.arrowUp || event.keyCode === PoKeyCodeEnum.arrowDown) {\n      event.preventDefault();\n      this.controlDropdownVisibility(true);\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.tab) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  toggleDropdownVisibility() {\n    if (this.disabled) {\n      return;\n    }\n\n    if (this.filterService) {\n      this.applyFilterInFirstClick();\n    }\n\n    this.controlDropdownVisibility(!this.dropdownOpen);\n  }\n\n  openDropdown(toOpen) {\n    if (toOpen && !this.disabled) {\n      this.controlDropdownVisibility(true);\n    }\n  }\n\n  controlDropdownVisibility(toOpen: boolean) {\n    toOpen ? this.open() : this.close();\n  }\n\n  scrollToSelectedOptions() {\n    if (this.selectedOptions && this.selectedOptions.length) {\n      const index = this.options.findIndex(option => option.value === this.selectedOptions[0].value);\n      this.dropdown.scrollTo(index);\n    }\n  }\n\n  setVisibleOptionsDropdown(options) {\n    this.visibleOptionsDropdown = options;\n  }\n\n  changeSearch(event) {\n    if (event && event.value !== undefined) {\n      if (this.filterService) {\n        this.filterSubject.next(event.value);\n      } else {\n        this.searchByLabel(event.value, this.options, this.filterMode);\n      }\n    } else {\n      this.setVisibleOptionsDropdown(this.options);\n    }\n\n    // timeout necessário para reposicionar corretamente quando dropdown estiver pra cima do input e realizar busca no input\n    setTimeout(() => this.adjustContainerPosition());\n  }\n\n  closeDisclaimer(value) {\n    const index = this.selectedOptions.findIndex(option => option.value === value);\n    this.selectedOptions.splice(index, 1);\n\n    this.updateVisibleItems();\n    this.callOnChange(this.selectedOptions);\n  }\n\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      this.dropdownOpen &&\n      !this.inputElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target) &&\n      !this.dropdownElement.nativeElement.contains(event.target)\n    ) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  applyFilter(value: string = ''): Observable<Array<PoMultiselectOption>> {\n    const param = { property: 'label', value: value };\n    return this.service.getFilteredData(param).pipe(\n      catchError(err => {\n        this.isServerSearching = false;\n        return of([]);\n      }),\n      tap((options: Array<PoMultiselectOption>) => {\n        this.setOptionsByApplyFilter(options);\n      })\n    );\n  }\n\n  private applyFilterInFirstClick() {\n    if (this.isFirstFilter) {\n      this.isServerSearching = true;\n\n      // necessario enviar um objeto string vazia para refazer a busca, quando alterar filterService, fieldValue e fieldLabel\n      // pois temos o distinctUntilChange no pipe do filterSubject\n      /* eslint-disable no-new-wrappers */\n      this.filterSubject.next(new String());\n    } else {\n      this.options = [...this.cacheOptions];\n    }\n  }\n\n  private setOptionsByApplyFilter(items: Array<PoMultiselectOption>) {\n    if (this.isFirstFilter) {\n      this.cacheOptions = [...items];\n      this.isFirstFilter = false;\n    }\n\n    this.options = [...items];\n    this.setVisibleOptionsDropdown(this.options);\n  }\n\n  private adjustContainerPosition(): void {\n    this.controlPosition.adjustPosition(poMultiselectContainerPositionDefault);\n  }\n\n  private close(): void {\n    this.dropdownIcon = 'po-icon-arrow-down';\n    this.dropdownOpen = false;\n\n    this.dropdown.controlVisibility(false);\n    this.setVisibleOptionsDropdown(this.options);\n\n    this.removeListeners();\n  }\n\n  private initializeListeners(): void {\n    this.clickOutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.resizeListener = this.renderer.listen('window', 'resize', () => {\n      this.updateVisibleItems();\n\n      isMobile() ? this.adjustContainerPosition() : this.close();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.adjustContainerPosition();\n  };\n\n  private open(): void {\n    this.dropdownIcon = 'po-icon-arrow-up';\n    this.dropdownOpen = true;\n\n    this.dropdown.controlVisibility(true);\n    this.setVisibleOptionsDropdown(this.options);\n    this.initializeListeners();\n    this.scrollToSelectedOptions();\n\n    this.changeDetector.detectChanges();\n    this.setPositionDropdown();\n  }\n\n  private removeListeners(): void {\n    if (this.clickOutListener) {\n      this.clickOutListener();\n    }\n\n    if (this.resizeListener) {\n      this.resizeListener();\n    }\n\n    window.removeEventListener('scroll', this.onScroll, true);\n  }\n\n  private setPositionDropdown(): void {\n    this.controlPosition.setElements(\n      this.dropdown.container.nativeElement,\n      poMultiselectContainerOffset,\n      this.inputElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.adjustContainerPosition();\n  }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tcGFnZS1hY3Rpb24uaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLXBhZ2UvcG8tcGFnZS1hY3Rpb24uaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQb1BvcHVwQWN0aW9uIH0gZnJvbSAnLi4vcG8tcG9wdXAvcG8tcG9wdXAtYWN0aW9uLmludGVyZmFjZSc7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uXG4gKiBJbnRlcmZhY2UgcGFyYSBhcyBhw6fDtWVzIGRvcyBjb21wb25lbnRlcyBwby1wYWdlLWRlZmF1bHQgZSBwby1wYWdlLWxpc3QuXG4gKlxuICogPiBBcyBwcm9wcmllZGFkZXMgYHNlbGVjdGVkYCwgYHNlcGFyYXRvcmAgZSBgdHlwZWAgc2Vyw6NvIHZpc3RhcyBhIHBhcnRpciBkYSB0ZXJjZWlyYSBhw6fDo28gZSBzb21lbnRlIHF1YW5kb1xuICogZGVmaW5pciBxdWF0cm8gYcOnw7VlcyBvdSBtYWlzLlxuICpcbiAqIEBkb2NzRXh0ZW5kcyBQb1BvcHVwQWN0aW9uXG4gKlxuICogQGlnbm9yZUV4dGVuZGVkRGVzY3JpcHRpb25cbiAqXG4gKiBAdXNlZEJ5IFBvUGFnZURlZmF1bHRDb21wb25lbnQsIFBvUGFnZUxpc3RDb21wb25lbnRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQb1BhZ2VBY3Rpb24gZXh0ZW5kcyBQb1BvcHVwQWN0aW9uIHt9XG4iXX0=
|