@po-ui/ng-components 16.7.0 → 16.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/esm2022/lib/components/po-progress/enums/po-progress-size.enum.mjs +13 -0
  2. package/esm2022/lib/components/po-progress/index.mjs +2 -1
  3. package/esm2022/lib/components/po-progress/literals/po-progress.literals.mjs +19 -0
  4. package/esm2022/lib/components/po-progress/po-progress-bar/po-progress-bar.component.mjs +24 -9
  5. package/esm2022/lib/components/po-progress/po-progress-base.component.mjs +39 -2
  6. package/esm2022/lib/components/po-progress/po-progress.component.mjs +77 -54
  7. package/esm2022/lib/components/po-progress/po-progress.module.mjs +7 -4
  8. package/esm2022/lib/components/po-search/enum/po-search-filter-mode.enum.mjs +17 -0
  9. package/esm2022/lib/components/po-search/index.mjs +3 -2
  10. package/esm2022/lib/components/po-search/literals/po-search-literals-default.mjs +19 -0
  11. package/esm2022/lib/components/po-search/literals/po-search-literals.mjs +1 -1
  12. package/esm2022/lib/components/po-search/po-search-base.component.mjs +177 -10
  13. package/esm2022/lib/components/po-search/po-search.component.mjs +52 -48
  14. package/esm2022/lib/components/po-table/po-table-base.component.mjs +3 -3
  15. package/fesm2022/po-ui-ng-components.mjs +413 -124
  16. package/fesm2022/po-ui-ng-components.mjs.map +1 -1
  17. package/lib/components/po-progress/enums/po-progress-size.enum.d.ts +11 -0
  18. package/lib/components/po-progress/index.d.ts +1 -0
  19. package/lib/components/po-progress/literals/po-progress.literals.d.ts +18 -0
  20. package/lib/components/po-progress/po-progress-base.component.d.ts +30 -3
  21. package/lib/components/po-progress/po-progress.component.d.ts +5 -1
  22. package/lib/components/po-progress/po-progress.module.d.ts +4 -1
  23. package/lib/components/po-search/{po-search-filter-mode.enum.d.ts → enum/po-search-filter-mode.enum.d.ts} +2 -2
  24. package/lib/components/po-search/index.d.ts +2 -1
  25. package/lib/components/po-search/literals/po-search-literals-default.d.ts +7 -0
  26. package/lib/components/po-search/literals/po-search-literals.d.ts +11 -1
  27. package/lib/components/po-search/po-search-base.component.d.ts +140 -5
  28. package/lib/components/po-search/po-search.component.d.ts +23 -8
  29. package/lib/components/po-table/po-table-base.component.d.ts +2 -2
  30. package/package.json +4 -4
  31. package/po-ui-ng-components-16.8.0.tgz +0 -0
  32. package/schematics/ng-add/index.js +1 -1
  33. package/schematics/ng-update/v14/index.js +1 -1
  34. package/schematics/ng-update/v15/index.js +1 -1
  35. package/schematics/ng-update/v16/index.js +1 -1
  36. package/schematics/ng-update/v2/index.js +1 -1
  37. package/schematics/ng-update/v3/index.js +1 -1
  38. package/schematics/ng-update/v4/index.js +1 -1
  39. package/schematics/ng-update/v5/index.js +1 -1
  40. package/schematics/ng-update/v6/index.js +1 -1
  41. package/esm2022/lib/components/po-search/po-search-filter-mode.enum.mjs +0 -17
  42. package/po-ui-ng-components-16.7.0.tgz +0 -0
@@ -1,35 +1,202 @@
1
- import { PoFilterMode } from './po-search-filter-mode.enum';
1
+ import { poLocaleDefault } from '../../services/po-language/po-language.constant';
2
2
  import { Directive, EventEmitter, Input, Output } from '@angular/core';
3
3
  import { convertToBoolean } from '../../utils/util';
4
+ import { poSearchLiteralsDefault } from './literals/po-search-literals-default';
5
+ import { PoSearchFilterMode } from './enum/po-search-filter-mode.enum';
4
6
  import * as i0 from "@angular/core";
