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.
@@ -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/local-storage.service';
5
- export * from './pipes';
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
- ? typeof option === 'object'
37
- ? ObjectUtils.resolveFieldData(option, this.optionValue())
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
- ? selectionItems.filter((t) => this.ngControl.value?.some((v) => v === t.key)) ?? []
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
- const optionLabel = this.optionLabel();
90
- const optionValue = this.optionValue();
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(optionValue ? selectedItem[optionLabel] : selectedItem);
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 { EnumDisplayPipe } from 'aril/theme/layout';
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.enumDisplayPipe = inject(EnumDisplayPipe);
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 }, enumGroupName: { classPropertyName: "enumGroupName", publicName: "enumGroupName", isSignal: true, isRequired: false, transformFunction: null }, isClickable: { classPropertyName: "isClickable", publicName: "isClickable", isSignal: true, isRequired: false, transformFunction: null } }, providers: [EnumDisplayPipe], 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 {\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.color]=\"color\" [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 }); }
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, imports: [EnumDisplayPipe], providers: [EnumDisplayPipe], 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 {\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.color]=\"color\" [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" }]
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,{"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\nimport { EnumDisplayPipe } 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    standalone: true,\r\n    selector: 'aril-value',\r\n    templateUrl: './value.component.html',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    imports:[EnumDisplayPipe],\r\n    providers:[EnumDisplayPipe]\r\n})\r\nexport class ValueComponent {\r\n    model = input.required<string | number | boolean | undefined>();\r\n    type = input<ValueTypes>('text');\r\n    format = input<string>();\r\n    color = input<string>('#333');\r\n    enumGroupName = input<string>();\r\n    isClickable = input<boolean>(false);\r\n\r\n    private enumDisplayPipe = inject(EnumDisplayPipe);\r\n\r\n    private formatNumber(value: number, formatString: string, isDecimal: boolean): string {\r\n        const [integerPart, decimalPart = ''] = value.toString().split('.');\r\n        const formattedInteger = integerPart.replace(/\\B(?=(\\d{3})+(?!\\d))/g, '.');\r\n        return isDecimal ? `${formattedInteger},${this.formatDecimal(decimalPart, formatString)}` : formattedInteger;\r\n    }\r\n\r\n    private formatDecimal(decimalPart: string, formatString: string): string {\r\n        const decimalPlaces = formatString.includes('.') ? formatString.split('.')[1].length : 3;\r\n        return decimalPart.slice(0, decimalPlaces).padEnd(decimalPlaces, '0');\r\n    }\r\n\r\n    display = computed(() => {\r\n        const appliedFormat = this.format() || (this.type() === 'decimal' ? '#.000' : '0.###');\r\n\r\n        switch (this.type()) {\r\n            case 'text':\r\n                return this.model();\r\n            case 'number':\r\n                return this.formatNumber(<number>this.model(), appliedFormat, false);\r\n            case 'decimal':\r\n                return this.formatNumber(<number>this.model(), appliedFormat, true);\r\n            case 'date':\r\n                return (<number>this.model()).longToString(this.format() ?? 'time');\r\n            case 'password':\r\n                return (<string>this.model()).replace(/./g, '*');\r\n            case 'enum':\r\n                let displayValue=this.model();\r\n                this.enumDisplayPipe.transform(<string>this.model(),<string>this.enumGroupName()).subscribe(res => {\r\n                    displayValue = res;\r\n                });\r\n                return displayValue;\r\n            default:\r\n                console.error(\"Invalid type: '\" + this.type() + \"'\");\r\n                return '';\r\n        }\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 {\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.color]=\"color\" [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"]}
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, Pipe } from '@angular/core';
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, firstValueFrom, of, map } from 'rxjs';
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 LocalStorageService {
1097
+ class SelectionGroupService {
1098
1098
  constructor(http) {
1099
1099
  this.http = http;
1100
- this.requestCache = new Map();
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 loadSelectionItems(key, parentSelectionKey) {
1103
- if (this.requestCache.has(key)) {
1104
- return this.requestCache.get(key);
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: key,
1108
- parentSelectionKey: parentSelectionKey !== undefined ? parentSelectionKey : 'ALL'
1125
+ groupName,
1126
+ parentSelectionKey: parentSelectionKey ?? 'ALL'
1109
1127
  };
1110
- const requestPromise = firstValueFrom(this.http.post(API_CONFIGS.api + '/selection-group/load', payload))
1111
- .then((selectionGroup) => {
1112
- this.saveToLocalStorage(key, selectionGroup?.selectionItems);
1113
- this.requestCache.delete(key);
1114
- return selectionGroup;
1115
- })
1116
- .catch((error) => {
1117
- this.requestCache.delete(key);
1118
- throw error;
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
- base64ToUtf8(str) {
1132
- return decodeURIComponent(escape(atob(str)));
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: LocalStorageService, decorators: [{
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, EnumDisplayPipe, LocalStorageService, MFELayoutComponent };
1156
+ export { AppLayoutComponent, AppMenuService, MFELayoutComponent, SelectionGroupService };
1197
1157
  //# sourceMappingURL=aril-theme-layout.mjs.map