@recursyve/nice-data-filter-kit 12.1.30 → 13.0.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/_index.scss +1 -7
- package/{esm2015/lib/api/dto/saved-reports.dto.js → esm2020/lib/api/dto/saved-reports.dto.mjs} +0 -0
- package/esm2020/lib/api/filter.api.mjs +51 -0
- package/{esm2015/lib/api/models/saved-reports.model.js → esm2020/lib/api/models/saved-reports.model.mjs} +0 -0
- package/{esm2015/lib/api/public-api.js → esm2020/lib/api/public-api.mjs} +0 -0
- package/esm2020/lib/api/saved-report.api.mjs +48 -0
- package/esm2020/lib/components/base-list/base-list.component.mjs +288 -0
- package/{esm2015/lib/components/base-list/base-list.constant.js → esm2020/lib/components/base-list/base-list.constant.mjs} +0 -0
- package/esm2020/lib/components/base-list/base-list.module.mjs +171 -0
- package/{esm2015/lib/components/base-list/directives/base-list-buttons.directive.js → esm2020/lib/components/base-list/directives/base-list-buttons.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/directives/base-list-cards.directive.js → esm2020/lib/components/base-list/directives/base-list-cards.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/directives/base-list-custom-content.directive.js → esm2020/lib/components/base-list/directives/base-list-custom-content.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/directives/base-list-directives.module.js → esm2020/lib/components/base-list/directives/base-list-directives.module.mjs} +4 -4
- package/{esm2015/lib/components/base-list/directives/base-list-filters.directive.js → esm2020/lib/components/base-list/directives/base-list-filters.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/directives/base-list-table.directive.js → esm2020/lib/components/base-list/directives/base-list-table.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/directives/base-list-title.directive.js → esm2020/lib/components/base-list/directives/base-list-title.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/models/columns.model.js → esm2020/lib/components/base-list/models/columns.model.mjs} +0 -0
- package/{esm2015/lib/components/base-list/models/export.model.js → esm2020/lib/components/base-list/models/export.model.mjs} +0 -0
- package/esm2020/lib/components/base-list/models/layout.model.mjs +149 -0
- package/esm2020/lib/components/base-list/providers/base-filter.service.mjs +34 -0
- package/{esm2015/lib/components/base-list/providers/base-list-saved-report.service.js → esm2020/lib/components/base-list/providers/base-list-saved-report.service.mjs} +3 -3
- package/{esm2015/lib/components/base-list/public-api.js → esm2020/lib/components/base-list/public-api.mjs} +0 -0
- package/esm2020/lib/components/base-list/store/base-list.query.mjs +35 -0
- package/esm2020/lib/components/base-list/store/base-list.service.mjs +341 -0
- package/esm2020/lib/components/base-list/store/base-list.store.mjs +81 -0
- package/{esm2015/lib/components/multi-state-list/models/list-states.model.js → esm2020/lib/components/multi-state-list/models/list-states.model.mjs} +0 -0
- package/esm2020/lib/components/multi-state-list/multi-state-list.component.mjs +71 -0
- package/{esm2015/lib/components/multi-state-list/multi-state-list.constant.js → esm2020/lib/components/multi-state-list/multi-state-list.constant.mjs} +0 -0
- package/{esm2015/lib/components/multi-state-list/multi-state-list.module.js → esm2020/lib/components/multi-state-list/multi-state-list.module.mjs} +6 -14
- package/{esm2015/lib/components/multi-state-list/providers/multi-state-filter.service.js → esm2020/lib/components/multi-state-list/providers/multi-state-filter.service.mjs} +0 -0
- package/{esm2015/lib/components/multi-state-list/public-api.js → esm2020/lib/components/multi-state-list/public-api.mjs} +0 -0
- package/{esm2015/lib/components/multi-state-list/store/multi-state-list.query.js → esm2020/lib/components/multi-state-list/store/multi-state-list.query.mjs} +3 -3
- package/{esm2015/lib/components/multi-state-list/store/multi-state-list.service.js → esm2020/lib/components/multi-state-list/store/multi-state-list.service.mjs} +5 -6
- package/esm2020/lib/components/multi-state-list/store/multi-state-list.store.mjs +24 -0
- package/{esm2015/lib/components/public-api.js → esm2020/lib/components/public-api.mjs} +0 -0
- package/esm2020/lib/components/query-builder/filter-selection/filter-selection.component.mjs +41 -0
- package/{esm2015/lib/components/query-builder/pipes/filter-group-icon.pipe.js → esm2020/lib/components/query-builder/pipes/filter-group-icon.pipe.mjs} +3 -3
- package/{esm2015/lib/components/query-builder/providers/filter-group.service.js → esm2020/lib/components/query-builder/providers/filter-group.service.mjs} +0 -0
- package/{esm2015/lib/components/query-builder/public-api.js → esm2020/lib/components/query-builder/public-api.mjs} +0 -0
- package/{esm2015/lib/components/query-builder/query-builder-trigger.directive.js → esm2020/lib/components/query-builder/query-builder-trigger.directive.mjs} +3 -3
- package/esm2020/lib/components/query-builder/query-builder.component.mjs +93 -0
- package/{esm2015/lib/components/query-builder/query-builder.form.js → esm2020/lib/components/query-builder/query-builder.form.mjs} +0 -0
- package/esm2020/lib/components/query-builder/query-builder.module.mjs +116 -0
- package/esm2020/lib/components/query-builder/rule/components/date/date-filter.component.mjs +29 -0
- package/esm2020/lib/components/query-builder/rule/components/filter.component.mjs +45 -0
- package/esm2020/lib/components/query-builder/rule/components/number/number-filter.component.mjs +28 -0
- package/esm2020/lib/components/query-builder/rule/components/radio/radio-filter.component.mjs +30 -0
- package/esm2020/lib/components/query-builder/rule/components/select/select-filter.component.mjs +83 -0
- package/esm2020/lib/components/query-builder/rule/components/text/text-filter.component.mjs +31 -0
- package/esm2020/lib/components/query-builder/rule/rule.component.mjs +78 -0
- package/{esm2015/lib/components/query-builder/utils/qb-filter.utils.js → esm2020/lib/components/query-builder/utils/qb-filter.utils.mjs} +23 -9
- package/{esm2015/lib/models/filter.model.js → esm2020/lib/models/filter.model.mjs} +0 -0
- package/{esm2015/lib/models/public-api.js → esm2020/lib/models/public-api.mjs} +0 -0
- package/{esm2015/lib/models/query.model.js → esm2020/lib/models/query.model.mjs} +0 -0
- package/{esm2015/lib/utils/date.adapter.js → esm2020/lib/utils/date.adapter.mjs} +3 -3
- package/esm2020/lib/utils/filter.utils.mjs +40 -0
- package/{esm2015/lib/utils/public-api.js → esm2020/lib/utils/public-api.mjs} +0 -0
- package/{esm2015/lib/utils/query-params.utils.js → esm2020/lib/utils/query-params.utils.mjs} +0 -0
- package/{esm2015/lib/utils/string.utils.js → esm2020/lib/utils/string.utils.mjs} +0 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/{esm2015/recursyve-nice-data-filter-kit.js → esm2020/recursyve-nice-data-filter-kit.mjs} +0 -0
- package/fesm2015/recursyve-nice-data-filter-kit.mjs +2448 -0
- package/fesm2015/recursyve-nice-data-filter-kit.mjs.map +1 -0
- package/fesm2020/recursyve-nice-data-filter-kit.mjs +2446 -0
- package/fesm2020/recursyve-nice-data-filter-kit.mjs.map +1 -0
- package/lib/components/base-list/base-list.module.d.ts +15 -16
- package/lib/components/base-list/models/layout.model.d.ts +0 -4
- package/lib/components/multi-state-list/multi-state-list.module.d.ts +15 -16
- package/lib/components/query-builder/query-builder.module.d.ts +10 -11
- package/lib/components/query-builder/rule/components/filter.component.d.ts +2 -1
- package/package.json +30 -16
- package/src/lib/components/base-list/base-list.theme.scss +5 -5
- package/src/lib/components/query-builder/rule/rule.theme.scss +1 -1
- package/src/lib/nice-data-filter.theme.scss +7 -0
- package/bundles/recursyve-nice-data-filter-kit.umd.js +0 -3173
- package/bundles/recursyve-nice-data-filter-kit.umd.js.map +0 -1
- package/esm2015/lib/api/filter.api.js +0 -52
- package/esm2015/lib/api/saved-report.api.js +0 -49
- package/esm2015/lib/components/base-list/base-list.component.js +0 -297
- package/esm2015/lib/components/base-list/base-list.module.js +0 -180
- package/esm2015/lib/components/base-list/models/layout.model.js +0 -164
- package/esm2015/lib/components/base-list/providers/base-filter.service.js +0 -40
- package/esm2015/lib/components/base-list/store/base-list.query.js +0 -35
- package/esm2015/lib/components/base-list/store/base-list.service.js +0 -330
- package/esm2015/lib/components/base-list/store/base-list.store.js +0 -78
- package/esm2015/lib/components/multi-state-list/multi-state-list.component.js +0 -75
- package/esm2015/lib/components/multi-state-list/store/multi-state-list.store.js +0 -22
- package/esm2015/lib/components/query-builder/filter-selection/filter-selection.component.js +0 -48
- package/esm2015/lib/components/query-builder/query-builder.component.js +0 -100
- package/esm2015/lib/components/query-builder/query-builder.module.js +0 -120
- package/esm2015/lib/components/query-builder/rule/components/date/date-filter.component.js +0 -35
- package/esm2015/lib/components/query-builder/rule/components/filter.component.js +0 -29
- package/esm2015/lib/components/query-builder/rule/components/number/number-filter.component.js +0 -34
- package/esm2015/lib/components/query-builder/rule/components/radio/radio-filter.component.js +0 -36
- package/esm2015/lib/components/query-builder/rule/components/select/select-filter.component.js +0 -94
- package/esm2015/lib/components/query-builder/rule/components/text/text-filter.component.js +0 -37
- package/esm2015/lib/components/query-builder/rule/rule.component.js +0 -86
- package/esm2015/lib/utils/filter.utils.js +0 -41
- package/fesm2015/recursyve-nice-data-filter-kit.js +0 -2503
- package/fesm2015/recursyve-nice-data-filter-kit.js.map +0 -1
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { QueryParamsUtils } from "../utils/query-params.utils";
|
|
2
|
-
export class NiceFilterApi {
|
|
3
|
-
constructor(filterApiUrl, path, http) {
|
|
4
|
-
this.filterApiUrl = filterApiUrl;
|
|
5
|
-
this.path = path;
|
|
6
|
-
this.http = http;
|
|
7
|
-
}
|
|
8
|
-
filter(queryModel) {
|
|
9
|
-
return this.http.post(this.url("filter"), queryModel);
|
|
10
|
-
}
|
|
11
|
-
filterCount(queryModel) {
|
|
12
|
-
return this.http.post(this.url("filter-count"), queryModel);
|
|
13
|
-
}
|
|
14
|
-
downloadData(type, queryModel) {
|
|
15
|
-
return this.http.post(this.url(`download/${type}`), queryModel, { responseType: "blob" });
|
|
16
|
-
}
|
|
17
|
-
getPrintableHtml(queryModel) {
|
|
18
|
-
return this.http.post(this.url(`download/html`), queryModel, { responseType: "text" });
|
|
19
|
-
}
|
|
20
|
-
getFilterConfig() {
|
|
21
|
-
return this.http.get(this.url("filter/config"));
|
|
22
|
-
}
|
|
23
|
-
searchFilterValue(id, value) {
|
|
24
|
-
if (value === undefined) {
|
|
25
|
-
value = "";
|
|
26
|
-
}
|
|
27
|
-
return this.http.get(this.url(`filter/config/value?id=${id}&value=${value}`));
|
|
28
|
-
}
|
|
29
|
-
searchFilterResourceValue(id, resourceId) {
|
|
30
|
-
return this.http.get(this.url(`filter/config/id?id=${id}&resourceId=${resourceId}`));
|
|
31
|
-
}
|
|
32
|
-
url(...args) {
|
|
33
|
-
const [route, queryParams] = this.transformUrlArgs(args);
|
|
34
|
-
const params = queryParams ? `?${QueryParamsUtils.fromObject(queryParams)}` : "";
|
|
35
|
-
if (route) {
|
|
36
|
-
return `${this.filterApiUrl}/${this.path}/${route}${params}`;
|
|
37
|
-
}
|
|
38
|
-
return `${this.filterApiUrl}/${this.path}${params}`;
|
|
39
|
-
}
|
|
40
|
-
transformUrlArgs(args) {
|
|
41
|
-
var _a;
|
|
42
|
-
const [routeOfQueryParams, query] = args;
|
|
43
|
-
if (args.length === 1) {
|
|
44
|
-
if (typeof routeOfQueryParams === "string") {
|
|
45
|
-
return [routeOfQueryParams];
|
|
46
|
-
}
|
|
47
|
-
return ["", routeOfQueryParams];
|
|
48
|
-
}
|
|
49
|
-
return [(_a = routeOfQueryParams) !== null && _a !== void 0 ? _a : "", query];
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLmFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtZGF0YS1maWx0ZXIta2l0L3NyYy9saWIvYXBpL2ZpbHRlci5hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFFL0QsTUFBTSxPQUFPLGFBQWE7SUFDdEIsWUFBb0IsWUFBb0IsRUFBVSxJQUFZLEVBQVksSUFBZ0I7UUFBdEUsaUJBQVksR0FBWixZQUFZLENBQVE7UUFBVSxTQUFJLEdBQUosSUFBSSxDQUFRO1FBQVksU0FBSSxHQUFKLElBQUksQ0FBWTtJQUFHLENBQUM7SUFFdkYsTUFBTSxDQUFDLFVBQTRCO1FBQ3RDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQW9CLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDN0UsQ0FBQztJQUVNLFdBQVcsQ0FBQyxVQUE0QjtRQUMzQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFTLElBQUksQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDeEUsQ0FBQztJQUVNLFlBQVksQ0FBQyxJQUFZLEVBQUUsVUFBNEI7UUFDMUQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUMsRUFBRSxVQUFVLEVBQUUsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUM5RixDQUFDO0lBRU0sZ0JBQWdCLENBQUMsVUFBNEI7UUFDaEQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxFQUFFLFVBQVUsRUFBRSxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQzNGLENBQUM7SUFFTSxlQUFlO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQTZCLElBQUksQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQztJQUNoRixDQUFDO0lBRU0saUJBQWlCLENBQUMsRUFBVSxFQUFFLEtBQWE7UUFDOUMsSUFBSSxLQUFLLEtBQUssU0FBUyxFQUFFO1lBQ3JCLEtBQUssR0FBRyxFQUFFLENBQUM7U0FDZDtRQUVELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQXNCLElBQUksQ0FBQyxHQUFHLENBQUMsMEJBQTBCLEVBQUUsVUFBVSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDdkcsQ0FBQztJQUVNLHlCQUF5QixDQUFDLEVBQVUsRUFBRSxVQUFrQjtRQUMzRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFvQixJQUFJLENBQUMsR0FBRyxDQUFDLHVCQUF1QixFQUFFLGVBQWUsVUFBVSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzVHLENBQUM7SUFJUyxHQUFHLENBQUMsR0FBRyxJQUFnQztRQUM3QyxNQUFNLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6RCxNQUFNLE1BQU0sR0FBRyxXQUFXLENBQUMsQ0FBQyxDQUFDLElBQUksZ0JBQWdCLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUNqRixJQUFJLEtBQUssRUFBRTtZQUNQLE9BQU8sR0FBRyxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksS0FBSyxHQUFHLE1BQU0sRUFBRSxDQUFDO1NBQ2hFO1FBRUQsT0FBTyxHQUFHLElBQUksQ0FBQyxZQUFZLElBQUksSUFBSSxDQUFDLElBQUksR0FBRyxNQUFNLEVBQUUsQ0FBQztJQUN4RCxDQUFDO0lBRU8sZ0JBQWdCLENBQUMsSUFBZ0M7O1FBQ3JELE1BQU0sQ0FBQyxrQkFBa0IsRUFBRSxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDekMsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUNuQixJQUFJLE9BQU8sa0JBQWtCLEtBQUssUUFBUSxFQUFFO2dCQUN4QyxPQUFPLENBQUMsa0JBQWtCLENBQUMsQ0FBQzthQUMvQjtZQUVELE9BQU8sQ0FBQyxFQUFFLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztTQUNuQztRQUVELE9BQU8sQ0FBQyxNQUFDLGtCQUE2QixtQ0FBSSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDekQsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cFBhcmFtcyB9IGZyb20gXCJAYW5ndWxhci9jb21tb24vaHR0cFwiO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyBGaWx0ZXJDb25maWd1cmF0aW9uTW9kZWwsIEZpbHRlclF1ZXJ5TW9kZWwsIEZpbHRlclJlc3VsdE1vZGVsLCBTZWxlY3RGaWx0ZXJWYWx1ZSB9IGZyb20gXCIuLi9tb2RlbHMvZmlsdGVyLm1vZGVsXCI7XG5pbXBvcnQgeyBRdWVyeVBhcmFtc1V0aWxzIH0gZnJvbSBcIi4uL3V0aWxzL3F1ZXJ5LXBhcmFtcy51dGlsc1wiO1xuXG5leHBvcnQgY2xhc3MgTmljZUZpbHRlckFwaTxUPiB7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBmaWx0ZXJBcGlVcmw6IHN0cmluZywgcHJpdmF0ZSBwYXRoOiBzdHJpbmcsIHByb3RlY3RlZCBodHRwOiBIdHRwQ2xpZW50KSB7fVxuXG4gICAgcHVibGljIGZpbHRlcihxdWVyeU1vZGVsOiBGaWx0ZXJRdWVyeU1vZGVsKTogT2JzZXJ2YWJsZTxGaWx0ZXJSZXN1bHRNb2RlbD4ge1xuICAgICAgICByZXR1cm4gdGhpcy5odHRwLnBvc3Q8RmlsdGVyUmVzdWx0TW9kZWw+KHRoaXMudXJsKFwiZmlsdGVyXCIpLCBxdWVyeU1vZGVsKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZmlsdGVyQ291bnQocXVlcnlNb2RlbDogRmlsdGVyUXVlcnlNb2RlbCk6IE9ic2VydmFibGU8bnVtYmVyPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmh0dHAucG9zdDxudW1iZXI+KHRoaXMudXJsKFwiZmlsdGVyLWNvdW50XCIpLCBxdWVyeU1vZGVsKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZG93bmxvYWREYXRhKHR5cGU6IHN0cmluZywgcXVlcnlNb2RlbDogRmlsdGVyUXVlcnlNb2RlbCk6IE9ic2VydmFibGU8QmxvYj4ge1xuICAgICAgICByZXR1cm4gdGhpcy5odHRwLnBvc3QodGhpcy51cmwoYGRvd25sb2FkLyR7dHlwZX1gKSwgcXVlcnlNb2RlbCwgeyByZXNwb25zZVR5cGU6IFwiYmxvYlwiIH0pO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRQcmludGFibGVIdG1sKHF1ZXJ5TW9kZWw6IEZpbHRlclF1ZXJ5TW9kZWwpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuICAgICAgICByZXR1cm4gdGhpcy5odHRwLnBvc3QodGhpcy51cmwoYGRvd25sb2FkL2h0bWxgKSwgcXVlcnlNb2RlbCwgeyByZXNwb25zZVR5cGU6IFwidGV4dFwiIH0pO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRGaWx0ZXJDb25maWcoKTogT2JzZXJ2YWJsZTxGaWx0ZXJDb25maWd1cmF0aW9uTW9kZWxbXT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5odHRwLmdldDxGaWx0ZXJDb25maWd1cmF0aW9uTW9kZWxbXT4odGhpcy51cmwoXCJmaWx0ZXIvY29uZmlnXCIpKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgc2VhcmNoRmlsdGVyVmFsdWUoaWQ6IHN0cmluZywgdmFsdWU6IHN0cmluZyk6IE9ic2VydmFibGU8U2VsZWN0RmlsdGVyVmFsdWVbXT4ge1xuICAgICAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdmFsdWUgPSBcIlwiO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8U2VsZWN0RmlsdGVyVmFsdWVbXT4odGhpcy51cmwoYGZpbHRlci9jb25maWcvdmFsdWU/aWQ9JHtpZH0mdmFsdWU9JHt2YWx1ZX1gKSk7XG4gICAgfVxuXG4gICAgcHVibGljIHNlYXJjaEZpbHRlclJlc291cmNlVmFsdWUoaWQ6IHN0cmluZywgcmVzb3VyY2VJZDogbnVtYmVyKTogT2JzZXJ2YWJsZTxTZWxlY3RGaWx0ZXJWYWx1ZT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5odHRwLmdldDxTZWxlY3RGaWx0ZXJWYWx1ZT4odGhpcy51cmwoYGZpbHRlci9jb25maWcvaWQ/aWQ9JHtpZH0mcmVzb3VyY2VJZD0ke3Jlc291cmNlSWR9YCkpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCB1cmwocm91dGU/OiBzdHJpbmcsIHF1ZXJ5UGFyYW1zPzogb2JqZWN0KTogc3RyaW5nO1xuICAgIHByb3RlY3RlZCB1cmwocXVlcnlQYXJhbXM6IG9iamVjdCk6IHN0cmluZztcbiAgICBwcm90ZWN0ZWQgdXJsKC4uLmFyZ3M6IFtzdHJpbmcgfCBvYmplY3QsIG9iamVjdD9dKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgW3JvdXRlLCBxdWVyeVBhcmFtc10gPSB0aGlzLnRyYW5zZm9ybVVybEFyZ3MoYXJncyk7XG4gICAgICAgIGNvbnN0IHBhcmFtcyA9IHF1ZXJ5UGFyYW1zID8gYD8ke1F1ZXJ5UGFyYW1zVXRpbHMuZnJvbU9iamVjdChxdWVyeVBhcmFtcyl9YCA6IFwiXCI7XG4gICAgICAgIGlmIChyb3V0ZSkge1xuICAgICAgICAgICAgcmV0dXJuIGAke3RoaXMuZmlsdGVyQXBpVXJsfS8ke3RoaXMucGF0aH0vJHtyb3V0ZX0ke3BhcmFtc31gO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIGAke3RoaXMuZmlsdGVyQXBpVXJsfS8ke3RoaXMucGF0aH0ke3BhcmFtc31gO1xuICAgIH1cblxuICAgIHByaXZhdGUgdHJhbnNmb3JtVXJsQXJncyhhcmdzOiBbc3RyaW5nIHwgb2JqZWN0LCBvYmplY3Q/XSk6IFtyb3V0ZTogc3RyaW5nLCBxdWVyeVBhcmFtcz86IG9iamVjdF0ge1xuICAgICAgICBjb25zdCBbcm91dGVPZlF1ZXJ5UGFyYW1zLCBxdWVyeV0gPSBhcmdzO1xuICAgICAgICBpZiAoYXJncy5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgICAgIGlmICh0eXBlb2Ygcm91dGVPZlF1ZXJ5UGFyYW1zID09PSBcInN0cmluZ1wiKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIFtyb3V0ZU9mUXVlcnlQYXJhbXNdO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICByZXR1cm4gW1wiXCIsIHJvdXRlT2ZRdWVyeVBhcmFtc107XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gWyhyb3V0ZU9mUXVlcnlQYXJhbXMgYXMgc3RyaW5nKSA/PyBcIlwiLCBxdWVyeV07XG4gICAgfVxufVxuIl19
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { QueryParamsUtils } from "../utils/query-params.utils";
|
|
2
|
-
export class NiceSavedReportsApi {
|
|
3
|
-
constructor(filterApiUrl, path, http) {
|
|
4
|
-
this.filterApiUrl = filterApiUrl;
|
|
5
|
-
this.path = path;
|
|
6
|
-
this.http = http;
|
|
7
|
-
}
|
|
8
|
-
create(dto) {
|
|
9
|
-
return this.http.post(this.url(), dto);
|
|
10
|
-
}
|
|
11
|
-
getAll() {
|
|
12
|
-
return this.http.get(this.url());
|
|
13
|
-
}
|
|
14
|
-
getByTable(table) {
|
|
15
|
-
return this.http.get(this.url(`${table}`));
|
|
16
|
-
}
|
|
17
|
-
getTopByTable(table) {
|
|
18
|
-
return this.http.get(this.url(`${table}/top`));
|
|
19
|
-
}
|
|
20
|
-
hit(id) {
|
|
21
|
-
return this.http.put(this.url(`${id}/hit`), null);
|
|
22
|
-
}
|
|
23
|
-
update(id, dto) {
|
|
24
|
-
return this.http.put(this.url(`${id}`), dto);
|
|
25
|
-
}
|
|
26
|
-
delete(id) {
|
|
27
|
-
return this.http.delete(this.url(`${id}`));
|
|
28
|
-
}
|
|
29
|
-
url(...args) {
|
|
30
|
-
const [route, queryParams] = this.transformUrlArgs(args);
|
|
31
|
-
const params = queryParams ? `?${QueryParamsUtils.fromObject(queryParams)}` : "";
|
|
32
|
-
if (route) {
|
|
33
|
-
return `${this.filterApiUrl}/${this.path}/${route}${params}`;
|
|
34
|
-
}
|
|
35
|
-
return `${this.filterApiUrl}/${this.path}${params}`;
|
|
36
|
-
}
|
|
37
|
-
transformUrlArgs(args) {
|
|
38
|
-
var _a;
|
|
39
|
-
const [routeOfQueryParams, query] = args;
|
|
40
|
-
if (args.length === 1) {
|
|
41
|
-
if (typeof routeOfQueryParams === "string") {
|
|
42
|
-
return [routeOfQueryParams];
|
|
43
|
-
}
|
|
44
|
-
return ["", routeOfQueryParams];
|
|
45
|
-
}
|
|
46
|
-
return [(_a = routeOfQueryParams) !== null && _a !== void 0 ? _a : "", query];
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2F2ZWQtcmVwb3J0LmFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtZGF0YS1maWx0ZXIta2l0L3NyYy9saWIvYXBpL3NhdmVkLXJlcG9ydC5hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFJL0QsTUFBTSxPQUFPLG1CQUFtQjtJQUM1QixZQUFvQixZQUFvQixFQUFVLElBQVksRUFBWSxJQUFnQjtRQUF0RSxpQkFBWSxHQUFaLFlBQVksQ0FBUTtRQUFVLFNBQUksR0FBSixJQUFJLENBQVE7UUFBWSxTQUFJLEdBQUosSUFBSSxDQUFZO0lBQUcsQ0FBQztJQUV2RixNQUFNLENBQUMsR0FBdUI7UUFDakMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBbUIsSUFBSSxDQUFDLEdBQUcsRUFBRSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFTSxNQUFNO1FBQ1QsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBcUIsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVNLFVBQVUsQ0FBQyxLQUFhO1FBQzNCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQXFCLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDbkUsQ0FBQztJQUVNLGFBQWEsQ0FBQyxLQUF5QjtRQUMxQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFxQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsS0FBSyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7SUFFTSxHQUFHLENBQUMsRUFBVTtRQUNqQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFTSxNQUFNLENBQUMsRUFBVSxFQUFFLEdBQXVCO1FBQzdDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQW1CLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ25FLENBQUM7SUFFTSxNQUFNLENBQUMsRUFBVTtRQUNwQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUlTLEdBQUcsQ0FBQyxHQUFHLElBQWdDO1FBQzdDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pELE1BQU0sTUFBTSxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsSUFBSSxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ2pGLElBQUksS0FBSyxFQUFFO1lBQ1AsT0FBTyxHQUFHLElBQUksQ0FBQyxZQUFZLElBQUksSUFBSSxDQUFDLElBQUksSUFBSSxLQUFLLEdBQUcsTUFBTSxFQUFFLENBQUM7U0FDaEU7UUFFRCxPQUFPLEdBQUcsSUFBSSxDQUFDLFlBQVksSUFBSSxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sRUFBRSxDQUFDO0lBQ3hELENBQUM7SUFFTyxnQkFBZ0IsQ0FBQyxJQUFnQzs7UUFDckQsTUFBTSxDQUFDLGtCQUFrQixFQUFFLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQztRQUN6QyxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ25CLElBQUksT0FBTyxrQkFBa0IsS0FBSyxRQUFRLEVBQUU7Z0JBQ3hDLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO2FBQy9CO1lBRUQsT0FBTyxDQUFDLEVBQUUsRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO1NBQ25DO1FBRUQsT0FBTyxDQUFDLE1BQUMsa0JBQTZCLG1DQUFJLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN6RCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7IFF1ZXJ5UGFyYW1zVXRpbHMgfSBmcm9tIFwiLi4vdXRpbHMvcXVlcnktcGFyYW1zLnV0aWxzXCI7XG5pbXBvcnQgeyBOaWNlU2F2ZWRSZXBvcnREdG8gfSBmcm9tIFwiLi9kdG8vc2F2ZWQtcmVwb3J0cy5kdG9cIjtcbmltcG9ydCB7IE5pY2VTYXZlZFJlcG9ydHMgfSBmcm9tIFwiLi9tb2RlbHMvc2F2ZWQtcmVwb3J0cy5tb2RlbFwiO1xuXG5leHBvcnQgY2xhc3MgTmljZVNhdmVkUmVwb3J0c0FwaSB7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBmaWx0ZXJBcGlVcmw6IHN0cmluZywgcHJpdmF0ZSBwYXRoOiBzdHJpbmcsIHByb3RlY3RlZCBodHRwOiBIdHRwQ2xpZW50KSB7fVxuXG4gICAgcHVibGljIGNyZWF0ZShkdG86IE5pY2VTYXZlZFJlcG9ydER0byk6IE9ic2VydmFibGU8TmljZVNhdmVkUmVwb3J0cz4ge1xuICAgICAgICByZXR1cm4gdGhpcy5odHRwLnBvc3Q8TmljZVNhdmVkUmVwb3J0cz4odGhpcy51cmwoKSwgZHRvKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0QWxsKCk6IE9ic2VydmFibGU8TmljZVNhdmVkUmVwb3J0c1tdPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PE5pY2VTYXZlZFJlcG9ydHNbXT4odGhpcy51cmwoKSk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldEJ5VGFibGUodGFibGU6IHN0cmluZyk6IE9ic2VydmFibGU8TmljZVNhdmVkUmVwb3J0c1tdPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PE5pY2VTYXZlZFJlcG9ydHNbXT4odGhpcy51cmwoYCR7dGFibGV9YCkpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRUb3BCeVRhYmxlKHRhYmxlOiBzdHJpbmcgfCB1bmRlZmluZWQpOiBPYnNlcnZhYmxlPE5pY2VTYXZlZFJlcG9ydHNbXT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5odHRwLmdldDxOaWNlU2F2ZWRSZXBvcnRzW10+KHRoaXMudXJsKGAke3RhYmxlfS90b3BgKSk7XG4gICAgfVxuXG4gICAgcHVibGljIGhpdChpZDogbnVtYmVyKTogT2JzZXJ2YWJsZTx2b2lkPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmh0dHAucHV0PHZvaWQ+KHRoaXMudXJsKGAke2lkfS9oaXRgKSwgbnVsbCk7XG4gICAgfVxuXG4gICAgcHVibGljIHVwZGF0ZShpZDogbnVtYmVyLCBkdG86IE5pY2VTYXZlZFJlcG9ydER0byk6IE9ic2VydmFibGU8TmljZVNhdmVkUmVwb3J0cz4ge1xuICAgICAgICByZXR1cm4gdGhpcy5odHRwLnB1dDxOaWNlU2F2ZWRSZXBvcnRzPih0aGlzLnVybChgJHtpZH1gKSwgZHRvKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZGVsZXRlKGlkOiBudW1iZXIpOiBPYnNlcnZhYmxlPHZvaWQ+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cC5kZWxldGU8dm9pZD4odGhpcy51cmwoYCR7aWR9YCkpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCB1cmwocm91dGU/OiBzdHJpbmcsIHF1ZXJ5UGFyYW1zPzogb2JqZWN0KTogc3RyaW5nO1xuICAgIHByb3RlY3RlZCB1cmwocXVlcnlQYXJhbXM6IG9iamVjdCk6IHN0cmluZztcbiAgICBwcm90ZWN0ZWQgdXJsKC4uLmFyZ3M6IFtzdHJpbmcgfCBvYmplY3QsIG9iamVjdD9dKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgW3JvdXRlLCBxdWVyeVBhcmFtc10gPSB0aGlzLnRyYW5zZm9ybVVybEFyZ3MoYXJncyk7XG4gICAgICAgIGNvbnN0IHBhcmFtcyA9IHF1ZXJ5UGFyYW1zID8gYD8ke1F1ZXJ5UGFyYW1zVXRpbHMuZnJvbU9iamVjdChxdWVyeVBhcmFtcyl9YCA6IFwiXCI7XG4gICAgICAgIGlmIChyb3V0ZSkge1xuICAgICAgICAgICAgcmV0dXJuIGAke3RoaXMuZmlsdGVyQXBpVXJsfS8ke3RoaXMucGF0aH0vJHtyb3V0ZX0ke3BhcmFtc31gO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIGAke3RoaXMuZmlsdGVyQXBpVXJsfS8ke3RoaXMucGF0aH0ke3BhcmFtc31gO1xuICAgIH1cblxuICAgIHByaXZhdGUgdHJhbnNmb3JtVXJsQXJncyhhcmdzOiBbc3RyaW5nIHwgb2JqZWN0LCBvYmplY3Q/XSk6IFtyb3V0ZTogc3RyaW5nLCBxdWVyeVBhcmFtcz86IG9iamVjdF0ge1xuICAgICAgICBjb25zdCBbcm91dGVPZlF1ZXJ5UGFyYW1zLCBxdWVyeV0gPSBhcmdzO1xuICAgICAgICBpZiAoYXJncy5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgICAgIGlmICh0eXBlb2Ygcm91dGVPZlF1ZXJ5UGFyYW1zID09PSBcInN0cmluZ1wiKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIFtyb3V0ZU9mUXVlcnlQYXJhbXNdO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICByZXR1cm4gW1wiXCIsIHJvdXRlT2ZRdWVyeVBhcmFtc107XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gWyhyb3V0ZU9mUXVlcnlQYXJhbXMgYXMgc3RyaW5nKSA/PyBcIlwiLCBxdWVyeV07XG4gICAgfVxufVxuIl19
|
|
@@ -1,297 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, ContentChild, ContentChildren, EventEmitter, Inject, Input, Optional, Output, TemplateRef } from "@angular/core";
|
|
3
|
-
import { MediaObserver } from "@angular/flex-layout";
|
|
4
|
-
import { MatBottomSheet } from "@angular/material/bottom-sheet";
|
|
5
|
-
import { ActivatedRoute, Router } from "@angular/router";
|
|
6
|
-
import { ExportBottomSheetComponent } from "@recursyve/nice-ui-kit.v2";
|
|
7
|
-
import { Subject } from "rxjs";
|
|
8
|
-
import { debounceTime, distinctUntilChanged, map, switchMap } from "rxjs/operators";
|
|
9
|
-
import { BASE_LIST_LAYOUT, ENABLE_QUERY_BUILDER, EXPORTS_SETTINGS, TABLE_COLUMNS } from "./base-list.constant";
|
|
10
|
-
import { NiceBaseListButtonsDirective } from "./directives/base-list-buttons.directive";
|
|
11
|
-
import { NiceBaseListCardsDirective } from "./directives/base-list-cards.directive";
|
|
12
|
-
import { NiceBaseListCustomContentDirective } from "./directives/base-list-custom-content.directive";
|
|
13
|
-
import { NiceBaseListFiltersDirective } from "./directives/base-list-filters.directive";
|
|
14
|
-
import { NiceBaseListTableDirective } from "./directives/base-list-table.directive";
|
|
15
|
-
import { NiceBaseListTitleDirective } from "./directives/base-list-title.directive";
|
|
16
|
-
import { LayoutContent } from "./models/layout.model";
|
|
17
|
-
import { NiceBaseListQuery } from "./store/base-list.query";
|
|
18
|
-
import { NiceBaseListService } from "./store/base-list.service";
|
|
19
|
-
import { NiceBaseListStore } from "./store/base-list.store";
|
|
20
|
-
import * as i0 from "@angular/core";
|
|
21
|
-
import * as i1 from "./store/base-list.query";
|
|
22
|
-
import * as i2 from "./store/base-list.service";
|
|
23
|
-
import * as i3 from "@angular/router";
|
|
24
|
-
import * as i4 from "@angular/material/bottom-sheet";
|
|
25
|
-
import * as i5 from "@angular/flex-layout";
|
|
26
|
-
import * as i6 from "@angular/material/icon";
|
|
27
|
-
import * as i7 from "@angular/material/button";
|
|
28
|
-
import * as i8 from "@angular/material/paginator";
|
|
29
|
-
import * as i9 from "@angular/material/card";
|
|
30
|
-
import * as i10 from "../query-builder/query-builder.component";
|
|
31
|
-
import * as i11 from "@angular/material/table";
|
|
32
|
-
import * as i12 from "@angular/material/sort";
|
|
33
|
-
import * as i13 from "@angular/common";
|
|
34
|
-
import * as i14 from "@angular/forms";
|
|
35
|
-
import * as i15 from "../query-builder/query-builder-trigger.directive";
|
|
36
|
-
import * as i16 from "@angular/material/tooltip";
|
|
37
|
-
import * as i17 from "@angular/material/badge";
|
|
38
|
-
import * as i18 from "@recursyve/nice-ui-kit.v2";
|
|
39
|
-
import * as i19 from "@angular/material/core";
|
|
40
|
-
import * as i20 from "@ngx-translate/core";
|
|
41
|
-
export class NiceBaseListComponent {
|
|
42
|
-
constructor(enableQueryBuilder, listLayout, columns, exportsSettings, query, service, activatedRoute, bottomSheet, router, mediaObserver) {
|
|
43
|
-
this.enableQueryBuilder = enableQueryBuilder;
|
|
44
|
-
this.listLayout = listLayout;
|
|
45
|
-
this.columns = columns;
|
|
46
|
-
this.exportsSettings = exportsSettings;
|
|
47
|
-
this.query = query;
|
|
48
|
-
this.service = service;
|
|
49
|
-
this.activatedRoute = activatedRoute;
|
|
50
|
-
this.bottomSheet = bottomSheet;
|
|
51
|
-
this.router = router;
|
|
52
|
-
this.mediaObserver = mediaObserver;
|
|
53
|
-
this.mode = "normal";
|
|
54
|
-
this.layout = "page";
|
|
55
|
-
this.layoutContent = LayoutContent.Table;
|
|
56
|
-
this.autoChangeLayout = true;
|
|
57
|
-
this.autoLoad = true;
|
|
58
|
-
this.canExport = true;
|
|
59
|
-
this.disableRouting = false;
|
|
60
|
-
this.customExport = [];
|
|
61
|
-
this.newPage = new EventEmitter();
|
|
62
|
-
this.defaultPageSizeOptions = [10, 25, 50, 100];
|
|
63
|
-
this.columnNames = [];
|
|
64
|
-
this.loading$ = this.query.selectLoading();
|
|
65
|
-
this.filterResult$ = this.query.selectFilterResult();
|
|
66
|
-
this.data$ = this.query.selectData();
|
|
67
|
-
this.recordsFiltered$ = this.filterResult$.pipe(map(f => f && f.total));
|
|
68
|
-
this.showQueryBuilder$ = this.query.selectShowQueryBuilder();
|
|
69
|
-
this.filterParameters$ = this.query.selectFilterParameters();
|
|
70
|
-
this.index$ = this.filterParameters$.pipe(map(f => { var _a, _b; return Math.floor(((_a = f.start) !== null && _a !== void 0 ? _a : 0) / ((_b = f.length) !== null && _b !== void 0 ? _b : 1)); }));
|
|
71
|
-
this.length$ = this.filterParameters$.pipe(map(f => f.length));
|
|
72
|
-
this.isEmpty$ = this.recordsFiltered$.pipe(map(r => r === 0));
|
|
73
|
-
this.searchQuery$ = this.filterParameters$.pipe(map(f => f.search));
|
|
74
|
-
this.filterConfig$ = this.query.selectFilterConfig();
|
|
75
|
-
this.sortColumn$ = this.filterParameters$.pipe(map(f => { var _a; return (_a = (f.order && f.order.column)) !== null && _a !== void 0 ? _a : ""; }));
|
|
76
|
-
this.sortDirection$ = this.filterParameters$.pipe(map(f => f.order && f.order.direction));
|
|
77
|
-
this.filterConfigLoading$ = this.query.selectFilterConfigLoading();
|
|
78
|
-
this.rules$ = this.filterParameters$.pipe(map(parameters => parameters.rules));
|
|
79
|
-
this.rulesCount$ = this.filterParameters$.pipe(map(parameters => { var _a, _b; return (_b = (_a = parameters.rules) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0; }));
|
|
80
|
-
this.searchText$ = new Subject();
|
|
81
|
-
this.setColumn(columns);
|
|
82
|
-
}
|
|
83
|
-
get prefixButtons() {
|
|
84
|
-
var _a, _b;
|
|
85
|
-
return (_b = (_a = this.buttons) === null || _a === void 0 ? void 0 : _a.find(x => x.position === "prefix")) === null || _b === void 0 ? void 0 : _b.template;
|
|
86
|
-
}
|
|
87
|
-
get suffixButtons() {
|
|
88
|
-
var _a, _b;
|
|
89
|
-
return (_b = (_a = this.buttons) === null || _a === void 0 ? void 0 : _a.find(x => x.position === "suffix")) === null || _b === void 0 ? void 0 : _b.template;
|
|
90
|
-
}
|
|
91
|
-
ngOnInit() {
|
|
92
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
93
|
-
yield this.service.init();
|
|
94
|
-
this.service.loadQueryParams(this.autoLoad);
|
|
95
|
-
this.searchText$
|
|
96
|
-
.pipe(debounceTime(300), distinctUntilChanged(), switchMap((search) => {
|
|
97
|
-
this.service.resetPaging();
|
|
98
|
-
return this.service.searchData(search);
|
|
99
|
-
}))
|
|
100
|
-
.subscribe();
|
|
101
|
-
this.mediaObserver.asObservable().subscribe(() => {
|
|
102
|
-
if (!this.autoChangeLayout) {
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
if (this.mediaObserver.isActive("lt-md") && this.layoutContent === LayoutContent.Table) {
|
|
106
|
-
this.layoutContent = LayoutContent.Cards;
|
|
107
|
-
}
|
|
108
|
-
else {
|
|
109
|
-
this.layoutContent = LayoutContent.Table;
|
|
110
|
-
}
|
|
111
|
-
});
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
ngOnDestroy() {
|
|
115
|
-
this.service.closeSubscriptions();
|
|
116
|
-
}
|
|
117
|
-
ngOnChanges(changes) {
|
|
118
|
-
if ("mode" in changes) {
|
|
119
|
-
this.service.setMode(changes.mode.currentValue);
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
setLoading(loading) {
|
|
123
|
-
this.service.setLoading(loading);
|
|
124
|
-
}
|
|
125
|
-
clickToggleShowQueryBuilder() {
|
|
126
|
-
this.service.toggleQueryBuilder();
|
|
127
|
-
}
|
|
128
|
-
onUpdateRules(rules) {
|
|
129
|
-
this.service.updateGlobalRules(rules);
|
|
130
|
-
}
|
|
131
|
-
onQueryBuilderFilterSelected(filterConfigurationModel) {
|
|
132
|
-
this.service.addRuleFromConfig(filterConfigurationModel);
|
|
133
|
-
}
|
|
134
|
-
onUpdatePage(pageEvent) {
|
|
135
|
-
this.service.loadNewPage(pageEvent.pageIndex * pageEvent.pageSize, pageEvent.pageSize);
|
|
136
|
-
this.newPage.emit(pageEvent);
|
|
137
|
-
}
|
|
138
|
-
onUpdateSearch(search) {
|
|
139
|
-
this.searchText$.next(search);
|
|
140
|
-
}
|
|
141
|
-
getFilterRule$(id) {
|
|
142
|
-
return this.filterParameters$.pipe(map(f => {
|
|
143
|
-
return (f.rules &&
|
|
144
|
-
f.rules[0] &&
|
|
145
|
-
f.rules[0].rules &&
|
|
146
|
-
f.rules[0].rules.find((r) => r.id === id));
|
|
147
|
-
}));
|
|
148
|
-
}
|
|
149
|
-
onUpdateSort(sort) {
|
|
150
|
-
if (!sort.active || !sort.direction) {
|
|
151
|
-
sort = {
|
|
152
|
-
active: "id",
|
|
153
|
-
direction: "asc"
|
|
154
|
-
};
|
|
155
|
-
}
|
|
156
|
-
this.service.loadData({
|
|
157
|
-
order: sort.active && sort.direction ? { column: sort.active, direction: sort.direction } : null
|
|
158
|
-
});
|
|
159
|
-
}
|
|
160
|
-
updateRule(id, newRule) {
|
|
161
|
-
this.service.updateRule(id, newRule);
|
|
162
|
-
}
|
|
163
|
-
updateRules(rules) {
|
|
164
|
-
this.service.updateRules(rules);
|
|
165
|
-
}
|
|
166
|
-
clickExport() {
|
|
167
|
-
const exports = [];
|
|
168
|
-
if (this.exportsSettings.xlsx) {
|
|
169
|
-
exports.push({
|
|
170
|
-
type: "xlsx",
|
|
171
|
-
onClickExport: () => this.clickXlsx()
|
|
172
|
-
});
|
|
173
|
-
}
|
|
174
|
-
else if (this.exportsSettings.csv) {
|
|
175
|
-
exports.push({
|
|
176
|
-
type: "csv",
|
|
177
|
-
onClickExport: () => this.clickCsv()
|
|
178
|
-
});
|
|
179
|
-
}
|
|
180
|
-
else if (this.exportsSettings.pdf) {
|
|
181
|
-
exports.push({
|
|
182
|
-
type: "pdf",
|
|
183
|
-
onClickExport: () => this.clickPdf()
|
|
184
|
-
});
|
|
185
|
-
}
|
|
186
|
-
this.bottomSheet.open(ExportBottomSheetComponent, {
|
|
187
|
-
data: {
|
|
188
|
-
exportStrategies: [
|
|
189
|
-
...exports,
|
|
190
|
-
...this.customExport
|
|
191
|
-
]
|
|
192
|
-
}
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
navigate(item) {
|
|
196
|
-
if (this.navigateFn) {
|
|
197
|
-
this.navigateFn(this.baseRoute, item);
|
|
198
|
-
}
|
|
199
|
-
else {
|
|
200
|
-
const route = this.routeFn ? this.routeFn(item) : [(this.baseRoute || "") + (item === null || item === void 0 ? void 0 : item.id)];
|
|
201
|
-
this.router.navigate(typeof route === "string" ? [route] : route, { relativeTo: this.activatedRoute });
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
clickXlsx() {
|
|
205
|
-
this.service.downloadData("xlsx");
|
|
206
|
-
}
|
|
207
|
-
clickCsv() {
|
|
208
|
-
this.service.downloadData("csv");
|
|
209
|
-
}
|
|
210
|
-
clickPrint() {
|
|
211
|
-
this.service.printData();
|
|
212
|
-
}
|
|
213
|
-
clickPdf() {
|
|
214
|
-
this.service.downloadData("pdf");
|
|
215
|
-
}
|
|
216
|
-
setColumn(columns) {
|
|
217
|
-
this.columns = columns;
|
|
218
|
-
this.columnNames = columns.map(x => x.id);
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
NiceBaseListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NiceBaseListComponent, deps: [{ token: ENABLE_QUERY_BUILDER, optional: true }, { token: BASE_LIST_LAYOUT }, { token: TABLE_COLUMNS }, { token: EXPORTS_SETTINGS }, { token: i1.NiceBaseListQuery }, { token: i2.NiceBaseListService }, { token: i3.ActivatedRoute }, { token: i4.MatBottomSheet }, { token: i3.Router }, { token: i5.MediaObserver }], target: i0.ɵɵFactoryTarget.Component });
|
|
222
|
-
NiceBaseListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.0", type: NiceBaseListComponent, selector: "nice-base-list", inputs: { mode: "mode", layout: "layout", layoutContent: "layoutContent", autoChangeLayout: "autoChangeLayout", baseRoute: "baseRoute", routeFn: "routeFn", navigateFn: "navigateFn", autoLoad: "autoLoad", pageTitle: "pageTitle", canExport: "canExport", disableRouting: "disableRouting", customExport: "customExport" }, outputs: { newPage: "newPage" }, providers: [
|
|
223
|
-
NiceBaseListQuery,
|
|
224
|
-
NiceBaseListService,
|
|
225
|
-
NiceBaseListStore
|
|
226
|
-
], queries: [{ propertyName: "title", first: true, predicate: NiceBaseListTitleDirective, descendants: true, read: TemplateRef }, { propertyName: "table", first: true, predicate: NiceBaseListTableDirective, descendants: true, read: TemplateRef }, { propertyName: "cards", first: true, predicate: NiceBaseListCardsDirective, descendants: true, read: TemplateRef }, { propertyName: "customContent", first: true, predicate: NiceBaseListCustomContentDirective, descendants: true, read: TemplateRef }, { propertyName: "filters", first: true, predicate: NiceBaseListFiltersDirective, descendants: true, read: TemplateRef }, { propertyName: "buttons", predicate: NiceBaseListButtonsDirective }], usesOnChanges: true, ngImport: i0, template: "<div class=\"list page-layout carded fullwidth inner-scroll\" *ngIf=\"layout === 'page'; else content\">\n <div class=\"center\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n</div>\n\n<ng-template #content>\n <ng-container *ngIf=\"listLayout.xl\">\n <div fxHide fxShow.xl>\n <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.xl }\"></ng-container>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"listLayout.lg\">\n <div fxHide fxShow.lg>\n <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.lg }\"></ng-container>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"listLayout.md\">\n <div fxHide fxShow.md>\n <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.md }\"></ng-container>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"listLayout.sm\">\n <div fxHide fxShow.sm>\n <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.sm }\"></ng-container>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"listLayout.xs\">\n <div fxHide fxShow.xs>\n <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.xs }\"></ng-container>\n </div>\n </ng-container>\n\n <div\n [fxHide.xs]=\"!!listLayout.xs\"\n [fxHide.sm]=\"!!listLayout.sm\"\n [fxHide.md]=\"!!listLayout.md\"\n [fxHide.lg]=\"!!listLayout.lg\"\n [fxHide.xl]=\"!!listLayout.xl\"\n >\n <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.default }\"></ng-container>\n </div>\n</ng-template>\n\n<ng-template #pageLayout let-layout=\"layout\">\n <ng-container *ngIf=\"layout?.length; else isObject\">\n <ng-container *ngTemplateOutlet=\"contentLayout; context: { layout: { type: 'column', items: layout } }\"></ng-container>\n </ng-container>\n\n <ng-template #isObject>\n <ng-container *ngTemplateOutlet=\"contentLayout; context: { layout: layout }\"></ng-container>\n </ng-template>\n</ng-template>\n\n<ng-template #contentLayout let-layout=\"layout\">\n <div [fxFlex]=\"layout.flex\" [fxLayout]=\"layout.type\" [fxLayoutAlign]=\"layout.align || ''\" [ngClass]=\"layout.classes\">\n <ng-container *ngFor=\"let item of layout.items\">\n <ng-container *ngIf=\"item.name; else childIsLayout\">\n <ng-container *ngTemplateOutlet=\"layoutItem; context: { item: item }\"></ng-container>\n </ng-container>\n <ng-template #childIsLayout>\n <ng-container *ngTemplateOutlet=\"contentLayout; context: { layout: item }\"></ng-container>\n </ng-template>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #layoutItem let-item=\"item\">\n <ng-container *ngIf=\"item.name === 'title' && title\">\n <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n <ng-container *ngTemplateOutlet=\"title\"></ng-container>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"item.name === 'search'\">\n <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\">\n <div class=\"search-wrapper mx-md-0\">\n <div class=\"search\" fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon>search</mat-icon>\n <input [ngModel]=\"searchQuery$ | async\" (ngModelChange)=\"onUpdateSearch($event)\" [placeholder]=\"'general.search' | translate\" />\n <ng-container *ngIf=\"enableQueryBuilder\">\n <button\n *ngIf=\"!(showQueryBuilder$ | async) && !(rulesCount$ | async)\"\n mat-icon-button\n niceQueryBuilderTrigger\n [queryBuilderFilters]=\"filterConfig$ | async\"\n [queryBuilderFiltersLoading]=\"(filterConfigLoading$ | async) || false\"\n (queryBuilderFilterSelected)=\"onQueryBuilderFilterSelected($event)\"\n [matTooltip]=\"'general.query_builder.show_advanced_search' | translate\"\n >\n <mat-icon\n [matBadge]=\"rulesCount$ | async\"\n [matBadgeHidden]=\"!(rulesCount$ | async)\"\n matBadgeColor=\"accent\"\n >\n filter_list\n </mat-icon>\n </button>\n <button\n mat-icon-button\n *ngIf=\"!(showQueryBuilder$ | async) && (rulesCount$ | async)\"\n [disabled]=\"filterConfigLoading$ | async\"\n (click)=\"clickToggleShowQueryBuilder()\"\n [matTooltip]=\"'general.query_builder.show_advanced_search' | translate\"\n >\n <mat-icon\n [matBadge]=\"rulesCount$ | async\"\n [matBadgeHidden]=\"!(rulesCount$ | async)\"\n matBadgeColor=\"accent\"\n >\n filter_list\n </mat-icon>\n </button>\n <button\n mat-icon-button\n *ngIf=\"showQueryBuilder$ | async\"\n (click)=\"clickToggleShowQueryBuilder()\"\n [matTooltip]=\"'general.query_builder.close_advanced_search' | translate\"\n >\n <mat-icon>\n clear\n </mat-icon>\n </button>\n </ng-container>\n </div>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"item.name === 'prefixButtons' && prefixButtons\">\n <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\">\n <ng-container *ngTemplateOutlet=\"prefixButtons\"></ng-container>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"item.name === 'suffixButtons' && suffixButtons\">\n <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\">\n <ng-container *ngTemplateOutlet=\"suffixButtons\"></ng-container>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"item.name === 'exportButtons' && canExport\">\n <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\" [class.mr-2]=\"!!suffixButtons\" [class.ml-2]=\"!!prefixButtons\">\n <button\n (click)=\"clickPrint()\"\n [disabled]=\"loading$ | async\"\n [matTooltip]=\"'general.print' | translate\"\n class=\"list-button mr-2\"\n mat-mini-fab\n >\n <mat-icon>print</mat-icon>\n </button>\n\n <button\n (click)=\"clickExport()\"\n [disabled]=\"loading$ | async\"\n [matTooltip]=\"'general.export' | translate\"\n class=\"list-button mr-2\"\n mat-mini-fab\n >\n <mat-icon>cloud_download</mat-icon>\n </button>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"item.name === 'content'\">\n <ng-container *ngIf=\"layoutContent === 'table' && table\">\n <ng-container *ngTemplateOutlet=\"tableLayout; context: { item: item }\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"layoutContent === 'cards' && cards\">\n <ng-container *ngTemplateOutlet=\"cardsLayout; context: { item: item }\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"layoutContent === 'custom' && customContent\">\n <ng-container *ngTemplateOutlet=\"customLayout; context: { item: item }\"></ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"item.name === 'pagination' && layoutContent !== 'custom'\">\n <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n <mat-paginator\n (page)=\"onUpdatePage($event)\"\n [length]=\"recordsFiltered$ | async\"\n [pageIndex]=\"index$ | async\"\n [pageSizeOptions]=\"defaultPageSizeOptions\"\n [pageSize]=\"length$ | async\"\n [showFirstLastButtons]=\"true\"\n >\n </mat-paginator>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"item.name === 'queryBuilder' && enableQueryBuilder\">\n <div fxLayout=\"column\" *ngIf=\"showQueryBuilder$ | async\">\n <mat-card class=\"my-4\" [niceLoadingOverlay]=\"filterConfigLoading$ | async\">\n <mat-card-content fxLayout=\"column\">\n <div fxFlex>\n <nice-query-builder\n [filterConfigs]=\"filterConfig$ | async\"\n [ngModel]=\"rules$ | async\"\n (ngModelChange)=\"onUpdateRules($event)\"\n (close)=\"clickToggleShowQueryBuilder()\"\n ></nice-query-builder>\n </div>\n </mat-card-content>\n </mat-card>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"item.name === 'filters' && filters\">\n <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\">\n <ng-container *ngTemplateOutlet=\"filters\"></ng-container>\n </div>\n </ng-container>\n</ng-template>\n\n<ng-template #tableLayout let-item=\"item\">\n <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n <div\n [niceLoadingOverlay]=\"loading$ | async\"\n class=\"content-card base-list\"\n fxLayout=\"column\"\n fxLayoutAlign=\"space-between\"\n >\n <mat-table\n (matSortChange)=\"onUpdateSort($event)\"\n [dataSource]=\"data$\"\n [matSortActive]=\"(sortColumn$ | async) || ''\"\n [matSortDirection]=\"(sortDirection$ | async) || ''\"\n fxFlex=\"1 1 auto\"\n matSort\n >\n <mat-header-row *matHeaderRowDef=\"columnNames; sticky: true\"></mat-header-row>\n\n <ng-container *ngFor=\"let column of columns\" [matColumnDef]=\"column.id\">\n <ng-container *ngIf=\"column.sortable\">\n <mat-header-cell *matHeaderCellDef mat-sort-header>\n <ng-container\n *ngTemplateOutlet=\"table; context: { column: column.id, header: true }\"\n ></ng-container>\n </mat-header-cell>\n </ng-container>\n <ng-container *ngIf=\"!column.sortable\">\n <mat-header-cell *matHeaderCellDef>\n <ng-container\n *ngTemplateOutlet=\"table; context: { column: column.id, header: true }\"\n ></ng-container>\n </mat-header-cell>\n </ng-container>\n\n <mat-cell *matCellDef=\"let item\">\n <ng-container\n *ngTemplateOutlet=\"table; context: { column: column.id, data: true, item: item }\"\n ></ng-container>\n </mat-cell>\n </ng-container>\n\n <ng-container *ngIf=\"disableRouting; else withRouting\">\n <mat-row *matRowDef=\"let item; columns: columnNames;\" class=\"item\"></mat-row>\n </ng-container>\n\n <ng-template #withRouting>\n <mat-row\n *matRowDef=\"let item; columns: columnNames;\"\n (click)=\"navigate(item)\"\n class=\"item clickable\"\n matRipple\n >\n </mat-row>\n </ng-template>\n </mat-table>\n </div>\n </div>\n</ng-template>\n\n<ng-template #cardsLayout let-item=\"item\">\n <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n <ng-container *ngFor=\"let data of data$ | async\">\n <ng-container *ngTemplateOutlet=\"cards; context: { item: data }\"></ng-container>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #customLayout let-item=\"item\">\n <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n <ng-container *ngTemplateOutlet=\"customContent; context: { data: data$ | async }\"></ng-container>\n </div>\n</ng-template>\n", components: [{ type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i8.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { type: i9.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i10.QueryBuilderComponent, selector: "nice-query-builder", inputs: ["filterConfigs", "currentSavedReport", "loading"], outputs: ["close", "createReport", "updateReport"] }, { type: i11.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { type: i11.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { type: i12.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "arrowPosition", "disableClear", "mat-sort-header", "start"], exportAs: ["matSortHeader"] }, { type: i11.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }], directives: [{ type: i13.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i13.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5.DefaultShowHideDirective, selector: " [fxShow], [fxShow.print], [fxShow.xs], [fxShow.sm], [fxShow.md], [fxShow.lg], [fxShow.xl], [fxShow.lt-sm], [fxShow.lt-md], [fxShow.lt-lg], [fxShow.lt-xl], [fxShow.gt-xs], [fxShow.gt-sm], [fxShow.gt-md], [fxShow.gt-lg], [fxHide], [fxHide.print], [fxHide.xs], [fxHide.sm], [fxHide.md], [fxHide.lg], [fxHide.xl], [fxHide.lt-sm], [fxHide.lt-md], [fxHide.lt-lg], [fxHide.lt-xl], [fxHide.gt-xs], [fxHide.gt-sm], [fxHide.gt-md], [fxHide.gt-lg]", inputs: ["fxShow", "fxShow.print", "fxShow.xs", "fxShow.sm", "fxShow.md", "fxShow.lg", "fxShow.xl", "fxShow.lt-sm", "fxShow.lt-md", "fxShow.lt-lg", "fxShow.lt-xl", "fxShow.gt-xs", "fxShow.gt-sm", "fxShow.gt-md", "fxShow.gt-lg", "fxHide", "fxHide.print", "fxHide.xs", "fxHide.sm", "fxHide.md", "fxHide.lg", "fxHide.xl", "fxHide.lt-sm", "fxHide.lt-md", "fxHide.lt-lg", "fxHide.lt-xl", "fxHide.gt-xs", "fxHide.gt-sm", "fxHide.gt-md", "fxHide.gt-lg"] }, { type: i5.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { type: i5.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i5.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i13.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { type: i13.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i14.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i14.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i14.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i15.QueryBuilderTriggerDirective, selector: "[niceQueryBuilderTrigger]", inputs: ["queryBuilderFilters", "queryBuilderFiltersLoading"], outputs: ["queryBuilderFilterSelected"] }, { type: i16.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i17.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgePosition", "matBadgeSize", "matBadgeColor", "matBadgeOverlap", "matBadgeDescription", "matBadgeHidden", "matBadge"] }, { type: i18.NiceLoadingDirective, selector: "[niceLoadingOverlay]", inputs: ["niceLoadingOverlay"] }, { type: i9.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { type: i12.MatSort, selector: "[matSort]", inputs: ["matSortDisabled", "matSortStart", "matSortDirection", "matSortDisableClear", "matSortActive"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { type: i11.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { type: i11.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i11.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i11.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i11.MatCellDef, selector: "[matCellDef]" }, { type: i11.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i11.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { type: i19.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleRadius", "matRippleDisabled", "matRippleTrigger", "matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleAnimation"], exportAs: ["matRipple"] }], pipes: { "async": i13.AsyncPipe, "translate": i20.TranslatePipe } });
|
|
227
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NiceBaseListComponent, decorators: [{
|
|
228
|
-
type: Component,
|
|
229
|
-
args: [{
|
|
230
|
-
selector: "nice-base-list",
|
|
231
|
-
templateUrl: "./base-list.template.html",
|
|
232
|
-
providers: [
|
|
233
|
-
NiceBaseListQuery,
|
|
234
|
-
NiceBaseListService,
|
|
235
|
-
NiceBaseListStore
|
|
236
|
-
]
|
|
237
|
-
}]
|
|
238
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
239
|
-
type: Optional
|
|
240
|
-
}, {
|
|
241
|
-
type: Inject,
|
|
242
|
-
args: [ENABLE_QUERY_BUILDER]
|
|
243
|
-
}] }, { type: undefined, decorators: [{
|
|
244
|
-
type: Inject,
|
|
245
|
-
args: [BASE_LIST_LAYOUT]
|
|
246
|
-
}] }, { type: undefined, decorators: [{
|
|
247
|
-
type: Inject,
|
|
248
|
-
args: [TABLE_COLUMNS]
|
|
249
|
-
}] }, { type: undefined, decorators: [{
|
|
250
|
-
type: Inject,
|
|
251
|
-
args: [EXPORTS_SETTINGS]
|
|
252
|
-
}] }, { type: i1.NiceBaseListQuery }, { type: i2.NiceBaseListService }, { type: i3.ActivatedRoute }, { type: i4.MatBottomSheet }, { type: i3.Router }, { type: i5.MediaObserver }]; }, propDecorators: { title: [{
|
|
253
|
-
type: ContentChild,
|
|
254
|
-
args: [NiceBaseListTitleDirective, { read: TemplateRef }]
|
|
255
|
-
}], buttons: [{
|
|
256
|
-
type: ContentChildren,
|
|
257
|
-
args: [NiceBaseListButtonsDirective]
|
|
258
|
-
}], table: [{
|
|
259
|
-
type: ContentChild,
|
|
260
|
-
args: [NiceBaseListTableDirective, { read: TemplateRef }]
|
|
261
|
-
}], cards: [{
|
|
262
|
-
type: ContentChild,
|
|
263
|
-
args: [NiceBaseListCardsDirective, { read: TemplateRef }]
|
|
264
|
-
}], customContent: [{
|
|
265
|
-
type: ContentChild,
|
|
266
|
-
args: [NiceBaseListCustomContentDirective, { read: TemplateRef }]
|
|
267
|
-
}], filters: [{
|
|
268
|
-
type: ContentChild,
|
|
269
|
-
args: [NiceBaseListFiltersDirective, { read: TemplateRef }]
|
|
270
|
-
}], mode: [{
|
|
271
|
-
type: Input
|
|
272
|
-
}], layout: [{
|
|
273
|
-
type: Input
|
|
274
|
-
}], layoutContent: [{
|
|
275
|
-
type: Input
|
|
276
|
-
}], autoChangeLayout: [{
|
|
277
|
-
type: Input
|
|
278
|
-
}], baseRoute: [{
|
|
279
|
-
type: Input
|
|
280
|
-
}], routeFn: [{
|
|
281
|
-
type: Input
|
|
282
|
-
}], navigateFn: [{
|
|
283
|
-
type: Input
|
|
284
|
-
}], autoLoad: [{
|
|
285
|
-
type: Input
|
|
286
|
-
}], pageTitle: [{
|
|
287
|
-
type: Input
|
|
288
|
-
}], canExport: [{
|
|
289
|
-
type: Input
|
|
290
|
-
}], disableRouting: [{
|
|
291
|
-
type: Input
|
|
292
|
-
}], customExport: [{
|
|
293
|
-
type: Input
|
|
294
|
-
}], newPage: [{
|
|
295
|
-
type: Output
|
|
296
|
-
}] } });
|
|
297
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-list.component.js","sourceRoot":"","sources":["../../../../../../projects/nice-data-filter-kit/src/lib/components/base-list/base-list.component.ts","../../../../../../projects/nice-data-filter-kit/src/lib/components/base-list/base-list.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    ContentChildren,\n    EventEmitter,\n    Inject,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output, SimpleChanges,\n    TemplateRef\n} from \"@angular/core\";\nimport { MediaObserver } from \"@angular/flex-layout\";\nimport { MatBottomSheet } from \"@angular/material/bottom-sheet\";\nimport { PageEvent } from \"@angular/material/paginator\";\nimport { Sort } from \"@angular/material/sort\";\nimport { ActivatedRoute, Router } from \"@angular/router\";\nimport { ExportBottomSheetComponent, ExportStrategy } from \"@recursyve/nice-ui-kit.v2\";\nimport { Observable, Subject } from \"rxjs\";\nimport { debounceTime, distinctUntilChanged, map, switchMap } from \"rxjs/operators\";\nimport { FilterConfigurationModel } from \"../../models/filter.model\";\nimport { QueryModel, QueryRuleModel } from \"../../models/query.model\";\nimport { BASE_LIST_LAYOUT, ENABLE_QUERY_BUILDER, EXPORTS_SETTINGS, TABLE_COLUMNS } from \"./base-list.constant\";\nimport { NiceBaseListButtonsDirective } from \"./directives/base-list-buttons.directive\";\nimport { NiceBaseListCardsDirective } from \"./directives/base-list-cards.directive\";\nimport { NiceBaseListCustomContentDirective } from \"./directives/base-list-custom-content.directive\";\nimport { NiceBaseListFiltersDirective } from \"./directives/base-list-filters.directive\";\nimport { NiceBaseListTableDirective } from \"./directives/base-list-table.directive\";\nimport { NiceBaseListTitleDirective } from \"./directives/base-list-title.directive\";\nimport { TableColumns } from \"./models/columns.model\";\nimport { ExportSettings } from \"./models/export.model\";\nimport { BaseListLayout, LayoutContent } from \"./models/layout.model\";\nimport { NiceBaseListQuery } from \"./store/base-list.query\";\nimport { NiceBaseListService } from \"./store/base-list.service\";\nimport { NiceBaseListStore } from \"./store/base-list.store\";\n\n@Component({\n    selector: \"nice-base-list\",\n    templateUrl: \"./base-list.template.html\",\n    providers: [\n        NiceBaseListQuery,\n        NiceBaseListService,\n        NiceBaseListStore\n    ]\n})\nexport class NiceBaseListComponent implements OnInit, OnDestroy, OnChanges {\n    @ContentChild(NiceBaseListTitleDirective, { read: TemplateRef })\n    public title: TemplateRef<any>;\n\n    @ContentChildren(NiceBaseListButtonsDirective)\n    public buttons: NiceBaseListButtonsDirective[];\n\n    @ContentChild(NiceBaseListTableDirective, { read: TemplateRef })\n    public table: TemplateRef<any>;\n\n    @ContentChild(NiceBaseListCardsDirective, { read: TemplateRef })\n    public cards: TemplateRef<any>;\n\n    @ContentChild(NiceBaseListCustomContentDirective, { read: TemplateRef })\n    public customContent: TemplateRef<any>;\n\n    @ContentChild(NiceBaseListFiltersDirective, { read: TemplateRef })\n    public filters: TemplateRef<any>;\n\n    @Input()\n    public mode: \"normal\" | \"infinite-scroll\" = \"normal\";\n\n    @Input()\n    public layout: \"page\" | \"component\" = \"page\";\n\n    @Input()\n    public layoutContent = LayoutContent.Table;\n\n    @Input()\n    public autoChangeLayout = true;\n\n    @Input()\n    public baseRoute: string;\n\n    @Input()\n    public routeFn: (item: any) => string | string[];\n\n    @Input()\n    public navigateFn: (baseRoute: string, item: any) => string;\n\n    @Input()\n    public autoLoad = true;\n\n    @Input()\n    public pageTitle: string;\n\n    @Input()\n    public canExport = true;\n\n    @Input()\n    public disableRouting = false;\n\n    @Input()\n    public customExport: ExportStrategy[] = [];\n\n    @Output()\n    public newPage = new EventEmitter<PageEvent>();\n\n    public defaultPageSizeOptions = [10, 25, 50, 100];\n    public columnNames: string[] = [];\n\n    public loading$ = this.query.selectLoading();\n\n    public filterResult$ = this.query.selectFilterResult();\n    public data$ = this.query.selectData();\n    public recordsFiltered$ = this.filterResult$.pipe(map(f => f && f.total));\n\n    public showQueryBuilder$ = this.query.selectShowQueryBuilder();\n    public filterParameters$ = this.query.selectFilterParameters();\n    public index$ = this.filterParameters$.pipe(map(f => Math.floor((f.start ?? 0) / (f.length ?? 1))));\n    public length$ = this.filterParameters$.pipe(map(f => f.length));\n    public isEmpty$ = this.recordsFiltered$.pipe(map(r => r === 0));\n    public searchQuery$ = this.filterParameters$.pipe(map(f => f.search));\n    public filterConfig$ = this.query.selectFilterConfig();\n    public sortColumn$ = this.filterParameters$.pipe(map(f => (f.order && f.order.column) ?? \"\"));\n    public sortDirection$ = this.filterParameters$.pipe(map(f => f.order && f.order.direction));\n\n    public filterConfigLoading$ = this.query.selectFilterConfigLoading();\n    public rules$ = this.filterParameters$.pipe(map(parameters => parameters.rules));\n    public rulesCount$ = this.filterParameters$.pipe(map(parameters => parameters.rules?.length ?? 0));\n\n    private searchText$ = new Subject<string>();\n\n    constructor(\n        @Optional()\n        @Inject(ENABLE_QUERY_BUILDER)\n        public enableQueryBuilder: boolean,\n        @Inject(BASE_LIST_LAYOUT)\n        public listLayout: BaseListLayout,\n        @Inject(TABLE_COLUMNS)\n        public columns: TableColumns[],\n        @Inject(EXPORTS_SETTINGS)\n        private readonly exportsSettings: ExportSettings,\n        public readonly query: NiceBaseListQuery,\n        public readonly service: NiceBaseListService,\n        private readonly activatedRoute: ActivatedRoute,\n        private readonly bottomSheet: MatBottomSheet,\n        private readonly router: Router,\n        private mediaObserver: MediaObserver\n    ) {\n        this.setColumn(columns);\n    }\n\n    public get prefixButtons(): TemplateRef<any> | undefined {\n        return this.buttons?.find(x => x.position === \"prefix\")?.template;\n    }\n\n    public get suffixButtons(): TemplateRef<any> | undefined {\n        return this.buttons?.find(x => x.position === \"suffix\")?.template;\n    }\n\n    public async ngOnInit(): Promise<void> {\n        await this.service.init();\n        this.service.loadQueryParams(this.autoLoad);\n\n        this.searchText$\n            .pipe(\n                debounceTime(300),\n                distinctUntilChanged(),\n                switchMap((search) => {\n                    this.service.resetPaging();\n                    return this.service.searchData(search);\n                })\n            )\n            .subscribe();\n\n        this.mediaObserver.asObservable().subscribe(() => {\n            if (!this.autoChangeLayout) {\n                return;\n            }\n\n            if (this.mediaObserver.isActive(\"lt-md\") && this.layoutContent === LayoutContent.Table) {\n                this.layoutContent = LayoutContent.Cards;\n            } else {\n                this.layoutContent = LayoutContent.Table;\n            }\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this.service.closeSubscriptions();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (\"mode\" in changes) {\n            this.service.setMode(changes.mode.currentValue);\n        }\n    }\n\n    public setLoading(loading: boolean): void {\n        this.service.setLoading(loading);\n    }\n\n    public clickToggleShowQueryBuilder(): void {\n        this.service.toggleQueryBuilder();\n    }\n\n    public onUpdateRules(rules: QueryModel[]): void {\n        this.service.updateGlobalRules(rules);\n    }\n\n    public onQueryBuilderFilterSelected(filterConfigurationModel: FilterConfigurationModel): void {\n        this.service.addRuleFromConfig(filterConfigurationModel);\n    }\n\n    public onUpdatePage(pageEvent: PageEvent): void {\n        this.service.loadNewPage(pageEvent.pageIndex * pageEvent.pageSize, pageEvent.pageSize);\n        this.newPage.emit(pageEvent);\n    }\n\n    public onUpdateSearch(search: string): void {\n        this.searchText$.next(search);\n    }\n\n    public getFilterRule$(id: string): Observable<QueryRuleModel | undefined> {\n        return this.filterParameters$.pipe(\n            map(f => {\n                return (\n                    f.rules &&\n                    f.rules[0] &&\n                    f.rules[0].rules &&\n                    (f.rules[0].rules.find((r) => (r as QueryRuleModel).id === id) as QueryRuleModel)\n                );\n            })\n        );\n    }\n\n    public onUpdateSort(sort: Sort): void {\n        if (!sort.active || !sort.direction) {\n            sort = {\n                active: \"id\",\n                direction: \"asc\"\n            };\n        }\n\n        this.service.loadData({\n            order: sort.active && sort.direction ? { column: sort.active, direction: sort.direction } : null\n        });\n    }\n\n    public updateRule(id: string, newRule: QueryRuleModel): void {\n        this.service.updateRule(id, newRule);\n    }\n\n    public updateRules(rules: QueryRuleModel[]): void {\n        this.service.updateRules(rules);\n    }\n\n    public clickExport(): void {\n        const exports = [];\n        if (this.exportsSettings.xlsx) {\n            exports.push({\n                type: \"xlsx\",\n                onClickExport: () => this.clickXlsx()\n            });\n        } else if (this.exportsSettings.csv) {\n            exports.push({\n                type: \"csv\",\n                onClickExport: () => this.clickCsv()\n            });\n        } else if (this.exportsSettings.pdf) {\n            exports.push({\n                type: \"pdf\",\n                onClickExport: () => this.clickPdf()\n            });\n        }\n        this.bottomSheet.open(ExportBottomSheetComponent, {\n            data: {\n                exportStrategies: [\n                    ...exports,\n                    ...this.customExport\n                ]\n            }\n        });\n    }\n\n    public navigate(item: any): void {\n        if (this.navigateFn) {\n            this.navigateFn(this.baseRoute, item);\n        } else {\n            const route = this.routeFn ? this.routeFn(item) : [(this.baseRoute || \"\") + item?.id];\n            this.router.navigate(typeof route === \"string\" ? [route] : route, { relativeTo: this.activatedRoute });\n        }\n    }\n\n    public clickXlsx(): void {\n        this.service.downloadData(\"xlsx\");\n    }\n\n    public clickCsv(): void {\n        this.service.downloadData(\"csv\");\n    }\n\n    public clickPrint(): void {\n        this.service.printData();\n    }\n\n    public clickPdf(): void {\n        this.service.downloadData(\"pdf\");\n    }\n\n    protected setColumn(columns: TableColumns[]): void {\n        this.columns = columns;\n        this.columnNames = columns.map(x => x.id);\n    }\n}\n","<div class=\"list page-layout carded fullwidth inner-scroll\" *ngIf=\"layout === 'page'; else content\">\n    <div class=\"center\">\n        <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n    </div>\n</div>\n\n<ng-template #content>\n    <ng-container *ngIf=\"listLayout.xl\">\n        <div fxHide fxShow.xl>\n            <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.xl }\"></ng-container>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"listLayout.lg\">\n        <div fxHide fxShow.lg>\n            <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.lg }\"></ng-container>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"listLayout.md\">\n        <div fxHide fxShow.md>\n            <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.md }\"></ng-container>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"listLayout.sm\">\n        <div fxHide fxShow.sm>\n            <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.sm }\"></ng-container>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"listLayout.xs\">\n        <div fxHide fxShow.xs>\n            <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.xs }\"></ng-container>\n        </div>\n    </ng-container>\n\n    <div\n            [fxHide.xs]=\"!!listLayout.xs\"\n            [fxHide.sm]=\"!!listLayout.sm\"\n            [fxHide.md]=\"!!listLayout.md\"\n            [fxHide.lg]=\"!!listLayout.lg\"\n            [fxHide.xl]=\"!!listLayout.xl\"\n    >\n        <ng-container *ngTemplateOutlet=\"pageLayout; context: { layout: listLayout.default }\"></ng-container>\n    </div>\n</ng-template>\n\n<ng-template #pageLayout let-layout=\"layout\">\n    <ng-container *ngIf=\"layout?.length; else isObject\">\n        <ng-container *ngTemplateOutlet=\"contentLayout; context: { layout: { type: 'column', items: layout } }\"></ng-container>\n    </ng-container>\n\n    <ng-template #isObject>\n        <ng-container *ngTemplateOutlet=\"contentLayout; context: { layout: layout }\"></ng-container>\n    </ng-template>\n</ng-template>\n\n<ng-template #contentLayout let-layout=\"layout\">\n    <div [fxFlex]=\"layout.flex\" [fxLayout]=\"layout.type\" [fxLayoutAlign]=\"layout.align || ''\" [ngClass]=\"layout.classes\">\n        <ng-container *ngFor=\"let item of layout.items\">\n            <ng-container *ngIf=\"item.name; else childIsLayout\">\n                <ng-container *ngTemplateOutlet=\"layoutItem; context: { item: item }\"></ng-container>\n            </ng-container>\n            <ng-template #childIsLayout>\n                <ng-container *ngTemplateOutlet=\"contentLayout; context: { layout: item }\"></ng-container>\n            </ng-template>\n        </ng-container>\n    </div>\n</ng-template>\n\n<ng-template #layoutItem let-item=\"item\">\n    <ng-container *ngIf=\"item.name === 'title' && title\">\n        <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n            <ng-container *ngTemplateOutlet=\"title\"></ng-container>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"item.name === 'search'\">\n        <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\">\n            <div class=\"search-wrapper mx-md-0\">\n                <div class=\"search\" fxFlex fxLayout=\"row\" fxLayoutAlign=\"start center\">\n                    <mat-icon>search</mat-icon>\n                    <input [ngModel]=\"searchQuery$ | async\" (ngModelChange)=\"onUpdateSearch($event)\" [placeholder]=\"'general.search' | translate\" />\n                    <ng-container *ngIf=\"enableQueryBuilder\">\n                        <button\n                                *ngIf=\"!(showQueryBuilder$ | async) && !(rulesCount$ | async)\"\n                                mat-icon-button\n                                niceQueryBuilderTrigger\n                                [queryBuilderFilters]=\"filterConfig$ | async\"\n                                [queryBuilderFiltersLoading]=\"(filterConfigLoading$ | async) || false\"\n                                (queryBuilderFilterSelected)=\"onQueryBuilderFilterSelected($event)\"\n                                [matTooltip]=\"'general.query_builder.show_advanced_search' | translate\"\n                        >\n                            <mat-icon\n                                [matBadge]=\"rulesCount$ | async\"\n                                [matBadgeHidden]=\"!(rulesCount$ | async)\"\n                                matBadgeColor=\"accent\"\n                            >\n                                filter_list\n                            </mat-icon>\n                        </button>\n                        <button\n                                mat-icon-button\n                                *ngIf=\"!(showQueryBuilder$ | async) && (rulesCount$ | async)\"\n                                [disabled]=\"filterConfigLoading$ | async\"\n                                (click)=\"clickToggleShowQueryBuilder()\"\n                                [matTooltip]=\"'general.query_builder.show_advanced_search' | translate\"\n                        >\n                            <mat-icon\n                                [matBadge]=\"rulesCount$ | async\"\n                                [matBadgeHidden]=\"!(rulesCount$ | async)\"\n                                matBadgeColor=\"accent\"\n                            >\n                                filter_list\n                            </mat-icon>\n                        </button>\n                        <button\n                            mat-icon-button\n                            *ngIf=\"showQueryBuilder$ | async\"\n                            (click)=\"clickToggleShowQueryBuilder()\"\n                            [matTooltip]=\"'general.query_builder.close_advanced_search' | translate\"\n                        >\n                            <mat-icon>\n                                clear\n                            </mat-icon>\n                        </button>\n                    </ng-container>\n                </div>\n            </div>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"item.name === 'prefixButtons' && prefixButtons\">\n        <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\">\n            <ng-container *ngTemplateOutlet=\"prefixButtons\"></ng-container>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"item.name === 'suffixButtons' && suffixButtons\">\n        <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\">\n            <ng-container *ngTemplateOutlet=\"suffixButtons\"></ng-container>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"item.name === 'exportButtons' && canExport\">\n        <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\" [class.mr-2]=\"!!suffixButtons\" [class.ml-2]=\"!!prefixButtons\">\n            <button\n                    (click)=\"clickPrint()\"\n                    [disabled]=\"loading$ | async\"\n                    [matTooltip]=\"'general.print' | translate\"\n                    class=\"list-button mr-2\"\n                    mat-mini-fab\n            >\n                <mat-icon>print</mat-icon>\n            </button>\n\n            <button\n                    (click)=\"clickExport()\"\n                    [disabled]=\"loading$ | async\"\n                    [matTooltip]=\"'general.export' | translate\"\n                    class=\"list-button mr-2\"\n                    mat-mini-fab\n            >\n                <mat-icon>cloud_download</mat-icon>\n            </button>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"item.name === 'content'\">\n        <ng-container *ngIf=\"layoutContent === 'table' && table\">\n            <ng-container *ngTemplateOutlet=\"tableLayout; context: { item: item }\"></ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"layoutContent === 'cards' && cards\">\n            <ng-container *ngTemplateOutlet=\"cardsLayout; context: { item: item }\"></ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"layoutContent === 'custom' && customContent\">\n            <ng-container *ngTemplateOutlet=\"customLayout; context: { item: item }\"></ng-container>\n        </ng-container>\n    </ng-container>\n\n    <ng-container *ngIf=\"item.name === 'pagination' && layoutContent !== 'custom'\">\n        <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n            <mat-paginator\n                (page)=\"onUpdatePage($event)\"\n                [length]=\"recordsFiltered$ | async\"\n                [pageIndex]=\"index$ | async\"\n                [pageSizeOptions]=\"defaultPageSizeOptions\"\n                [pageSize]=\"length$ | async\"\n                [showFirstLastButtons]=\"true\"\n            >\n            </mat-paginator>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"item.name === 'queryBuilder' && enableQueryBuilder\">\n        <div fxLayout=\"column\" *ngIf=\"showQueryBuilder$ | async\">\n            <mat-card class=\"my-4\" [niceLoadingOverlay]=\"filterConfigLoading$ | async\">\n                <mat-card-content fxLayout=\"column\">\n                    <div fxFlex>\n                        <nice-query-builder\n                            [filterConfigs]=\"filterConfig$ | async\"\n                            [ngModel]=\"rules$ | async\"\n                            (ngModelChange)=\"onUpdateRules($event)\"\n                            (close)=\"clickToggleShowQueryBuilder()\"\n                        ></nice-query-builder>\n                    </div>\n                </mat-card-content>\n            </mat-card>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"item.name === 'filters' && filters\">\n        <div [fxFlex]=\"item.flex\" [fxLayoutAlign]=\"item.align || ''\" [ngClass]=\"item.classes\">\n            <ng-container *ngTemplateOutlet=\"filters\"></ng-container>\n        </div>\n    </ng-container>\n</ng-template>\n\n<ng-template #tableLayout let-item=\"item\">\n    <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n        <div\n                [niceLoadingOverlay]=\"loading$ | async\"\n                class=\"content-card base-list\"\n                fxLayout=\"column\"\n                fxLayoutAlign=\"space-between\"\n        >\n            <mat-table\n                    (matSortChange)=\"onUpdateSort($event)\"\n                    [dataSource]=\"data$\"\n                    [matSortActive]=\"(sortColumn$ | async) || ''\"\n                    [matSortDirection]=\"(sortDirection$ | async) || ''\"\n                    fxFlex=\"1 1 auto\"\n                    matSort\n            >\n                <mat-header-row *matHeaderRowDef=\"columnNames; sticky: true\"></mat-header-row>\n\n                <ng-container *ngFor=\"let column of columns\" [matColumnDef]=\"column.id\">\n                    <ng-container *ngIf=\"column.sortable\">\n                        <mat-header-cell *matHeaderCellDef mat-sort-header>\n                            <ng-container\n                                    *ngTemplateOutlet=\"table; context: { column: column.id, header: true }\"\n                            ></ng-container>\n                        </mat-header-cell>\n                    </ng-container>\n                    <ng-container *ngIf=\"!column.sortable\">\n                        <mat-header-cell *matHeaderCellDef>\n                            <ng-container\n                                    *ngTemplateOutlet=\"table; context: { column: column.id, header: true }\"\n                            ></ng-container>\n                        </mat-header-cell>\n                    </ng-container>\n\n                    <mat-cell *matCellDef=\"let item\">\n                        <ng-container\n                                *ngTemplateOutlet=\"table; context: { column: column.id, data: true, item: item }\"\n                        ></ng-container>\n                    </mat-cell>\n                </ng-container>\n\n                <ng-container *ngIf=\"disableRouting; else withRouting\">\n                    <mat-row *matRowDef=\"let item; columns: columnNames;\" class=\"item\"></mat-row>\n                </ng-container>\n\n                <ng-template #withRouting>\n                    <mat-row\n                            *matRowDef=\"let item; columns: columnNames;\"\n                            (click)=\"navigate(item)\"\n                            class=\"item clickable\"\n                            matRipple\n                    >\n                    </mat-row>\n                </ng-template>\n            </mat-table>\n        </div>\n    </div>\n</ng-template>\n\n<ng-template #cardsLayout let-item=\"item\">\n    <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n        <ng-container *ngFor=\"let data of data$ | async\">\n            <ng-container *ngTemplateOutlet=\"cards; context: { item: data }\"></ng-container>\n        </ng-container>\n    </div>\n</ng-template>\n\n<ng-template #customLayout let-item=\"item\">\n    <div [fxFlex]=\"item.flex\" [ngClass]=\"item.classes\">\n        <ng-container *ngTemplateOutlet=\"customContent; context: { data: data$ | async }\"></ng-container>\n    </div>\n</ng-template>\n"]}
|