7
+ import * as i1 from "../../services/po-language/po-language.service";
8
+ /**
9
+ * @description
10
+ *
11
+ * O componente search, também conhecido como barra de pesquisa, é utilizado para ajudar os usuários a localizar um determinado conteúdo
12
+ *
13
+ * Normalmente localizado no canto superior direito, junto com o ícone de lupa, uma vez que este ícone é amplamente reconhecido.
14
+ *
15
+ * Portanto, é de extrema importância que, ao utilizar este componente, as pessoas responsáveis por seu desenvolvimento considerem os seguintes critérios.
16
+ *
17
+ * #### Boas práticas
18
+ *
19
+ * Foram estruturados os padrões de usabilidade para auxiliar na utilização do componente e garantir uma boa experiência aos usuários. Por isso, é muito importante que ao utilizar este componente, as pessoas que o projetarem devem levar em consideração os seguintes critérios:
20
+ * - Utilize labels para apresentar resultados que estão sendo exibidos e apresente os resultados mais relevantes primeiro.
21
+ * - Exiba uma mensagem clara quando não forem encontrados resultados para busca e sempre que possível ofereça outras sugestões de busca.
22
+ * - Mantenha o texto original no campo de input, que facilita a ação do usuário caso queira fazer uma nova busca com alguma modificação na pesquisa.
23
+ * - Caso seja possível detectar um erro de digitação, mostre os resultados para a palavra "corrigida", isso evita a frustração de não obter resultados e não força o usuário a realizar uma nova busca.
24
+ * - Quando apropriado, destaque os termos da busca nos resultados.
25
+ * - A entrada do campo de pesquisa deve caber em uma linha. Não use entradas de pesquisa de várias linhas.
26
+ * - Recomenda-se ter apenas uma pesquisa por página. Se você precisar de várias pesquisas, rotule-as claramente para indicar sua finalidade.
27
+ * - Se possível, forneça sugestões de pesquisa, seja em um helptext ou sugestão de pesquisa que é um autocomplete. Isso ajuda os usuários a encontrar o que estão procurando, especialmente se os itens pesquisáveis forem complexos.
28
+ *
29
+ * #### Acessibilidade tratada no componente
30
+ *
31
+ * Algumas diretrizes de acessibilidade já são tratadas no componente, internamente, e não podem ser alteradas pelo proprietário do conteúdo. São elas:
32
+ *
33
+ * - Permitir a interação via teclado (2.1.1: Keyboard (A));
34
+ * - Alteração entre os estados precisa ser indicada por mais de um elemento além da cor (1.4.1: Use of Color);
35
+ */
5
36
  export class PoSearchBaseComponent {
37
+ _literals;
38
+ _ariaLabel;
39
+ language;
40
+ /**
41
+ * @optional
42
+ *
43
+ * @description
44
+ *
45
+ * Desabilita o po-search e não permite que o usuário interaja com o mesmo.
46
+ *
47
+ * @default `false`
48
+ */
6
49
  disabled;
7
- loading;
50
+ /**
51
+ * @optional
52
+ *
53
+ * @description
54
+ *
55
+ * Lista de itens que serão utilizados para pesquisa
56
+ */
8
57
  items = [];
58
+ /**
59
+ * @optional
60
+ *
61
+ * @description
62
+ *
63
+ * Define um aria-label para o po-search.
64
+ *
65
+ * > Devido o componente não possuir uma label assim como outros campos de texto, o `aria-label` é utilizado para acessibilidade.
66
+ */
67
+ set ariaLabel(value) {
68
+ this._ariaLabel = value;
69
+ if (value !== this.literals.search) {
70
+ this._ariaLabel = `${this._ariaLabel} ${this.literals.search}`;
71
+ }
72
+ }
73
+ get ariaLabel() {
74
+ return this._ariaLabel;
75
+ }
76
+ /**
77
+ * @optional
78
+ *
79
+ * @description
80
+ *
81
+ * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente (p-items), esta propriedade será responsável pelo texto de apresentação de cada item da lista.
82
+ */
9
83
  filterKeys = [];
10
- filterType = PoFilterMode.startsWith;
84
+ /**
85
+ * @optional
86
+ *
87
+ * @description
88
+ *
89
+ * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente (p-items), esta propriedade será responsável pelo texto de apresentação de cada item da lista.
90
+ */
91
+ icon;
92
+ /**
93
+ * @optional
94
+ *
95
+ * @description
96
+ *
97
+ * Objeto com as literais usadas no `po-search`.
98
+ *
99
+ * Para utilizar basta passar a literal que deseja customizar:
100
+ *
101
+ * ```
102
+ * const customLiterals: PoSearchLiterals = {
103
+ * search: 'Pesquisar',
104
+ * clean: 'Limpar',
105
+ * };
106
+ * ```
107
+ *
108
+ * E para carregar a literal customizada, basta apenas passar o objeto para o componente.
109
+ *
110
+ * ```
111
+ * <po-search
112
+ * [p-literals]="customLiterals">
113
+ * </po-search>
114
+ * ```
115
+ *
116
+ * > O objeto padrão de literais será traduzido de acordo com o idioma do
117
+ * [`PoI18nService`](/documentation/po-i18n) ou do browser.
118
+ */
119
+ set literals(value) {
120
+ if (value instanceof Object && !(value instanceof Array)) {
121
+ this._literals = {
122
+ ...poSearchLiteralsDefault[poLocaleDefault],
123
+ ...poSearchLiteralsDefault[this.language],
124
+ ...value
125
+ };
126
+ }
127
+ else {
128
+ this._literals = poSearchLiteralsDefault[this.language];
129
+ }
130
+ }
131
+ get literals() {
132
+ return this._literals || poSearchLiteralsDefault[this.language];
133
+ }
134
+ /**
135
+ * @optional
136
+ *
137
+ * @description
138
+ *
139
+ * Define o modo de pesquisa utilizado no campo de busca, quando habilitado. Valores definidos no enum: PoSearchFilterMode
140
+ *
141
+ * @default `startsWith`
142
+ */
143
+ filterType = PoSearchFilterMode.startsWith;
144
+ /**
145
+ * @optional
146
+ *
147
+ * @description
148
+ *
149
+ * Evento disparado ao alterar valor do model.
150
+ */
151
+ changeModel = new EventEmitter();
152
+ /**
153
+ * @optional
154
+ *
155
+ * @description
156
+ *
157
+ * Pode ser informada uma função que será disparada quando houver alterações no input.
158
+ */
11
159
  filteredItemsChange = new EventEmitter();
160
+ /**
161
+ * @optional
162
+ *
163
+ * @description
164
+ *
165
+ * Pode ser informada uma função que será disparada quando houver alterações nos filtros.
166
+ */
12
167
  filter = new EventEmitter();
13
- static ɵfac = function PoSearchBaseComponent_Factory(t) { return new (t || PoSearchBaseComponent)(); };
14
- static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoSearchBaseComponent, inputs: { disabled: ["p-disabled", "disabled", convertToBoolean], loading: ["p-loading", "loading"], items: ["p-items", "items"], filterKeys: ["p-filter-keys", "filterKeys"], filterType: ["p-filter-type", "filterType"] }, outputs: { filteredItemsChange: "p-filtered-items-change", filter: "p-filter" }, features: [i0.ɵɵInputTransformsFeature] });
168
+ constructor(languageService) {
169
+ this.language = languageService.getShortLanguage();
170
+ }
171
+ static ɵfac = function PoSearchBaseComponent_Factory(t) { return new (t || PoSearchBaseComponent)(i0.ɵɵdirectiveInject(i1.PoLanguageService)); };
172
+ static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoSearchBaseComponent, inputs: { disabled: ["p-disabled", "disabled", convertToBoolean], items: ["p-items", "items"], ariaLabel: ["p-aria-label", "ariaLabel"], filterKeys: ["p-filter-keys", "filterKeys"], icon: ["p-icon", "icon"], literals: ["p-literals", "literals"], filterType: ["p-filter-type", "filterType"] }, outputs: { changeModel: "p-change-model", filteredItemsChange: "p-filtered-items-change", filter: "p-filter" }, features: [i0.ɵɵInputTransformsFeature] });
15
173
  }
