nuxeo-development-framework 3.3.2 → 3.3.3-snapshot
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/bundles/nuxeo-development-framework.umd.js +214 -224
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/cts-tags/components/correspondence-tags/correspondence-tags.component.js +2 -2
- package/esm2015/lib/components/custom-toastr/components/custom-toastr/custom-toastr.component.js +22 -2
- package/esm2015/lib/components/documents/components/document-scan/document-scan.service.js +1 -1
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-department/dynamic-form-department.component.js +14 -3
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-department/services/department-api.service.js +18 -55
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.js +5 -2
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.js +2 -2
- package/esm2015/lib/components/dynamic-form/components/form-wrappers/user-selector-wrapper/user-selector-wrapper.component.js +2 -2
- package/esm2015/lib/components/dynamic-search/dynamic-search/dynamic-search.component.js +7 -1
- package/esm2015/lib/components/filter/filter/filter.component.js +1 -1
- package/esm2015/lib/components/select-users-by-department/select-users-by-departments/select-users-by-departments.component.js +1 -1
- package/esm2015/lib/directive/app-has-role/app-has-role.directive.js +1 -1
- package/esm2015/public-api.js +1 -2
- package/fesm2015/nuxeo-development-framework.js +98 -114
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/custom-toastr/components/custom-toastr/custom-toastr.component.d.ts +11 -0
- package/lib/components/dynamic-form/components/dynamic-form-department/dynamic-form-department.component.d.ts +6 -3
- package/lib/components/dynamic-form/components/dynamic-form-department/services/department-api.service.d.ts +2 -4
- package/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.d.ts +2 -1
- package/lib/components/dynamic-search/dynamic-search/dynamic-search.component.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +0 -1
- package/esm2015/lib/shared-services/global-admin.service.js +0 -24
- package/lib/shared-services/global-admin.service.d.ts +0 -13
|
@@ -10,37 +10,23 @@ import * as i1 from "../../../../../Core/services/callApi/call-api.service";
|
|
|
10
10
|
import * as i2 from "../../../../../Core/services/translation/translation.service";
|
|
11
11
|
import * as i3 from "../../../../../Core/services/nuxeo/nuxeo.service";
|
|
12
12
|
import * as i4 from "../../../../../Core/adapters/adapter.service";
|
|
13
|
-
import * as i5 from "../../../../../shared-services/global-admin.service";
|
|
14
13
|
export const departmentCacheBuster$ = new Subject();
|
|
15
14
|
export const minute = 60000;
|
|
16
15
|
/** @ignore */
|
|
17
16
|
export class DepartmentApiService {
|
|
18
|
-
constructor(CallApiService, translation, nuxeoService, adapter,
|
|
17
|
+
constructor(CallApiService, translation, nuxeoService, adapter, environment) {
|
|
19
18
|
this.CallApiService = CallApiService;
|
|
20
19
|
this.translation = translation;
|
|
21
20
|
this.nuxeoService = nuxeoService;
|
|
22
21
|
this.adapter = adapter;
|
|
23
|
-
this.globalAdminService = globalAdminService;
|
|
24
22
|
this.environment = environment;
|
|
25
23
|
this.translation.isArabic.subscribe((res) => {
|
|
26
24
|
this.arabic = res;
|
|
27
25
|
});
|
|
28
26
|
}
|
|
29
|
-
getDepartmentTree(customPageProvider) {
|
|
30
|
-
let
|
|
31
|
-
|
|
32
|
-
currentPageIndex: 0,
|
|
33
|
-
offset: 0,
|
|
34
|
-
pageSize: 40,
|
|
35
|
-
quickFilters: 'Parent Dept'
|
|
36
|
-
};
|
|
37
|
-
if (this.globalAdminService.isGlobalAdmin) {
|
|
38
|
-
params['queryParams'] = '/' + this.globalAdminService.activeTenant;
|
|
39
|
-
}
|
|
40
|
-
else if (!this.globalAdminService.isGlobalAdmin && this.nuxeoService.nuxeoClient.user.properties.tenantId) {
|
|
41
|
-
params['queryParams'] = '/' + this.nuxeoService.nuxeoClient.user.properties.tenantId;
|
|
42
|
-
}
|
|
43
|
-
return this.CallApiService.query(Object.assign({}, params), {
|
|
27
|
+
getDepartmentTree(customPageProvider, customParams) {
|
|
28
|
+
let obj = customParams ? customParams : {};
|
|
29
|
+
return this.CallApiService.query(Object.assign({ pageProvider: customPageProvider ? customPageProvider : 'PP_Department', currentPageIndex: 0, offset: 0, pageSize: 40, quickFilters: 'Parent Dept' }, obj), {
|
|
44
30
|
headers: {
|
|
45
31
|
'X-NXproperties': '*',
|
|
46
32
|
'enrichers-document': 'children',
|
|
@@ -49,20 +35,13 @@ export class DepartmentApiService {
|
|
|
49
35
|
});
|
|
50
36
|
}
|
|
51
37
|
getDepartmentDetails(code, customPageProvider) {
|
|
52
|
-
|
|
38
|
+
return this.CallApiService.query({
|
|
53
39
|
pageProvider: customPageProvider ? customPageProvider : 'PP_Department_With_ElasticSearch',
|
|
54
40
|
currentPageIndex: 0,
|
|
55
41
|
offset: 0,
|
|
56
42
|
pageSize: 40,
|
|
57
43
|
dublincore_title: code,
|
|
58
|
-
}
|
|
59
|
-
if (this.globalAdminService.isGlobalAdmin) {
|
|
60
|
-
params['queryParams'] = '/' + this.globalAdminService.activeTenant;
|
|
61
|
-
}
|
|
62
|
-
else if (!this.globalAdminService.isGlobalAdmin && this.nuxeoService.nuxeoClient.user.properties.tenantId) {
|
|
63
|
-
params['queryParams'] = '/' + this.nuxeoService.nuxeoClient.user.properties.tenantId;
|
|
64
|
-
}
|
|
65
|
-
return this.CallApiService.query(Object.assign({}, params), {
|
|
44
|
+
}, {
|
|
66
45
|
headers: {
|
|
67
46
|
'X-NXproperties': '*',
|
|
68
47
|
'enrichers-document': 'children',
|
|
@@ -73,12 +52,6 @@ export class DepartmentApiService {
|
|
|
73
52
|
getDepartmentNestedTree(code, customPageProvider, customParentCodeProperty) {
|
|
74
53
|
let params = {};
|
|
75
54
|
customParentCodeProperty ? (params[customParentCodeProperty] = code) : (params = { 'department_parentDepartmentCode': code });
|
|
76
|
-
if (this.globalAdminService.isGlobalAdmin) {
|
|
77
|
-
params['queryParams'] = '/' + this.globalAdminService.activeTenant;
|
|
78
|
-
}
|
|
79
|
-
else if (!this.globalAdminService.isGlobalAdmin && this.nuxeoService.nuxeoClient.user.properties.tenantId) {
|
|
80
|
-
params['queryParams'] = '/' + this.nuxeoService.nuxeoClient.user.properties.tenantId;
|
|
81
|
-
}
|
|
82
55
|
return this.CallApiService.query(Object.assign({ pageProvider: customPageProvider ? customPageProvider : 'PP_Department', currentPageIndex: 0, offset: 0, pageSize: 40 }, params), {
|
|
83
56
|
headers: {
|
|
84
57
|
'X-NXproperties': '*',
|
|
@@ -101,51 +74,41 @@ export class DepartmentApiService {
|
|
|
101
74
|
}
|
|
102
75
|
// testing
|
|
103
76
|
createDepartment(Department, parentId, customOperation, fields) {
|
|
104
|
-
let context = { department: this.adapter.adaptOut(Department, fields ? fields : DepartmentConstants.fields) };
|
|
105
|
-
if (this.globalAdminService.isGlobalAdmin) {
|
|
106
|
-
context['tenantId'] = this.globalAdminService.activeTenant;
|
|
107
|
-
}
|
|
108
77
|
return from(this.nuxeoService.nuxeoClient
|
|
109
78
|
.operation(customOperation ? customOperation : 'AC_UA_Depatrment_Create', {
|
|
110
79
|
url: `${this.environment.nuxeo}${this.environment.customAutomation}`,
|
|
111
80
|
})
|
|
112
81
|
.input(parentId)
|
|
113
|
-
.context(
|
|
82
|
+
.context({
|
|
83
|
+
department: this.adapter.adaptOut(Department, fields ? fields : DepartmentConstants.fields),
|
|
84
|
+
})
|
|
114
85
|
.execute()).pipe(catchError((err) => {
|
|
115
86
|
console.log(err);
|
|
116
87
|
throw err;
|
|
117
88
|
}));
|
|
118
89
|
}
|
|
119
90
|
createDepartmentInRoot(Department, customOperation) {
|
|
120
|
-
let context = {
|
|
121
|
-
department: this.adapter.adaptOut(Department, DepartmentConstants.fields)
|
|
122
|
-
};
|
|
123
|
-
if (this.globalAdminService.isGlobalAdmin) {
|
|
124
|
-
context['tenantId'] = this.globalAdminService.activeTenant;
|
|
125
|
-
}
|
|
126
91
|
return from(this.nuxeoService.nuxeoClient
|
|
127
92
|
.operation(customOperation ? customOperation : 'AC_UA_Depatrment_Create_InRoot', {
|
|
128
93
|
url: `${this.environment.nuxeo}${this.environment.customAutomation}`,
|
|
129
94
|
})
|
|
130
|
-
.context(
|
|
95
|
+
.context({
|
|
96
|
+
department: this.adapter.adaptOut(Department, DepartmentConstants.fields),
|
|
97
|
+
})
|
|
131
98
|
.execute()).pipe(catchError((err) => {
|
|
132
99
|
console.log(err);
|
|
133
100
|
throw err;
|
|
134
101
|
}));
|
|
135
102
|
}
|
|
136
103
|
updateDepartment(Department, departmentId, customOperation, fields) {
|
|
137
|
-
let context = {
|
|
138
|
-
department: this.adapter.adaptOut(Department, fields ? fields : DepartmentConstants.fields)
|
|
139
|
-
};
|
|
140
|
-
if (this.globalAdminService.isGlobalAdmin) {
|
|
141
|
-
context['tenantId'] = this.globalAdminService.activeTenant;
|
|
142
|
-
}
|
|
143
104
|
return from(this.nuxeoService.nuxeoClient
|
|
144
105
|
.operation(customOperation ? customOperation : 'AC_UA_Department_Update', {
|
|
145
106
|
url: `${this.environment.nuxeo}${this.environment.customAutomation}`,
|
|
146
107
|
})
|
|
147
108
|
.input(departmentId)
|
|
148
|
-
.context(
|
|
109
|
+
.context({
|
|
110
|
+
department: this.adapter.adaptOut(Department, fields ? fields : DepartmentConstants.fields),
|
|
111
|
+
})
|
|
149
112
|
.execute()).pipe(catchError((err) => {
|
|
150
113
|
console.log(err);
|
|
151
114
|
throw err;
|
|
@@ -183,7 +146,7 @@ export class DepartmentApiService {
|
|
|
183
146
|
});
|
|
184
147
|
}
|
|
185
148
|
}
|
|
186
|
-
DepartmentApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DepartmentApiService, deps: [{ token: i1.CallApiService }, { token: i2.TranslationService }, { token: i3.NuxeoService }, { token: i4.AdapterService }, { token:
|
|
149
|
+
DepartmentApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DepartmentApiService, deps: [{ token: i1.CallApiService }, { token: i2.TranslationService }, { token: i3.NuxeoService }, { token: i4.AdapterService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
187
150
|
DepartmentApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DepartmentApiService, providedIn: 'root' });
|
|
188
151
|
__decorate([
|
|
189
152
|
Cacheable({
|
|
@@ -228,8 +191,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
228
191
|
args: [{
|
|
229
192
|
providedIn: 'root',
|
|
230
193
|
}]
|
|
231
|
-
}], ctorParameters: function () { return [{ type: i1.CallApiService }, { type: i2.TranslationService }, { type: i3.NuxeoService }, { type: i4.AdapterService }, { type:
|
|
194
|
+
}], ctorParameters: function () { return [{ type: i1.CallApiService }, { type: i2.TranslationService }, { type: i3.NuxeoService }, { type: i4.AdapterService }, { type: undefined, decorators: [{
|
|
232
195
|
type: Inject,
|
|
233
196
|
args: ['environment']
|
|
234
197
|
}] }]; }, propDecorators: { getDepartmentTree: [], getDepartmentDetails: [], getDepartmentNestedTree: [], createDepartment: [], createDepartmentInRoot: [], updateDepartment: [] } });
|
|
235
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"department-api.service.js","sourceRoot":"","sources":["../../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-department/services/department-api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Inject, Injectable } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { TreeviewItem } from 'ngx-treeview';\r\nimport { from, Observable, Subject } from 'rxjs';\r\nimport { catchError, map } from 'rxjs/operators';\r\nimport { AdapterService } from '../../../../../Core/adapters/adapter.service';\r\nimport { CallApiService } from '../../../../../Core/services/callApi/call-api.service';\r\nimport { NuxeoService } from '../../../../../Core/services/nuxeo/nuxeo.service';\r\nimport { TranslationService } from '../../../../../Core/services/translation/translation.service';\r\nimport { DepartmentConstants } from '../constants/department';\r\nimport { Cacheable, CacheBuster, LocalStorageStrategy } from 'ts-cacheable';\r\nimport { GlobalAdminService } from '../../../../../shared-services/global-admin.service';\r\nexport const departmentCacheBuster$ = new Subject<void>();\r\nexport const minute = 60000;\r\n/** @ignore */\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class DepartmentApiService {\r\n  arabic;\r\n  constructor(\r\n    private CallApiService: CallApiService,\r\n    private translation: TranslationService,\r\n    private nuxeoService: NuxeoService,\r\n    private adapter: AdapterService, \r\n    private globalAdminService : GlobalAdminService,\r\n    @Inject('environment') private environment\r\n  ) {\r\n    this.translation.isArabic.subscribe((res) => {\r\n      this.arabic = res;\r\n    });\r\n  }\r\n\r\n  @Cacheable({\r\n    cacheBusterObserver: departmentCacheBuster$,\r\n    storageStrategy: LocalStorageStrategy,\r\n    maxAge: 60 * minute,\r\n  })\r\n  \r\n  getDepartmentTree(customPageProvider?): Observable<any> {\r\n    let params = {\r\n      pageProvider: customPageProvider ? customPageProvider : 'PP_Department',\r\n      currentPageIndex: 0,\r\n      offset: 0,\r\n      pageSize: 40,\r\n      quickFilters: 'Parent Dept'\r\n    }\r\n    if(this.globalAdminService.isGlobalAdmin){\r\n      params['queryParams'] = '/' + this.globalAdminService.activeTenant\r\n    }else if(!this.globalAdminService.isGlobalAdmin && this.nuxeoService.nuxeoClient.user.properties.tenantId){\r\n      params['queryParams'] = '/' + this.nuxeoService.nuxeoClient.user.properties.tenantId\r\n    }\r\n    return this.CallApiService.query(\r\n      {\r\n        ...params\r\n      },\r\n      {\r\n        headers: {\r\n          'X-NXproperties': '*',\r\n          'enrichers-document': 'children',\r\n          depth: 'max',\r\n        },\r\n      }\r\n    );\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 200,\r\n    storageStrategy: LocalStorageStrategy,\r\n    cacheBusterObserver: departmentCacheBuster$,\r\n    maxAge: 120 * minute,\r\n  })\r\n  getDepartmentDetails(code , customPageProvider?){\r\n    let params = {\r\n      pageProvider: customPageProvider ? customPageProvider: 'PP_Department_With_ElasticSearch',\r\n      currentPageIndex: 0,\r\n      offset: 0,\r\n      pageSize: 40,\r\n      dublincore_title: code,\r\n    }\r\n    if(this.globalAdminService.isGlobalAdmin){\r\n      params['queryParams'] = '/' + this.globalAdminService.activeTenant\r\n    }else if(!this.globalAdminService.isGlobalAdmin && this.nuxeoService.nuxeoClient.user.properties.tenantId){\r\n      params['queryParams'] = '/' + this.nuxeoService.nuxeoClient.user.properties.tenantId\r\n    }\r\n    return this.CallApiService.query(\r\n      {\r\n        ...params\r\n      },\r\n      {\r\n        headers: {\r\n          'X-NXproperties': '*',\r\n          'enrichers-document': 'children',\r\n          depth: 'max',\r\n        },\r\n      }\r\n    );\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 200,\r\n    cacheBusterObserver: departmentCacheBuster$,\r\n    storageStrategy: LocalStorageStrategy,\r\n    maxAge: 60 * minute,\r\n  })\r\n  getDepartmentNestedTree(code , customPageProvider? , customParentCodeProperty?): Observable<any> {\r\n    let params = {};\r\n     customParentCodeProperty ? (params[customParentCodeProperty] = code)  : (params = {'department_parentDepartmentCode': code})\r\n     if(this.globalAdminService.isGlobalAdmin){\r\n      params['queryParams'] = '/' + this.globalAdminService.activeTenant\r\n    }else if(!this.globalAdminService.isGlobalAdmin && this.nuxeoService.nuxeoClient.user.properties.tenantId){\r\n      params['queryParams'] = '/' + this.nuxeoService.nuxeoClient.user.properties.tenantId\r\n    }\r\n    return this.CallApiService.query(\r\n      {\r\n        pageProvider: customPageProvider ? customPageProvider : 'PP_Department',\r\n        currentPageIndex: 0,\r\n        offset: 0,\r\n        pageSize: 40,\r\n        ...params\r\n      },\r\n      {\r\n        headers: {\r\n          'X-NXproperties': '*',\r\n          'enrichers-document': 'children',\r\n          depth: 'max',\r\n        },\r\n      }\r\n    );\r\n  }\r\n\r\n  getDepartment(uid , fields?) {\r\n    return from(\r\n      this.nuxeoService.nuxeoClient\r\n        .repository()\r\n        .headers({\r\n          'X-NXproperties': '*',\r\n        })\r\n        .fetch(uid)\r\n    ).pipe(\r\n      map((data: any) => {\r\n        return this.adapter.adaptIn(data, fields ? fields : DepartmentConstants.fields);\r\n      }),\r\n      catchError((err) => {\r\n        throw err;\r\n      })\r\n    );\r\n  }\r\n\r\n  // testing\r\n  @CacheBuster({\r\n    cacheBusterNotifier: departmentCacheBuster$,\r\n  })\r\n  createDepartment(Department, parentId , customOperation? , fields?) {\r\n    let context ={ department: this.adapter.adaptOut(\r\n      Department,\r\n      fields ? fields : DepartmentConstants.fields\r\n    )};\r\n    if(this.globalAdminService.isGlobalAdmin){\r\n      context['tenantId'] = this.globalAdminService.activeTenant\r\n    }\r\n\r\n    return from(\r\n      this.nuxeoService.nuxeoClient\r\n        .operation( customOperation ? customOperation: 'AC_UA_Depatrment_Create' , {\r\n          url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n        })\r\n        .input(parentId)\r\n        .context({\r\n          ...context\r\n        })\r\n        .execute()\r\n    ).pipe(\r\n      catchError((err) => {\r\n        console.log(err);\r\n        throw err;\r\n      })\r\n    );\r\n  }\r\n\r\n  @CacheBuster({\r\n    cacheBusterNotifier: departmentCacheBuster$,\r\n  })\r\n  createDepartmentInRoot(Department , customOperation?) {\r\n    let context = {\r\n      department: this.adapter.adaptOut(\r\n        Department,\r\n        DepartmentConstants.fields\r\n      )\r\n    }\r\n    if(this.globalAdminService.isGlobalAdmin){\r\n      context['tenantId'] = this.globalAdminService.activeTenant\r\n    }\r\n    return from(\r\n      this.nuxeoService.nuxeoClient\r\n        .operation(customOperation ? customOperation : 'AC_UA_Depatrment_Create_InRoot', {\r\n          url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n        })\r\n        .context({\r\n          ...context\r\n        })\r\n        .execute()\r\n    ).pipe(\r\n      catchError((err) => {\r\n        console.log(err);\r\n        throw err;\r\n      })\r\n    );\r\n  }\r\n\r\n  @CacheBuster({\r\n    cacheBusterNotifier: departmentCacheBuster$,\r\n  })\r\n  updateDepartment(Department, departmentId , customOperation? , fields?) {\r\n    let context = {\r\n      department: this.adapter.adaptOut(\r\n        Department,\r\n        fields ? fields : DepartmentConstants.fields\r\n      )\r\n    }\r\n    if(this.globalAdminService.isGlobalAdmin){\r\n      context['tenantId'] = this.globalAdminService.activeTenant\r\n    }\r\n    return from(\r\n      this.nuxeoService.nuxeoClient\r\n        .operation( customOperation ? customOperation : 'AC_UA_Department_Update' , {\r\n          url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n        })\r\n        .input(departmentId)\r\n        .context({\r\n          ...context\r\n        })\r\n        .execute()\r\n    ).pipe(\r\n      catchError((err) => {\r\n        console.log(err);\r\n        throw err;\r\n      })\r\n    );\r\n  }\r\n\r\n  recursiveFill(\r\n    entries,\r\n    level = 0,\r\n    treeview = true,\r\n    collapsed = true,\r\n    customPrefix?\r\n  ): TreeviewItem[] {\r\n    return entries.map((item) => {\r\n      let treeViewObj = treeview\r\n        ? {\r\n            text: this.arabic\r\n              ? item.properties\r\n                ? item.properties[customPrefix ? (customPrefix + ':arabicName') : 'dept:arabicName']\r\n                : '--'\r\n              : item.properties\r\n              ? item.properties[customPrefix ? (customPrefix + ':englishName') : 'dept:englishName']\r\n              : '--',\r\n            value: { ...item, level },\r\n          }\r\n        : {\r\n            text: this.arabic\r\n              ? item.properties\r\n                ? item.properties[customPrefix ? (customPrefix + ':arabicName') : 'dept:arabicName']\r\n                : '--'\r\n              : item.properties\r\n              ? item.properties[customPrefix ? (customPrefix + ':englishName') : 'dept:englishName']\r\n              : '--',\r\n            value: item.title,\r\n          };\r\n      const treeItem = new TreeviewItem({\r\n        ...treeViewObj,\r\n        collapsed: level >= 2 && collapsed ? true : false,\r\n      });\r\n      if (\r\n        item.contextParameters &&\r\n        item.contextParameters.children.entries.length\r\n      ) {\r\n        treeItem.children = this.recursiveFill(\r\n          item.contextParameters.children.entries,\r\n          level + 1,\r\n          undefined,\r\n          undefined,\r\n          customPrefix\r\n        );\r\n      }\r\n      return treeItem;\r\n    });\r\n  }\r\n}\r\n"]}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"department-api.service.js","sourceRoot":"","sources":["../../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-department/services/department-api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Inject, Injectable } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { TreeviewItem } from 'ngx-treeview';\r\nimport { from, Observable, Subject } from 'rxjs';\r\nimport { catchError, map } from 'rxjs/operators';\r\nimport { AdapterService } from '../../../../../Core/adapters/adapter.service';\r\nimport { CallApiService } from '../../../../../Core/services/callApi/call-api.service';\r\nimport { NuxeoService } from '../../../../../Core/services/nuxeo/nuxeo.service';\r\nimport { TranslationService } from '../../../../../Core/services/translation/translation.service';\r\nimport { DepartmentConstants } from '../constants/department';\r\nimport { Cacheable, CacheBuster, LocalStorageStrategy } from 'ts-cacheable';\r\nexport const departmentCacheBuster$ = new Subject<void>();\r\nexport const minute = 60000;\r\n/** @ignore */\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class DepartmentApiService {\r\n  arabic;\r\n  constructor(\r\n    private CallApiService: CallApiService,\r\n    private translation: TranslationService,\r\n    private nuxeoService: NuxeoService,\r\n    private adapter: AdapterService, \r\n    @Inject('environment') private environment\r\n  ) {\r\n    this.translation.isArabic.subscribe((res) => {\r\n      this.arabic = res;\r\n    });\r\n  }\r\n\r\n  @Cacheable({\r\n    cacheBusterObserver: departmentCacheBuster$,\r\n    storageStrategy: LocalStorageStrategy,\r\n    maxAge: 60 * minute,\r\n  })\r\n  \r\n  getDepartmentTree(customPageProvider?,customParams?): Observable<any> {\r\n    let obj = customParams ? customParams : {};\r\n    return this.CallApiService.query(\r\n      {\r\n        pageProvider: customPageProvider ? customPageProvider : 'PP_Department',\r\n        currentPageIndex: 0,\r\n        offset: 0,\r\n        pageSize: 40,\r\n        quickFilters: 'Parent Dept',\r\n        ...obj\r\n      },\r\n      {\r\n        headers: {\r\n          'X-NXproperties': '*',\r\n          'enrichers-document': 'children',\r\n          depth: 'max',\r\n        },\r\n      }\r\n    );\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 200,\r\n    storageStrategy: LocalStorageStrategy,\r\n    cacheBusterObserver: departmentCacheBuster$,\r\n    maxAge: 120 * minute,\r\n  })\r\n  getDepartmentDetails(code , customPageProvider?){\r\n    return this.CallApiService.query(\r\n      {\r\n        pageProvider: customPageProvider ? customPageProvider: 'PP_Department_With_ElasticSearch',\r\n        currentPageIndex: 0,\r\n        offset: 0,\r\n        pageSize: 40,\r\n        dublincore_title: code,\r\n      },\r\n      {\r\n        headers: {\r\n          'X-NXproperties': '*',\r\n          'enrichers-document': 'children',\r\n          depth: 'max',\r\n        },\r\n      }\r\n    );\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 200,\r\n    cacheBusterObserver: departmentCacheBuster$,\r\n    storageStrategy: LocalStorageStrategy,\r\n    maxAge: 60 * minute,\r\n  })\r\n  getDepartmentNestedTree(code , customPageProvider? , customParentCodeProperty?): Observable<any> {\r\n    let params = {};\r\n     customParentCodeProperty ? (params[customParentCodeProperty] = code)  : (params = {'department_parentDepartmentCode': code})\r\n    return this.CallApiService.query(\r\n      {\r\n        pageProvider: customPageProvider ? customPageProvider : 'PP_Department',\r\n        currentPageIndex: 0,\r\n        offset: 0,\r\n        pageSize: 40,\r\n        ...params\r\n      },\r\n      {\r\n        headers: {\r\n          'X-NXproperties': '*',\r\n          'enrichers-document': 'children',\r\n          depth: 'max',\r\n        },\r\n      }\r\n    );\r\n  }\r\n\r\n  getDepartment(uid , fields?) {\r\n    return from(\r\n      this.nuxeoService.nuxeoClient\r\n        .repository()\r\n        .headers({\r\n          'X-NXproperties': '*',\r\n        })\r\n        .fetch(uid)\r\n    ).pipe(\r\n      map((data: any) => {\r\n        return this.adapter.adaptIn(data, fields ? fields : DepartmentConstants.fields);\r\n      }),\r\n      catchError((err) => {\r\n        throw err;\r\n      })\r\n    );\r\n  }\r\n\r\n  // testing\r\n  @CacheBuster({\r\n    cacheBusterNotifier: departmentCacheBuster$,\r\n  })\r\n  createDepartment(Department, parentId , customOperation? , fields?) {\r\n    return from(\r\n      this.nuxeoService.nuxeoClient\r\n        .operation( customOperation ? customOperation: 'AC_UA_Depatrment_Create' , {\r\n          url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n        })\r\n        .input(parentId)\r\n        .context({\r\n          department: this.adapter.adaptOut(\r\n            Department,\r\n            fields ? fields : DepartmentConstants.fields\r\n          ),\r\n        })\r\n        .execute()\r\n    ).pipe(\r\n      catchError((err) => {\r\n        console.log(err);\r\n        throw err;\r\n      })\r\n    );\r\n  }\r\n\r\n  @CacheBuster({\r\n    cacheBusterNotifier: departmentCacheBuster$,\r\n  })\r\n  createDepartmentInRoot(Department , customOperation?) {\r\n    return from(\r\n      this.nuxeoService.nuxeoClient\r\n        .operation(customOperation ? customOperation : 'AC_UA_Depatrment_Create_InRoot', {\r\n          url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n        })\r\n        .context({\r\n          department: this.adapter.adaptOut(\r\n            Department,\r\n            DepartmentConstants.fields\r\n          ),\r\n        })\r\n        .execute()\r\n    ).pipe(\r\n      catchError((err) => {\r\n        console.log(err);\r\n        throw err;\r\n      })\r\n    );\r\n  }\r\n\r\n  @CacheBuster({\r\n    cacheBusterNotifier: departmentCacheBuster$,\r\n  })\r\n  updateDepartment(Department, departmentId , customOperation? , fields?) {\r\n    return from(\r\n      this.nuxeoService.nuxeoClient\r\n        .operation( customOperation ? customOperation : 'AC_UA_Department_Update' , {\r\n          url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n        })\r\n        .input(departmentId)\r\n        .context({\r\n          department: this.adapter.adaptOut(\r\n            Department,\r\n            fields ? fields : DepartmentConstants.fields\r\n          ),\r\n        })\r\n        .execute()\r\n    ).pipe(\r\n      catchError((err) => {\r\n        console.log(err);\r\n        throw err;\r\n      })\r\n    );\r\n  }\r\n\r\n  recursiveFill(\r\n    entries,\r\n    level = 0,\r\n    treeview = true,\r\n    collapsed = true,\r\n    customPrefix?\r\n  ): TreeviewItem[] {\r\n    return entries.map((item) => {\r\n      let treeViewObj = treeview\r\n        ? {\r\n            text: this.arabic\r\n              ? item.properties\r\n                ? item.properties[customPrefix ? (customPrefix + ':arabicName') : 'dept:arabicName']\r\n                : '--'\r\n              : item.properties\r\n              ? item.properties[customPrefix ? (customPrefix + ':englishName') : 'dept:englishName']\r\n              : '--',\r\n            value: { ...item, level },\r\n          }\r\n        : {\r\n            text: this.arabic\r\n              ? item.properties\r\n                ? item.properties[customPrefix ? (customPrefix + ':arabicName') : 'dept:arabicName']\r\n                : '--'\r\n              : item.properties\r\n              ? item.properties[customPrefix ? (customPrefix + ':englishName') : 'dept:englishName']\r\n              : '--',\r\n            value: item.title,\r\n          };\r\n      const treeItem = new TreeviewItem({\r\n        ...treeViewObj,\r\n        collapsed: level >= 2 && collapsed ? true : false,\r\n      });\r\n      if (\r\n        item.contextParameters &&\r\n        item.contextParameters.children.entries.length\r\n      ) {\r\n        treeItem.children = this.recursiveFill(\r\n          item.contextParameters.children.entries,\r\n          level + 1,\r\n          undefined,\r\n          undefined,\r\n          customPrefix\r\n        );\r\n      }\r\n      return treeItem;\r\n    });\r\n  }\r\n}\r\n"]}
|
|
@@ -27,6 +27,7 @@ export class DynamicFormSelectTagComponent {
|
|
|
27
27
|
this.onChange = () => { };
|
|
28
28
|
this.onTouched = () => { };
|
|
29
29
|
this.multiple = true;
|
|
30
|
+
this.selectedTagsCustomTemplate = null;
|
|
30
31
|
if (this.control) {
|
|
31
32
|
this.control.valueAccessor = this;
|
|
32
33
|
}
|
|
@@ -80,7 +81,7 @@ export class DynamicFormSelectTagComponent {
|
|
|
80
81
|
}
|
|
81
82
|
}
|
|
82
83
|
DynamicFormSelectTagComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicFormSelectTagComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i2.TagsApiService }], target: i0.ɵɵFactoryTarget.Component });
|
|
83
|
-
DynamicFormSelectTagComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: DynamicFormSelectTagComponent, selector: "cts-dynamic-form-select-tag", inputs: { label: "label", multiple: "multiple" }, ngImport: i0, template: "<ng-container *ngIf=\"label\">\r\n <div>\r\n <label class=\"select-label\"\r\n >{{ label | translate\r\n }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n >\r\n </div>\r\n</ng-container>\r\n<div class=\"tags\">\r\n <ng-select\r\n [items]=\"tags$ | async\"\r\n bindLabel=\"displayLabel\"\r\n [addTag]=\"true\"\r\n [addTagText]=\"'Tags.add' | translate\"\r\n [multiple]=\"multiple\"\r\n [hideSelected]=\"true\"\r\n [minTermLength]=\"2\"\r\n [loading]=\"tagsLoading\"\r\n [typeToSearchText]=\"'Tags.typeToSearchText' | translate\"\r\n [typeahead]=\"tagsInput$\"\r\n [(ngModel)]=\"selectedTags\"\r\n (change)=\"emitSelection($event)\"\r\n required\r\n [placeholder]=\"'Tags.placeholder' | translate\"\r\n >\r\n </ng-select>\r\n</div>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.select-label{color:#8f98aa;font-size:12px;margin-bottom:0}.tags .ng-select-container{border:1px solid #ccc!important;border-radius:5px!important;background-color:#8f98aa1a!important;height:40px!important;box-shadow:none!important}.tags .ng-select-container .ng-value-container{padding:5px 7px 0!important}.tags .ng-select-container .ng-value-container .ng-placeholder{padding:0 5px;font-size:12px;margin-top:6px}.tags .ng-select-container .ng-value-container .ng-value{color:#495057}.tags .ng-select-container .ng-arrow-wrapper{padding:0 20px}.tags .ng-select-container .ng-input{left:10px;right:10px;width:auto}.ng-select-disabled .ng-select-container{background-color:#e9ecef!important}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper{position:relative}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper input{visibility:hidden;width:20px;height:20px}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper{position:absolute;top:0px;left:0px;width:20px;height:20px;border:1px solid #2e62df;display:flex;justify-content:center;align-items:center}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper .icon{color:#2e62df;display:none;justify-content:center;align-items:center;font-weight:bold}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .check-box-wrapper .icon-wrapper .icon{display:flex}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .label-wrapper{color:#2e62df}.ng-select .ng-select-focused:not(.ng-select-opened) .ng-select-container{border-color:#ccc;box-shadow:none}\n"], components: [{ type: i3.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i5.TranslatePipe, "async": i4.AsyncPipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
84
|
+
DynamicFormSelectTagComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: DynamicFormSelectTagComponent, selector: "cts-dynamic-form-select-tag", inputs: { label: "label", multiple: "multiple", selectedTagsCustomTemplate: "selectedTagsCustomTemplate" }, ngImport: i0, template: "<ng-container *ngIf=\"label\">\r\n <div>\r\n <label class=\"select-label\"\r\n >{{ label | translate\r\n }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n >\r\n </div>\r\n</ng-container>\r\n<div class=\"tags\">\r\n <ng-select\r\n [items]=\"tags$ | async\"\r\n bindLabel=\"displayLabel\"\r\n [addTag]=\"true\"\r\n [addTagText]=\"'Tags.add' | translate\"\r\n [multiple]=\"multiple\"\r\n [hideSelected]=\"true\"\r\n [minTermLength]=\"2\"\r\n [loading]=\"tagsLoading\"\r\n [typeToSearchText]=\"'Tags.typeToSearchText' | translate\"\r\n [typeahead]=\"tagsInput$\"\r\n [(ngModel)]=\"selectedTags\"\r\n (change)=\"emitSelection($event)\"\r\n required\r\n [placeholder]=\"'Tags.placeholder' | translate\"\r\n >\r\n <ng-container *ngIf=\"selectedTagsCustomTemplate\">\r\n <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n <ng-container *ngTemplateOutlet=\"\r\n selectedTagsCustomTemplate;\r\n context: { $implicit: item }\r\n \">\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n </ng-select>\r\n</div>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.select-label{color:#8f98aa;font-size:12px;margin-bottom:0}.tags .ng-select-container{border:1px solid #ccc!important;border-radius:5px!important;background-color:#8f98aa1a!important;height:40px!important;box-shadow:none!important}.tags .ng-select-container .ng-value-container{padding:5px 7px 0!important}.tags .ng-select-container .ng-value-container .ng-placeholder{padding:0 5px;font-size:12px;margin-top:6px}.tags .ng-select-container .ng-value-container .ng-value{color:#495057}.tags .ng-select-container .ng-arrow-wrapper{padding:0 20px}.tags .ng-select-container .ng-input{left:10px;right:10px;width:auto}.ng-select-disabled .ng-select-container{background-color:#e9ecef!important}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper{position:relative}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper input{visibility:hidden;width:20px;height:20px}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper{position:absolute;top:0px;left:0px;width:20px;height:20px;border:1px solid #2e62df;display:flex;justify-content:center;align-items:center}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .option-wrapper .check-box-wrapper .icon-wrapper .icon{color:#2e62df;display:none;justify-content:center;align-items:center;font-weight:bold}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .check-box-wrapper .icon-wrapper .icon{display:flex}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option-selected .option-wrapper .label-wrapper{color:#2e62df}.ng-select .ng-select-focused:not(.ng-select-opened) .ng-select-container{border-color:#ccc;box-shadow:none}\n"], components: [{ type: i3.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i3.ɵh, selector: "[ng-label-tmp]" }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "translate": i5.TranslatePipe, "async": i4.AsyncPipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
84
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicFormSelectTagComponent, decorators: [{
|
|
85
86
|
type: Component,
|
|
86
87
|
args: [{
|
|
@@ -97,5 +98,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
97
98
|
type: Input
|
|
98
99
|
}], multiple: [{
|
|
99
100
|
type: Input
|
|
101
|
+
}], selectedTagsCustomTemplate: [{
|
|
102
|
+
type: Input
|
|
100
103
|
}] } });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-select-tag.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Self,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { concat, Observable, of, Subject } from 'rxjs';\r\nimport {\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  tap,\r\n  switchMap,\r\n  catchError,\r\n} from 'rxjs/operators';\r\nimport { TagsApiService } from '../../../cts-tags/services/tags-api.service';\r\n\r\n/**\r\n * A tags dropdown input integrated with tags API,\r\n *  that can be used inside reactive or template driven forms\r\n * @title\r\n * tags dropdown\r\n * @example\r\n * <cts-dynamic-form-select-tag\r\n *     formControlName=\"controlName\"\r\n *     [label]=\"'PATH.TO.TRANSLATION'\"\r\n * ></cts-dynamic-form-select-tag>\r\n */\r\n@Component({\r\n  selector: 'cts-dynamic-form-select-tag',\r\n  templateUrl: './dynamic-form-select-tag.component.html',\r\n  styleUrls: ['./dynamic-form-select-tag.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormSelectTagComponent\r\n  implements OnInit, ControlValueAccessor\r\n{\r\n  /** Field Label */\r\n  @Input() label: string;\r\n\r\n  tags$: Observable<any[]>;\r\n  tagsLoading = false;\r\n  tagsInput$ = new Subject<string>();\r\n  selectedTags;\r\n  tagsList: any[];\r\n  onChange: any = () => {};\r\n  onTouched: any = () => {};\r\n  @Input() multiple = true;\r\n  constructor(\r\n    @Self() @Optional() private control: NgControl,\r\n    private tagsApiService: TagsApiService\r\n  ) {\r\n    if (this.control) {\r\n      this.control.valueAccessor = this;\r\n    }\r\n  }\r\n  writeValue(value) {\r\n    if (value) {\r\n      this.selectedTags = this.buildTagObj(value);\r\n    }\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {}\r\n\r\n  ngOnInit(): void {\r\n    this.loadTags();\r\n  }\r\n  \r\n  emitSelection(event) {\r\n    if(this.multiple) {\r\n      let tags = [];\r\n      this.selectedTags.forEach((tagObj) => {\r\n        tags.push(tagObj.id || tagObj.displayLabel);\r\n      });\r\n      this.onChange(tags);\r\n    } else {\r\n      this.onChange(this.selectedTags)\r\n    }\r\n  }\r\n\r\n  private loadTags() {\r\n    this.tags$ = concat(\r\n      of([]), // default items\r\n      this.tagsInput$.pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.tagsLoading = true)),\r\n        switchMap((term) =>\r\n          this.tagsApiService.tagsSuggestion(term).pipe(\r\n            catchError(() => of([])), // empty list on error\r\n            tap(() => (this.tagsLoading = false))\r\n          )\r\n        )\r\n      )\r\n    );\r\n  }\r\n  isRequired() {\r\n    if (!this.control || !this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  buildTagObj(value) {\r\n    let arrayOfTags = [];\r\n    value.forEach((tag) => {\r\n      arrayOfTags.push({ id: tag, displayLabel: tag });\r\n    });\r\n    console.log(\"arrayOfTags\",arrayOfTags)\r\n    return arrayOfTags;\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n  <div>\r\n    <label class=\"select-label\"\r\n      >{{ label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n    >\r\n  </div>\r\n</ng-container>\r\n<div class=\"tags\">\r\n  <ng-select\r\n    [items]=\"tags$ | async\"\r\n    bindLabel=\"displayLabel\"\r\n    [addTag]=\"true\"\r\n    [addTagText]=\"'Tags.add' | translate\"\r\n    [multiple]=\"multiple\"\r\n    [hideSelected]=\"true\"\r\n    [minTermLength]=\"2\"\r\n    [loading]=\"tagsLoading\"\r\n    [typeToSearchText]=\"'Tags.typeToSearchText' | translate\"\r\n    [typeahead]=\"tagsInput$\"\r\n    [(ngModel)]=\"selectedTags\"\r\n    (change)=\"emitSelection($event)\"\r\n    required\r\n    [placeholder]=\"'Tags.placeholder' | translate\"\r\n  >\r\n  </ng-select>\r\n</div>\r\n"]}
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-select-tag.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Self,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { concat, Observable, of, Subject } from 'rxjs';\r\nimport {\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  tap,\r\n  switchMap,\r\n  catchError,\r\n} from 'rxjs/operators';\r\nimport { TagsApiService } from '../../../cts-tags/services/tags-api.service';\r\n\r\n/**\r\n * A tags dropdown input integrated with tags API,\r\n *  that can be used inside reactive or template driven forms\r\n * @title\r\n * tags dropdown\r\n * @example\r\n * <cts-dynamic-form-select-tag\r\n *     formControlName=\"controlName\"\r\n *     [label]=\"'PATH.TO.TRANSLATION'\"\r\n * ></cts-dynamic-form-select-tag>\r\n */\r\n@Component({\r\n  selector: 'cts-dynamic-form-select-tag',\r\n  templateUrl: './dynamic-form-select-tag.component.html',\r\n  styleUrls: ['./dynamic-form-select-tag.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormSelectTagComponent\r\n  implements OnInit, ControlValueAccessor\r\n{\r\n  /** Field Label */\r\n  @Input() label: string;\r\n\r\n  tags$: Observable<any[]>;\r\n  tagsLoading = false;\r\n  tagsInput$ = new Subject<string>();\r\n  selectedTags;\r\n  tagsList: any[];\r\n  onChange: any = () => {};\r\n  onTouched: any = () => {};\r\n  @Input() multiple = true;\r\n  @Input() selectedTagsCustomTemplate = null;\r\n  constructor(\r\n    @Self() @Optional() private control: NgControl,\r\n    private tagsApiService: TagsApiService\r\n  ) {\r\n    if (this.control) {\r\n      this.control.valueAccessor = this;\r\n    }\r\n  }\r\n  writeValue(value) {\r\n    if (value) {\r\n      this.selectedTags = this.buildTagObj(value);\r\n    }\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {}\r\n\r\n  ngOnInit(): void {\r\n    this.loadTags();\r\n  }\r\n  \r\n  emitSelection(event) {\r\n    if(this.multiple) {\r\n      let tags = [];\r\n      this.selectedTags.forEach((tagObj) => {\r\n        tags.push(tagObj.id || tagObj.displayLabel);\r\n      });\r\n      this.onChange(tags);\r\n    } else {\r\n      this.onChange(this.selectedTags)\r\n    }\r\n  }\r\n\r\n  private loadTags() {\r\n    this.tags$ = concat(\r\n      of([]), // default items\r\n      this.tagsInput$.pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.tagsLoading = true)),\r\n        switchMap((term) =>\r\n          this.tagsApiService.tagsSuggestion(term).pipe(\r\n            catchError(() => of([])), // empty list on error\r\n            tap(() => (this.tagsLoading = false))\r\n          )\r\n        )\r\n      )\r\n    );\r\n  }\r\n  isRequired() {\r\n    if (!this.control || !this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  buildTagObj(value) {\r\n    let arrayOfTags = [];\r\n    value.forEach((tag) => {\r\n      arrayOfTags.push({ id: tag, displayLabel: tag });\r\n    });\r\n    console.log(\"arrayOfTags\",arrayOfTags)\r\n    return arrayOfTags;\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n  <div>\r\n    <label class=\"select-label\"\r\n      >{{ label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n    >\r\n  </div>\r\n</ng-container>\r\n<div class=\"tags\">\r\n  <ng-select\r\n    [items]=\"tags$ | async\"\r\n    bindLabel=\"displayLabel\"\r\n    [addTag]=\"true\"\r\n    [addTagText]=\"'Tags.add' | translate\"\r\n    [multiple]=\"multiple\"\r\n    [hideSelected]=\"true\"\r\n    [minTermLength]=\"2\"\r\n    [loading]=\"tagsLoading\"\r\n    [typeToSearchText]=\"'Tags.typeToSearchText' | translate\"\r\n    [typeahead]=\"tagsInput$\"\r\n    [(ngModel)]=\"selectedTags\"\r\n    (change)=\"emitSelection($event)\"\r\n    required\r\n    [placeholder]=\"'Tags.placeholder' | translate\"\r\n  >\r\n  <ng-container *ngIf=\"selectedTagsCustomTemplate\">\r\n    <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n      <ng-container *ngTemplateOutlet=\"\r\n      selectedTagsCustomTemplate;\r\n      context: { $implicit: item }\r\n      \">\r\n      </ng-container>\r\n    </ng-template>\r\n  </ng-container>\r\n  </ng-select>\r\n</div>\r\n"]}
|
|
@@ -107,7 +107,7 @@ export class TreeviewSelectComponent {
|
|
|
107
107
|
}
|
|
108
108
|
}
|
|
109
109
|
setPreSeletedItem(item, compareWithValue) {
|
|
110
|
-
if (
|
|
110
|
+
if (item.value === compareWithValue) {
|
|
111
111
|
this.select(item);
|
|
112
112
|
return;
|
|
113
113
|
}
|
|
@@ -311,4 +311,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
311
311
|
type: ViewChild,
|
|
312
312
|
args: [DropdownTreeviewComponent, { static: false }]
|
|
313
313
|
}] } });
|
|
314
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-treeview-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-treeview-select/dynamic-form-treeview-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewChild,\r\n  OnChanges,\r\n  ViewEncapsulation,\r\n  OnInit,\r\n  OnDestroy,\r\n} from \"@angular/core\";\r\nimport { isNil } from \"lodash\";\r\nimport {\r\n  TreeviewI18n,\r\n  TreeviewItem,\r\n  TreeviewConfig,\r\n  DropdownTreeviewComponent,\r\n  TreeviewHelper,\r\n} from \"ngx-treeview\";\r\nimport { Subject, Subscription } from \"rxjs\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\nimport { TranslationService } from \"../../../../Core/services/translation/translation.service\";\r\nimport { DepartmentManagementService } from \"../dynamic-form-department/services/department-management.service\";\r\nimport { DepartmentApiService } from \"../dynamic-form-department/services/department-api.service\";\r\nimport { DropdownTreeviewSelectI18n } from \"./dropdown-treeview-select-i18n\";\r\nimport { RolesService } from \"../../../../Core/services/roles/roles.service\";\r\nimport { NuxeoService } from \"../../../../Core/services/nuxeo/nuxeo.service\";\r\n/**\r\n * A tree view selector component that can be used in reactive and template driven forms,\r\n * it can be a flat tree or a dropdown\r\n * @title\r\n * Tree view selector\r\n *\r\n * @example\r\n * <app-dynamic-form-treeview-select\r\n * [treeview]=\"false\"\r\n * [multiple]=\"false\"\r\n * [items]=\"itemsTree\"\r\n * (valueChange)=\"onValueChange($event)\"\r\n * [(value)]=\"selectedValue\"\r\n * >\r\n * </app-dynamic-form-treeview-select>\r\n */\r\n@Component({\r\n  selector: \"app-dynamic-form-treeview-select\",\r\n  templateUrl: \"./dynamic-form-treeview-select.component.html\",\r\n  styleUrls: [\"./dynamic-form-treeview-select.component.scss\"],\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [{ provide: TreeviewI18n, useClass: DropdownTreeviewSelectI18n }],\r\n})\r\nexport class TreeviewSelectComponent implements OnInit, OnChanges, OnDestroy {\r\n  multipleSelection = [];\r\n  selectedItem;\r\n  selectedParentWithChild = [];\r\n  showPlus = false;\r\n  preSelected = [];\r\n  myDepartment: any;\r\n  /** is tree View or dropdown view */\r\n  @Input()\r\n  treeview = false;\r\n  /** use tree view inside form */\r\n  @Input()\r\n  treeViewAsFormControl = false;\r\n  /** Config object */\r\n  @Input() config: TreeviewConfig;\r\n  /** Items tree */\r\n  @Input() items: TreeviewItem[];\r\n  /** Selected value */\r\n  @Input() value: any;\r\n  /** can select multiple */\r\n  @Input() multiple: boolean = false;\r\n  /** event emitted on value change */\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  /** event emitted on plus button clicked (for department management) */\r\n  @Output() plusClicked = new EventEmitter<any>();\r\n  /** event emitted on plus button clicked (for department management) */\r\n  @Input() defaultSelect = false;\r\n/** custom page provider to get department nested tree from it can be passed from outside or not passed and use the defulte value */\r\n  @Input() pp_departmentNestedTree; \r\n  /** use outside custom function instead of the iner function  */\r\n  @Input() useCustomAddEditAction = false;\r\n    /** custom prefix to be used for adapting data coming from api */\r\n    @Input() customPrefix;\r\n  /** custom parent property name to be passed from outside the component */\r\n  @Input() customParentProperty;\r\n  @Input() placeholder;\r\n  @Output() actionClicked = new EventEmitter<any>();\r\n  @ViewChild(DropdownTreeviewComponent, { static: false })\r\n  dropdownTreeviewComponent: DropdownTreeviewComponent;\r\n  filterText: string;\r\n  arabic = false;\r\n  languageSubscription: Subscription;\r\n  onDestroy$: Subject<boolean> = new Subject<boolean>();\r\n\r\n  private dropdownTreeviewSelectI18n: DropdownTreeviewSelectI18n;\r\n\r\n  // this component is used in two places the flag is this.treeview\r\n\r\n  constructor(\r\n    public i18n: TreeviewI18n,\r\n    private translation: TranslationService,\r\n    private departmentApiService: DepartmentApiService,\r\n    private departmentManagment: DepartmentManagementService,\r\n    private rolesService: RolesService,\r\n    private nuxeoService: NuxeoService\r\n  ) {\r\n    this.config = TreeviewConfig.create({\r\n      hasAllCheckBox: false,\r\n      hasCollapseExpand: false,\r\n      hasFilter: true,\r\n      maxHeight: 200,\r\n      decoupleChildFromParent: true,\r\n    });\r\n    this.dropdownTreeviewSelectI18n = i18n as DropdownTreeviewSelectI18n;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.translation.isArabic\r\n      .pipe(takeUntil(this.onDestroy$))\r\n      .subscribe((res) => {\r\n        this.arabic = res;\r\n      });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.onDestroy$.complete();\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    if (this.items && this.treeview) {\r\n      this.updateSelectedItem();\r\n    }\r\n    if (!this.treeview && !this.multiple) {\r\n      // this. function is to set ui with pre selected value\r\n      // delay to make sure that page get the value and send it to here\r\n      // we use the value sent to here and search for its item on our items and set it as the selected item\r\n      this.items.map((item) => {\r\n        this.setPreSeletedItem(item, this.value);\r\n      });\r\n    }\r\n    if (\r\n      !this.treeview &&\r\n      this.multiple &&\r\n      this.value &&\r\n      this.value.length > 0\r\n    ) {\r\n      // this.preSelected = this.value;\r\n      this.multipleSelection = this.value;\r\n      this.dropdownTreeviewSelectI18n.selectionLength =\r\n        this.multipleSelection.length;\r\n      this.dropdownTreeviewComponent.onSelectedChange([\r\n        this.multipleSelection.length,\r\n      ]);\r\n    }\r\n  }\r\n\r\n  setPreSeletedItem(item, compareWithValue) {\r\n    if ((item.value === compareWithValue) || (item.value.title === compareWithValue)) {\r\n      this.select(item);\r\n      return;\r\n    } else {\r\n      if (item.internalChildren) {\r\n        item.internalChildren.map((child) => {\r\n          this.setPreSeletedItem(child, compareWithValue);\r\n        });\r\n      } else {\r\n        return;\r\n      }\r\n    }\r\n  }\r\n  selectDefault() {\r\n    this.myDepartment = this.rolesService.getUserDepartment(\r\n      this.nuxeoService.nuxeoClient.user\r\n    );\r\n    this.items.map((item) => {\r\n      this.setPreSeletedItem(item, this.myDepartment);\r\n    });\r\n  }\r\n  select(item: TreeviewItem): void {\r\n    // if (!item.children) {\r\n    this.selectItem(item);\r\n    // }\r\n  }\r\n\r\n  private updateSelectedItem(): void {\r\n    if (!isNil(this.items)) {\r\n      const selectedItem = TreeviewHelper.findItemInList(\r\n        this.items,\r\n        this.value\r\n      );\r\n      this.selectItem(selectedItem);\r\n    }\r\n  }\r\n\r\n  private selectItem(item: TreeviewItem): void {\r\n    document.body.click();\r\n    if (this.dropdownTreeviewSelectI18n.selectedItem !== item) {\r\n      this.dropdownTreeviewSelectI18n.selectedItem = item;\r\n      if (this.dropdownTreeviewComponent) {\r\n        this.dropdownTreeviewComponent.onSelectedChange([item]);\r\n      }\r\n\r\n      if (item) {\r\n        if (this.treeview) {\r\n          this.selectedItem = item.value;\r\n          // this.valueChange.emit(item.value.title);\r\n          this.valueChange.emit(item);\r\n        } else {\r\n          this.valueChange.emit(item.value);\r\n        }\r\n      }\r\n    }\r\n  }\r\n  selectMultiple(e, item: TreeviewItem) {\r\n    this.selectedParentWithChild = [];\r\n    this.getChildernValues(item);\r\n    if (e) {\r\n      this.multipleSelection = this.multipleSelection.concat(\r\n        this.selectedParentWithChild\r\n      );\r\n    } else {\r\n      this.multipleSelection = this.multipleSelection.filter((e) => {\r\n        return this.selectedParentWithChild.indexOf(e) < 0;\r\n      });\r\n    }\r\n\r\n    this.dropdownTreeviewSelectI18n.selectionLength =\r\n      this.multipleSelection.length;\r\n    this.dropdownTreeviewComponent.onSelectedChange([\r\n      this.multipleSelection.length,\r\n    ]);\r\n    this.valueChange.emit(this.multipleSelection);\r\n  }\r\n  getChildernValues(item: TreeviewItem) {\r\n    this.selectedParentWithChild.push(item.value);\r\n    if (item.children) {\r\n      item.children.forEach((item) => {\r\n        this.getChildernValues(item);\r\n      });\r\n    } else return;\r\n  }\r\n\r\n  onPlusClicked(e: MouseEvent, item: TreeviewItem): void {\r\n    e.stopPropagation();\r\n    if (item) {\r\n      this.plusClicked.emit(item.value.uid);\r\n    }\r\n  }\r\n  /**\r\n   *\r\n   * @param e  click event\r\n   * @param action name of action (add , update)\r\n   * @param item TreeviewItem\r\n   */\r\n  onAction(e: MouseEvent, action: string, item: TreeviewItem) {\r\n    e.stopPropagation();\r\n    if (item) {\r\n      if (action === \"add\") {\r\n        // emit action to outside to execute function from outside the component \r\n        if(this.useCustomAddEditAction){\r\n          this.actionClicked.emit({\r\n            action : action,\r\n            item : item\r\n          });\r\n        }else{\r\n          this.departmentManagment\r\n            .openFormDialog(item.value.uid, false, item.value.title, item)\r\n            .subscribe((res) => {\r\n              if (res) {\r\n                this.update(item);\r\n              }\r\n            });\r\n        }\r\n      }\r\n      if (action === \"update\") {\r\n        if(this.useCustomAddEditAction){\r\n        // emit action to outside to execute function from outside the component \r\n          this.actionClicked.emit({\r\n            action : action,\r\n            item : item\r\n          });\r\n        }else{\r\n          this.departmentManagment\r\n            .openFormDialog(item.value.uid, true)\r\n            .subscribe((res) => {\r\n              // this.update(item);\r\n              this.departmentApiService.getDepartmentTree().subscribe((res) => {\r\n                this.items = this.departmentApiService.recursiveFill(\r\n                  res.entries , \r\n                  undefined , \r\n                  undefined , \r\n                  undefined , \r\n                  this.customPrefix);\r\n              });\r\n            });\r\n        }\r\n      }\r\n    }\r\n  }\r\n  \r\n  /**\r\n   *due to the business requirements which stated that more than 3 levels will existed the current api support only 3 levels so *we have to inject 3 new levels on each tree end\r\n   * @param item TreeviewItem\r\n   */\r\n  onCollapsed(item: TreeviewItem) {\r\n    item.collapsed = !item.collapsed;\r\n    if (item.value.level === 2) {\r\n      this.departmentApiService\r\n        .getDepartmentNestedTree(\r\n          item.value.title , \r\n          this.pp_departmentNestedTree ? this.pp_departmentNestedTree : 'PP_Department',\r\n          this.customParentProperty)\r\n        .subscribe(\r\n          (res) => {\r\n            item.children = this.departmentApiService.recursiveFill(\r\n              res.entries , \r\n              undefined , \r\n              undefined , \r\n              undefined , \r\n              this.customPrefix\r\n            );\r\n          },\r\n          (err) => {}\r\n        );\r\n    }\r\n  }\r\n  /**\r\n   *due to the business requirements which stated that more than 3 levels will existed the current api support only 3 levels so *we have to inject 3 new levels on each tree end\r\n   * @param item TreeviewItem\r\n   */\r\n  update(item) {\r\n    this.departmentApiService\r\n      .getDepartmentNestedTree(\r\n        item.value.title , \r\n        this.pp_departmentNestedTree ? this.pp_departmentNestedTree : 'PP_Department',\r\n        this.customParentProperty)\r\n      .subscribe(\r\n        (data) => {\r\n          item.children = this.departmentApiService.recursiveFill(\r\n            data.entries,\r\n            0,\r\n            true,\r\n            true,\r\n            this.customPrefix\r\n          );\r\n        },\r\n        (err) => {}\r\n      );\r\n  }\r\n}\r\n","<ng-template\r\n  #itemTemplate\r\n  let-item=\"item\"\r\n  let-onCollapseExpand=\"onCollapseExpand\"\r\n  let-onCheckedChange=\"onCheckedChange\"\r\n>\r\n  <!-- single -->\r\n  <div *ngIf=\"!treeview && !multiple\">\r\n    <div\r\n      class=\"text-nowrap row-item\"\r\n      [ngClass]=\"{ active: item.value === this.value }\"\r\n    >\r\n      <i\r\n        *ngIf=\"item.children\"\r\n        (click)=\"onCollapseExpand()\"\r\n        aria-hidden=\"true\"\r\n        [ngSwitch]=\"item.collapsed\"\r\n      >\r\n        <span\r\n          *ngSwitchCase=\"true\"\r\n          class=\"bi bi-caret-{{ arabic ? 'left' : 'right' }}-fill caret-icon\"\r\n        ></span>\r\n        <span\r\n          *ngSwitchCase=\"false\"\r\n          class=\"bi bi-caret-down-fill caret-icon\"\r\n        ></span>\r\n      </i>\r\n      <!-- <label class=\"form-check-label\" (click)=\"select(item)\">{{\r\n        item.text\r\n      }}</label> -->\r\n      <label *ngIf=\"item.disabled\" class=\"form-check-label\">{{\r\n        item.text\r\n      }}</label>\r\n      <label *ngIf=\"!item.disabled\" class=\"form-check-label\" (click)=\"select(item)\">{{\r\n        item.text\r\n      }}</label>\r\n    </div>\r\n  </div>\r\n  <!-- Multiple -->\r\n  <div *ngIf=\"!treeview && multiple\">\r\n    <div\r\n      class=\"text-nowrap row-item\"\r\n      [ngClass]=\"{ active: item.value === this.value }\"\r\n    >\r\n      <i\r\n        *ngIf=\"item.children\"\r\n        (click)=\"onCollapseExpand()\"\r\n        aria-hidden=\"true\"\r\n        [ngSwitch]=\"item.collapsed\"\r\n      >\r\n        <span\r\n          *ngSwitchCase=\"true\"\r\n          class=\"bi bi-caret-{{ arabic ? 'left' : 'right' }}-fill caret-icon\"\r\n        ></span>\r\n        <span\r\n          *ngSwitchCase=\"false\"\r\n          class=\"bi bi-caret-down-fill caret-icon\"\r\n        ></span>\r\n      </i>\r\n      <!-- <input\r\n        class=\"multiple-checkBox\"\r\n        type=\"checkbox\"\r\n        [checked]=\"multipleSelection.includes(item.value)\"\r\n        (change)=\"selectMultiple($event.target.checked, item)\"\r\n      />\r\n\r\n      <label class=\"form-check-label\">{{ item.text }}</label> -->\r\n      <div class=\"multiple-treeview\">\r\n        <mat-checkbox\r\n          [checked]=\"multipleSelection.includes(item.value)\"\r\n          (change)=\"selectMultiple($event.checked, item)\"\r\n        >\r\n          <span> {{ item.text }} </span>\r\n        </mat-checkbox>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <!-- treeView -->\r\n  <div *ngIf=\"treeview && !treeViewAsFormControl\" class=\"tree-view-container\">\r\n    <div\r\n      (mouseenter)=\"hoverField.style.display = 'flex'\"\r\n      (mouseleave)=\"hoverField.style.display = 'none'\"\r\n      class=\"text-nowrap row-item treeview-row\"\r\n      [ngClass]=\"{ selected: item.value == selectedItem }\"\r\n    >\r\n      <i\r\n        *ngIf=\"item.children\"\r\n        (click)=\"onCollapsed(item)\"\r\n        aria-hidden=\"true\"\r\n        [ngSwitch]=\"item.collapsed\"\r\n      >\r\n        <span\r\n          *ngSwitchCase=\"true\"\r\n          class=\"bi bi-caret-{{ arabic ? 'left' : 'right' }}-fill caret-icon\"\r\n        ></span>\r\n\r\n        <span\r\n          *ngSwitchCase=\"false\"\r\n          class=\"bi bi-caret-down-fill caret-icon\"\r\n        ></span>\r\n      </i>\r\n      <label class=\"form-check-label-treeview\" (click)=\"select(item)\"\r\n        >{{ item.text }}\r\n        <span #hoverField class=\"hoverField\">\r\n          <span\r\n            type=\"button\"\r\n            matTooltip=\"{{ 'department_management.form.edit' | translate }}\"\r\n            (click)=\"onAction($event, 'update', item)\"\r\n          >\r\n            <li class=\"bi bi-pencil\"></li>\r\n          </span>\r\n\r\n          <span\r\n            type=\"button\"\r\n            matTooltip=\"{{\r\n              'department_management.form.toolTip_message' | translate\r\n            }}\"\r\n            (click)=\"onAction($event, 'add', item)\"\r\n          >\r\n            <li class=\"bi bi-plus\"></li>\r\n          </span>\r\n        </span>\r\n      </label>\r\n    </div>\r\n  </div>\r\n    <!-- treeView as form control -->\r\n    <div *ngIf=\"treeview && treeViewAsFormControl\" class=\"tree-view-container\">\r\n      <div\r\n        class=\"text-nowrap row-item treeview-row-form-control\"\r\n        [ngClass]=\"{ 'selected-form-control': item.value == selectedItem }\"\r\n      >\r\n        <i\r\n          *ngIf=\"item.children\"\r\n          (click)=\"onCollapsed(item)\"\r\n          aria-hidden=\"true\"\r\n          [ngSwitch]=\"item.collapsed\"\r\n        >\r\n          <span\r\n            *ngSwitchCase=\"true\"\r\n            class=\"bi bi-caret-{{ arabic ? 'left' : 'right' }}-fill caret-icon\"\r\n          ></span>\r\n  \r\n          <span\r\n            *ngSwitchCase=\"false\"\r\n            class=\"bi bi-caret-down-fill caret-icon\"\r\n          ></span>\r\n        </i>\r\n        <label class=\"form-check-label-treeview\" (click)=\"select(item)\"\r\n          >{{ item.text }}\r\n        </label>\r\n      </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template\r\n  #headerTemplate\r\n  let-config=\"config\"\r\n  let-item=\"item\"\r\n  let-onCollapseExpand=\"onCollapseExpand\"\r\n  let-onCheckedChange=\"onCheckedChange\"\r\n  let-onFilterTextChange=\"onFilterTextChange\"\r\n>\r\n  <div *ngIf=\"config.hasFilter\" class=\"row row-filter\">\r\n    <div class=\"col-12\">\r\n      <input\r\n        class=\"form-control\"\r\n        type=\"text\"\r\n        [placeholder]=\"i18n.getFilterPlaceholder(placeholder)\"\r\n        [(ngModel)]=\"filterText\"\r\n        (ngModelChange)=\"onFilterTextChange($event)\"\r\n      />\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"config.hasAllCheckBox || config.hasCollapseExpand\" class=\"row\">\r\n    <div class=\"col-12\">\r\n      <label *ngIf=\"config.hasAllCheckBox\" (click)=\"select(item)\">\r\n        <strong>{{ i18n.getAllCheckboxText() }}</strong>\r\n      </label>\r\n      <label\r\n        *ngIf=\"config.hasCollapseExpand\"\r\n        class=\"float-right\"\r\n        (click)=\"onCollapseExpand()\"\r\n      >\r\n        <i\r\n          [title]=\"i18n.getTooltipCollapseExpandText(item.collapsed)\"\r\n          aria-hidden=\"true\"\r\n          [ngSwitch]=\"item.collapsed\"\r\n        >\r\n          <span *ngSwitchCase=\"true\" class=\"bi bi-arrows-angle-expand\"></span>\r\n          <span\r\n            *ngSwitchCase=\"false\"\r\n            class=\"bi bi-arrows-angle-contract\"\r\n          ></span>\r\n        </i>\r\n      </label>\r\n    </div>\r\n  </div>\r\n  <a *ngIf=\"defaultSelect\" class=\"select-default\" (click)=\"selectDefault()\">{{'department_management.selectDefault'| translate}}</a>\r\n  <div *ngIf=\"config.hasDivider\" class=\"dropdown-divider\" [ngClass]=\"{'dropdown-divider-noMargin': defaultSelect}\"></div>\r\n</ng-template>\r\n\r\n<ng-container *ngIf=\"!treeview && !multiple\">\r\n  <ngx-dropdown-treeview\r\n    [config]=\"config\"\r\n    [headerTemplate]=\"headerTemplate\"\r\n    [items]=\"items\"\r\n    [itemTemplate]=\"itemTemplate\"\r\n  >\r\n  </ngx-dropdown-treeview\r\n></ng-container>\r\n<ng-container *ngIf=\"!treeview && multiple\">\r\n  <div class=\"multiple-tree-view\">\r\n    <ngx-dropdown-treeview\r\n      [config]=\"config\"\r\n      [items]=\"items\"\r\n      [itemTemplate]=\"itemTemplate\"\r\n    >\r\n    </ngx-dropdown-treeview>\r\n  </div>\r\n</ng-container>\r\n<ng-container *ngIf=\"treeview && !treeViewAsFormControl\">\r\n  <div class=\"tree-view\">\r\n    <ngx-treeview\r\n      [config]=\"config\"\r\n      [headerTemplate]=\"headerTemplate\"\r\n      [items]=\"items\"\r\n      [itemTemplate]=\"itemTemplate\"\r\n    >\r\n    </ngx-treeview>\r\n  </div>\r\n</ng-container>\r\n<ng-container *ngIf=\"treeview && treeViewAsFormControl\">\r\n  <div class=\"tree-view-form-control\">\r\n    <ngx-treeview\r\n      [config]=\"config\"\r\n      [headerTemplate]=\"headerTemplate\"\r\n      [items]=\"items\"\r\n      [itemTemplate]=\"itemTemplate\"\r\n    >\r\n    </ngx-treeview>\r\n  </div>\r\n</ng-container>\r\n"]}
|
|
314
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-treeview-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-treeview-select/dynamic-form-treeview-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewChild,\r\n  OnChanges,\r\n  ViewEncapsulation,\r\n  OnInit,\r\n  OnDestroy,\r\n} from \"@angular/core\";\r\nimport { isNil } from \"lodash\";\r\nimport {\r\n  TreeviewI18n,\r\n  TreeviewItem,\r\n  TreeviewConfig,\r\n  DropdownTreeviewComponent,\r\n  TreeviewHelper,\r\n} from \"ngx-treeview\";\r\nimport { Subject, Subscription } from \"rxjs\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\nimport { TranslationService } from \"../../../../Core/services/translation/translation.service\";\r\nimport { DepartmentManagementService } from \"../dynamic-form-department/services/department-management.service\";\r\nimport { DepartmentApiService } from \"../dynamic-form-department/services/department-api.service\";\r\nimport { DropdownTreeviewSelectI18n } from \"./dropdown-treeview-select-i18n\";\r\nimport { RolesService } from \"../../../../Core/services/roles/roles.service\";\r\nimport { NuxeoService } from \"../../../../Core/services/nuxeo/nuxeo.service\";\r\n/**\r\n * A tree view selector component that can be used in reactive and template driven forms,\r\n * it can be a flat tree or a dropdown\r\n * @title\r\n * Tree view selector\r\n *\r\n * @example\r\n * <app-dynamic-form-treeview-select\r\n * [treeview]=\"false\"\r\n * [multiple]=\"false\"\r\n * [items]=\"itemsTree\"\r\n * (valueChange)=\"onValueChange($event)\"\r\n * [(value)]=\"selectedValue\"\r\n * >\r\n * </app-dynamic-form-treeview-select>\r\n */\r\n@Component({\r\n  selector: \"app-dynamic-form-treeview-select\",\r\n  templateUrl: \"./dynamic-form-treeview-select.component.html\",\r\n  styleUrls: [\"./dynamic-form-treeview-select.component.scss\"],\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [{ provide: TreeviewI18n, useClass: DropdownTreeviewSelectI18n }],\r\n})\r\nexport class TreeviewSelectComponent implements OnInit, OnChanges, OnDestroy {\r\n  multipleSelection = [];\r\n  selectedItem;\r\n  selectedParentWithChild = [];\r\n  showPlus = false;\r\n  preSelected = [];\r\n  myDepartment: any;\r\n  /** is tree View or dropdown view */\r\n  @Input()\r\n  treeview = false;\r\n  /** use tree view inside form */\r\n  @Input()\r\n  treeViewAsFormControl = false;\r\n  /** Config object */\r\n  @Input() config: TreeviewConfig;\r\n  /** Items tree */\r\n  @Input() items: TreeviewItem[];\r\n  /** Selected value */\r\n  @Input() value: any;\r\n  /** can select multiple */\r\n  @Input() multiple: boolean = false;\r\n  /** event emitted on value change */\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  /** event emitted on plus button clicked (for department management) */\r\n  @Output() plusClicked = new EventEmitter<any>();\r\n  /** event emitted on plus button clicked (for department management) */\r\n  @Input() defaultSelect = false;\r\n/** custom page provider to get department nested tree from it can be passed from outside or not passed and use the defulte value */\r\n  @Input() pp_departmentNestedTree; \r\n  /** use outside custom function instead of the iner function  */\r\n  @Input() useCustomAddEditAction = false;\r\n    /** custom prefix to be used for adapting data coming from api */\r\n    @Input() customPrefix;\r\n  /** custom parent property name to be passed from outside the component */\r\n  @Input() customParentProperty;\r\n  @Input() placeholder;\r\n  @Output() actionClicked = new EventEmitter<any>();\r\n  @ViewChild(DropdownTreeviewComponent, { static: false })\r\n  dropdownTreeviewComponent: DropdownTreeviewComponent;\r\n  filterText: string;\r\n  arabic = false;\r\n  languageSubscription: Subscription;\r\n  onDestroy$: Subject<boolean> = new Subject<boolean>();\r\n\r\n  private dropdownTreeviewSelectI18n: DropdownTreeviewSelectI18n;\r\n\r\n  // this component is used in two places the flag is this.treeview\r\n\r\n  constructor(\r\n    public i18n: TreeviewI18n,\r\n    private translation: TranslationService,\r\n    private departmentApiService: DepartmentApiService,\r\n    private departmentManagment: DepartmentManagementService,\r\n    private rolesService: RolesService,\r\n    private nuxeoService: NuxeoService\r\n  ) {\r\n    this.config = TreeviewConfig.create({\r\n      hasAllCheckBox: false,\r\n      hasCollapseExpand: false,\r\n      hasFilter: true,\r\n      maxHeight: 200,\r\n      decoupleChildFromParent: true,\r\n    });\r\n    this.dropdownTreeviewSelectI18n = i18n as DropdownTreeviewSelectI18n;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.translation.isArabic\r\n      .pipe(takeUntil(this.onDestroy$))\r\n      .subscribe((res) => {\r\n        this.arabic = res;\r\n      });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.onDestroy$.complete();\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    if (this.items && this.treeview) {\r\n      this.updateSelectedItem();\r\n    }\r\n    if (!this.treeview && !this.multiple) {\r\n      // this. function is to set ui with pre selected value\r\n      // delay to make sure that page get the value and send it to here\r\n      // we use the value sent to here and search for its item on our items and set it as the selected item\r\n      this.items.map((item) => {\r\n        this.setPreSeletedItem(item, this.value);\r\n      });\r\n    }\r\n    if (\r\n      !this.treeview &&\r\n      this.multiple &&\r\n      this.value &&\r\n      this.value.length > 0\r\n    ) {\r\n      // this.preSelected = this.value;\r\n      this.multipleSelection = this.value;\r\n      this.dropdownTreeviewSelectI18n.selectionLength =\r\n        this.multipleSelection.length;\r\n      this.dropdownTreeviewComponent.onSelectedChange([\r\n        this.multipleSelection.length,\r\n      ]);\r\n    }\r\n  }\r\n\r\n  setPreSeletedItem(item, compareWithValue) {\r\n    if (item.value === compareWithValue) {\r\n      this.select(item);\r\n      return;\r\n    } else {\r\n      if (item.internalChildren) {\r\n        item.internalChildren.map((child) => {\r\n          this.setPreSeletedItem(child, compareWithValue);\r\n        });\r\n      } else {\r\n        return;\r\n      }\r\n    }\r\n  }\r\n  selectDefault() {\r\n    this.myDepartment = this.rolesService.getUserDepartment(\r\n      this.nuxeoService.nuxeoClient.user\r\n    );\r\n    this.items.map((item) => {\r\n      this.setPreSeletedItem(item, this.myDepartment);\r\n    });\r\n  }\r\n  select(item: TreeviewItem): void {\r\n    // if (!item.children) {\r\n    this.selectItem(item);\r\n    // }\r\n  }\r\n\r\n  private updateSelectedItem(): void {\r\n    if (!isNil(this.items)) {\r\n      const selectedItem = TreeviewHelper.findItemInList(\r\n        this.items,\r\n        this.value\r\n      );\r\n      this.selectItem(selectedItem);\r\n    }\r\n  }\r\n\r\n  private selectItem(item: TreeviewItem): void {\r\n    document.body.click();\r\n    if (this.dropdownTreeviewSelectI18n.selectedItem !== item) {\r\n      this.dropdownTreeviewSelectI18n.selectedItem = item;\r\n      if (this.dropdownTreeviewComponent) {\r\n        this.dropdownTreeviewComponent.onSelectedChange([item]);\r\n      }\r\n\r\n      if (item) {\r\n        if (this.treeview) {\r\n          this.selectedItem = item.value;\r\n          // this.valueChange.emit(item.value.title);\r\n          this.valueChange.emit(item);\r\n        } else {\r\n          this.valueChange.emit(item.value);\r\n        }\r\n      }\r\n    }\r\n  }\r\n  selectMultiple(e, item: TreeviewItem) {\r\n    this.selectedParentWithChild = [];\r\n    this.getChildernValues(item);\r\n    if (e) {\r\n      this.multipleSelection = this.multipleSelection.concat(\r\n        this.selectedParentWithChild\r\n      );\r\n    } else {\r\n      this.multipleSelection = this.multipleSelection.filter((e) => {\r\n        return this.selectedParentWithChild.indexOf(e) < 0;\r\n      });\r\n    }\r\n\r\n    this.dropdownTreeviewSelectI18n.selectionLength =\r\n      this.multipleSelection.length;\r\n    this.dropdownTreeviewComponent.onSelectedChange([\r\n      this.multipleSelection.length,\r\n    ]);\r\n    this.valueChange.emit(this.multipleSelection);\r\n  }\r\n  getChildernValues(item: TreeviewItem) {\r\n    this.selectedParentWithChild.push(item.value);\r\n    if (item.children) {\r\n      item.children.forEach((item) => {\r\n        this.getChildernValues(item);\r\n      });\r\n    } else return;\r\n  }\r\n\r\n  onPlusClicked(e: MouseEvent, item: TreeviewItem): void {\r\n    e.stopPropagation();\r\n    if (item) {\r\n      this.plusClicked.emit(item.value.uid);\r\n    }\r\n  }\r\n  /**\r\n   *\r\n   * @param e  click event\r\n   * @param action name of action (add , update)\r\n   * @param item TreeviewItem\r\n   */\r\n  onAction(e: MouseEvent, action: string, item: TreeviewItem) {\r\n    e.stopPropagation();\r\n    if (item) {\r\n      if (action === \"add\") {\r\n        // emit action to outside to execute function from outside the component \r\n        if(this.useCustomAddEditAction){\r\n          this.actionClicked.emit({\r\n            action : action,\r\n            item : item\r\n          });\r\n        }else{\r\n          this.departmentManagment\r\n            .openFormDialog(item.value.uid, false, item.value.title, item)\r\n            .subscribe((res) => {\r\n              if (res) {\r\n                this.update(item);\r\n              }\r\n            });\r\n        }\r\n      }\r\n      if (action === \"update\") {\r\n        if(this.useCustomAddEditAction){\r\n        // emit action to outside to execute function from outside the component \r\n          this.actionClicked.emit({\r\n            action : action,\r\n            item : item\r\n          });\r\n        }else{\r\n          this.departmentManagment\r\n            .openFormDialog(item.value.uid, true)\r\n            .subscribe((res) => {\r\n              // this.update(item);\r\n              this.departmentApiService.getDepartmentTree().subscribe((res) => {\r\n                this.items = this.departmentApiService.recursiveFill(\r\n                  res.entries , \r\n                  undefined , \r\n                  undefined , \r\n                  undefined , \r\n                  this.customPrefix);\r\n              });\r\n            });\r\n        }\r\n      }\r\n    }\r\n  }\r\n  \r\n  /**\r\n   *due to the business requirements which stated that more than 3 levels will existed the current api support only 3 levels so *we have to inject 3 new levels on each tree end\r\n   * @param item TreeviewItem\r\n   */\r\n  onCollapsed(item: TreeviewItem) {\r\n    item.collapsed = !item.collapsed;\r\n    if (item.value.level === 2) {\r\n      this.departmentApiService\r\n        .getDepartmentNestedTree(\r\n          item.value.title , \r\n          this.pp_departmentNestedTree ? this.pp_departmentNestedTree : 'PP_Department',\r\n          this.customParentProperty)\r\n        .subscribe(\r\n          (res) => {\r\n            item.children = this.departmentApiService.recursiveFill(\r\n              res.entries , \r\n              undefined , \r\n              undefined , \r\n              undefined , \r\n              this.customPrefix\r\n            );\r\n          },\r\n          (err) => {}\r\n        );\r\n    }\r\n  }\r\n  /**\r\n   *due to the business requirements which stated that more than 3 levels will existed the current api support only 3 levels so *we have to inject 3 new levels on each tree end\r\n   * @param item TreeviewItem\r\n   */\r\n  update(item) {\r\n    this.departmentApiService\r\n      .getDepartmentNestedTree(\r\n        item.value.title , \r\n        this.pp_departmentNestedTree ? this.pp_departmentNestedTree : 'PP_Department',\r\n        this.customParentProperty)\r\n      .subscribe(\r\n        (data) => {\r\n          item.children = this.departmentApiService.recursiveFill(\r\n            data.entries,\r\n            0,\r\n            true,\r\n            true,\r\n            this.customPrefix\r\n          );\r\n        },\r\n        (err) => {}\r\n      );\r\n  }\r\n}\r\n","<ng-template\r\n  #itemTemplate\r\n  let-item=\"item\"\r\n  let-onCollapseExpand=\"onCollapseExpand\"\r\n  let-onCheckedChange=\"onCheckedChange\"\r\n>\r\n  <!-- single -->\r\n  <div *ngIf=\"!treeview && !multiple\">\r\n    <div\r\n      class=\"text-nowrap row-item\"\r\n      [ngClass]=\"{ active: item.value === this.value }\"\r\n    >\r\n      <i\r\n        *ngIf=\"item.children\"\r\n        (click)=\"onCollapseExpand()\"\r\n        aria-hidden=\"true\"\r\n        [ngSwitch]=\"item.collapsed\"\r\n      >\r\n        <span\r\n          *ngSwitchCase=\"true\"\r\n          class=\"bi bi-caret-{{ arabic ? 'left' : 'right' }}-fill caret-icon\"\r\n        ></span>\r\n        <span\r\n          *ngSwitchCase=\"false\"\r\n          class=\"bi bi-caret-down-fill caret-icon\"\r\n        ></span>\r\n      </i>\r\n      <!-- <label class=\"form-check-label\" (click)=\"select(item)\">{{\r\n        item.text\r\n      }}</label> -->\r\n      <label *ngIf=\"item.disabled\" class=\"form-check-label\">{{\r\n        item.text\r\n      }}</label>\r\n      <label *ngIf=\"!item.disabled\" class=\"form-check-label\" (click)=\"select(item)\">{{\r\n        item.text\r\n      }}</label>\r\n    </div>\r\n  </div>\r\n  <!-- Multiple -->\r\n  <div *ngIf=\"!treeview && multiple\">\r\n    <div\r\n      class=\"text-nowrap row-item\"\r\n      [ngClass]=\"{ active: item.value === this.value }\"\r\n    >\r\n      <i\r\n        *ngIf=\"item.children\"\r\n        (click)=\"onCollapseExpand()\"\r\n        aria-hidden=\"true\"\r\n        [ngSwitch]=\"item.collapsed\"\r\n      >\r\n        <span\r\n          *ngSwitchCase=\"true\"\r\n          class=\"bi bi-caret-{{ arabic ? 'left' : 'right' }}-fill caret-icon\"\r\n        ></span>\r\n        <span\r\n          *ngSwitchCase=\"false\"\r\n          class=\"bi bi-caret-down-fill caret-icon\"\r\n        ></span>\r\n      </i>\r\n      <!-- <input\r\n        class=\"multiple-checkBox\"\r\n        type=\"checkbox\"\r\n        [checked]=\"multipleSelection.includes(item.value)\"\r\n        (change)=\"selectMultiple($event.target.checked, item)\"\r\n      />\r\n\r\n      <label class=\"form-check-label\">{{ item.text }}</label> -->\r\n      <div class=\"multiple-treeview\">\r\n        <mat-checkbox\r\n          [checked]=\"multipleSelection.includes(item.value)\"\r\n          (change)=\"selectMultiple($event.checked, item)\"\r\n        >\r\n          <span> {{ item.text }} </span>\r\n        </mat-checkbox>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <!-- treeView -->\r\n  <div *ngIf=\"treeview && !treeViewAsFormControl\" class=\"tree-view-container\">\r\n    <div\r\n      (mouseenter)=\"hoverField.style.display = 'flex'\"\r\n      (mouseleave)=\"hoverField.style.display = 'none'\"\r\n      class=\"text-nowrap row-item treeview-row\"\r\n      [ngClass]=\"{ selected: item.value == selectedItem }\"\r\n    >\r\n      <i\r\n        *ngIf=\"item.children\"\r\n        (click)=\"onCollapsed(item)\"\r\n        aria-hidden=\"true\"\r\n        [ngSwitch]=\"item.collapsed\"\r\n      >\r\n        <span\r\n          *ngSwitchCase=\"true\"\r\n          class=\"bi bi-caret-{{ arabic ? 'left' : 'right' }}-fill caret-icon\"\r\n        ></span>\r\n\r\n        <span\r\n          *ngSwitchCase=\"false\"\r\n          class=\"bi bi-caret-down-fill caret-icon\"\r\n        ></span>\r\n      </i>\r\n      <label class=\"form-check-label-treeview\" (click)=\"select(item)\"\r\n        >{{ item.text }}\r\n        <span #hoverField class=\"hoverField\">\r\n          <span\r\n            type=\"button\"\r\n            matTooltip=\"{{ 'department_management.form.edit' | translate }}\"\r\n            (click)=\"onAction($event, 'update', item)\"\r\n          >\r\n            <li class=\"bi bi-pencil\"></li>\r\n          </span>\r\n\r\n          <span\r\n            type=\"button\"\r\n            matTooltip=\"{{\r\n              'department_management.form.toolTip_message' | translate\r\n            }}\"\r\n            (click)=\"onAction($event, 'add', item)\"\r\n          >\r\n            <li class=\"bi bi-plus\"></li>\r\n          </span>\r\n        </span>\r\n      </label>\r\n    </div>\r\n  </div>\r\n    <!-- treeView as form control -->\r\n    <div *ngIf=\"treeview && treeViewAsFormControl\" class=\"tree-view-container\">\r\n      <div\r\n        class=\"text-nowrap row-item treeview-row-form-control\"\r\n        [ngClass]=\"{ 'selected-form-control': item.value == selectedItem }\"\r\n      >\r\n        <i\r\n          *ngIf=\"item.children\"\r\n          (click)=\"onCollapsed(item)\"\r\n          aria-hidden=\"true\"\r\n          [ngSwitch]=\"item.collapsed\"\r\n        >\r\n          <span\r\n            *ngSwitchCase=\"true\"\r\n            class=\"bi bi-caret-{{ arabic ? 'left' : 'right' }}-fill caret-icon\"\r\n          ></span>\r\n  \r\n          <span\r\n            *ngSwitchCase=\"false\"\r\n            class=\"bi bi-caret-down-fill caret-icon\"\r\n          ></span>\r\n        </i>\r\n        <label class=\"form-check-label-treeview\" (click)=\"select(item)\"\r\n          >{{ item.text }}\r\n        </label>\r\n      </div>\r\n    </div>\r\n</ng-template>\r\n<ng-template\r\n  #headerTemplate\r\n  let-config=\"config\"\r\n  let-item=\"item\"\r\n  let-onCollapseExpand=\"onCollapseExpand\"\r\n  let-onCheckedChange=\"onCheckedChange\"\r\n  let-onFilterTextChange=\"onFilterTextChange\"\r\n>\r\n  <div *ngIf=\"config.hasFilter\" class=\"row row-filter\">\r\n    <div class=\"col-12\">\r\n      <input\r\n        class=\"form-control\"\r\n        type=\"text\"\r\n        [placeholder]=\"i18n.getFilterPlaceholder(placeholder)\"\r\n        [(ngModel)]=\"filterText\"\r\n        (ngModelChange)=\"onFilterTextChange($event)\"\r\n      />\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"config.hasAllCheckBox || config.hasCollapseExpand\" class=\"row\">\r\n    <div class=\"col-12\">\r\n      <label *ngIf=\"config.hasAllCheckBox\" (click)=\"select(item)\">\r\n        <strong>{{ i18n.getAllCheckboxText() }}</strong>\r\n      </label>\r\n      <label\r\n        *ngIf=\"config.hasCollapseExpand\"\r\n        class=\"float-right\"\r\n        (click)=\"onCollapseExpand()\"\r\n      >\r\n        <i\r\n          [title]=\"i18n.getTooltipCollapseExpandText(item.collapsed)\"\r\n          aria-hidden=\"true\"\r\n          [ngSwitch]=\"item.collapsed\"\r\n        >\r\n          <span *ngSwitchCase=\"true\" class=\"bi bi-arrows-angle-expand\"></span>\r\n          <span\r\n            *ngSwitchCase=\"false\"\r\n            class=\"bi bi-arrows-angle-contract\"\r\n          ></span>\r\n        </i>\r\n      </label>\r\n    </div>\r\n  </div>\r\n  <a *ngIf=\"defaultSelect\" class=\"select-default\" (click)=\"selectDefault()\">{{'department_management.selectDefault'| translate}}</a>\r\n  <div *ngIf=\"config.hasDivider\" class=\"dropdown-divider\" [ngClass]=\"{'dropdown-divider-noMargin': defaultSelect}\"></div>\r\n</ng-template>\r\n\r\n<ng-container *ngIf=\"!treeview && !multiple\">\r\n  <ngx-dropdown-treeview\r\n    [config]=\"config\"\r\n    [headerTemplate]=\"headerTemplate\"\r\n    [items]=\"items\"\r\n    [itemTemplate]=\"itemTemplate\"\r\n  >\r\n  </ngx-dropdown-treeview\r\n></ng-container>\r\n<ng-container *ngIf=\"!treeview && multiple\">\r\n  <div class=\"multiple-tree-view\">\r\n    <ngx-dropdown-treeview\r\n      [config]=\"config\"\r\n      [items]=\"items\"\r\n      [itemTemplate]=\"itemTemplate\"\r\n    >\r\n    </ngx-dropdown-treeview>\r\n  </div>\r\n</ng-container>\r\n<ng-container *ngIf=\"treeview && !treeViewAsFormControl\">\r\n  <div class=\"tree-view\">\r\n    <ngx-treeview\r\n      [config]=\"config\"\r\n      [headerTemplate]=\"headerTemplate\"\r\n      [items]=\"items\"\r\n      [itemTemplate]=\"itemTemplate\"\r\n    >\r\n    </ngx-treeview>\r\n  </div>\r\n</ng-container>\r\n<ng-container *ngIf=\"treeview && treeViewAsFormControl\">\r\n  <div class=\"tree-view-form-control\">\r\n    <ngx-treeview\r\n      [config]=\"config\"\r\n      [headerTemplate]=\"headerTemplate\"\r\n      [items]=\"items\"\r\n      [itemTemplate]=\"itemTemplate\"\r\n    >\r\n    </ngx-treeview>\r\n  </div>\r\n</ng-container>\r\n"]}
|