@mediusinc/mng-commons-audit 4.2.0 → 5.0.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +12 -26
- package/esm2022/lib/api/models/entityChange.mjs +10 -10
- package/esm2022/lib/api/models/guiEntityModel.mjs +10 -10
- package/esm2022/lib/api/models/guiPropertyModel.mjs +10 -10
- package/esm2022/lib/api/models/guiPropertyType.mjs +13 -13
- package/esm2022/lib/api/models/guiRelationModel.mjs +10 -10
- package/esm2022/lib/api/models/revEntityWithChangesDto.mjs +10 -10
- package/esm2022/lib/api/models/revEntityWithStateDto.mjs +10 -10
- package/esm2022/lib/api/models/revisionType.mjs +11 -9
- package/esm2022/lib/api/services/audit-revisions-api.service.mjs +29 -20
- package/esm2022/lib/api/services/audit.service.mjs +12 -11
- package/esm2022/lib/audit.routes.mjs +17 -19
- package/esm2022/lib/components/entity-changes-field/entity-changes-field.component.mjs +17 -14
- package/esm2022/lib/components/pages/audit/audit.page.component.mjs +7 -7
- package/esm2022/lib/components/pages/entity-revisions/audit-entity-revisions.page.component.mjs +114 -99
- package/esm2022/lib/components/pages/revisions/audit-revisions.page.component.mjs +61 -70
- package/esm2022/lib/models/config.model.mjs +1 -1
- package/esm2022/lib/models/entity-revision-change-state.model.mjs +6 -6
- package/esm2022/lib/models/entity-revision-changes.model.mjs +6 -6
- package/esm2022/lib/models/guiEntityModelWithI18n.model.mjs +7 -7
- package/esm2022/lib/models/rev-entity-detailed.model.mjs +7 -7
- package/esm2022/lib/models/rev-entity.model.mjs +6 -6
- package/esm2022/lib/models/revEntityWithId.model.mjs +8 -8
- package/esm2022/lib/service/module-config.token.mjs +2 -2
- package/esm2022/lib/utils/audit.util.mjs +66 -117
- package/fesm2022/mediusinc-mng-commons-audit.mjs +386 -442
- package/fesm2022/mediusinc-mng-commons-audit.mjs.map +1 -1
- package/lib/api/models/entityChange.d.ts +4 -4
- package/lib/api/models/guiEntityModel.d.ts +4 -4
- package/lib/api/models/guiPropertyModel.d.ts +6 -6
- package/lib/api/models/guiPropertyType.d.ts +1 -1
- package/lib/api/models/guiRelationModel.d.ts +2 -2
- package/lib/api/models/revEntityWithChangesDto.d.ts +4 -4
- package/lib/api/models/revEntityWithStateDto.d.ts +4 -4
- package/lib/api/models/revisionType.d.ts +2 -1
- package/lib/api/services/audit-revisions-api.service.d.ts +14 -13
- package/lib/api/services/audit.service.d.ts +7 -7
- package/lib/audit.routes.d.ts +5 -5
- package/lib/components/entity-changes-field/entity-changes-field.component.d.ts +6 -6
- package/lib/components/pages/audit/audit.page.component.d.ts +3 -3
- package/lib/components/pages/entity-revisions/audit-entity-revisions.page.component.d.ts +24 -23
- package/lib/components/pages/revisions/audit-revisions.page.component.d.ts +11 -14
- package/lib/models/config.model.d.ts +1 -1
- package/lib/models/entity-revision-change-state.model.d.ts +3 -3
- package/lib/models/entity-revision-changes.model.d.ts +3 -3
- package/lib/models/guiEntityModelWithI18n.model.d.ts +2 -2
- package/lib/models/rev-entity-detailed.model.d.ts +4 -4
- package/lib/models/rev-entity.model.d.ts +2 -2
- package/lib/models/revEntityWithId.model.d.ts +2 -2
- package/lib/service/module-config.token.d.ts +2 -2
- package/lib/utils/audit.util.d.ts +17 -14
- package/package.json +3 -2
- package/esm2022/lib/models/new-filter-match-type.model.mjs +0 -19
- package/lib/models/new-filter-match-type.model.d.ts +0 -17
- /package/{assets/i18n → i18n}/en.json +0 -0
- /package/{assets/i18n → i18n}/sl.json +0 -0
|
@@ -1,42 +1,40 @@
|
|
|
1
|
-
import { RouteBuilder, RoutesBuilder
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
1
|
+
import { RouteBuilder, RoutesBuilder } from '@mediusinc/mng-commons/core';
|
|
2
|
+
import { TableviewRouteBuilder } from '@mediusinc/mng-commons/tableview';
|
|
3
|
+
import { AuditService } from './api/services/audit.service';
|
|
4
|
+
import { AuditPageComponent } from './components/pages/audit/audit.page.component';
|
|
5
|
+
import { AuditEntityRevisionsPageComponent } from './components/pages/entity-revisions/audit-entity-revisions.page.component';
|
|
6
|
+
import { AuditRevisionsPageComponent } from './components/pages/revisions/audit-revisions.page.component';
|
|
7
|
+
import { COMMONS_AUDIT_MODULE_CONFIG_IT } from './service/module-config.token';
|
|
8
8
|
/**
|
|
9
9
|
* Provides routes for the mng-commons-audit functionalities.
|
|
10
10
|
* @param config Module config for audit section.
|
|
11
11
|
* @param routeConfig Optionally provide route configs.
|
|
12
12
|
*/
|
|
13
|
-
export function
|
|
14
|
-
const routeBuilder = RouteBuilder.create('', config.rootPageComponent ??
|
|
15
|
-
.withProvider(
|
|
16
|
-
.withProvider(MngAuditService)
|
|
17
|
-
.withProvider(MngAuditRevisionsApiService)
|
|
13
|
+
export function provideAuditRoutes(config, routeConfig) {
|
|
14
|
+
const routeBuilder = RouteBuilder.create('', config.rootPageComponent ?? AuditPageComponent)
|
|
15
|
+
.withProvider(AuditService)
|
|
18
16
|
.withProvider({
|
|
19
|
-
provide:
|
|
17
|
+
provide: COMMONS_AUDIT_MODULE_CONFIG_IT,
|
|
20
18
|
useValue: config
|
|
21
19
|
})
|
|
22
20
|
.addChildBuilder(RouteBuilder.createRedirect('', routeConfig?.defaultRedirect ?? 'revisions', 'full'));
|
|
23
21
|
if (routeConfig?.preRevisionRoutes?.length) {
|
|
24
22
|
routeConfig.preRevisionRoutes.forEach(r => routeBuilder.addChildBuilder(r));
|
|
25
23
|
}
|
|
26
|
-
const revisionsRouteBuilder = TableviewRouteBuilder.fromComponent('revisions', config.revisionsPageComponent ??
|
|
24
|
+
const revisionsRouteBuilder = TableviewRouteBuilder.fromComponent('revisions', config.revisionsPageComponent ?? AuditRevisionsPageComponent)
|
|
27
25
|
.withTitle('pages.revisions.title')
|
|
28
26
|
.withAdd(false)
|
|
29
27
|
.withDelete(false)
|
|
30
28
|
.withEdit(false);
|
|
31
29
|
if (routeConfig?.revisionsMenuItem) {
|
|
32
|
-
revisionsRouteBuilder.
|
|
30
|
+
revisionsRouteBuilder.withCommonsMenuItem(routeConfig.revisionsMenuItem);
|
|
33
31
|
}
|
|
34
32
|
else {
|
|
35
33
|
revisionsRouteBuilder.withMenuItem('pi pi-book', 'pages.revisions.title');
|
|
36
34
|
}
|
|
37
|
-
const entityRevisionsRouteBuilder = RouteBuilder.create('entity-revisions', config.entityRevisionsPageComponent ??
|
|
35
|
+
const entityRevisionsRouteBuilder = RouteBuilder.create('entity-revisions', config.entityRevisionsPageComponent ?? AuditEntityRevisionsPageComponent).withTitle('pages.entityRevisions.title');
|
|
38
36
|
if (routeConfig?.entityRevisionsMenuItem) {
|
|
39
|
-
entityRevisionsRouteBuilder.
|
|
37
|
+
entityRevisionsRouteBuilder.withCommonsMenuItem(routeConfig.entityRevisionsMenuItem);
|
|
40
38
|
}
|
|
41
39
|
else {
|
|
42
40
|
entityRevisionsRouteBuilder.withMenuItem('pi pi-building', 'pages.entityRevisions.title');
|
|
@@ -44,10 +42,10 @@ export function provideMngAuditRoutes(config, routeConfig) {
|
|
|
44
42
|
routeBuilder
|
|
45
43
|
.addChildBuilder(revisionsRouteBuilder)
|
|
46
44
|
.addChildBuilder(entityRevisionsRouteBuilder)
|
|
47
|
-
.addChildBuilder(TableviewRouteBuilder.fromComponent('entity-revisions/:entityClass', config.entityRevisionsPageComponent ??
|
|
45
|
+
.addChildBuilder(TableviewRouteBuilder.fromComponent('entity-revisions/:entityClass', config.entityRevisionsPageComponent ?? AuditEntityRevisionsPageComponent).withTitle('pages.entityRevisions.title'));
|
|
48
46
|
if (routeConfig?.postRevisionRoutes?.length) {
|
|
49
47
|
routeConfig.postRevisionRoutes.forEach(r => routeBuilder.addChildBuilder(r));
|
|
50
48
|
}
|
|
51
49
|
return RoutesBuilder.create().addRouteBuilder(routeBuilder).build();
|
|
52
50
|
}
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXVkaXQucm91dGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9hdWRpdC5yb3V0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFrQixZQUFZLEVBQUUsYUFBYSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDekYsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFFdkUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQzFELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLCtDQUErQyxDQUFDO0FBQ2pGLE9BQU8sRUFBQyxpQ0FBaUMsRUFBQyxNQUFNLDJFQUEyRSxDQUFDO0FBQzVILE9BQU8sRUFBQywyQkFBMkIsRUFBQyxNQUFNLDZEQUE2RCxDQUFDO0FBRXhHLE9BQU8sRUFBQyw4QkFBOEIsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBRTdFOzs7O0dBSUc7QUFDSCxNQUFNLFVBQVUsa0JBQWtCLENBQzlCLE1BQWdDLEVBQ2hDLFdBTUM7SUFFRCxNQUFNLFlBQVksR0FBRyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxNQUFNLENBQUMsaUJBQWlCLElBQUksa0JBQWtCLENBQUM7U0FDdkYsWUFBWSxDQUFDLFlBQVksQ0FBQztTQUMxQixZQUFZLENBQUM7UUFDVixPQUFPLEVBQUUsOEJBQThCO1FBQ3ZDLFFBQVEsRUFBRSxNQUFNO0tBQ25CLENBQUM7U0FDRCxlQUFlLENBQUMsWUFBWSxDQUFDLGNBQWMsQ0FBQyxFQUFFLEVBQUUsV0FBVyxFQUFFLGVBQWUsSUFBSSxXQUFXLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztJQUUzRyxJQUFJLFdBQVcsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLEVBQUU7UUFDeEMsV0FBVyxDQUFDLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztLQUMvRTtJQUVELE1BQU0scUJBQXFCLEdBQUcscUJBQXFCLENBQUMsYUFBYSxDQUFDLFdBQVcsRUFBRSxNQUFNLENBQUMsc0JBQXNCLElBQUksMkJBQTJCLENBQUM7U0FDdkksU0FBUyxDQUFDLHVCQUF1QixDQUFDO1NBQ2xDLE9BQU8sQ0FBQyxLQUFLLENBQUM7U0FDZCxVQUFVLENBQUMsS0FBSyxDQUFDO1NBQ2pCLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNyQixJQUFJLFdBQVcsRUFBRSxpQkFBaUIsRUFBRTtRQUNoQyxxQkFBcUIsQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQUMsQ0FBQztLQUM1RTtTQUFNO1FBQ0gscUJBQXFCLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSx1QkFBdUIsQ0FBQyxDQUFDO0tBQzdFO0lBRUQsTUFBTSwyQkFBMkIsR0FBRyxZQUFZLENBQUMsTUFBTSxDQUFDLGtCQUFrQixFQUFFLE1BQU0sQ0FBQyw0QkFBNEIsSUFBSSxpQ0FBaUMsQ0FBQyxDQUFDLFNBQVMsQ0FDM0osNkJBQTZCLENBQ2hDLENBQUM7SUFDRixJQUFJLFdBQVcsRUFBRSx1QkFBdUIsRUFBRTtRQUN0QywyQkFBMkIsQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUMsdUJBQXVCLENBQUMsQ0FBQztLQUN4RjtTQUFNO1FBQ0gsMkJBQTJCLENBQUMsWUFBWSxDQUFDLGdCQUFnQixFQUFFLDZCQUE2QixDQUFDLENBQUM7S0FDN0Y7SUFFRCxZQUFZO1NBQ1AsZUFBZSxDQUFDLHFCQUFxQixDQUFDO1NBQ3RDLGVBQWUsQ0FBQywyQkFBMkIsQ0FBQztTQUM1QyxlQUFlLENBQ1oscUJBQXFCLENBQUMsYUFBYSxDQUFDLCtCQUErQixFQUFFLE1BQU0sQ0FBQyw0QkFBNEIsSUFBSSxpQ0FBaUMsQ0FBQyxDQUFDLFNBQVMsQ0FDcEosNkJBQTZCLENBQ2hDLENBQ0osQ0FBQztJQUVOLElBQUksV0FBVyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sRUFBRTtRQUN6QyxXQUFXLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ2hGO0lBRUQsT0FBTyxhQUFhLENBQUMsTUFBTSxFQUFFLENBQUMsZUFBZSxDQUFDLFlBQVksQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO0FBQ3hFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1JvdXRlc30gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcblxuaW1wb3J0IHtDb21tb25zTWVudUl0ZW0sIFJvdXRlQnVpbGRlciwgUm91dGVzQnVpbGRlcn0gZnJvbSAnQG1lZGl1c2luYy9tbmctY29tbW9ucy9jb3JlJztcbmltcG9ydCB7VGFibGV2aWV3Um91dGVCdWlsZGVyfSBmcm9tICdAbWVkaXVzaW5jL21uZy1jb21tb25zL3RhYmxldmlldyc7XG5cbmltcG9ydCB7QXVkaXRTZXJ2aWNlfSBmcm9tICcuL2FwaS9zZXJ2aWNlcy9hdWRpdC5zZXJ2aWNlJztcbmltcG9ydCB7QXVkaXRQYWdlQ29tcG9uZW50fSBmcm9tICcuL2NvbXBvbmVudHMvcGFnZXMvYXVkaXQvYXVkaXQucGFnZS5jb21wb25lbnQnO1xuaW1wb3J0IHtBdWRpdEVudGl0eVJldmlzaW9uc1BhZ2VDb21wb25lbnR9IGZyb20gJy4vY29tcG9uZW50cy9wYWdlcy9lbnRpdHktcmV2aXNpb25zL2F1ZGl0LWVudGl0eS1yZXZpc2lvbnMucGFnZS5jb21wb25lbnQnO1xuaW1wb3J0IHtBdWRpdFJldmlzaW9uc1BhZ2VDb21wb25lbnR9IGZyb20gJy4vY29tcG9uZW50cy9wYWdlcy9yZXZpc2lvbnMvYXVkaXQtcmV2aXNpb25zLnBhZ2UuY29tcG9uZW50JztcbmltcG9ydCB7Q29tbW9uc0F1ZGl0TW9kdWxlQ29uZmlnfSBmcm9tICcuL21vZGVscy9jb25maWcubW9kZWwnO1xuaW1wb3J0IHtDT01NT05TX0FVRElUX01PRFVMRV9DT05GSUdfSVR9IGZyb20gJy4vc2VydmljZS9tb2R1bGUtY29uZmlnLnRva2VuJztcblxuLyoqXG4gKiBQcm92aWRlcyByb3V0ZXMgZm9yIHRoZSBtbmctY29tbW9ucy1hdWRpdCBmdW5jdGlvbmFsaXRpZXMuXG4gKiBAcGFyYW0gY29uZmlnIE1vZHVsZSBjb25maWcgZm9yIGF1ZGl0IHNlY3Rpb24uXG4gKiBAcGFyYW0gcm91dGVDb25maWcgT3B0aW9uYWxseSBwcm92aWRlIHJvdXRlIGNvbmZpZ3MuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlQXVkaXRSb3V0ZXMoXG4gICAgY29uZmlnOiBDb21tb25zQXVkaXRNb2R1bGVDb25maWcsXG4gICAgcm91dGVDb25maWc/OiB7XG4gICAgICAgIGRlZmF1bHRSZWRpcmVjdD86IHN0cmluZztcbiAgICAgICAgcHJlUmV2aXNpb25Sb3V0ZXM/OiBSb3V0ZUJ1aWxkZXJbXTtcbiAgICAgICAgcG9zdFJldmlzaW9uUm91dGVzPzogUm91dGVCdWlsZGVyW107XG4gICAgICAgIHJldmlzaW9uc01lbnVJdGVtPzogQ29tbW9uc01lbnVJdGVtO1xuICAgICAgICBlbnRpdHlSZXZpc2lvbnNNZW51SXRlbT86IENvbW1vbnNNZW51SXRlbTtcbiAgICB9XG4pOiBSb3V0ZXMge1xuICAgIGNvbnN0IHJvdXRlQnVpbGRlciA9IFJvdXRlQnVpbGRlci5jcmVhdGUoJycsIGNvbmZpZy5yb290UGFnZUNvbXBvbmVudCA/PyBBdWRpdFBhZ2VDb21wb25lbnQpXG4gICAgICAgIC53aXRoUHJvdmlkZXIoQXVkaXRTZXJ2aWNlKVxuICAgICAgICAud2l0aFByb3ZpZGVyKHtcbiAgICAgICAgICAgIHByb3ZpZGU6IENPTU1PTlNfQVVESVRfTU9EVUxFX0NPTkZJR19JVCxcbiAgICAgICAgICAgIHVzZVZhbHVlOiBjb25maWdcbiAgICAgICAgfSlcbiAgICAgICAgLmFkZENoaWxkQnVpbGRlcihSb3V0ZUJ1aWxkZXIuY3JlYXRlUmVkaXJlY3QoJycsIHJvdXRlQ29uZmlnPy5kZWZhdWx0UmVkaXJlY3QgPz8gJ3JldmlzaW9ucycsICdmdWxsJykpO1xuXG4gICAgaWYgKHJvdXRlQ29uZmlnPy5wcmVSZXZpc2lvblJvdXRlcz8ubGVuZ3RoKSB7XG4gICAgICAgIHJvdXRlQ29uZmlnLnByZVJldmlzaW9uUm91dGVzLmZvckVhY2gociA9PiByb3V0ZUJ1aWxkZXIuYWRkQ2hpbGRCdWlsZGVyKHIpKTtcbiAgICB9XG5cbiAgICBjb25zdCByZXZpc2lvbnNSb3V0ZUJ1aWxkZXIgPSBUYWJsZXZpZXdSb3V0ZUJ1aWxkZXIuZnJvbUNvbXBvbmVudCgncmV2aXNpb25zJywgY29uZmlnLnJldmlzaW9uc1BhZ2VDb21wb25lbnQgPz8gQXVkaXRSZXZpc2lvbnNQYWdlQ29tcG9uZW50KVxuICAgICAgICAud2l0aFRpdGxlKCdwYWdlcy5yZXZpc2lvbnMudGl0bGUnKVxuICAgICAgICAud2l0aEFkZChmYWxzZSlcbiAgICAgICAgLndpdGhEZWxldGUoZmFsc2UpXG4gICAgICAgIC53aXRoRWRpdChmYWxzZSk7XG4gICAgaWYgKHJvdXRlQ29uZmlnPy5yZXZpc2lvbnNNZW51SXRlbSkge1xuICAgICAgICByZXZpc2lvbnNSb3V0ZUJ1aWxkZXIud2l0aENvbW1vbnNNZW51SXRlbShyb3V0ZUNvbmZpZy5yZXZpc2lvbnNNZW51SXRlbSk7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgcmV2aXNpb25zUm91dGVCdWlsZGVyLndpdGhNZW51SXRlbSgncGkgcGktYm9vaycsICdwYWdlcy5yZXZpc2lvbnMudGl0bGUnKTtcbiAgICB9XG5cbiAgICBjb25zdCBlbnRpdHlSZXZpc2lvbnNSb3V0ZUJ1aWxkZXIgPSBSb3V0ZUJ1aWxkZXIuY3JlYXRlKCdlbnRpdHktcmV2aXNpb25zJywgY29uZmlnLmVudGl0eVJldmlzaW9uc1BhZ2VDb21wb25lbnQgPz8gQXVkaXRFbnRpdHlSZXZpc2lvbnNQYWdlQ29tcG9uZW50KS53aXRoVGl0bGUoXG4gICAgICAgICdwYWdlcy5lbnRpdHlSZXZpc2lvbnMudGl0bGUnXG4gICAgKTtcbiAgICBpZiAocm91dGVDb25maWc/LmVudGl0eVJldmlzaW9uc01lbnVJdGVtKSB7XG4gICAgICAgIGVudGl0eVJldmlzaW9uc1JvdXRlQnVpbGRlci53aXRoQ29tbW9uc01lbnVJdGVtKHJvdXRlQ29uZmlnLmVudGl0eVJldmlzaW9uc01lbnVJdGVtKTtcbiAgICB9IGVsc2Uge1xuICAgICAgICBlbnRpdHlSZXZpc2lvbnNSb3V0ZUJ1aWxkZXIud2l0aE1lbnVJdGVtKCdwaSBwaS1idWlsZGluZycsICdwYWdlcy5lbnRpdHlSZXZpc2lvbnMudGl0bGUnKTtcbiAgICB9XG5cbiAgICByb3V0ZUJ1aWxkZXJcbiAgICAgICAgLmFkZENoaWxkQnVpbGRlcihyZXZpc2lvbnNSb3V0ZUJ1aWxkZXIpXG4gICAgICAgIC5hZGRDaGlsZEJ1aWxkZXIoZW50aXR5UmV2aXNpb25zUm91dGVCdWlsZGVyKVxuICAgICAgICAuYWRkQ2hpbGRCdWlsZGVyKFxuICAgICAgICAgICAgVGFibGV2aWV3Um91dGVCdWlsZGVyLmZyb21Db21wb25lbnQoJ2VudGl0eS1yZXZpc2lvbnMvOmVudGl0eUNsYXNzJywgY29uZmlnLmVudGl0eVJldmlzaW9uc1BhZ2VDb21wb25lbnQgPz8gQXVkaXRFbnRpdHlSZXZpc2lvbnNQYWdlQ29tcG9uZW50KS53aXRoVGl0bGUoXG4gICAgICAgICAgICAgICAgJ3BhZ2VzLmVudGl0eVJldmlzaW9ucy50aXRsZSdcbiAgICAgICAgICAgIClcbiAgICAgICAgKTtcblxuICAgIGlmIChyb3V0ZUNvbmZpZz8ucG9zdFJldmlzaW9uUm91dGVzPy5sZW5ndGgpIHtcbiAgICAgICAgcm91dGVDb25maWcucG9zdFJldmlzaW9uUm91dGVzLmZvckVhY2gociA9PiByb3V0ZUJ1aWxkZXIuYWRkQ2hpbGRCdWlsZGVyKHIpKTtcbiAgICB9XG5cbiAgICByZXR1cm4gUm91dGVzQnVpbGRlci5jcmVhdGUoKS5hZGRSb3V0ZUJ1aWxkZXIocm91dGVCdWlsZGVyKS5idWlsZCgpO1xufVxuIl19
|
|
@@ -1,14 +1,17 @@
|
|
|
1
1
|
import { AsyncPipe } from '@angular/common';
|
|
2
|
-
import { Component, DestroyRef, Injector, Input, inject } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, DestroyRef, Injector, Input, inject } from '@angular/core';
|
|
3
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
4
|
import { BehaviorSubject } from 'rxjs';
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
5
|
+
import { CommonsInternalError } from '@mediusinc/mng-commons/core';
|
|
6
|
+
import { TableComponent } from '@mediusinc/mng-commons/table';
|
|
7
|
+
import { TableDescriptor, TablePaginationModeEnum } from '@mediusinc/mng-commons/table/api';
|
|
8
|
+
import { AFormlyCustomFieldComponent } from '@mediusinc/mng-commons/tableview/api';
|
|
9
|
+
import { RevisionTypeDto, revisionTypeEnum } from '../../api/models/revisionType';
|
|
10
|
+
import { AuditService } from '../../api/services/audit.service';
|
|
11
|
+
import { EntityRevisionChangeState } from '../../models/entity-revision-change-state.model';
|
|
9
12
|
import { AuditUtil } from '../../utils/audit.util';
|
|
10
13
|
import * as i0 from "@angular/core";
|
|
11
|
-
export class EntityChangesFieldComponent extends
|
|
14
|
+
export class EntityChangesFieldComponent extends AFormlyCustomFieldComponent {
|
|
12
15
|
constructor() {
|
|
13
16
|
super(...arguments);
|
|
14
17
|
this.destroyRef = inject(DestroyRef);
|
|
@@ -19,7 +22,7 @@ export class EntityChangesFieldComponent extends AMngFormlyCustomFieldComponent
|
|
|
19
22
|
ngOnInit() {
|
|
20
23
|
this.fieldValue = this.formControl.value;
|
|
21
24
|
this.injector
|
|
22
|
-
?.get(
|
|
25
|
+
?.get(AuditService, undefined, { optional: true })
|
|
23
26
|
?.auditModel$.pipe(takeUntilDestroyed(this.destroyRef))
|
|
24
27
|
.subscribe({
|
|
25
28
|
next: model => {
|
|
@@ -30,13 +33,13 @@ export class EntityChangesFieldComponent extends AMngFormlyCustomFieldComponent
|
|
|
30
33
|
}
|
|
31
34
|
},
|
|
32
35
|
error: err => {
|
|
33
|
-
throw new
|
|
36
|
+
throw new CommonsInternalError('Error while trying to fetch audit model from audit service', { name: 'EntityChangesFieldComponentError', cause: err });
|
|
34
37
|
}
|
|
35
38
|
});
|
|
36
39
|
}
|
|
37
40
|
createDescriptor(entityChanges) {
|
|
38
41
|
const changedFields = [];
|
|
39
|
-
if (entityChanges.items && entityChanges.items[0].revType ===
|
|
42
|
+
if (entityChanges.items && entityChanges.items[0].revType === RevisionTypeDto.Mod) {
|
|
40
43
|
for (const key in entityChanges.items[0]) {
|
|
41
44
|
if (entityChanges.items[0][key] !== entityChanges.items[1][key]) {
|
|
42
45
|
changedFields.push(key);
|
|
@@ -44,11 +47,11 @@ export class EntityChangesFieldComponent extends AMngFormlyCustomFieldComponent
|
|
|
44
47
|
}
|
|
45
48
|
}
|
|
46
49
|
const guiEntityModel = this.auditModel.filter(m => m.entityName === entityChanges.entityType)[0];
|
|
47
|
-
const desc = TableDescriptor.fromClass(
|
|
50
|
+
const desc = TableDescriptor.fromClass(EntityRevisionChangeState, undefined, undefined, guiEntityModel.entityName).withClassName('py-2');
|
|
48
51
|
if (guiEntityModel.entityName) {
|
|
49
52
|
desc.withTitle(guiEntityModel.entityName);
|
|
50
53
|
}
|
|
51
|
-
desc.
|
|
54
|
+
desc.addColumnEnum('revType', revisionTypeEnum).withTitle('MngEntityRevisionChangeState.properties.revType');
|
|
52
55
|
if (guiEntityModel.properties) {
|
|
53
56
|
AuditUtil.addColumnsFromModel(desc, guiEntityModel.properties, undefined, false, false);
|
|
54
57
|
}
|
|
@@ -65,12 +68,12 @@ export class EntityChangesFieldComponent extends AMngFormlyCustomFieldComponent
|
|
|
65
68
|
return desc;
|
|
66
69
|
}
|
|
67
70
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EntityChangesFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
68
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.1", type: EntityChangesFieldComponent, isStandalone: true, selector: "mng-entity-changes-field", inputs: { injector: "injector" }, usesInheritance: true, ngImport: i0, template: "@if (modelFetched | async) {\n <div>\n @for (ec of entityChanges; track ec) {\n <mng-table [items]=\"ec.items\" [descriptor]=\"createDescriptor(ec)\"></mng-table>\n }\n </div>\n} @else {\n <div class=\"text-center\">\n <i class=\"pi pi-spin pi-spinner\" style=\"font-size: 2rem\"></i>\n </div>\n}\n", styles: ["::ng-deep tr.audit-row-deleted{background:#ff3d331a!important}::ng-deep tr.audit-row-deleted .audit-cell{background:#f6544c4d!important}::ng-deep tr.audit-row-added{background-color:#1bc5621a!important}::ng-deep tr.audit-row-added .audit-cell{background:#1bc5624d!important}\n"], dependencies: [{ kind: "component", type:
|
|
71
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.1", type: EntityChangesFieldComponent, isStandalone: true, selector: "mng-entity-changes-field", inputs: { injector: "injector" }, usesInheritance: true, ngImport: i0, template: "@if (modelFetched | async) {\n <div>\n @for (ec of entityChanges; track ec) {\n <mng-table [items]=\"ec.items\" [descriptor]=\"createDescriptor(ec)\"></mng-table>\n }\n </div>\n} @else {\n <div class=\"text-center\">\n <i class=\"pi pi-spin pi-spinner\" style=\"font-size: 2rem\"></i>\n </div>\n}\n", styles: ["::ng-deep tr.audit-row-deleted{background:#ff3d331a!important}::ng-deep tr.audit-row-deleted .audit-cell{background:#f6544c4d!important}::ng-deep tr.audit-row-added{background-color:#1bc5621a!important}::ng-deep tr.audit-row-added .audit-cell{background:#1bc5624d!important}\n"], dependencies: [{ kind: "component", type: TableComponent, selector: "mng-table", inputs: ["descriptor", "items", "result", "loading", "dataProvider", "useQueryParams", "selectionMode", "selectionEnabled", "columnLastMinWidth", "captionComponent", "columnCustomLastComponent", "globalFilterFields"], outputs: ["tableLoad", "cellClick", "selectionChange", "captionComponentInstance", "columnCustomLastComponentInstance"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
69
72
|
}
|
|
70
73
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EntityChangesFieldComponent, decorators: [{
|
|
71
74
|
type: Component,
|
|
72
|
-
args: [{ standalone: true, selector: 'mng-entity-changes-field', imports: [
|
|
75
|
+
args: [{ standalone: true, selector: 'mng-entity-changes-field', imports: [TableComponent, AsyncPipe], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (modelFetched | async) {\n <div>\n @for (ec of entityChanges; track ec) {\n <mng-table [items]=\"ec.items\" [descriptor]=\"createDescriptor(ec)\"></mng-table>\n }\n </div>\n} @else {\n <div class=\"text-center\">\n <i class=\"pi pi-spin pi-spinner\" style=\"font-size: 2rem\"></i>\n </div>\n}\n", styles: ["::ng-deep tr.audit-row-deleted{background:#ff3d331a!important}::ng-deep tr.audit-row-deleted .audit-cell{background:#f6544c4d!important}::ng-deep tr.audit-row-added{background-color:#1bc5621a!important}::ng-deep tr.audit-row-added .audit-cell{background:#1bc5624d!important}\n"] }]
|
|
73
76
|
}], propDecorators: { injector: [{
|
|
74
77
|
type: Input
|
|
75
78
|
}] } });
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-changes-field.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/entity-changes-field/entity-changes-field.component.ts","../../../../../src/lib/components/entity-changes-field/entity-changes-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {Component, DestroyRef, Injector, Input, OnInit, inject} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\nimport {BehaviorSubject} from 'rxjs';\n\nimport {AMngFormlyCustomFieldComponent, MngInternalError, MngTableComponent, TableDescriptor, TablePaginationModeEnum} from '@mediusinc/mng-commons';\n\nimport {MngEntityChangeDto} from '../../api/models/entityChange';\nimport {MngGuiEntityModelDto} from '../../api/models/guiEntityModel';\nimport {MngRevisionTypeDto} from '../../api/models/revisionType';\nimport {MngAuditService} from '../../api/services/audit.service';\nimport {MngEntityRevisionChangeState} from '../../models/entity-revision-change-state.model';\nimport {MngEntityRevisionChanges} from '../../models/entity-revision-changes.model';\nimport {AuditUtil} from '../../utils/audit.util';\n\n@Component({\n    standalone: true,\n    selector: 'mng-entity-changes-field',\n    imports: [MngTableComponent, AsyncPipe],\n    styleUrls: ['entity-changes-field.component.scss'],\n    templateUrl: 'entity-changes-field.component.html'\n})\nexport class EntityChangesFieldComponent extends AMngFormlyCustomFieldComponent implements OnInit {\n    @Input() public injector?: Injector;\n\n    private destroyRef = inject(DestroyRef);\n\n    public entityChanges: MngEntityRevisionChanges[] = [];\n    public modelFetched = new BehaviorSubject(false);\n\n    private auditModel: MngGuiEntityModelDto[] = [];\n    private fieldValue?: {[key: string]: Array<MngEntityChangeDto>};\n\n    ngOnInit(): void {\n        this.fieldValue = this.formControl.value as {[key: string]: Array<MngEntityChangeDto>};\n        this.injector\n            ?.get(MngAuditService, undefined, {optional: true})\n            ?.auditModel$.pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe({\n                next: model => {\n                    this.auditModel = model;\n                    if (this.fieldValue) {\n                        this.entityChanges = AuditUtil.mapItemsToEntityChangesArray(this.fieldValue);\n                        this.modelFetched.next(true);\n                    }\n                },\n                error: err => {\n                    throw new MngInternalError('Error while trying to fetch audit model from audit service', {name: 'EntityChangesFieldComponentError', cause: err});\n                }\n            });\n    }\n\n    public createDescriptor(entityChanges: MngEntityRevisionChanges) {\n        const changedFields: string[] = [];\n        if (entityChanges.items && entityChanges.items[0].revType === MngRevisionTypeDto.Mod) {\n            for (const key in entityChanges.items[0]) {\n                if (entityChanges.items[0][key] !== entityChanges.items[1][key]) {\n                    changedFields.push(key);\n                }\n            }\n        }\n\n        const guiEntityModel = this.auditModel.filter(m => m.entityName === entityChanges.entityType)[0];\n\n        const desc = TableDescriptor.fromClass(MngEntityRevisionChangeState, undefined, undefined, guiEntityModel.entityName).withClassName('py-2');\n        if (guiEntityModel.entityName) {\n            desc.withTitle(guiEntityModel.entityName);\n        }\n\n        desc.addColumn('revType').withTitle('MngEntityRevisionChangeState.properties.revType').asEnum(MngRevisionTypeDto);\n\n        if (guiEntityModel.properties) {\n            AuditUtil.addColumnsFromModel(desc, guiEntityModel.properties, undefined, false, false);\n        }\n\n        desc.withRowClassName(undefined, (_, item) => (item ? (item.color === 'green' ? 'audit-row-added' : 'audit-row-deleted') : ''));\n        desc.columns.forEach(col => {\n            if (changedFields.length > 0 && changedFields.some(val => col.property === val)) {\n                col.withClassName('audit-cell');\n            }\n        });\n\n        desc.withPaginationMode(TablePaginationModeEnum.Pagination);\n        desc.withCurrentColumnsReorderable();\n        desc.withCurrentColumnsToggleable();\n        desc.withTrackProperty(`EntityChangeField_${entityChanges.entityType ?? 'default'}`);\n\n        return desc;\n    }\n}\n","@if (modelFetched | async) {\n    <div>\n        @for (ec of entityChanges; track ec) {\n            <mng-table [items]=\"ec.items\" [descriptor]=\"createDescriptor(ec)\"></mng-table>\n        }\n    </div>\n} @else {\n    <div class=\"text-center\">\n        <i class=\"pi pi-spin pi-spinner\" style=\"font-size: 2rem\"></i>\n    </div>\n}\n"]}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-changes-field.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/entity-changes-field/entity-changes-field.component.ts","../../../../../src/lib/components/entity-changes-field/entity-changes-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, DestroyRef, Injector, Input, OnInit, inject} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\nimport {BehaviorSubject} from 'rxjs';\n\nimport {CommonsInternalError} from '@mediusinc/mng-commons/core';\nimport {TableComponent} from '@mediusinc/mng-commons/table';\nimport {TableDescriptor, TablePaginationModeEnum} from '@mediusinc/mng-commons/table/api';\nimport {AFormlyCustomFieldComponent} from '@mediusinc/mng-commons/tableview/api';\n\nimport {EntityChangeDto} from '../../api/models/entityChange';\nimport {GuiEntityModelDto} from '../../api/models/guiEntityModel';\nimport {RevisionTypeDto, revisionTypeEnum} from '../../api/models/revisionType';\nimport {AuditService} from '../../api/services/audit.service';\nimport {EntityRevisionChangeState} from '../../models/entity-revision-change-state.model';\nimport {EntityRevisionChanges} from '../../models/entity-revision-changes.model';\nimport {AuditUtil} from '../../utils/audit.util';\n\n@Component({\n    standalone: true,\n    selector: 'mng-entity-changes-field',\n    imports: [TableComponent, AsyncPipe],\n    styleUrls: ['entity-changes-field.component.scss'],\n    templateUrl: 'entity-changes-field.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class EntityChangesFieldComponent extends AFormlyCustomFieldComponent implements OnInit {\n    @Input() public injector?: Injector;\n\n    private destroyRef = inject(DestroyRef);\n\n    public entityChanges: EntityRevisionChanges[] = [];\n    public modelFetched = new BehaviorSubject(false);\n\n    private auditModel: GuiEntityModelDto[] = [];\n    private fieldValue?: {[key: string]: Array<EntityChangeDto>};\n\n    ngOnInit(): void {\n        this.fieldValue = this.formControl.value as {[key: string]: Array<EntityChangeDto>};\n        this.injector\n            ?.get(AuditService, undefined, {optional: true})\n            ?.auditModel$.pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe({\n                next: model => {\n                    this.auditModel = model;\n                    if (this.fieldValue) {\n                        this.entityChanges = AuditUtil.mapItemsToEntityChangesArray(this.fieldValue);\n                        this.modelFetched.next(true);\n                    }\n                },\n                error: err => {\n                    throw new CommonsInternalError('Error while trying to fetch audit model from audit service', {name: 'EntityChangesFieldComponentError', cause: err});\n                }\n            });\n    }\n\n    public createDescriptor(entityChanges: EntityRevisionChanges) {\n        const changedFields: string[] = [];\n        if (entityChanges.items && entityChanges.items[0].revType === RevisionTypeDto.Mod) {\n            for (const key in entityChanges.items[0]) {\n                if (entityChanges.items[0][key] !== entityChanges.items[1][key]) {\n                    changedFields.push(key);\n                }\n            }\n        }\n\n        const guiEntityModel = this.auditModel.filter(m => m.entityName === entityChanges.entityType)[0];\n\n        const desc = TableDescriptor.fromClass(EntityRevisionChangeState, undefined, undefined, guiEntityModel.entityName).withClassName('py-2');\n        if (guiEntityModel.entityName) {\n            desc.withTitle(guiEntityModel.entityName);\n        }\n\n        desc.addColumnEnum('revType', revisionTypeEnum).withTitle('MngEntityRevisionChangeState.properties.revType');\n\n        if (guiEntityModel.properties) {\n            AuditUtil.addColumnsFromModel(desc, guiEntityModel.properties, undefined, false, false);\n        }\n\n        desc.withRowClassName(undefined, (_, item) => (item ? (item.color === 'green' ? 'audit-row-added' : 'audit-row-deleted') : ''));\n        desc.columns.forEach(col => {\n            if (changedFields.length > 0 && changedFields.some(val => col.property === val)) {\n                col.withClassName('audit-cell');\n            }\n        });\n\n        desc.withPaginationMode(TablePaginationModeEnum.Pagination);\n        desc.withCurrentColumnsReorderable();\n        desc.withCurrentColumnsToggleable();\n        desc.withTrackProperty(`EntityChangeField_${entityChanges.entityType ?? 'default'}`);\n\n        return desc;\n    }\n}\n","@if (modelFetched | async) {\n    <div>\n        @for (ec of entityChanges; track ec) {\n            <mng-table [items]=\"ec.items\" [descriptor]=\"createDescriptor(ec)\"></mng-table>\n        }\n    </div>\n} @else {\n    <div class=\"text-center\">\n        <i class=\"pi pi-spin pi-spinner\" style=\"font-size: 2rem\"></i>\n    </div>\n}\n"]}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
2
|
import { RouterOutlet } from '@angular/router';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
export class
|
|
5
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type:
|
|
6
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type:
|
|
4
|
+
export class AuditPageComponent {
|
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AuditPageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
6
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: AuditPageComponent, isStandalone: true, selector: "mng-audit-page", ngImport: i0, template: "<router-outlet></router-outlet>\n", dependencies: [{ kind: "directive", type: RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
7
7
|
}
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type:
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AuditPageComponent, decorators: [{
|
|
9
9
|
type: Component,
|
|
10
|
-
args: [{ standalone: true, selector: 'mng-audit-page', imports: [RouterOutlet], template: "<router-outlet></router-outlet>\n" }]
|
|
10
|
+
args: [{ standalone: true, selector: 'mng-audit-page', imports: [RouterOutlet], changeDetection: ChangeDetectionStrategy.OnPush, template: "<router-outlet></router-outlet>\n" }]
|
|
11
11
|
}] });
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXVkaXQucGFnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvcGFnZXMvYXVkaXQvYXVkaXQucGFnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvcGFnZXMvYXVkaXQvYXVkaXQucGFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ2pFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQzs7QUFTN0MsTUFBTSxPQUFPLGtCQUFrQjs4R0FBbEIsa0JBQWtCO2tHQUFsQixrQkFBa0IsMEVDVi9CLG1DQUNBLDRDREtjLFlBQVk7OzJGQUliLGtCQUFrQjtrQkFQOUIsU0FBUztpQ0FDTSxJQUFJLFlBQ04sZ0JBQWdCLFdBQ2pCLENBQUMsWUFBWSxDQUFDLG1CQUVOLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtSb3V0ZXJPdXRsZXR9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICdtbmctYXVkaXQtcGFnZScsXG4gICAgaW1wb3J0czogW1JvdXRlck91dGxldF0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2F1ZGl0LnBhZ2UuY29tcG9uZW50Lmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEF1ZGl0UGFnZUNvbXBvbmVudCB7fVxuIiwiPHJvdXRlci1vdXRsZXQ+PC9yb3V0ZXItb3V0bGV0PlxuIl19
|