16
174
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoSearchBaseComponent, [{
17
175
  type: Directive
18
- }], null, { disabled: [{
176
+ }], function () { return [{ type: i1.PoLanguageService }]; }, { disabled: [{
19
177
  type: Input,
20
178
  args: [{ alias: 'p-disabled', transform: convertToBoolean }]
21
- }], loading: [{
22
- type: Input,
23
- args: ['p-loading']
24
179
  }], items: [{
25
180
  type: Input,
26
181
  args: ['p-items']
182
+ }], ariaLabel: [{
183
+ type: Input,
184
+ args: ['p-aria-label']
27
185
  }], filterKeys: [{
28
186
  type: Input,
29
187
  args: ['p-filter-keys']
188
+ }], icon: [{
189
+ type: Input,
190
+ args: ['p-icon']
191
+ }], literals: [{
192
+ type: Input,
193
+ args: ['p-literals']
30
194
  }], filterType: [{
31
195
  type: Input,
32
196
  args: ['p-filter-type']
197
+ }], changeModel: [{
198
+ type: Output,
199
+ args: ['p-change-model']
33
200
  }], filteredItemsChange: [{
34
201
  type: Output,
35
202
  args: ['p-filtered-items-change']
@@ -37,4 +204,4 @@ export class PoSearchBaseComponent {
37
204
  type: Output,
38
205
  args: ['p-filter']
39
206
  }] }); })();
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tc2VhcmNoLWJhc2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLXNlYXJjaC9wby1zZWFyY2gtYmFzZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBRTVELE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7O0FBR3BELE1BQU0sT0FBTyxxQkFBcUI7SUFDNkIsUUFBUSxDQUFXO0lBRTVELE9BQU8sQ0FBVTtJQUVuQixLQUFLLEdBQWUsRUFBRSxDQUFDO0lBRWpCLFVBQVUsR0FBZSxFQUFFLENBQUM7SUFFNUIsVUFBVSxHQUFpQixZQUFZLENBQUMsVUFBVSxDQUFDO0lBRXhDLG1CQUFtQixHQUFHLElBQUksWUFBWSxFQUFjLENBQUM7SUFFcEUsTUFBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDOytFQWI3RCxxQkFBcUI7NkRBQXJCLHFCQUFxQixpREFDUyxnQkFBZ0I7O3VGQUQ5QyxxQkFBcUI7Y0FEakMsU0FBUztnQkFFcUQsUUFBUTtrQkFBcEUsS0FBSzttQkFBQyxFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFO1lBRXZDLE9BQU87a0JBQTFCLEtBQUs7bUJBQUMsV0FBVztZQUVBLEtBQUs7a0JBQXRCLEtBQUs7bUJBQUMsU0FBUztZQUVRLFVBQVU7a0JBQWpDLEtBQUs7bUJBQUMsZUFBZTtZQUVFLFVBQVU7a0JBQWpDLEtBQUs7bUJBQUMsZUFBZTtZQUVhLG1CQUFtQjtrQkFBckQsTUFBTTttQkFBQyx5QkFBeUI7WUFFYixNQUFNO2tCQUF6QixNQUFNO21CQUFDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQb0ZpbHRlck1vZGUgfSBmcm9tICcuL3BvLXNlYXJjaC1maWx0ZXItbW9kZS5lbnVtJztcblxuaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGNvbnZlcnRUb0Jvb2xlYW4gfSBmcm9tICcuLi8uLi91dGlscy91dGlsJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgUG9TZWFyY2hCYXNlQ29tcG9uZW50IHtcbiAgQElucHV0KHsgYWxpYXM6ICdwLWRpc2FibGVkJywgdHJhbnNmb3JtOiBjb252ZXJ0VG9Cb29sZWFuIH0pIGRpc2FibGVkPzogYm9vbGVhbjtcblxuICBASW5wdXQoJ3AtbG9hZGluZycpIGxvYWRpbmc6IGJvb2xlYW47XG5cbiAgQElucHV0KCdwLWl0ZW1zJykgaXRlbXM6IEFycmF5PGFueT4gPSBbXTtcblxuICBASW5wdXQoJ3AtZmlsdGVyLWtleXMnKSBmaWx0ZXJLZXlzOiBBcnJheTxhbnk+ID0gW107XG5cbiAgQElucHV0KCdwLWZpbHRlci10eXBlJykgZmlsdGVyVHlwZTogUG9GaWx0ZXJNb2RlID0gUG9GaWx0ZXJNb2RlLnN0YXJ0c1dpdGg7XG5cbiAgQE91dHB1dCgncC1maWx0ZXJlZC1pdGVtcy1jaGFuZ2UnKSBmaWx0ZXJlZEl0ZW1zQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxBcnJheTxhbnk+PigpO1xuXG4gIEBPdXRwdXQoJ3AtZmlsdGVyJykgZmlsdGVyOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xufVxuIl19
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-search-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-search/po-search-base.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,iDAAiD,CAAC;AAElF,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAe,MAAM,eAAe,CAAC;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAEpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,uCAAuC,CAAC;AAChF,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;;;AAEvE;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AAEH,MAAM,OAAO,qBAAqB;IACxB,SAAS,CAAoB;IAC7B,UAAU,CAAU;IACpB,QAAQ,CAAS;IAEzB;;;;;;;;OAQG;IAC0D,QAAQ,CAAW;IAEhF;;;;;;OAMG;IACe,KAAK,GAAe,EAAE,CAAC;IAEzC;;;;;;;;OAQG;IACH,IAA2B,SAAS,CAAC,KAAa;QAChD,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAExB,IAAI,KAAK,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YAClC,IAAI,CAAC,UAAU,GAAG,GAAG,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;SAChE;IACH,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;;;;OAMG;IACqB,UAAU,GAAe,EAAE,CAAC;IAEpD;;;;;;OAMG;IACc,IAAI,CAA6B;IAElD;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BG;IACH,IAAyB,QAAQ,CAAC,KAAuB;QACvD,IAAI,KAAK,YAAY,MAAM,IAAI,CAAC,CAAC,KAAK,YAAY,KAAK,CAAC,EAAE;YACxD,IAAI,CAAC,SAAS,GAAG;gBACf,GAAG,uBAAuB,CAAC,eAAe,CAAC;gBAC3C,GAAG,uBAAuB,CAAC,IAAI,CAAC,QAAQ,CAAC;gBACzC,GAAG,KAAK;aACT,CAAC;SACH;aAAM;YACL,IAAI,CAAC,SAAS,GAAG,uBAAuB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACzD;IACH,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,IAAI,uBAAuB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAClE,CAAC;IAED;;;;;;;;OAQG;IACqB,UAAU,GAAuB,kBAAkB,CAAC,UAAU,CAAC;IAEvF;;;;;;OAMG;IACuB,WAAW,GAAsB,IAAI,YAAY,EAAE,CAAC;IAE9E;;;;;;OAMG;IACgC,mBAAmB,GAAG,IAAI,YAAY,EAAc,CAAC;IAExF;;;;;;OAMG;IACiB,MAAM,GAAsB,IAAI,YAAY,EAAO,CAAC;IAExE,YAAY,eAAkC;QAC5C,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,gBAAgB,EAAE,CAAC;IACrD,CAAC;+EAnJU,qBAAqB;6DAArB,qBAAqB,iDAcS,gBAAgB;;uFAd9C,qBAAqB;cADjC,SAAS;oEAeqD,QAAQ;kBAApE,KAAK;mBAAC,EAAE,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,gBAAgB,EAAE;YASzC,KAAK;kBAAtB,KAAK;mBAAC,SAAS;YAWW,SAAS;kBAAnC,KAAK;mBAAC,cAAc;YAmBG,UAAU;kBAAjC,KAAK;mBAAC,eAAe;YASL,IAAI;kBAApB,KAAK;mBAAC,QAAQ;YA6BU,QAAQ;kBAAhC,KAAK;mBAAC,YAAY;YAyBK,UAAU;kBAAjC,KAAK;mBAAC,eAAe;YASI,WAAW;kBAApC,MAAM;mBAAC,gBAAgB;YASW,mBAAmB;kBAArD,MAAM;mBAAC,yBAAyB;YASb,MAAM;kBAAzB,MAAM;mBAAC,UAAU","sourcesContent":["import { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { poLocaleDefault } from '../../services/po-language/po-language.constant';\n\nimport { Directive, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { convertToBoolean } from '../../utils/util';\nimport { PoSearchLiterals } from './literals/po-search-literals';\nimport { poSearchLiteralsDefault } from './literals/po-search-literals-default';\nimport { PoSearchFilterMode } from './enum/po-search-filter-mode.enum';\n\n/**\n * @description\n *\n * O componente search, também conhecido como barra de pesquisa, é utilizado para ajudar os usuários a localizar um determinado conteúdo\n *\n * Normalmente localizado no canto superior direito, junto com o ícone de lupa, uma vez que este ícone é amplamente reconhecido.\n *\n * Portanto, é de extrema importância que, ao utilizar este componente, as pessoas responsáveis por seu desenvolvimento considerem os seguintes critérios.\n *\n * #### Boas práticas\n *\n * Foram estruturados os padrões de usabilidade para auxiliar na utilização do componente e garantir uma boa experiência aos usuários. Por isso, é muito importante que ao utilizar este componente, as pessoas que o projetarem devem levar em consideração os seguintes critérios:\n * - Utilize labels para apresentar resultados que estão sendo exibidos e apresente os resultados mais relevantes primeiro.\n * - Exiba uma mensagem clara quando não forem encontrados resultados para busca e sempre que possível ofereça outras sugestões de busca.\n * - Mantenha o texto original no campo de input, que facilita a ação do usuário caso queira fazer uma nova busca com alguma modificação na pesquisa.\n * - Caso seja possível detectar um erro de digitação, mostre os resultados para a palavra \"corrigida\", isso evita a frustração de não obter resultados e não força o usuário a realizar uma nova busca.\n * - Quando apropriado, destaque os termos da busca nos resultados.\n * - A entrada do campo de pesquisa deve caber em uma linha. Não use entradas de pesquisa de várias linhas.\n * - Recomenda-se ter apenas uma pesquisa por página. Se você precisar de várias pesquisas, rotule-as claramente para indicar sua finalidade.\n * - Se possível, forneça sugestões de pesquisa, seja em um helptext ou sugestão de pesquisa que é um autocomplete. Isso ajuda os usuários a encontrar o que estão procurando, especialmente se os itens pesquisáveis forem complexos.\n *\n * #### Acessibilidade tratada no componente\n *\n *  Algumas diretrizes de acessibilidade já são tratadas no componente, internamente, e não podem ser alteradas pelo proprietário do conteúdo. São elas:\n *\n * - Permitir a interação via teclado (2.1.1: Keyboard (A));\n * - Alteração entre os estados precisa ser indicada por mais de um elemento além da cor (1.4.1: Use of Color);\n */\n@Directive()\nexport class PoSearchBaseComponent {\n  private _literals?: PoSearchLiterals;\n  private _ariaLabel?: string;\n  private language: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Desabilita o po-search e não permite que o usuário interaja com o mesmo.\n   *\n   * @default `false`\n   */\n  @Input({ alias: 'p-disabled', transform: convertToBoolean }) disabled?: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista de itens que serão utilizados para pesquisa\n   */\n  @Input('p-items') items: Array<any> = [];\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define um aria-label para o po-search.\n   *\n   * > Devido o componente não possuir uma label assim como outros campos de texto, o `aria-label` é utilizado para acessibilidade.\n   */\n  @Input('p-aria-label') set ariaLabel(value: string) {\n    this._ariaLabel = value;\n\n    if (value !== this.literals.search) {\n      this._ariaLabel = `${this._ariaLabel} ${this.literals.search}`;\n    }\n  }\n\n  get ariaLabel(): string {\n    return this._ariaLabel;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente (p-items), esta propriedade será responsável pelo texto de apresentação de cada item da lista.\n   */\n  @Input('p-filter-keys') filterKeys: Array<any> = [];\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente (p-items), esta propriedade será responsável pelo texto de apresentação de cada item da lista.\n   */\n  @Input('p-icon') icon: string | TemplateRef<void>;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Objeto com as literais usadas no `po-search`.\n   *\n   * Para utilizar basta passar a literal que deseja customizar:\n   *\n   * ```\n   *  const customLiterals: PoSearchLiterals = {\n   *    search: 'Pesquisar',\n   *    clean: 'Limpar',\n   *  };\n   * ```\n   *\n   * E para carregar a literal customizada, basta apenas passar o objeto para o componente.\n   *\n   * ```\n   * <po-search\n   *   [p-literals]=\"customLiterals\">\n   * </po-search>\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: PoSearchLiterals) {\n    if (value instanceof Object && !(value instanceof Array)) {\n      this._literals = {\n        ...poSearchLiteralsDefault[poLocaleDefault],\n        ...poSearchLiteralsDefault[this.language],\n        ...value\n      };\n    } else {\n      this._literals = poSearchLiteralsDefault[this.language];\n    }\n  }\n\n  get literals() {\n    return this._literals || poSearchLiteralsDefault[this.language];\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o modo de pesquisa utilizado no campo de busca, quando habilitado. Valores definidos no enum: PoSearchFilterMode\n   *\n   * @default `startsWith`\n   */\n  @Input('p-filter-type') filterType: PoSearchFilterMode = PoSearchFilterMode.startsWith;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor do model.\n   */\n  @Output('p-change-model') changeModel: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Pode ser informada uma função que será disparada quando houver alterações no input.\n   */\n  @Output('p-filtered-items-change') filteredItemsChange = new EventEmitter<Array<any>>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Pode ser informada uma função que será disparada quando houver alterações nos filtros.\n   */\n  @Output('p-filter') filter: EventEmitter<any> = new EventEmitter<any>();\n\n  constructor(languageService: PoLanguageService) {\n    this.language = languageService.getShortLanguage();\n  }\n}\n"]}
@@ -1,59 +1,63 @@
1
- import { PoFilterMode } from './po-search-filter-mode.enum';
2
1
  import { Component, ElementRef, ViewChild } from '@angular/core';
3
2
  import { PoSearchBaseComponent } from './po-search-base.component';
3
+ import { PoSearchFilterMode } from './enum/po-search-filter-mode.enum';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "../../services/po-language/po-language.service";
6
6
  import * as i2 from "@angular/common";
7
- import * as i3 from "../po-field/po-clean/po-clean.component";
8
- import * as i4 from "../po-icon/po-icon.component";
9
- import * as i5 from "../po-loading/po-loading-icon/po-loading-icon.component";
7
+ import * as i3 from "../po-icon/po-icon.component";
10
8
  const _c0 = ["poSearchInput"];
11
- function PoSearchComponent_po_icon_2_Template(rf, ctx) { if (rf & 1) {
12
- i0.ɵɵelement(0, "po-icon", 7);
13
- } }
14
- function PoSearchComponent_po_loading_icon_3_Template(rf, ctx) { if (rf & 1) {
15
- i0.ɵɵelement(0, "po-loading-icon", 8);
16
- } }
17
- function PoSearchComponent_div_6_Template(rf, ctx) { if (rf & 1) {
18
- const _r5 = i0.ɵɵgetCurrentView();
19
- i0.ɵɵelementStart(0, "div", 9)(1, "po-clean", 10);
20
- i0.ɵɵlistener("p-change-event", function PoSearchComponent_div_6_Template_po_clean_p_change_event_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.clearSearch()); });
9
+ function PoSearchComponent_div_5_Template(rf, ctx) { if (rf & 1) {
10
+ const _r3 = i0.ɵɵgetCurrentView();
11
+ i0.ɵɵelementStart(0, "div", 6)(1, "button", 7);
12
+ i0.ɵɵlistener("click", function PoSearchComponent_div_5_Template_button_click_1_listener() { i0.ɵɵrestoreView(_r3); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.clearSearch()); })("keydown.enter", function PoSearchComponent_div_5_Template_button_keydown_enter_1_listener() { i0.ɵɵrestoreView(_r3); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.clearSearch()); });
13
+ i0.ɵɵelement(2, "po-icon", 8);
21
14
  i0.ɵɵelementEnd()();
22
15
  } if (rf & 2) {
23
- const ctx_r3 = i0.ɵɵnextContext();
24
- const _r2 = i0.ɵɵreference(5);
25
- i0.ɵɵproperty("tabindex", !ctx_r3.disabled ? 0 : -1);
16
+ const ctx_r1 = i0.ɵɵnextContext();
26
17
  i0.ɵɵadvance(1);
27
- i0.ɵɵproperty("p-element-ref", _r2);
18
+ i0.ɵɵproperty("ariaLabel", ctx_r1.literals.clean);
28
19
  } }
29
- export const poSearchLiteralsDefault = {
30
- en: { search: 'Search' },
31
- es: { search: 'Buscar' },
32
- pt: { search: 'Pesquisar' },
33
- ru: { search: 'Поиск' }
34
- };
20
+ /**
21
+ * @docsExtends PoSearchBaseComponent
22
+ *
23
+ * @example
24
+ *
25
+ * <example name="po-search-basic" title="PO Search Basic">
26
+ * <file name="sample-po-search-basic/sample-po-search-basic.component.html"> </file>
27
+ * <file name="sample-po-search-basic/sample-po-search-basic.component.ts"> </file>
28
+ * </example>
29
+ *
30
+ * <example name="po-search-labs" title="PO Search Labs">
31
+ * <file name="sample-po-search-labs/sample-po-search-labs.component.html"> </file>
32
+ * <file name="sample-po-search-labs/sample-po-search-labs.component.ts"> </file>
33
+ * <file name="sample-po-search-labs/sample-po-search-labs.service.ts"> </file>
34
+ * </example>
35
+ *
36
+ * <example name="po-search-find-people" title="PO Search Find People">
37
+ * <file name="sample-po-search-find-people/sample-po-search-find-people.component.html"> </file>
38
+ * <file name="sample-po-search-find-people/sample-po-search-find-people.component.ts"> </file>
39
+ * <file name="sample-po-search-find-people/sample-po-search-find-people.service.ts"> </file>
40
+ * </example>
41
+ *
42
+ */
35
43
  export class PoSearchComponent extends PoSearchBaseComponent {
36
44
  languageService;
37
45
  renderer;
38
46
  poSearchInput;
39
47
  filteredItems = [];
40
- literals;
41
48
  constructor(languageService, renderer) {
42
- super();
49
+ super(languageService);
43
50
  this.languageService = languageService;
44
51
  this.renderer = renderer;
45
52
  }
46
53
  ngOnInit() {
47
- this.literals = {
48
- ...poSearchLiteralsDefault[this.languageService?.getLanguageDefault()],
49
- ...poSearchLiteralsDefault[this.languageService?.getShortLanguage()]
50
- };
51
54
  this.filteredItems = this.items;
52
55
  }
53
56
  clearSearch() {
54
57
  this.poSearchInput.nativeElement.value = '';
55
58
  this.onSearchChange('');
56
59
  this.filteredItemsChange.emit(this.items);
60
+ this.poSearchInput.nativeElement.focus();
57
61
  }
58
62
  onBlur() {
59
63
  this.renderer.removeClass(this.poSearchInput.nativeElement.parentElement, 'po-search-focused');
@@ -70,13 +74,13 @@ export class PoSearchComponent extends PoSearchBaseComponent {
70
74
  value = value != null ? value.toString() : null;
71
75
  }
72
76
  value = value != null ? value.toLowerCase() : null;
73
- if (this.filterType === PoFilterMode.startsWith) {
77
+ if (this.filterType === PoSearchFilterMode.startsWith) {
74
78
  return value != null && value.startsWith(searchText);
75
79
  }
76
- else if (this.filterType === PoFilterMode.contains) {
80
+ else if (this.filterType === PoSearchFilterMode.contains) {
77
81
  return value != null && value.includes(searchText);
78
82
  }
79
- else if (this.filterType === PoFilterMode.endsWith) {
83
+ else if (this.filterType === PoSearchFilterMode.endsWith) {
80
84
  return value != null && value.endsWith(searchText);
81
85
  }
82
86
  return false;
@@ -87,6 +91,7 @@ export class PoSearchComponent extends PoSearchBaseComponent {
87
91
  this.filteredItems = [];
88
92
  this.filteredItemsChange.emit(this.filteredItems);
89
93
  }
94
+ this.changeModel.emit(searchText);
90
95
  }
91
96
  static ɵfac = function PoSearchComponent_Factory(t) { return new (t || PoSearchComponent)(i0.ɵɵdirectiveInject(i1.PoLanguageService), i0.ɵɵdirectiveInject(i0.Renderer2)); };
92
97
  static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSearchComponent, selectors: [["po-search"]], viewQuery: function PoSearchComponent_Query(rf, ctx) { if (rf & 1) {
@@ -94,33 +99,32 @@ export class PoSearchComponent extends PoSearchBaseComponent {
94
99
  } if (rf & 2) {
95
100
  let _t;
96
101
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.poSearchInput = _t.first);
97
- } }, features: [i0.ɵɵInheritDefinitionFeature], decls: 7, vars: 5, consts: [[1, "po-search"], [1, "po-search-icon"], ["p-icon", "po-icon-search", 4, "ngIf"], ["p-size", "sm", 4, "ngIf"], ["type", "text", 3, "disabled", "placeholder", "blur", "focus", "input"], ["poSearchInput", ""], ["class", "po-search-clean", 3, "tabindex", 4, "ngIf"], ["p-icon", "po-icon-search"], ["p-size", "sm"], [1, "po-search-clean", 3, "tabindex"], [3, "p-element-ref", "p-change-event"]], template: function PoSearchComponent_Template(rf, ctx) { if (rf & 1) {
102
+ } }, features: [i0.ɵɵInheritDefinitionFeature], decls: 6, vars: 9, consts: [[1, "po-search"], [1, "po-search-icon"], [3, "p-icon"], ["type", "text", 1, "po-search-input", 3, "ariaLabel", "disabled", "placeholder", "blur", "focus", "input"], ["poSearchInput", ""], ["class", "po-search-container-clean", 4, "ngIf"], [1, "po-search-container-clean"], [1, "po-search-clean", 3, "ariaLabel", "click", "keydown.enter"], ["p-icon", "po-icon-clear-content"]], template: function PoSearchComponent_Template(rf, ctx) { if (rf & 1) {
98
103
  i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
99
- i0.ɵɵtemplate(2, PoSearchComponent_po_icon_2_Template, 1, 0, "po-icon", 2);
100
- i0.ɵɵtemplate(3, PoSearchComponent_po_loading_icon_3_Template, 1, 0, "po-loading-icon", 3);
104
+ i0.ɵɵelement(2, "po-icon", 2);
101
105
  i0.ɵɵelementEnd();
102
- i0.ɵɵelementStart(4, "input", 4, 5);
103
- i0.ɵɵlistener("blur", function PoSearchComponent_Template_input_blur_4_listener() { return ctx.onBlur(); })("focus", function PoSearchComponent_Template_input_focus_4_listener() { return ctx.onFocus(); })("input", function PoSearchComponent_Template_input_input_4_listener($event) { return ctx.onSearchChange($event.target.value); });
106
+ i0.ɵɵelementStart(3, "input", 3, 4);
107
+ i0.ɵɵlistener("blur", function PoSearchComponent_Template_input_blur_3_listener() { return ctx.onBlur(); })("focus", function PoSearchComponent_Template_input_focus_3_listener() { return ctx.onFocus(); })("input", function PoSearchComponent_Template_input_input_3_listener($event) { return ctx.onSearchChange($event.target.value); });
104
108
  i0.ɵɵelementEnd();
105
- i0.ɵɵtemplate(6, PoSearchComponent_div_6_Template, 2, 2, "div", 6);
109
+ i0.ɵɵtemplate(5, PoSearchComponent_div_5_Template, 3, 1, "div", 5);
106
110
  i0.ɵɵelementEnd();
107
111
  } if (rf & 2) {
108
- const _r2 = i0.ɵɵreference(5);
112
+ const _r0 = i0.ɵɵreference(4);
113
+ i0.ɵɵclassProp("po-search-disabled", ctx.disabled);
109
114
  i0.ɵɵadvance(2);
110
- i0.ɵɵproperty("ngIf", !ctx.loading);
111
- i0.ɵɵadvance(1);
112
- i0.ɵɵproperty("ngIf", ctx.loading);
115
+ i0.ɵɵproperty("p-icon", ctx.icon ? ctx.icon : "po-icon-search");
113
116
  i0.ɵɵadvance(1);
114
- i0.ɵɵproperty("disabled", ctx.disabled)("placeholder", ctx.literals.search);
117
+ i0.ɵɵclassProp("po-search-icon-right", !!_r0.value && !ctx.disabled);
118
+ i0.ɵɵproperty("ariaLabel", ctx.ariaLabel)("disabled", ctx.disabled)("placeholder", ctx.literals.search);
115
119
  i0.ɵɵadvance(2);
116
- i0.ɵɵproperty("ngIf", !!_r2.value && !ctx.disabled);
117
- } }, dependencies: [i2.NgIf, i3.PoCleanComponent, i4.PoIconComponent, i5.PoLoadingIconComponent], encapsulation: 2 });
120
+ i0.ɵɵproperty("ngIf", !!_r0.value && !ctx.disabled);
121
+ } }, dependencies: [i2.NgIf, i3.PoIconComponent], encapsulation: 2 });
118
122
  }
119
123
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoSearchComponent, [{
120
124
  type: Component,
121
- args: [{ selector: 'po-search', template: "<div class=\"po-search\">\n <div class=\"po-search-icon\">\n <po-icon *ngIf=\"!loading\" p-icon=\"po-icon-search\"></po-icon>\n <po-loading-icon *ngIf=\"loading\" p-size=\"sm\"></po-loading-icon>\n </div>\n\n <input\n #poSearchInput\n type=\"text\"\n [disabled]=\"disabled\"\n [placeholder]=\"literals.search\"\n (blur)=\"onBlur()\"\n (focus)=\"onFocus()\"\n (input)=\"onSearchChange($event.target.value)\"\n />\n\n <div *ngIf=\"!!poSearchInput.value && !disabled\" class=\"po-search-clean\" [tabindex]=\"!disabled ? 0 : -1\">\n <po-clean [p-element-ref]=\"poSearchInput\" (p-change-event)=\"clearSearch()\"></po-clean>\n </div>\n</div>\n" }]
125
+ args: [{ selector: 'po-search', template: "<div class=\"po-search\" [class.po-search-disabled]=\"disabled\">\n <div class=\"po-search-icon\">\n <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"></po-icon>\n </div>\n\n <input\n #poSearchInput\n type=\"text\"\n class=\"po-search-input\"\n [ariaLabel]=\"ariaLabel\"\n [class.po-search-icon-right]=\"!!poSearchInput.value && !disabled\"\n [disabled]=\"disabled\"\n [placeholder]=\"literals.search\"\n (blur)=\"onBlur()\"\n (focus)=\"onFocus()\"\n (input)=\"onSearchChange($event.target.value)\"\n />\n\n <div *ngIf=\"!!poSearchInput.value && !disabled\" class=\"po-search-container-clean\">\n <button\n class=\"po-search-clean\"\n [ariaLabel]=\"literals.clean\"\n (click)=\"clearSearch()\"\n (keydown.enter)=\"clearSearch()\"\n >\n <po-icon p-icon=\"po-icon-clear-content\"></po-icon>\n </button>\n </div>\n</div>\n" }]
122
126
  }], function () { return [{ type: i1.PoLanguageService }, { type: i0.Renderer2 }]; }, { poSearchInput: [{
123
127
  type: ViewChild,
124
128
  args: ['poSearchInput', { read: ElementRef, static: true }]
125
129
  }] }); })();
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-search.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-search/po-search.component.ts","../../../../../../projects/ui/src/lib/components/po-search/po-search.component.html"],"names":[],"mappings":"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","sourcesContent":["import { PoFilterMode } from './po-search-filter-mode.enum';\n\nimport { Component, ElementRef, OnInit, Renderer2, ViewChild } from '@angular/core';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { PoSearchLiterals } from './literals/po-search-literals';\nimport { PoSearchBaseComponent } from './po-search-base.component';\n\nexport const poSearchLiteralsDefault = {\n  en: <PoSearchLiterals>{ search: 'Search' },\n  es: <PoSearchLiterals>{ search: 'Buscar' },\n  pt: <PoSearchLiterals>{ search: 'Pesquisar' },\n  ru: <PoSearchLiterals>{ search: 'Поиск' }\n};\n\n@Component({\n  selector: 'po-search',\n  templateUrl: './po-search.component.html'\n})\nexport class PoSearchComponent extends PoSearchBaseComponent implements OnInit {\n  @ViewChild('poSearchInput', { read: ElementRef, static: true }) poSearchInput: ElementRef;\n\n  filteredItems: Array<any> = [];\n\n  public literals?: any;\n\n  constructor(public languageService: PoLanguageService, private renderer: Renderer2) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.literals = {\n      ...poSearchLiteralsDefault[this.languageService?.getLanguageDefault()],\n      ...poSearchLiteralsDefault[this.languageService?.getShortLanguage()]\n    };\n\n    this.filteredItems = this.items;\n  }\n\n  clearSearch(): void {\n    this.poSearchInput.nativeElement.value = '';\n    this.onSearchChange('');\n    this.filteredItemsChange.emit(this.items);\n  }\n\n  onBlur(): void {\n    this.renderer.removeClass(this.poSearchInput.nativeElement.parentElement, 'po-search-focused');\n  }\n\n  onFocus(): void {\n    this.renderer.addClass(this.poSearchInput.nativeElement.parentElement, 'po-search-focused');\n  }\n\n  onSearchChange(searchText: string): void {\n    searchText = searchText.toLowerCase();\n\n    if (this.items && this.items.length > 0) {\n      this.filteredItems = this.items.filter(item =>\n        this.filterKeys.some(key => {\n          let value = item[key];\n\n          if (typeof value !== 'string') {\n            value = value != null ? value.toString() : null;\n          }\n\n          value = value != null ? value.toLowerCase() : null;\n\n          if (this.filterType === PoFilterMode.startsWith) {\n            return value != null && value.startsWith(searchText);\n          } else if (this.filterType === PoFilterMode.contains) {\n            return value != null && value.includes(searchText);\n          } else if (this.filterType === PoFilterMode.endsWith) {\n            return value != null && value.endsWith(searchText);\n          }\n\n          return false;\n        })\n      );\n\n      this.filteredItemsChange.emit(this.filteredItems);\n    } else {\n      this.filteredItems = [];\n      this.filteredItemsChange.emit(this.filteredItems);\n    }\n  }\n}\n","<div class=\"po-search\">\n  <div class=\"po-search-icon\">\n    <po-icon *ngIf=\"!loading\" p-icon=\"po-icon-search\"></po-icon>\n    <po-loading-icon *ngIf=\"loading\" p-size=\"sm\"></po-loading-icon>\n  </div>\n\n  <input\n    #poSearchInput\n    type=\"text\"\n    [disabled]=\"disabled\"\n    [placeholder]=\"literals.search\"\n    (blur)=\"onBlur()\"\n    (focus)=\"onFocus()\"\n    (input)=\"onSearchChange($event.target.value)\"\n  />\n\n  <div *ngIf=\"!!poSearchInput.value && !disabled\" class=\"po-search-clean\" [tabindex]=\"!disabled ? 0 : -1\">\n    <po-clean [p-element-ref]=\"poSearchInput\" (p-change-event)=\"clearSearch()\"></po-clean>\n  </div>\n</div>\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-search.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-search/po-search.component.ts","../../../../../../projects/ui/src/lib/components/po-search/po-search.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnInit, Renderer2, ViewChild } from '@angular/core';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { PoSearchBaseComponent } from './po-search-base.component';\nimport { PoSearchFilterMode } from './enum/po-search-filter-mode.enum';\n\n/**\n * @docsExtends PoSearchBaseComponent\n *\n * @example\n *\n * <example name=\"po-search-basic\" title=\"PO Search Basic\">\n *  <file name=\"sample-po-search-basic/sample-po-search-basic.component.html\"> </file>\n *  <file name=\"sample-po-search-basic/sample-po-search-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-search-labs\" title=\"PO Search Labs\">\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.component.html\"> </file>\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.component.ts\"> </file>\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-search-find-people\" title=\"PO Search Find People\">\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.component.html\"> </file>\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.component.ts\"> </file>\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.service.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-search',\n  templateUrl: './po-search.component.html'\n})\nexport class PoSearchComponent extends PoSearchBaseComponent implements OnInit {\n  @ViewChild('poSearchInput', { read: ElementRef, static: true }) poSearchInput: ElementRef;\n\n  filteredItems: Array<any> = [];\n\n  constructor(public languageService: PoLanguageService, private renderer: Renderer2) {\n    super(languageService);\n  }\n\n  ngOnInit(): void {\n    this.filteredItems = this.items;\n  }\n\n  clearSearch(): void {\n    this.poSearchInput.nativeElement.value = '';\n    this.onSearchChange('');\n    this.filteredItemsChange.emit(this.items);\n    this.poSearchInput.nativeElement.focus();\n  }\n\n  onBlur(): void {\n    this.renderer.removeClass(this.poSearchInput.nativeElement.parentElement, 'po-search-focused');\n  }\n\n  onFocus(): void {\n    this.renderer.addClass(this.poSearchInput.nativeElement.parentElement, 'po-search-focused');\n  }\n\n  onSearchChange(searchText: string): void {\n    searchText = searchText.toLowerCase();\n\n    if (this.items && this.items.length > 0) {\n      this.filteredItems = this.items.filter(item =>\n        this.filterKeys.some(key => {\n          let value = item[key];\n\n          if (typeof value !== 'string') {\n            value = value != null ? value.toString() : null;\n          }\n\n          value = value != null ? value.toLowerCase() : null;\n\n          if (this.filterType === PoSearchFilterMode.startsWith) {\n            return value != null && value.startsWith(searchText);\n          } else if (this.filterType === PoSearchFilterMode.contains) {\n            return value != null && value.includes(searchText);\n          } else if (this.filterType === PoSearchFilterMode.endsWith) {\n            return value != null && value.endsWith(searchText);\n          }\n\n          return false;\n        })\n      );\n      this.filteredItemsChange.emit(this.filteredItems);\n    } else {\n      this.filteredItems = [];\n      this.filteredItemsChange.emit(this.filteredItems);\n    }\n    this.changeModel.emit(searchText);\n  }\n}\n","<div class=\"po-search\" [class.po-search-disabled]=\"disabled\">\n  <div class=\"po-search-icon\">\n    <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"></po-icon>\n  </div>\n\n  <input\n    #poSearchInput\n    type=\"text\"\n    class=\"po-search-input\"\n    [ariaLabel]=\"ariaLabel\"\n    [class.po-search-icon-right]=\"!!poSearchInput.value && !disabled\"\n    [disabled]=\"disabled\"\n    [placeholder]=\"literals.search\"\n    (blur)=\"onBlur()\"\n    (focus)=\"onFocus()\"\n    (input)=\"onSearchChange($event.target.value)\"\n  />\n\n  <div *ngIf=\"!!poSearchInput.value && !disabled\" class=\"po-search-container-clean\">\n    <button\n      class=\"po-search-clean\"\n      [ariaLabel]=\"literals.clean\"\n      (click)=\"clearSearch()\"\n      (keydown.enter)=\"clearSearch()\"\n    >\n      <po-icon p-icon=\"po-icon-clear-content\"></po-icon>\n    </button>\n  </div>\n</div>\n"]}