aril 0.0.95 → 0.0.97
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/esm2022/theme/layout/index.mjs +2 -3
- package/esm2022/theme/layout/service/selection-group.service.mjs +60 -0
- package/esm2022/ui/autoComplete/src/auto-complete.component.mjs +13 -10
- package/esm2022/ui/value/src/value.component.mjs +12 -12
- package/fesm2022/aril-theme-layout.mjs +43 -83
- package/fesm2022/aril-theme-layout.mjs.map +1 -1
- package/fesm2022/aril-ui-autoComplete.mjs +12 -9
- package/fesm2022/aril-ui-autoComplete.mjs.map +1 -1
- package/fesm2022/aril-ui-value.mjs +11 -11
- package/fesm2022/aril-ui-value.mjs.map +1 -1
- package/package.json +42 -42
- package/theme/layout/index.d.ts +1 -2
- package/theme/layout/index.ts +2 -2
- package/theme/layout/service/selection-group.service.d.ts +16 -0
- package/theme/layout/service/selection-group.service.ts +65 -0
- package/ui/value/src/value.component.d.ts +5 -4
- package/esm2022/theme/layout/pipes/enumDisplay.pipe.mjs +0 -26
- package/esm2022/theme/layout/pipes/index.mjs +0 -2
- package/esm2022/theme/layout/service/local-storage.service.mjs +0 -78
- package/theme/layout/pipes/enumDisplay.pipe.d.ts +0 -11
- package/theme/layout/pipes/enumDisplay.pipe.ts +0 -22
- package/theme/layout/pipes/index.d.ts +0 -1
- package/theme/layout/pipes/index.ts +0 -1
- package/theme/layout/service/local-storage.service.d.ts +0 -17
- package/theme/layout/service/local-storage.service.ts +0 -92
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
export * from './app/layout/app.layout.component';
|
|
2
2
|
export * from './app/layout/mfe.layout.component';
|
|
3
3
|
export * from './service/app.menu.service';
|
|
4
|
-
export * from './service/
|
|
5
|
-
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hcmlsL3RoZW1lL2xheW91dC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hcHAvbGF5b3V0L2FwcC5sYXlvdXQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9hcHAvbGF5b3V0L21mZS5sYXlvdXQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlL2FwcC5tZW51LnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2UvbG9jYWwtc3RvcmFnZS5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9waXBlcyc7XHJcbiJdfQ==
|
|
4
|
+
export * from './service/selection-group.service';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hcmlsL3RoZW1lL2xheW91dC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLG1DQUFtQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hcHAvbGF5b3V0L2FwcC5sYXlvdXQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9hcHAvbGF5b3V0L21mZS5sYXlvdXQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlL2FwcC5tZW51LnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2Uvc2VsZWN0aW9uLWdyb3VwLnNlcnZpY2UnO1xyXG5cclxuIl19
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { Injectable, effect, signal } from '@angular/core';
|
|
2
|
+
import { take } from 'rxjs';
|
|
3
|
+
import { API_CONFIGS } from 'aril/boot/config/api';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common/http";
|
|
6
|
+
export class SelectionGroupService {
|
|
7
|
+
constructor(http) {
|
|
8
|
+
this.http = http;
|
|
9
|
+
this.selectionGroups = signal({});
|
|
10
|
+
this.loading = new Map();
|
|
11
|
+
this.loaded = new Map();
|
|
12
|
+
this.loadStatesFromLocalStorage();
|
|
13
|
+
effect(() => {
|
|
14
|
+
const encodedData = btoa(encodeURI(JSON.stringify(this.selectionGroups())));
|
|
15
|
+
localStorage.setItem('selection-groups', encodedData);
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
async loadStatesFromLocalStorage() {
|
|
19
|
+
const selectionGroups = localStorage.getItem('selection-groups');
|
|
20
|
+
if (selectionGroups) {
|
|
21
|
+
try {
|
|
22
|
+
const decodedData = decodeURI(atob(selectionGroups));
|
|
23
|
+
this.selectionGroups.set(JSON.parse(decodedData));
|
|
24
|
+
}
|
|
25
|
+
catch (e) {
|
|
26
|
+
console.error(e);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
fetchEnum(groupName, parentSelectionKey) {
|
|
31
|
+
if (this.loaded.get(groupName) || this.loading.get(groupName))
|
|
32
|
+
return;
|
|
33
|
+
const payload = {
|
|
34
|
+
groupName,
|
|
35
|
+
parentSelectionKey: parentSelectionKey ?? 'ALL'
|
|
36
|
+
};
|
|
37
|
+
this.loading.set(groupName, true);
|
|
38
|
+
this.loaded.set(groupName, false);
|
|
39
|
+
this.http
|
|
40
|
+
.post(API_CONFIGS.api + '/selection-group/load', payload)
|
|
41
|
+
.pipe(take(1))
|
|
42
|
+
.subscribe((selectionGroup) => {
|
|
43
|
+
this.loading.set(groupName, false);
|
|
44
|
+
this.loaded.set(groupName, true);
|
|
45
|
+
this.selectionGroups.update((groups) => ({
|
|
46
|
+
...groups,
|
|
47
|
+
[groupName]: selectionGroup
|
|
48
|
+
}));
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: SelectionGroupService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
52
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: SelectionGroupService, providedIn: 'root' }); }
|
|
53
|
+
}
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: SelectionGroupService, decorators: [{
|
|
55
|
+
type: Injectable,
|
|
56
|
+
args: [{
|
|
57
|
+
providedIn: 'root'
|
|
58
|
+
}]
|
|
59
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }] });
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLWdyb3VwLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcmlsL3RoZW1lL2xheW91dC9zZXJ2aWNlL3NlbGVjdGlvbi1ncm91cC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzRCxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTVCLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBT25ELE1BQU0sT0FBTyxxQkFBcUI7SUFNakMsWUFBb0IsSUFBZ0I7UUFBaEIsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUxwQyxvQkFBZSxHQUFHLE1BQU0sQ0FBb0QsRUFBRSxDQUFDLENBQUM7UUFFeEUsWUFBTyxHQUFHLElBQUksR0FBRyxFQUFtQixDQUFDO1FBQ3JDLFdBQU0sR0FBRyxJQUFJLEdBQUcsRUFBbUIsQ0FBQztRQUczQyxJQUFJLENBQUMsMEJBQTBCLEVBQUUsQ0FBQztRQUVsQyxNQUFNLENBQUMsR0FBRyxFQUFFO1lBQ1gsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM1RSxZQUFZLENBQUMsT0FBTyxDQUFDLGtCQUFrQixFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBQ3ZELENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUVPLEtBQUssQ0FBQywwQkFBMEI7UUFDdkMsTUFBTSxlQUFlLEdBQUcsWUFBWSxDQUFDLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBRWpFLElBQUksZUFBZSxFQUFFLENBQUM7WUFDckIsSUFBSSxDQUFDO2dCQUNKLE1BQU0sV0FBVyxHQUFHLFNBQVMsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQztnQkFDckQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO1lBQ25ELENBQUM7WUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO2dCQUNaLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDbEIsQ0FBQztRQUNGLENBQUM7SUFDRixDQUFDO0lBRUQsU0FBUyxDQUFDLFNBQWlCLEVBQUUsa0JBQWtDO1FBQzlELElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDO1lBQUUsT0FBTztRQUV0RSxNQUFNLE9BQU8sR0FBd0I7WUFDcEMsU0FBUztZQUNULGtCQUFrQixFQUFFLGtCQUFrQixJQUFJLEtBQUs7U0FDL0MsQ0FBQztRQUVGLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNsQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFbEMsSUFBSSxDQUFDLElBQUk7YUFDUCxJQUFJLENBQW9CLFdBQVcsQ0FBQyxHQUFHLEdBQUcsdUJBQXVCLEVBQUUsT0FBTyxDQUFDO2FBQzNFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDYixTQUFTLENBQUMsQ0FBQyxjQUFjLEVBQUUsRUFBRTtZQUM3QixJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDbkMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDO1lBRWpDLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO2dCQUN4QyxHQUFHLE1BQU07Z0JBQ1QsQ0FBQyxTQUFTLENBQUMsRUFBRSxjQUFjO2FBQzNCLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOzhHQW5EVyxxQkFBcUI7a0hBQXJCLHFCQUFxQixjQUZyQixNQUFNOzsyRkFFTixxQkFBcUI7a0JBSGpDLFVBQVU7bUJBQUM7b0JBQ1gsVUFBVSxFQUFFLE1BQU07aUJBQ2xCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSwgZWZmZWN0LCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IHRha2UgfSBmcm9tICdyeGpzJztcclxuXHJcbmltcG9ydCB7IEFQSV9DT05GSUdTIH0gZnJvbSAnYXJpbC9ib290L2NvbmZpZy9hcGknO1xyXG5cclxuaW1wb3J0IHsgU2VsZWN0aW9uR3JvdXBEVE8sIFNlbGVjdGlvblJlcXVlc3REVE8gfSBmcm9tICcuL2ludGVyZmFjZXMvaW50ZXJmYWNlcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcblx0cHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3Rpb25Hcm91cFNlcnZpY2Uge1xyXG5cdHNlbGVjdGlvbkdyb3VwcyA9IHNpZ25hbDx7IFtncm91cE5hbWU6IHN0cmluZ106IFNlbGVjdGlvbkdyb3VwRFRPIHwgbnVsbCB9Pih7fSk7XHJcblxyXG5cdHByaXZhdGUgbG9hZGluZyA9IG5ldyBNYXA8c3RyaW5nLCBib29sZWFuPigpO1xyXG5cdHByaXZhdGUgbG9hZGVkID0gbmV3IE1hcDxzdHJpbmcsIGJvb2xlYW4+KCk7XHJcblxyXG5cdGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cDogSHR0cENsaWVudCkge1xyXG5cdFx0dGhpcy5sb2FkU3RhdGVzRnJvbUxvY2FsU3RvcmFnZSgpO1xyXG5cclxuXHRcdGVmZmVjdCgoKSA9PiB7XHJcblx0XHRcdGNvbnN0IGVuY29kZWREYXRhID0gYnRvYShlbmNvZGVVUkkoSlNPTi5zdHJpbmdpZnkodGhpcy5zZWxlY3Rpb25Hcm91cHMoKSkpKTtcclxuXHRcdFx0bG9jYWxTdG9yYWdlLnNldEl0ZW0oJ3NlbGVjdGlvbi1ncm91cHMnLCBlbmNvZGVkRGF0YSk7XHJcblx0XHR9KTtcclxuXHR9XHJcblxyXG5cdHByaXZhdGUgYXN5bmMgbG9hZFN0YXRlc0Zyb21Mb2NhbFN0b3JhZ2UoKSB7XHJcblx0XHRjb25zdCBzZWxlY3Rpb25Hcm91cHMgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnc2VsZWN0aW9uLWdyb3VwcycpO1xyXG5cclxuXHRcdGlmIChzZWxlY3Rpb25Hcm91cHMpIHtcclxuXHRcdFx0dHJ5IHtcclxuXHRcdFx0XHRjb25zdCBkZWNvZGVkRGF0YSA9IGRlY29kZVVSSShhdG9iKHNlbGVjdGlvbkdyb3VwcykpO1xyXG5cdFx0XHRcdHRoaXMuc2VsZWN0aW9uR3JvdXBzLnNldChKU09OLnBhcnNlKGRlY29kZWREYXRhKSk7XHJcblx0XHRcdH0gY2F0Y2ggKGUpIHtcclxuXHRcdFx0XHRjb25zb2xlLmVycm9yKGUpO1xyXG5cdFx0XHR9XHJcblx0XHR9XHJcblx0fVxyXG5cclxuXHRmZXRjaEVudW0oZ3JvdXBOYW1lOiBzdHJpbmcsIHBhcmVudFNlbGVjdGlvbktleT86IHN0cmluZyB8IG51bGwpIHtcclxuXHRcdGlmICh0aGlzLmxvYWRlZC5nZXQoZ3JvdXBOYW1lKSB8fCB0aGlzLmxvYWRpbmcuZ2V0KGdyb3VwTmFtZSkpIHJldHVybjtcclxuXHJcblx0XHRjb25zdCBwYXlsb2FkOiBTZWxlY3Rpb25SZXF1ZXN0RFRPID0ge1xyXG5cdFx0XHRncm91cE5hbWUsXHJcblx0XHRcdHBhcmVudFNlbGVjdGlvbktleTogcGFyZW50U2VsZWN0aW9uS2V5ID8/ICdBTEwnXHJcblx0XHR9O1xyXG5cclxuXHRcdHRoaXMubG9hZGluZy5zZXQoZ3JvdXBOYW1lLCB0cnVlKTtcclxuXHRcdHRoaXMubG9hZGVkLnNldChncm91cE5hbWUsIGZhbHNlKTtcclxuXHJcblx0XHR0aGlzLmh0dHBcclxuXHRcdFx0LnBvc3Q8U2VsZWN0aW9uR3JvdXBEVE8+KEFQSV9DT05GSUdTLmFwaSArICcvc2VsZWN0aW9uLWdyb3VwL2xvYWQnLCBwYXlsb2FkKVxyXG5cdFx0XHQucGlwZSh0YWtlKDEpKVxyXG5cdFx0XHQuc3Vic2NyaWJlKChzZWxlY3Rpb25Hcm91cCkgPT4ge1xyXG5cdFx0XHRcdHRoaXMubG9hZGluZy5zZXQoZ3JvdXBOYW1lLCBmYWxzZSk7XHJcblx0XHRcdFx0dGhpcy5sb2FkZWQuc2V0KGdyb3VwTmFtZSwgdHJ1ZSk7XHJcblxyXG5cdFx0XHRcdHRoaXMuc2VsZWN0aW9uR3JvdXBzLnVwZGF0ZSgoZ3JvdXBzKSA9PiAoe1xyXG5cdFx0XHRcdFx0Li4uZ3JvdXBzLFxyXG5cdFx0XHRcdFx0W2dyb3VwTmFtZV06IHNlbGVjdGlvbkdyb3VwXHJcblx0XHRcdFx0fSkpO1xyXG5cdFx0XHR9KTtcclxuXHR9XHJcbn1cclxuIl19
|
|
@@ -32,19 +32,19 @@ export class AutoCompleteComponent extends BaseInputComponent {
|
|
|
32
32
|
this.autoCompleteRef.getOptionValue = this.getOptionValue.bind(this);
|
|
33
33
|
}
|
|
34
34
|
getOptionValue(option) {
|
|
35
|
-
return this.optionValue()
|
|
36
|
-
|
|
37
|
-
|
|
35
|
+
return (this.optionValue() ?
|
|
36
|
+
typeof option === 'object' ?
|
|
37
|
+
ObjectUtils.resolveFieldData(option, this.optionValue())
|
|
38
38
|
: option
|
|
39
|
-
: option;
|
|
39
|
+
: option);
|
|
40
40
|
}
|
|
41
41
|
search(event) {
|
|
42
42
|
const query = event.query;
|
|
43
43
|
this.filteredSelectionItems = this.filterSelection(query, this.selectionItems);
|
|
44
44
|
}
|
|
45
45
|
filterSelection(query, selectionItems) {
|
|
46
|
-
let filtered = this.multiple()
|
|
47
|
-
|
|
46
|
+
let filtered = this.multiple() ?
|
|
47
|
+
selectionItems.filter((t) => this.ngControl.value?.some((v) => v === t.key)) ?? []
|
|
48
48
|
: [];
|
|
49
49
|
return [
|
|
50
50
|
...new Set([
|
|
@@ -86,11 +86,14 @@ export class AutoCompleteComponent extends BaseInputComponent {
|
|
|
86
86
|
this.writeValue();
|
|
87
87
|
}
|
|
88
88
|
writeValue() {
|
|
89
|
-
|
|
90
|
-
|
|
89
|
+
if (this.multiple()) {
|
|
90
|
+
// BUG issue https://github.com/primefaces/primeng/issues/15495
|
|
91
|
+
this.autoCompleteRef.completeMethod.emit({ originalEvent: null, query: '' });
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
91
94
|
const selectedItem = this.selectionItems?.find((item) => item.key === this.ngControl.value);
|
|
92
95
|
if (selectedItem)
|
|
93
|
-
this.autoCompleteRef.writeValue(
|
|
96
|
+
this.autoCompleteRef.writeValue(this.autoCompleteRef.getOptionLabel(selectedItem));
|
|
94
97
|
}
|
|
95
98
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AutoCompleteComponent, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
96
99
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: AutoCompleteComponent, isStandalone: true, selector: "aril-auto-complete[ngModel], aril-auto-complete[formControl], aril-auto-complete[formControlName]", inputs: { items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, referenceAsset: { classPropertyName: "referenceAsset", publicName: "referenceAsset", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, forceSelection: { classPropertyName: "forceSelection", publicName: "forceSelection", isSignal: true, isRequired: false, transformFunction: null }, multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: true, isRequired: false, transformFunction: null }, optionValue: { classPropertyName: "optionValue", publicName: "optionValue", isSignal: true, isRequired: false, transformFunction: null }, optionLabel: { classPropertyName: "optionLabel", publicName: "optionLabel", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "autoCompleteRef", first: true, predicate: AutoComplete, descendants: true }], usesInheritance: true, hostDirectives: [{ directive: i2.ValueAccessorDirective }], ngImport: i0, template: "<p-autoComplete\r\n\t[optionLabel]=\"optionLabel()\"\r\n\t[optionValue]=\"optionValue()!\"\r\n\t[placeholder]=\"placeholder()\"\r\n\t[multiple]=\"multiple()\"\r\n\t[forceSelection]=\"forceSelection()\"\r\n\t[delay]=\"400\"\r\n\t[suggestions]=\"filteredSelectionItems\"\r\n\t(completeMethod)=\"search($event)\"\r\n\t[formControl]=\"ngControl.control\"\r\n\t(ngModelChange)=\"ngControl.viewToModelUpdate($event)\">\r\n</p-autoComplete>\r\n", dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: AutoCompleteModule }, { kind: "component", type: i4.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "disabled", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "type", "autoZIndex", "baseZIndex", "ariaLabel", "dropdownAriaLabel", "ariaLabelledBy", "dropdownIcon", "unique", "group", "completeOnFocus", "showClear", "field", "dropdown", "showEmptyMessage", "dropdownMode", "multiple", "tabindex", "dataKey", "emptyMessage", "showTransitionOptions", "hideTransitionOptions", "autofocus", "autocomplete", "optionGroupChildren", "optionGroupLabel", "overlayOptions", "suggestions", "itemSize", "optionLabel", "optionValue", "id", "searchMessage", "emptySelectionMessage", "selectionMessage", "autoOptionFocus", "selectOnFocus", "searchLocale", "optionDisabled", "focusOnHover", "variant"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide", "onLazyLoad"] }] }); }
|
|
@@ -102,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
102
105
|
type: ViewChild,
|
|
103
106
|
args: [AutoComplete]
|
|
104
107
|
}] } });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete.component.js","sourceRoot":"","sources":["../../../../../projects/aril/ui/autoComplete/src/auto-complete.component.ts","../../../../../projects/aril/ui/autoComplete/src/auto-complete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, Component, ViewChild, effect, input } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\n\r\nimport { AutoComplete, AutoCompleteModule } from 'primeng/autocomplete';\r\nimport { ObjectUtils } from 'primeng/utils';\r\n\r\nimport { firstValueFrom } from 'rxjs';\r\n\r\nimport { API_CONFIGS } from 'aril/boot/config/api';\r\nimport { BaseInputComponent, InputErrorMessagePipe, ValueAccessorDirective } from 'aril/ui/lib';\r\n\r\nimport { ReferenceAsset, SelectionItemRequestDTO, SuggestionsDTO } from './interfaces';\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'aril-auto-complete[ngModel], aril-auto-complete[formControl], aril-auto-complete[formControlName]',\r\n\ttemplateUrl: './auto-complete.component.html',\r\n\timports: [ReactiveFormsModule, InputErrorMessagePipe, AutoCompleteModule],\r\n\thostDirectives: [ValueAccessorDirective]\r\n})\r\nexport class AutoCompleteComponent extends BaseInputComponent implements AfterViewInit {\r\n\t@ViewChild(AutoComplete) autoCompleteRef!: AutoComplete;\r\n\r\n\titems = input<SuggestionsDTO[]>([]);\r\n\treferenceAsset = input<ReferenceAsset | null>(null);\r\n\tplaceholder = input<string>('Arama...');\r\n\tforceSelection = input<boolean>(false);\r\n\tmultiple = input<boolean>(false);\r\n\r\n\toptionValue = input<keyof SuggestionsDTO | null>(null);\r\n\toptionLabel = input<keyof SuggestionsDTO>('text');\r\n\r\n\tselectionItems!: SuggestionsDTO[];\r\n\tfilteredSelectionItems!: SuggestionsDTO[];\r\n\r\n\tconstructor(private http: HttpClient) {\r\n\t\tsuper();\r\n\t\teffect(() => {\r\n\t\t\tif (this.referenceAsset()) this.getSelectionItems();\r\n\r\n\t\t\tif (this.items()?.length) this.setSelectionItems();\r\n\t\t});\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tthis.autoCompleteRef.getOptionValue = this.getOptionValue.bind(this);\r\n\t}\r\n\r\n\tgetOptionValue(option: any) {\r\n\t\treturn this.optionValue()\r\n\t\t\t? typeof option === 'object'\r\n\t\t\t\t? ObjectUtils.resolveFieldData(option, this.optionValue())\r\n\t\t\t\t: option\r\n\t\t\t: option;\r\n\t}\r\n\r\n\tsearch(event: any) {\r\n\t\tconst query = event.query;\r\n\r\n\t\tthis.filteredSelectionItems = this.filterSelection(query, this.selectionItems);\r\n\t}\r\n\r\n\tfilterSelection(query: string, selectionItems: SuggestionsDTO[]): SuggestionsDTO[] {\r\n\t\tlet filtered: SuggestionsDTO[] = this.multiple()\r\n\t\t\t? selectionItems.filter((t) => this.ngControl.value?.some((v: unknown) => v === t.key)) ?? []\r\n\t\t\t: [];\r\n\r\n\t\treturn [\r\n\t\t\t...new Set([\r\n\t\t\t\t...filtered,\r\n\t\t\t\t...selectionItems.filter((selectionItem) => {\r\n\t\t\t\t\treturn selectionItem.text.toLowerCase().indexOf(query.toLowerCase()) == 0;\r\n\t\t\t\t})\r\n\t\t\t])\r\n\t\t];\r\n\t}\r\n\r\n\tasync getSelectionItems() {\r\n\t\tconst payload: SelectionItemRequestDTO = {\r\n\t\t\tpager: {\r\n\t\t\t\tpageSize: 100,\r\n\t\t\t\tpageNumber: 1\r\n\t\t\t},\r\n\t\t\tasset: {\r\n\t\t\t\talias: 'cp',\r\n\t\t\t\tassetDefinitionCode: this.referenceAsset()!.referringAssetCode\r\n\t\t\t},\r\n\t\t\tattributes: [\r\n\t\t\t\t{\r\n\t\t\t\t\tattribute: {\r\n\t\t\t\t\t\talias: 'cp',\r\n\t\t\t\t\t\tattributeCode: this.referenceAsset()!.referringAttributeCode\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t};\r\n\r\n\t\tconst selectionGroup = await firstValueFrom(this.http.post<any>(API_CONFIGS.api + '/md/search', payload));\r\n\r\n\t\tthis.selectionItems = selectionGroup?.result.map((item: any) => ({\r\n\t\t\tkey: item.id,\r\n\t\t\ttext: String(item.attributes[0].value)\r\n\t\t}));\r\n\r\n\t\tthis.writeValue();\r\n\t}\r\n\r\n\tsetSelectionItems() {\r\n\t\tthis.selectionItems = this.items();\r\n\r\n\t\tthis.writeValue();\r\n\t}\r\n\r\n\tprivate writeValue() {\r\n\t\tconst optionLabel = this.optionLabel();\r\n\t\tconst optionValue = this.optionValue();\r\n\r\n\t\tconst selectedItem = this.selectionItems?.find((item) => item.key === this.ngControl.value);\r\n\r\n\t\tif (selectedItem) this.autoCompleteRef.writeValue(optionValue ? selectedItem[optionLabel] : selectedItem);\r\n\t}\r\n}\r\n","<p-autoComplete\r\n\t[optionLabel]=\"optionLabel()\"\r\n\t[optionValue]=\"optionValue()!\"\r\n\t[placeholder]=\"placeholder()\"\r\n\t[multiple]=\"multiple()\"\r\n\t[forceSelection]=\"forceSelection()\"\r\n\t[delay]=\"400\"\r\n\t[suggestions]=\"filteredSelectionItems\"\r\n\t(completeMethod)=\"search($event)\"\r\n\t[formControl]=\"ngControl.control\"\r\n\t(ngModelChange)=\"ngControl.viewToModelUpdate($event)\">\r\n</p-autoComplete>\r\n"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete.component.js","sourceRoot":"","sources":["../../../../../projects/aril/ui/autoComplete/src/auto-complete.component.ts","../../../../../projects/aril/ui/autoComplete/src/auto-complete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, Component, ViewChild, effect, input } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\n\r\nimport { AutoComplete, AutoCompleteModule } from 'primeng/autocomplete';\r\nimport { ObjectUtils } from 'primeng/utils';\r\n\r\nimport { firstValueFrom } from 'rxjs';\r\n\r\nimport { API_CONFIGS } from 'aril/boot/config/api';\r\nimport { BaseInputComponent, InputErrorMessagePipe, ValueAccessorDirective } from 'aril/ui/lib';\r\n\r\nimport { ReferenceAsset, SelectionItemRequestDTO, SuggestionsDTO } from './interfaces';\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'aril-auto-complete[ngModel], aril-auto-complete[formControl], aril-auto-complete[formControlName]',\r\n\ttemplateUrl: './auto-complete.component.html',\r\n\timports: [ReactiveFormsModule, InputErrorMessagePipe, AutoCompleteModule],\r\n\thostDirectives: [ValueAccessorDirective]\r\n})\r\nexport class AutoCompleteComponent extends BaseInputComponent implements AfterViewInit {\r\n\t@ViewChild(AutoComplete) autoCompleteRef!: AutoComplete;\r\n\r\n\titems = input<SuggestionsDTO[]>([]);\r\n\treferenceAsset = input<ReferenceAsset | null>(null);\r\n\tplaceholder = input<string>('Arama...');\r\n\tforceSelection = input<boolean>(false);\r\n\tmultiple = input<boolean>(false);\r\n\r\n\toptionValue = input<keyof SuggestionsDTO | null>(null);\r\n\toptionLabel = input<keyof SuggestionsDTO>('text');\r\n\r\n\tselectionItems!: SuggestionsDTO[];\r\n\tfilteredSelectionItems!: SuggestionsDTO[];\r\n\r\n\tconstructor(private http: HttpClient) {\r\n\t\tsuper();\r\n\t\teffect(() => {\r\n\t\t\tif (this.referenceAsset()) this.getSelectionItems();\r\n\r\n\t\t\tif (this.items()?.length) this.setSelectionItems();\r\n\t\t});\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tthis.autoCompleteRef.getOptionValue = this.getOptionValue.bind(this);\r\n\t}\r\n\r\n\tgetOptionValue(option: any) {\r\n\t\treturn (\r\n\t\t\tthis.optionValue() ?\r\n\t\t\t\ttypeof option === 'object' ?\r\n\t\t\t\t\tObjectUtils.resolveFieldData(option, this.optionValue())\r\n\t\t\t\t:\toption\r\n\t\t\t:\toption\r\n\t\t);\r\n\t}\r\n\r\n\tsearch(event: any) {\r\n\t\tconst query = event.query;\r\n\r\n\t\tthis.filteredSelectionItems = this.filterSelection(query, this.selectionItems);\r\n\t}\r\n\r\n\tfilterSelection(query: string, selectionItems: SuggestionsDTO[]): SuggestionsDTO[] {\r\n\t\tlet filtered: SuggestionsDTO[] =\r\n\t\t\tthis.multiple() ?\r\n\t\t\t\tselectionItems.filter((t) => this.ngControl.value?.some((v: unknown) => v === t.key)) ?? []\r\n\t\t\t:\t[];\r\n\r\n\t\treturn [\r\n\t\t\t...new Set([\r\n\t\t\t\t...filtered,\r\n\t\t\t\t...selectionItems.filter((selectionItem) => {\r\n\t\t\t\t\treturn selectionItem.text.toLowerCase().indexOf(query.toLowerCase()) == 0;\r\n\t\t\t\t})\r\n\t\t\t])\r\n\t\t];\r\n\t}\r\n\r\n\tasync getSelectionItems() {\r\n\t\tconst payload: SelectionItemRequestDTO = {\r\n\t\t\tpager: {\r\n\t\t\t\tpageSize: 100,\r\n\t\t\t\tpageNumber: 1\r\n\t\t\t},\r\n\t\t\tasset: {\r\n\t\t\t\talias: 'cp',\r\n\t\t\t\tassetDefinitionCode: this.referenceAsset()!.referringAssetCode\r\n\t\t\t},\r\n\t\t\tattributes: [\r\n\t\t\t\t{\r\n\t\t\t\t\tattribute: {\r\n\t\t\t\t\t\talias: 'cp',\r\n\t\t\t\t\t\tattributeCode: this.referenceAsset()!.referringAttributeCode\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t};\r\n\r\n\t\tconst selectionGroup = await firstValueFrom(this.http.post<any>(API_CONFIGS.api + '/md/search', payload));\r\n\r\n\t\tthis.selectionItems = selectionGroup?.result.map((item: any) => ({\r\n\t\t\tkey: item.id,\r\n\t\t\ttext: String(item.attributes[0].value)\r\n\t\t}));\r\n\r\n\t\tthis.writeValue();\r\n\t}\r\n\r\n\tsetSelectionItems() {\r\n\t\tthis.selectionItems = this.items();\r\n\r\n\t\tthis.writeValue();\r\n\t}\r\n\r\n\tprivate writeValue() {\r\n\t\tif (this.multiple()) {\r\n\t\t\t// BUG issue https://github.com/primefaces/primeng/issues/15495\r\n\t\t\tthis.autoCompleteRef.completeMethod.emit({ originalEvent: null as any, query: '' });\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst selectedItem = this.selectionItems?.find((item) => item.key === this.ngControl.value);\r\n\r\n\t\tif (selectedItem) this.autoCompleteRef.writeValue(this.autoCompleteRef.getOptionLabel(selectedItem));\r\n\t}\r\n}\r\n","<p-autoComplete\r\n\t[optionLabel]=\"optionLabel()\"\r\n\t[optionValue]=\"optionValue()!\"\r\n\t[placeholder]=\"placeholder()\"\r\n\t[multiple]=\"multiple()\"\r\n\t[forceSelection]=\"forceSelection()\"\r\n\t[delay]=\"400\"\r\n\t[suggestions]=\"filteredSelectionItems\"\r\n\t(completeMethod)=\"search($event)\"\r\n\t[formControl]=\"ngControl.control\"\r\n\t(ngModelChange)=\"ngControl.viewToModelUpdate($event)\">\r\n</p-autoComplete>\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, computed, inject, input } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { SelectionGroupService } from 'aril/theme/layout';
|
|
3
3
|
import 'aril/util/primitive-extensions';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class ValueComponent {
|
|
@@ -8,9 +8,9 @@ export class ValueComponent {
|
|
|
8
8
|
this.type = input('text');
|
|
9
9
|
this.format = input();
|
|
10
10
|
this.color = input('#333');
|
|
11
|
-
this.enumGroupName = input();
|
|
12
11
|
this.isClickable = input(false);
|
|
13
|
-
this.
|
|
12
|
+
this.groupName = input();
|
|
13
|
+
this.selectionGroupService = inject(SelectionGroupService);
|
|
14
14
|
this.display = computed(() => {
|
|
15
15
|
const appliedFormat = this.format() || (this.type() === 'decimal' ? '#.000' : '0.###');
|
|
16
16
|
switch (this.type()) {
|
|
@@ -24,17 +24,17 @@ export class ValueComponent {
|
|
|
24
24
|
return this.model().longToString(this.format() ?? 'time');
|
|
25
25
|
case 'password':
|
|
26
26
|
return this.model().replace(/./g, '*');
|
|
27
|
-
case 'enum':
|
|
28
|
-
let displayValue = this.model();
|
|
29
|
-
this.enumDisplayPipe.transform(this.model(), this.enumGroupName()).subscribe(res => {
|
|
30
|
-
displayValue = res;
|
|
31
|
-
});
|
|
32
|
-
return displayValue;
|
|
33
27
|
default:
|
|
34
28
|
console.error("Invalid type: '" + this.type() + "'");
|
|
35
29
|
return '';
|
|
36
30
|
}
|
|
37
31
|
});
|
|
32
|
+
this.enumSelectionDisplay = computed(() => {
|
|
33
|
+
const selectionGroup = this.selectionGroupService.selectionGroups()[this.groupName()];
|
|
34
|
+
if (!selectionGroup)
|
|
35
|
+
this.selectionGroupService.fetchEnum(this.groupName());
|
|
36
|
+
return selectionGroup?.selectionItems.find((t) => t.selectionKey === this.model())?.selectionDisplay;
|
|
37
|
+
});
|
|
38
38
|
}
|
|
39
39
|
formatNumber(value, formatString, isDecimal) {
|
|
40
40
|
const [integerPart, decimalPart = ''] = value.toString().split('.');
|
|
@@ -46,10 +46,10 @@ export class ValueComponent {
|
|
|
46
46
|
return decimalPart.slice(0, decimalPlaces).padEnd(decimalPlaces, '0');
|
|
47
47
|
}
|
|
48
48
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ValueComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
49
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: ValueComponent, isStandalone: true, selector: "aril-value", inputs: { model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, format: { classPropertyName: "format", publicName: "format", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null },
|
|
49
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: ValueComponent, isStandalone: true, selector: "aril-value", inputs: { model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, format: { classPropertyName: "format", publicName: "format", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, isClickable: { classPropertyName: "isClickable", publicName: "isClickable", isSignal: true, isRequired: false, transformFunction: null }, groupName: { classPropertyName: "groupName", publicName: "groupName", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (model() == undefined || model() == null) {\r\n\t<i class=\"pi pi-minus\" style=\"color: red\" pTooltip=\"No item to show\"></i>\r\n} @else {\r\n\t@if (type() == 'bool') {\r\n\t\t@if (!!model()) {\r\n\t\t\t<i class=\"pi pi-check\" style=\"color: green\"></i>\r\n\t\t} @else {\r\n\t\t\t<i class=\"pi pi-times\" style=\"color: crimson\"></i>\r\n\t\t}\r\n\t} @else if (type() === 'enum') {\r\n\t\t{{ enumSelectionDisplay() }}\r\n\t} @else {\r\n\t\t@if (display() == undefined) {\r\n\t\t\t<i class=\"pi pi-exclamation-circle\" style=\"color: red\" pTooltip=\"Invalid Data\"> </i>\r\n\t\t} @else {\r\n\t\t\t<span [style]=\"isClickable() ? { 'text-decoration': 'underline', color: color(), cursor: 'pointer' } : ''\">\r\n\t\t\t\t{{ display() }}\r\n\t\t\t</span>\r\n\t\t}\r\n\t}\r\n}\r\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
50
50
|
}
|
|
51
51
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ValueComponent, decorators: [{
|
|
52
52
|
type: Component,
|
|
53
|
-
args: [{ standalone: true, selector: 'aril-value', changeDetection: ChangeDetectionStrategy.OnPush,
|
|
53
|
+
args: [{ standalone: true, selector: 'aril-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (model() == undefined || model() == null) {\r\n\t<i class=\"pi pi-minus\" style=\"color: red\" pTooltip=\"No item to show\"></i>\r\n} @else {\r\n\t@if (type() == 'bool') {\r\n\t\t@if (!!model()) {\r\n\t\t\t<i class=\"pi pi-check\" style=\"color: green\"></i>\r\n\t\t} @else {\r\n\t\t\t<i class=\"pi pi-times\" style=\"color: crimson\"></i>\r\n\t\t}\r\n\t} @else if (type() === 'enum') {\r\n\t\t{{ enumSelectionDisplay() }}\r\n\t} @else {\r\n\t\t@if (display() == undefined) {\r\n\t\t\t<i class=\"pi pi-exclamation-circle\" style=\"color: red\" pTooltip=\"Invalid Data\"> </i>\r\n\t\t} @else {\r\n\t\t\t<span [style]=\"isClickable() ? { 'text-decoration': 'underline', color: color(), cursor: 'pointer' } : ''\">\r\n\t\t\t\t{{ display() }}\r\n\t\t\t</span>\r\n\t\t}\r\n\t}\r\n}\r\n" }]
|
|
54
54
|
}] });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"value.component.js","sourceRoot":"","sources":["../../../../../projects/aril/ui/value/src/value.component.ts","../../../../../projects/aril/ui/value/src/value.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, inject, input } from '@angular/core';\r\n\r\nimport { SelectionGroupService } from 'aril/theme/layout';\r\nimport 'aril/util/primitive-extensions';\r\n\r\n/* number-format.js */\r\n// TODO declare const format: Function;\r\n\r\n/** Type Formats\r\n * #.00 -> Virgülden sonra 2 hane (Decimal)\r\n * #.0000 -> Virgülden sonra 4 hane (Decimal)\r\n * 0.### -> Sadece tam sayı göstermesi için (Number)\r\n */\r\n\r\ntype ValueTypes = 'text' | 'number' | 'bool' | 'decimal' | 'date' | 'password' | 'enum';\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'aril-value',\r\n\ttemplateUrl: './value.component.html',\r\n\tchangeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class ValueComponent {\r\n\tmodel = input.required<string | number | boolean | undefined>();\r\n\ttype = input<ValueTypes>('text');\r\n\tformat = input<string>();\r\n\tcolor = input<string>('#333');\r\n\tisClickable = input<boolean>(false);\r\n\tgroupName = input<string>();\r\n\r\n\tprivate selectionGroupService = inject(SelectionGroupService);\r\n\r\n\tprivate formatNumber(value: number, formatString: string, isDecimal: boolean): string {\r\n\t\tconst [integerPart, decimalPart = ''] = value.toString().split('.');\r\n\t\tconst formattedInteger = integerPart.replace(/\\B(?=(\\d{3})+(?!\\d))/g, '.');\r\n\t\treturn isDecimal ? `${formattedInteger},${this.formatDecimal(decimalPart, formatString)}` : formattedInteger;\r\n\t}\r\n\r\n\tprivate formatDecimal(decimalPart: string, formatString: string): string {\r\n\t\tconst decimalPlaces = formatString.includes('.') ? formatString.split('.')[1].length : 3;\r\n\t\treturn decimalPart.slice(0, decimalPlaces).padEnd(decimalPlaces, '0');\r\n\t}\r\n\r\n\tdisplay = computed(() => {\r\n\t\tconst appliedFormat = this.format() || (this.type() === 'decimal' ? '#.000' : '0.###');\r\n\r\n\t\tswitch (this.type()) {\r\n\t\t\tcase 'text':\r\n\t\t\t\treturn this.model();\r\n\t\t\tcase 'number':\r\n\t\t\t\treturn this.formatNumber(<number>this.model(), appliedFormat, false);\r\n\t\t\tcase 'decimal':\r\n\t\t\t\treturn this.formatNumber(<number>this.model(), appliedFormat, true);\r\n\t\t\tcase 'date':\r\n\t\t\t\treturn (<number>this.model()).longToString(this.format() ?? 'time');\r\n\t\t\tcase 'password':\r\n\t\t\t\treturn (<string>this.model()).replace(/./g, '*');\r\n\t\t\tdefault:\r\n\t\t\t\tconsole.error(\"Invalid type: '\" + this.type() + \"'\");\r\n\t\t\t\treturn '';\r\n\t\t}\r\n\t});\r\n\r\n\tenumSelectionDisplay = computed(() => {\r\n\t\tconst selectionGroup = this.selectionGroupService.selectionGroups()[this.groupName()!];\r\n\r\n\t\tif (!selectionGroup) this.selectionGroupService.fetchEnum(this.groupName()!);\r\n\r\n\t\treturn selectionGroup?.selectionItems.find((t) => t.selectionKey === this.model())?.selectionDisplay;\r\n\t});\r\n}\r\n","@if (model() == undefined || model() == null) {\r\n\t<i class=\"pi pi-minus\" style=\"color: red\" pTooltip=\"No item to show\"></i>\r\n} @else {\r\n\t@if (type() == 'bool') {\r\n\t\t@if (!!model()) {\r\n\t\t\t<i class=\"pi pi-check\" style=\"color: green\"></i>\r\n\t\t} @else {\r\n\t\t\t<i class=\"pi pi-times\" style=\"color: crimson\"></i>\r\n\t\t}\r\n\t} @else if (type() === 'enum') {\r\n\t\t{{ enumSelectionDisplay() }}\r\n\t} @else {\r\n\t\t@if (display() == undefined) {\r\n\t\t\t<i class=\"pi pi-exclamation-circle\" style=\"color: red\" pTooltip=\"Invalid Data\"> </i>\r\n\t\t} @else {\r\n\t\t\t<span [style]=\"isClickable() ? { 'text-decoration': 'underline', color: color(), cursor: 'pointer' } : ''\">\r\n\t\t\t\t{{ display() }}\r\n\t\t\t</span>\r\n\t\t}\r\n\t}\r\n}\r\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { NgClass, NgTemplateOutlet, AsyncPipe, NgStyle, UpperCasePipe } from '@angular/common';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
|
-
import { Component, signal, effect, Injectable, inject, computed, Input, HostBinding, ViewChild
|
|
3
|
+
import { Component, signal, effect, Injectable, inject, computed, Input, HostBinding, ViewChild } from '@angular/core';
|
|
4
4
|
import * as i1 from '@angular/router';
|
|
5
5
|
import { NavigationEnd, RouterLink, RouterLinkActive, RouterOutlet } from '@angular/router';
|
|
6
6
|
import * as i4$2 from 'primeng/confirmdialog';
|
|
@@ -13,7 +13,7 @@ import * as i7$1 from 'primeng/messages';
|
|
|
13
13
|
import { MessagesModule } from 'primeng/messages';
|
|
14
14
|
import * as i8 from 'primeng/toast';
|
|
15
15
|
import { ToastModule } from 'primeng/toast';
|
|
16
|
-
import { BehaviorSubject, Subject, filter as filter$1,
|
|
16
|
+
import { BehaviorSubject, Subject, filter as filter$1, take } from 'rxjs';
|
|
17
17
|
import * as i2 from 'primeng/breadcrumb';
|
|
18
18
|
import { BreadcrumbModule } from 'primeng/breadcrumb';
|
|
19
19
|
import { filter } from 'rxjs/operators';
|
|
@@ -1094,104 +1094,64 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
1094
1094
|
}]
|
|
1095
1095
|
}] });
|
|
1096
1096
|
|
|
1097
|
-
class
|
|
1097
|
+
class SelectionGroupService {
|
|
1098
1098
|
constructor(http) {
|
|
1099
1099
|
this.http = http;
|
|
1100
|
-
this.
|
|
1100
|
+
this.selectionGroups = signal({});
|
|
1101
|
+
this.loading = new Map();
|
|
1102
|
+
this.loaded = new Map();
|
|
1103
|
+
this.loadStatesFromLocalStorage();
|
|
1104
|
+
effect(() => {
|
|
1105
|
+
const encodedData = btoa(encodeURI(JSON.stringify(this.selectionGroups())));
|
|
1106
|
+
localStorage.setItem('selection-groups', encodedData);
|
|
1107
|
+
});
|
|
1101
1108
|
}
|
|
1102
|
-
async
|
|
1103
|
-
|
|
1104
|
-
|
|
1109
|
+
async loadStatesFromLocalStorage() {
|
|
1110
|
+
const selectionGroups = localStorage.getItem('selection-groups');
|
|
1111
|
+
if (selectionGroups) {
|
|
1112
|
+
try {
|
|
1113
|
+
const decodedData = decodeURI(atob(selectionGroups));
|
|
1114
|
+
this.selectionGroups.set(JSON.parse(decodedData));
|
|
1115
|
+
}
|
|
1116
|
+
catch (e) {
|
|
1117
|
+
console.error(e);
|
|
1118
|
+
}
|
|
1105
1119
|
}
|
|
1120
|
+
}
|
|
1121
|
+
fetchEnum(groupName, parentSelectionKey) {
|
|
1122
|
+
if (this.loaded.get(groupName) || this.loading.get(groupName))
|
|
1123
|
+
return;
|
|
1106
1124
|
const payload = {
|
|
1107
|
-
groupName
|
|
1108
|
-
parentSelectionKey: parentSelectionKey
|
|
1125
|
+
groupName,
|
|
1126
|
+
parentSelectionKey: parentSelectionKey ?? 'ALL'
|
|
1109
1127
|
};
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1115
|
-
|
|
1116
|
-
.
|
|
1117
|
-
this.
|
|
1118
|
-
|
|
1128
|
+
this.loading.set(groupName, true);
|
|
1129
|
+
this.loaded.set(groupName, false);
|
|
1130
|
+
this.http
|
|
1131
|
+
.post(API_CONFIGS.api + '/selection-group/load', payload)
|
|
1132
|
+
.pipe(take(1))
|
|
1133
|
+
.subscribe((selectionGroup) => {
|
|
1134
|
+
this.loading.set(groupName, false);
|
|
1135
|
+
this.loaded.set(groupName, true);
|
|
1136
|
+
this.selectionGroups.update((groups) => ({
|
|
1137
|
+
...groups,
|
|
1138
|
+
[groupName]: selectionGroup
|
|
1139
|
+
}));
|
|
1119
1140
|
});
|
|
1120
|
-
this.requestCache.set(key, requestPromise);
|
|
1121
|
-
return requestPromise;
|
|
1122
|
-
}
|
|
1123
|
-
saveToLocalStorage(key, value) {
|
|
1124
|
-
const jsonString = JSON.stringify(value);
|
|
1125
|
-
const encodedValue = this.utf8ToBase64(jsonString);
|
|
1126
|
-
localStorage.setItem(key, encodedValue);
|
|
1127
|
-
}
|
|
1128
|
-
utf8ToBase64(str) {
|
|
1129
|
-
return btoa(unescape(encodeURIComponent(str)));
|
|
1130
1141
|
}
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
}
|
|
1134
|
-
getFromLocalStorage(key) {
|
|
1135
|
-
const encodedValue = localStorage.getItem(key);
|
|
1136
|
-
if (encodedValue) {
|
|
1137
|
-
const decodedValue = this.base64ToUtf8(encodedValue);
|
|
1138
|
-
return JSON.parse(decodedValue);
|
|
1139
|
-
}
|
|
1140
|
-
return null;
|
|
1141
|
-
}
|
|
1142
|
-
getSelectionItems(key) {
|
|
1143
|
-
if (!localStorage.getItem(key))
|
|
1144
|
-
this.loadSelectionItems(key);
|
|
1145
|
-
return of(this.getFromLocalStorage(key)).pipe(map((storageValue) => storageValue
|
|
1146
|
-
? storageValue.map((item) => ({
|
|
1147
|
-
key: item.selectionKey,
|
|
1148
|
-
text: item.selectionDisplay,
|
|
1149
|
-
parentSelectionKey: item.parentSelectionKey,
|
|
1150
|
-
}))
|
|
1151
|
-
: []));
|
|
1152
|
-
}
|
|
1153
|
-
getSelectionItemsAsParentKey(parentSelectionKey) {
|
|
1154
|
-
console.log('parentSelectionKey', parentSelectionKey);
|
|
1155
|
-
// groupName e göre key alıp, parentselctionKey e göre filtre et
|
|
1156
|
-
}
|
|
1157
|
-
resetLocalStorage() {
|
|
1158
|
-
localStorage.clear();
|
|
1159
|
-
}
|
|
1160
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: LocalStorageService, deps: [{ token: i1$1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
1161
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: LocalStorageService, providedIn: 'root' }); }
|
|
1142
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: SelectionGroupService, deps: [{ token: i1$1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
1143
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: SelectionGroupService, providedIn: 'root' }); }
|
|
1162
1144
|
}
|
|
1163
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type:
|
|
1145
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: SelectionGroupService, decorators: [{
|
|
1164
1146
|
type: Injectable,
|
|
1165
1147
|
args: [{
|
|
1166
1148
|
providedIn: 'root'
|
|
1167
1149
|
}]
|
|
1168
1150
|
}], ctorParameters: () => [{ type: i1$1.HttpClient }] });
|
|
1169
1151
|
|
|
1170
|
-
class EnumDisplayPipe {
|
|
1171
|
-
constructor(localStorageService) {
|
|
1172
|
-
this.localStorageService = localStorageService;
|
|
1173
|
-
}
|
|
1174
|
-
transform(value, key) {
|
|
1175
|
-
return this.localStorageService.getSelectionItems(key).pipe(map((items) => {
|
|
1176
|
-
const filteredItem = items.find((item) => item.key === value);
|
|
1177
|
-
return filteredItem ? filteredItem.text : value;
|
|
1178
|
-
}));
|
|
1179
|
-
}
|
|
1180
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: EnumDisplayPipe, deps: [{ token: LocalStorageService }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
1181
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.1.2", ngImport: i0, type: EnumDisplayPipe, isStandalone: true, name: "enumDisplay" }); }
|
|
1182
|
-
}
|
|
1183
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: EnumDisplayPipe, decorators: [{
|
|
1184
|
-
type: Pipe,
|
|
1185
|
-
args: [{
|
|
1186
|
-
name: 'enumDisplay',
|
|
1187
|
-
standalone: true,
|
|
1188
|
-
pure: true
|
|
1189
|
-
}]
|
|
1190
|
-
}], ctorParameters: () => [{ type: LocalStorageService }] });
|
|
1191
|
-
|
|
1192
1152
|
/**
|
|
1193
1153
|
* Generated bundle index. Do not edit.
|
|
1194
1154
|
*/
|
|
1195
1155
|
|
|
1196
|
-
export { AppLayoutComponent, AppMenuService,
|
|
1156
|
+
export { AppLayoutComponent, AppMenuService, MFELayoutComponent, SelectionGroupService };
|
|
1197
1157
|
//# sourceMappingURL=aril-theme-layout.mjs.map
|