@po-ui/ng-components 6.6.0 → 6.9.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.
- package/esm2020/lib/components/po-chart/interfaces/po-chart-serie.interface.mjs +1 -1
- package/esm2020/lib/components/po-field/po-checkbox/po-checkbox-base.component.mjs +12 -4
- package/esm2020/lib/components/po-field/po-checkbox/po-checkbox.component.mjs +15 -10
- package/esm2020/lib/components/po-field/po-combo/po-combo-base.component.mjs +45 -3
- package/esm2020/lib/components/po-field/po-combo/po-combo-filter.service.mjs +16 -8
- package/esm2020/lib/components/po-field/po-combo/po-combo.component.mjs +221 -112
- package/esm2020/lib/components/po-field/po-rich-text/po-rich-text-toolbar/po-rich-text-toolbar.component.mjs +5 -3
- package/esm2020/lib/components/po-table/po-table-base.component.mjs +18 -2
- package/esm2020/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.mjs +10 -2
- package/esm2020/lib/components/po-table/po-table.component.mjs +987 -433
- package/esm2020/lib/directives/po-tooltip/po-tooltip-base.directive.mjs +2 -2
- package/esm2020/lib/directives/po-tooltip/po-tooltip.directive.mjs +32 -2
- package/esm2020/lib/services/po-color/po-color.service.mjs +3 -2
- package/fesm2015/po-ui-ng-components.mjs +1515 -601
- package/fesm2015/po-ui-ng-components.mjs.map +1 -1
- package/fesm2020/po-ui-ng-components.mjs +1346 -565
- package/fesm2020/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-chart/interfaces/po-chart-serie.interface.d.ts +3 -0
- package/lib/components/po-field/po-checkbox/po-checkbox-base.component.d.ts +12 -4
- package/lib/components/po-field/po-checkbox/po-checkbox.component.d.ts +2 -2
- package/lib/components/po-field/po-combo/po-combo-base.component.d.ts +30 -1
- package/lib/components/po-field/po-combo/po-combo-filter.service.d.ts +3 -0
- package/lib/components/po-field/po-combo/po-combo.component.d.ts +22 -3
- package/lib/components/po-table/po-table-base.component.d.ts +12 -1
- package/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.d.ts +3 -1
- package/lib/components/po-table/po-table.component.d.ts +3 -0
- package/lib/directives/po-tooltip/po-tooltip-base.directive.d.ts +1 -1
- package/lib/directives/po-tooltip/po-tooltip.directive.d.ts +3 -0
- package/lib/services/po-color/po-color.service.d.ts +1 -0
- package/package.json +4 -4
- package/po-ui-ng-components-6.9.0.tgz +0 -0
- 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/schematics/ng-update/v6/index.js +1 -1
- package/po-ui-ng-components-6.6.0.tgz +0 -0
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { HttpHeaders } from '@angular/common/http';
|
|
2
2
|
import { Injectable } from '@angular/core';
|
|
3
|
-
import {
|
|
3
|
+
import { fromEvent } from 'rxjs';
|
|
4
|
+
import { debounceTime, map, tap } from 'rxjs/operators';
|
|
4
5
|
import { validateObjectType } from '../../../utils/util';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/common/http";
|
|
@@ -16,6 +17,7 @@ export class PoComboFilterService {
|
|
|
16
17
|
this.http = http;
|
|
17
18
|
this.fieldLabel = 'label';
|
|
18
19
|
this.fieldValue = 'value';
|
|
20
|
+
this.hasNext = true;
|
|
19
21
|
this.headers = new HttpHeaders({
|
|
20
22
|
'X-PO-No-Message': 'true'
|
|
21
23
|
});
|
|
@@ -25,12 +27,8 @@ export class PoComboFilterService {
|
|
|
25
27
|
return this._url;
|
|
26
28
|
}
|
|
27
29
|
getFilteredData(param, filterParams) {
|
|
28
|
-
const
|
|
29
|
-
|
|
30
|
-
const params = { ...filterParamsValidated, filter: value };
|
|
31
|
-
return this.http
|
|
32
|
-
.get(`${this.url}`, { responseType: 'json', params, headers: this.headers })
|
|
33
|
-
.pipe(map((response) => this.parseToArrayComboOption(response.items)));
|
|
30
|
+
const params = this.prepareParams(param, filterParams);
|
|
31
|
+
return this.http.get(`${this.url}`, { responseType: 'json', params, headers: this.headers }).pipe(tap(res => (this.hasNext = res['hasNext'])), map((response) => this.parseToArrayComboOption(response.items)));
|
|
34
32
|
}
|
|
35
33
|
getObjectByValue(value, filterParams) {
|
|
36
34
|
const filterParamsValidated = validateObjectType(filterParams);
|
|
@@ -43,6 +41,16 @@ export class PoComboFilterService {
|
|
|
43
41
|
this.fieldLabel = fieldLabel;
|
|
44
42
|
this.fieldValue = fieldValue;
|
|
45
43
|
}
|
|
44
|
+
scrollListener(componentListner) {
|
|
45
|
+
return fromEvent(componentListner, 'scroll').pipe(debounceTime(100));
|
|
46
|
+
}
|
|
47
|
+
prepareParams(param, filterParams) {
|
|
48
|
+
const { page, pageSize, value } = param;
|
|
49
|
+
const filterParamsValidated = validateObjectType(filterParams);
|
|
50
|
+
return page
|
|
51
|
+
? { ...filterParamsValidated, page, pageSize, filter: value }
|
|
52
|
+
: { ...filterParamsValidated, filter: value };
|
|
53
|
+
}
|
|
46
54
|
parseToArrayComboOption(items) {
|
|
47
55
|
if (items && items.length > 0) {
|
|
48
56
|
const parsedOptions = items.map(item => this.parseToComboOption(item));
|
|
@@ -76,4 +84,4 @@ PoComboFilterService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: PoC
|
|
|
76
84
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoComboFilterService, [{
|
|
77
85
|
type: Injectable
|
|
78
86
|
}], function () { return [{ type: i1.HttpClient }]; }, null); })();
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-combo-filter.service.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-combo/po-combo-filter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\n\nimport { fromEvent, Observable } from 'rxjs';\nimport { debounceTime, map, tap } from 'rxjs/operators';\n\nimport { PoComboFilter } from './interfaces/po-combo-filter.interface';\nimport { PoComboOption } from './interfaces/po-combo-option.interface';\nimport { PoResponse } from './interfaces/po-response.interface';\nimport { validateObjectType } from '../../../utils/util';\n\n/**\n * @docsPrivate\n *\n * @description\n *\n * Serviço padrão utilizado para filtrar os dados do componente po-combo.\n */\n@Injectable()\nexport class PoComboFilterService implements PoComboFilter {\n  fieldLabel: string = 'label';\n  fieldValue: string = 'value';\n  hasNext: boolean = true;\n\n  readonly headers: HttpHeaders = new HttpHeaders({\n    'X-PO-No-Message': 'true'\n  });\n\n  private _url: string;\n  private messages = [];\n\n  get url(): string {\n    return this._url;\n  }\n\n  constructor(private http: HttpClient) {}\n\n  getFilteredData(param: any, filterParams?: any): Observable<Array<PoComboOption>> {\n    const params = this.prepareParams(param, filterParams);\n    return this.http.get(`${this.url}`, { responseType: 'json', params, headers: this.headers }).pipe(\n      tap(res => (this.hasNext = res['hasNext'])),\n      map((response: PoResponse) => this.parseToArrayComboOption(response.items))\n    );\n  }\n\n  getObjectByValue(value: string | number, filterParams?: any): Observable<PoComboOption> {\n    const filterParamsValidated = validateObjectType(filterParams);\n\n    return this.http\n      .get(`${this.url}/${value}`, { params: filterParamsValidated, headers: this.headers })\n      .pipe(map(item => this.parseToComboOption(item)));\n  }\n\n  configProperties(url: string, fieldLabel: string, fieldValue: string) {\n    this._url = url;\n    this.fieldLabel = fieldLabel;\n    this.fieldValue = fieldValue;\n  }\n\n  scrollListener(componentListner: HTMLElement): Observable<any> {\n    return fromEvent(componentListner, 'scroll').pipe(debounceTime(100));\n  }\n\n  private prepareParams(param: any, filterParams?: any) {\n    const { page, pageSize, value } = param;\n    const filterParamsValidated = validateObjectType(filterParams);\n\n    return page\n      ? { ...filterParamsValidated, page, pageSize, filter: value }\n      : { ...filterParamsValidated, filter: value };\n  }\n\n  private parseToArrayComboOption(items: Array<any>): Array<PoComboOption> {\n    if (items && items.length > 0) {\n      const parsedOptions = items.map(item => this.parseToComboOption(item));\n\n      this.displayMessages();\n\n      return parsedOptions;\n    }\n\n    return [];\n  }\n\n  private parseToComboOption(item: any): PoComboOption {\n    if (!item?.[this.fieldValue]) {\n      this.addMessage(item, this.fieldValue);\n\n      return { value: '' };\n    }\n\n    const label = item[this.fieldLabel];\n    const value = item[this.fieldValue];\n\n    return { label, value };\n  }\n\n  private addMessage(item, property: string) {\n    this.messages.push(`Cannot read property \"${property}\" of ${JSON.stringify(item)},\n      see [p-field-value] property at https://po-ui.io/documentation/po-combo`);\n  }\n\n  private displayMessages() {\n    if (this.messages.length) {\n      this.messages.forEach(message => console.error(message));\n\n      this.messages = [];\n    }\n  }\n}\n"]}
|