@alfresco/adf-process-services 8.1.0-16320806191 → 9.1.0-16312921641
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/fesm2022/adf-process-services.mjs +297 -301
- package/fesm2022/adf-process-services.mjs.map +1 -1
- package/package.json +4 -6
- package/esm2022/adf-process-services.mjs +0 -5
- package/esm2022/lib/app-list/apps-list.component.mjs +0 -195
- package/esm2022/lib/app-list/icon.model.mjs +0 -166
- package/esm2022/lib/app-list/index.mjs +0 -18
- package/esm2022/lib/app-list/public-api.mjs +0 -23
- package/esm2022/lib/app-list/select-apps-dialog/select-apps-dialog.component.mjs +0 -53
- package/esm2022/lib/attachment/create-process-attachment/create-process-attachment.component.mjs +0 -73
- package/esm2022/lib/attachment/create-task-attachment/create-task-attachment.component.mjs +0 -73
- package/esm2022/lib/attachment/index.mjs +0 -18
- package/esm2022/lib/attachment/process-attachment-list/process-attachment-list.component.mjs +0 -197
- package/esm2022/lib/attachment/public-api.mjs +0 -31
- package/esm2022/lib/attachment/task-attachment-list/task-attachment-list.component.mjs +0 -196
- package/esm2022/lib/compat/types.mjs +0 -18
- package/esm2022/lib/form/events/validate-dynamic-table-row.event.mjs +0 -26
- package/esm2022/lib/form/form-custom-outcomes.component.mjs +0 -31
- package/esm2022/lib/form/form-list/form-list.component.mjs +0 -50
- package/esm2022/lib/form/form.component.mjs +0 -346
- package/esm2022/lib/form/index.mjs +0 -18
- package/esm2022/lib/form/model/form-definition.model.mjs +0 -92
- package/esm2022/lib/form/process-form-rendering.service.mjs +0 -55
- package/esm2022/lib/form/public-api.mjs +0 -32
- package/esm2022/lib/form/services/activiti-alfresco.service.mjs +0 -113
- package/esm2022/lib/form/services/ecm-model.service.mjs +0 -156
- package/esm2022/lib/form/services/editor.service.mjs +0 -87
- package/esm2022/lib/form/services/external-alfresco-api.service.mjs +0 -57
- package/esm2022/lib/form/services/index.mjs +0 -26
- package/esm2022/lib/form/services/model.service.mjs +0 -130
- package/esm2022/lib/form/services/process-content.service.mjs +0 -223
- package/esm2022/lib/form/services/process-definition.service.mjs +0 -93
- package/esm2022/lib/form/services/task-form.service.mjs +0 -127
- package/esm2022/lib/form/services/task.service.mjs +0 -77
- package/esm2022/lib/form/start-form/start-form.component.mjs +0 -141
- package/esm2022/lib/form/widgets/content-widget/attach-file-widget-dialog-component.interface.mjs +0 -18
- package/esm2022/lib/form/widgets/content-widget/attach-file-widget-dialog.component.mjs +0 -115
- package/esm2022/lib/form/widgets/content-widget/attach-file-widget-dialog.service.mjs +0 -100
- package/esm2022/lib/form/widgets/content-widget/attach-file-widget.component.mjs +0 -254
- package/esm2022/lib/form/widgets/content-widget/attach-folder-widget.component.mjs +0 -93
- package/esm2022/lib/form/widgets/content-widget/index.mjs +0 -18
- package/esm2022/lib/form/widgets/content-widget/public-api.mjs +0 -22
- package/esm2022/lib/form/widgets/document/content.widget.mjs +0 -125
- package/esm2022/lib/form/widgets/document/document.widget.mjs +0 -61
- package/esm2022/lib/form/widgets/dropdown/dropdown.widget.mjs +0 -182
- package/esm2022/lib/form/widgets/dynamic-table/dynamic-table.widget.mjs +0 -192
- package/esm2022/lib/form/widgets/dynamic-table/editors/amount/amount.editor.mjs +0 -47
- package/esm2022/lib/form/widgets/dynamic-table/editors/boolean/boolean.editor.mjs +0 -42
- package/esm2022/lib/form/widgets/dynamic-table/editors/date/date.editor.mjs +0 -84
- package/esm2022/lib/form/widgets/dynamic-table/editors/datetime/datetime.editor.mjs +0 -84
- package/esm2022/lib/form/widgets/dynamic-table/editors/dropdown/dropdown.editor.mjs +0 -95
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/cell-validator.model.mjs +0 -18
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/date-cell-validator-model.mjs +0 -47
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-row-validation-summary.model.mjs +0 -24
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-table-column-option.model.mjs +0 -18
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-table-column.model.mjs +0 -18
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-table-row.model.mjs +0 -18
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-table.widget.model.mjs +0 -159
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/number-cell-validator.model.mjs +0 -45
- package/esm2022/lib/form/widgets/dynamic-table/editors/models/required-cell-validator.model.mjs +0 -40
- package/esm2022/lib/form/widgets/dynamic-table/editors/row-editor/row.editor.mjs +0 -89
- package/esm2022/lib/form/widgets/dynamic-table/editors/text/text.editor.mjs +0 -47
- package/esm2022/lib/form/widgets/dynamic-table/index.mjs +0 -18
- package/esm2022/lib/form/widgets/dynamic-table/public-api.mjs +0 -44
- package/esm2022/lib/form/widgets/file-viewer/file-viewer.widget.mjs +0 -46
- package/esm2022/lib/form/widgets/functional-group/functional-group.widget.mjs +0 -167
- package/esm2022/lib/form/widgets/index.mjs +0 -18
- package/esm2022/lib/form/widgets/people/people.widget.mjs +0 -169
- package/esm2022/lib/form/widgets/public-api.mjs +0 -54
- package/esm2022/lib/form/widgets/radio-buttons/radio-buttons.widget.mjs +0 -97
- package/esm2022/lib/form/widgets/typeahead/typeahead.widget.mjs +0 -152
- package/esm2022/lib/form/widgets/upload/upload.widget.mjs +0 -128
- package/esm2022/lib/people/components/people/people.component.mjs +0 -124
- package/esm2022/lib/people/components/people-list/people-list.component.mjs +0 -74
- package/esm2022/lib/people/components/people-search/people-search.component.mjs +0 -83
- package/esm2022/lib/people/components/people-search-field/people-search-field.component.mjs +0 -90
- package/esm2022/lib/people/components/people-selector/people-selector.component.mjs +0 -76
- package/esm2022/lib/people/helpers/get-display-user.mjs +0 -22
- package/esm2022/lib/people/index.mjs +0 -18
- package/esm2022/lib/people/interfaces/perform-search-callback.interface.mjs +0 -18
- package/esm2022/lib/people/public-api.mjs +0 -35
- package/esm2022/lib/process-comments/index.mjs +0 -21
- package/esm2022/lib/process-comments/process-comments.component.mjs +0 -45
- package/esm2022/lib/process-comments/services/comment-process.service.mjs +0 -77
- package/esm2022/lib/process-list/components/process-audit/process-audit.directive.mjs +0 -105
- package/esm2022/lib/process-list/components/process-filters/process-filters.component.mjs +0 -211
- package/esm2022/lib/process-list/components/process-instance-details/process-instance-details.component.mjs +0 -142
- package/esm2022/lib/process-list/components/process-instance-header/process-instance-header.component.mjs +0 -123
- package/esm2022/lib/process-list/components/process-instance-tasks/process-instance-tasks.component.mjs +0 -163
- package/esm2022/lib/process-list/components/process-list/process-list.component.mjs +0 -327
- package/esm2022/lib/process-list/components/start-process/start-process.component.mjs +0 -423
- package/esm2022/lib/process-list/index.mjs +0 -18
- package/esm2022/lib/process-list/public-api.mjs +0 -44
- package/esm2022/lib/process-list/services/process-filter.service.mjs +0 -182
- package/esm2022/lib/process-list/services/process.service.mjs +0 -259
- package/esm2022/lib/process.module.mjs +0 -132
- package/esm2022/lib/services/apps-process.service.mjs +0 -58
- package/esm2022/lib/services/people-process.service.mjs +0 -124
- package/esm2022/lib/services/task-comments.service.mjs +0 -65
- package/esm2022/lib/task-comments/index.mjs +0 -21
- package/esm2022/lib/task-comments/task-comments.component.mjs +0 -44
- package/esm2022/lib/task-list/components/attach-form/attach-form.component.mjs +0 -127
- package/esm2022/lib/task-list/components/checklist/checklist.component.mjs +0 -140
- package/esm2022/lib/task-list/components/start-task/start-task.component.mjs +0 -221
- package/esm2022/lib/task-list/components/task-details/task-details.component.mjs +0 -360
- package/esm2022/lib/task-list/components/task-filters/task-filters.component.mjs +0 -261
- package/esm2022/lib/task-list/components/task-form/claim-task.directive.mjs +0 -77
- package/esm2022/lib/task-list/components/task-form/task-form.component.mjs +0 -313
- package/esm2022/lib/task-list/components/task-form/unclaim-task.directive.mjs +0 -77
- package/esm2022/lib/task-list/components/task-header/task-header.component.mjs +0 -361
- package/esm2022/lib/task-list/components/task-list/task-list.component.mjs +0 -359
- package/esm2022/lib/task-list/components/task-standalone/task-standalone.component.mjs +0 -82
- package/esm2022/lib/task-list/index.mjs +0 -18
- package/esm2022/lib/task-list/models/form.model.mjs +0 -26
- package/esm2022/lib/task-list/models/task-details.event.mjs +0 -32
- package/esm2022/lib/task-list/models/task-preset.model.mjs +0 -41
- package/esm2022/lib/task-list/models/user-event.model.mjs +0 -18
- package/esm2022/lib/task-list/models/user-group.model.mjs +0 -18
- package/esm2022/lib/task-list/public-api.mjs +0 -60
- package/esm2022/lib/task-list/services/process-upload.service.mjs +0 -42
- package/esm2022/lib/task-list/services/task-filter.service.mjs +0 -249
- package/esm2022/lib/task-list/services/task-upload.service.mjs +0 -42
- package/esm2022/lib/task-list/services/tasklist.service.mjs +0 -251
- package/esm2022/lib/task-list/validators/task-description.validator.mjs +0 -26
- package/esm2022/public-api.mjs +0 -30
|
@@ -1,211 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.
|
|
4
|
-
*
|
|
5
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
-
* you may not use this file except in compliance with the License.
|
|
7
|
-
* You may obtain a copy of the License at
|
|
8
|
-
*
|
|
9
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
-
*
|
|
11
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
-
* See the License for the specific language governing permissions and
|
|
15
|
-
* limitations under the License.
|
|
16
|
-
*/
|
|
17
|
-
import { Component, DestroyRef, EventEmitter, inject, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
18
|
-
import { ProcessFilterService } from '../../services/process-filter.service';
|
|
19
|
-
import { AppsProcessService } from '../../../services/apps-process.service';
|
|
20
|
-
import { IconModel } from '../../../app-list/icon.model';
|
|
21
|
-
import { NavigationStart, Router } from '@angular/router';
|
|
22
|
-
import { filter } from 'rxjs/operators';
|
|
23
|
-
import { CommonModule, Location } from '@angular/common';
|
|
24
|
-
import { TranslatePipe } from '@ngx-translate/core';
|
|
25
|
-
import { MatButtonModule } from '@angular/material/button';
|
|
26
|
-
import { IconComponent } from '@alfresco/adf-core';
|
|
27
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
28
|
-
import * as i0 from "@angular/core";
|
|
29
|
-
import * as i1 from "../../services/process-filter.service";
|
|
30
|
-
import * as i2 from "../../../services/apps-process.service";
|
|
31
|
-
import * as i3 from "@angular/router";
|
|
32
|
-
import * as i4 from "@angular/common";
|
|
33
|
-
import * as i5 from "@angular/material/button";
|
|
34
|
-
export class ProcessFiltersComponent {
|
|
35
|
-
constructor(processFilterService, appsProcessService, router, location) {
|
|
36
|
-
this.processFilterService = processFilterService;
|
|
37
|
-
this.appsProcessService = appsProcessService;
|
|
38
|
-
this.router = router;
|
|
39
|
-
this.location = location;
|
|
40
|
-
/** Emitted when a filter is being clicked from the UI. */
|
|
41
|
-
this.filterClicked = new EventEmitter();
|
|
42
|
-
/** Emitted when the list of filters has been successfully loaded from the server. */
|
|
43
|
-
this.success = new EventEmitter();
|
|
44
|
-
/** Emitted when an error occurs. */
|
|
45
|
-
this.error = new EventEmitter();
|
|
46
|
-
/** Toggle to show or hide the filter's icon. */
|
|
47
|
-
this.showIcon = true;
|
|
48
|
-
/** Emitted when a filter is being selected based on the filterParam input. */
|
|
49
|
-
this.filterSelected = new EventEmitter();
|
|
50
|
-
this.filters = [];
|
|
51
|
-
this.active = false;
|
|
52
|
-
this.destroyRef = inject(DestroyRef);
|
|
53
|
-
}
|
|
54
|
-
ngOnInit() {
|
|
55
|
-
this.iconsMDL = new IconModel();
|
|
56
|
-
this.router.events
|
|
57
|
-
.pipe(filter((event) => event instanceof NavigationStart), takeUntilDestroyed(this.destroyRef))
|
|
58
|
-
.subscribe((navigationStart) => {
|
|
59
|
-
const activeRoute = navigationStart.url;
|
|
60
|
-
this.isProcessActive = activeRoute.includes('processes');
|
|
61
|
-
});
|
|
62
|
-
const currentRoute = this.location.path();
|
|
63
|
-
this.isProcessRoute = currentRoute.includes('processes');
|
|
64
|
-
}
|
|
65
|
-
ngOnChanges(changes) {
|
|
66
|
-
const appId = changes['appId'];
|
|
67
|
-
const appName = changes['appName'];
|
|
68
|
-
const filterParam = changes['filterParam'];
|
|
69
|
-
if (appId && (appId.currentValue || appId.currentValue === null)) {
|
|
70
|
-
this.getFiltersByAppId(appId.currentValue);
|
|
71
|
-
}
|
|
72
|
-
else if (appName?.currentValue) {
|
|
73
|
-
this.getFiltersByAppName(appName.currentValue);
|
|
74
|
-
}
|
|
75
|
-
else if (filterParam && filterParam.currentValue !== filterParam.previousValue) {
|
|
76
|
-
this.selectProcessFilter(filterParam.currentValue);
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
isActiveRoute(filterActive) {
|
|
80
|
-
return (this.isProcessActive || this.isProcessRoute) && this.currentFilter === filterActive;
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* Return the filter list filtered by appId
|
|
84
|
-
*
|
|
85
|
-
* @param appId - optional
|
|
86
|
-
*/
|
|
87
|
-
getFiltersByAppId(appId) {
|
|
88
|
-
this.processFilterService.getProcessFilters(appId).subscribe((res) => {
|
|
89
|
-
if (res.length === 0 && this.isFilterListEmpty()) {
|
|
90
|
-
this.processFilterService.createDefaultFilters(appId).subscribe((resDefault) => {
|
|
91
|
-
this.resetFilter();
|
|
92
|
-
this.filters = resDefault;
|
|
93
|
-
this.selectProcessFilter(this.filterParam);
|
|
94
|
-
this.success.emit(resDefault);
|
|
95
|
-
}, (errDefault) => {
|
|
96
|
-
this.error.emit(errDefault);
|
|
97
|
-
});
|
|
98
|
-
}
|
|
99
|
-
else {
|
|
100
|
-
this.resetFilter();
|
|
101
|
-
this.filters = res;
|
|
102
|
-
this.selectProcessFilter(this.filterParam);
|
|
103
|
-
this.success.emit(res);
|
|
104
|
-
}
|
|
105
|
-
}, (err) => {
|
|
106
|
-
this.error.emit(err);
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
/**
|
|
110
|
-
* Return the filter list filtered by appName
|
|
111
|
-
*
|
|
112
|
-
* @param appName application name
|
|
113
|
-
*/
|
|
114
|
-
getFiltersByAppName(appName) {
|
|
115
|
-
this.appsProcessService.getDeployedApplicationsByName(appName).subscribe((application) => {
|
|
116
|
-
this.getFiltersByAppId(application.id);
|
|
117
|
-
this.selectProcessFilter(this.filterParam);
|
|
118
|
-
}, (err) => {
|
|
119
|
-
this.error.emit(err);
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
/**
|
|
123
|
-
* Pass the selected filter as next
|
|
124
|
-
*
|
|
125
|
-
* @param filterModel filter model
|
|
126
|
-
*/
|
|
127
|
-
selectFilter(filterModel) {
|
|
128
|
-
this.currentFilter = filterModel;
|
|
129
|
-
this.active = true;
|
|
130
|
-
this.filterClicked.emit(filterModel);
|
|
131
|
-
}
|
|
132
|
-
/**
|
|
133
|
-
* Select the first filter of a list if present
|
|
134
|
-
*
|
|
135
|
-
* @param filterParam filter parameter
|
|
136
|
-
*/
|
|
137
|
-
selectProcessFilter(filterParam) {
|
|
138
|
-
if (filterParam) {
|
|
139
|
-
const newFilter = this.filters.find((processFilter, index) => filterParam.index === index ||
|
|
140
|
-
filterParam.id === processFilter.id ||
|
|
141
|
-
(filterParam.name && filterParam.name.toLocaleLowerCase() === processFilter.name.toLocaleLowerCase()));
|
|
142
|
-
this.currentFilter = newFilter;
|
|
143
|
-
if (newFilter) {
|
|
144
|
-
this.filterSelected.emit(newFilter);
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
/**
|
|
149
|
-
* Select the Running filter
|
|
150
|
-
*
|
|
151
|
-
* @deprecated in 3.9.0, Use the filterParam Input() with a running filter instance instead
|
|
152
|
-
*/
|
|
153
|
-
selectRunningFilter() {
|
|
154
|
-
this.selectProcessFilter(this.processFilterService.getRunningFilterInstance(null));
|
|
155
|
-
}
|
|
156
|
-
/**
|
|
157
|
-
* Get the current task
|
|
158
|
-
*
|
|
159
|
-
* @returns process instance filter
|
|
160
|
-
*/
|
|
161
|
-
getCurrentFilter() {
|
|
162
|
-
return this.currentFilter;
|
|
163
|
-
}
|
|
164
|
-
/**
|
|
165
|
-
* Check if the filter list is empty
|
|
166
|
-
*
|
|
167
|
-
* @returns `true` if filter list is empty, otherwise `false`
|
|
168
|
-
*/
|
|
169
|
-
isFilterListEmpty() {
|
|
170
|
-
return this.filters === undefined || (this.filters && this.filters.length === 0);
|
|
171
|
-
}
|
|
172
|
-
/**
|
|
173
|
-
* Get the material icons equivalent of the glyphicon icon
|
|
174
|
-
*
|
|
175
|
-
* @param icon glyphicon name
|
|
176
|
-
* @returns material icons equivalent of the icon
|
|
177
|
-
*/
|
|
178
|
-
getFilterIcon(icon) {
|
|
179
|
-
return this.iconsMDL.mapGlyphiconToMaterialDesignIcons(icon);
|
|
180
|
-
}
|
|
181
|
-
/**
|
|
182
|
-
* Reset the filters properties
|
|
183
|
-
*/
|
|
184
|
-
resetFilter() {
|
|
185
|
-
this.filters = [];
|
|
186
|
-
this.currentFilter = undefined;
|
|
187
|
-
}
|
|
188
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProcessFiltersComponent, deps: [{ token: i1.ProcessFilterService }, { token: i2.AppsProcessService }, { token: i3.Router }, { token: i4.Location }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
189
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ProcessFiltersComponent, isStandalone: true, selector: "adf-process-instance-filters", inputs: { filterParam: "filterParam", appId: "appId", appName: "appName", showIcon: "showIcon" }, outputs: { filterClicked: "filterClicked", success: "success", error: "error", filterSelected: "filterSelected" }, usesOnChanges: true, ngImport: i0, template: "<div *ngFor=\"let filter of filters\" class=\"adf-filters__entry\" [class.adf-active]=\"isActiveRoute(filter)\">\n <button\n (click)=\"selectFilter(filter)\"\n [attr.aria-label]=\"filter.name | translate\"\n [id]=\"filter.id\"\n [attr.data-automation-id]=\"filter.name + '_filter'\"\n mat-button\n class=\"adf-filter-action-button adf-full-width\">\n <adf-icon data-automation-id=\"adf-filter-icon\" *ngIf=\"showIcon\" [value]=\"getFilterIcon(filter.icon)\" />\n <span data-automation-id=\"adf-filter-label\" class=\"adf-filter-action-button__label\">{{ filter.name | translate }}</span>\n </button>\n</div>\n", styles: ["adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button){padding:0;width:100%;cursor:pointer;font-size:var(--theme-body-1-font-size);font-weight:700}adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button) .adf-full-width{display:flex;width:100%}adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button) .adf-filter-action-button{align-items:center;height:32px;justify-content:flex-start}adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button) .adf-filter-action-button .adf-filter-action-button__label{padding-left:20px;margin:0 8px;color:var(--theme-action-button-text-color)}adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button).adf-active .adf-filter-action-button__label{color:var(--adf-sidenav-active-text-color)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: IconComponent, selector: "adf-icon", inputs: ["color", "fontSet", "value"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
190
|
-
}
|
|
191
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProcessFiltersComponent, decorators: [{
|
|
192
|
-
type: Component,
|
|
193
|
-
args: [{ selector: 'adf-process-instance-filters', standalone: true, imports: [CommonModule, TranslatePipe, MatButtonModule, IconComponent], encapsulation: ViewEncapsulation.None, template: "<div *ngFor=\"let filter of filters\" class=\"adf-filters__entry\" [class.adf-active]=\"isActiveRoute(filter)\">\n <button\n (click)=\"selectFilter(filter)\"\n [attr.aria-label]=\"filter.name | translate\"\n [id]=\"filter.id\"\n [attr.data-automation-id]=\"filter.name + '_filter'\"\n mat-button\n class=\"adf-filter-action-button adf-full-width\">\n <adf-icon data-automation-id=\"adf-filter-icon\" *ngIf=\"showIcon\" [value]=\"getFilterIcon(filter.icon)\" />\n <span data-automation-id=\"adf-filter-label\" class=\"adf-filter-action-button__label\">{{ filter.name | translate }}</span>\n </button>\n</div>\n", styles: ["adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button){padding:0;width:100%;cursor:pointer;font-size:var(--theme-body-1-font-size);font-weight:700}adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button) .adf-full-width{display:flex;width:100%}adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button) .adf-filter-action-button{align-items:center;height:32px;justify-content:flex-start}adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button) .adf-filter-action-button .adf-filter-action-button__label{padding-left:20px;margin:0 8px;color:var(--theme-action-button-text-color)}adf-process-instance-filters .adf-filters__entry:has(.adf-filter-action-button).adf-active .adf-filter-action-button__label{color:var(--adf-sidenav-active-text-color)}\n"] }]
|
|
194
|
-
}], ctorParameters: () => [{ type: i1.ProcessFilterService }, { type: i2.AppsProcessService }, { type: i3.Router }, { type: i4.Location }], propDecorators: { filterParam: [{
|
|
195
|
-
type: Input
|
|
196
|
-
}], filterClicked: [{
|
|
197
|
-
type: Output
|
|
198
|
-
}], success: [{
|
|
199
|
-
type: Output
|
|
200
|
-
}], error: [{
|
|
201
|
-
type: Output
|
|
202
|
-
}], appId: [{
|
|
203
|
-
type: Input
|
|
204
|
-
}], appName: [{
|
|
205
|
-
type: Input
|
|
206
|
-
}], showIcon: [{
|
|
207
|
-
type: Input
|
|
208
|
-
}], filterSelected: [{
|
|
209
|
-
type: Output
|
|
210
|
-
}] } });
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process-filters.component.js","sourceRoot":"","sources":["../../../../../../../../lib/process-services/src/lib/process-list/components/process-filters/process-filters.component.ts","../../../../../../../../lib/process-services/src/lib/process-list/components/process-filters/process-filters.component.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Component, DestroyRef, EventEmitter, inject, Input, OnChanges, OnInit, Output, SimpleChanges, ViewEncapsulation } from '@angular/core';\nimport { ProcessInstanceFilterRepresentation, UserProcessInstanceFilterRepresentation } from '@alfresco/js-api';\nimport { ProcessFilterService } from '../../services/process-filter.service';\nimport { AppsProcessService } from '../../../services/apps-process.service';\nimport { IconModel } from '../../../app-list/icon.model';\nimport { NavigationStart, Router } from '@angular/router';\nimport { filter } from 'rxjs/operators';\nimport { CommonModule, Location } from '@angular/common';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { MatButtonModule } from '@angular/material/button';\nimport { IconComponent } from '@alfresco/adf-core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'adf-process-instance-filters',\n    standalone: true,\n    imports: [CommonModule, TranslatePipe, MatButtonModule, IconComponent],\n    templateUrl: './process-filters.component.html',\n    styleUrls: ['./process-filters.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\nexport class ProcessFiltersComponent implements OnInit, OnChanges {\n    /**\n     * The parameters to filter the task filter. If there is no match then the default one\n     * (ie, the first filter in the list) is selected.\n     */\n    @Input()\n    filterParam: UserProcessInstanceFilterRepresentation;\n\n    /** Emitted when a filter is being clicked from the UI. */\n    @Output()\n    filterClicked = new EventEmitter<UserProcessInstanceFilterRepresentation>();\n\n    /** Emitted when the list of filters has been successfully loaded from the server. */\n    @Output()\n    success = new EventEmitter<ProcessInstanceFilterRepresentation[]>();\n\n    /** Emitted when an error occurs. */\n    @Output()\n    error = new EventEmitter<any>();\n\n    /** Display filters available to the current user for the application with the specified ID. */\n    @Input()\n    appId: number;\n\n    /** Display filters available to the current user for the application with the specified name. */\n    @Input()\n    appName: string;\n\n    /** Toggle to show or hide the filter's icon. */\n    @Input()\n    showIcon = true;\n\n    /** Emitted when a filter is being selected based on the filterParam input. */\n    @Output()\n    filterSelected = new EventEmitter<UserProcessInstanceFilterRepresentation>();\n\n    currentFilter: ProcessInstanceFilterRepresentation;\n\n    filters: UserProcessInstanceFilterRepresentation[] = [];\n    active = false;\n    isProcessRoute: boolean;\n    isProcessActive: boolean;\n\n    private iconsMDL: IconModel;\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    constructor(\n        private processFilterService: ProcessFilterService,\n        private appsProcessService: AppsProcessService,\n        private router: Router,\n        private location: Location\n    ) {}\n\n    ngOnInit() {\n        this.iconsMDL = new IconModel();\n        this.router.events\n            .pipe(\n                filter((event) => event instanceof NavigationStart),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe((navigationStart: NavigationStart) => {\n                const activeRoute = navigationStart.url;\n                this.isProcessActive = activeRoute.includes('processes');\n            });\n        const currentRoute = this.location.path();\n        this.isProcessRoute = currentRoute.includes('processes');\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        const appId = changes['appId'];\n        const appName = changes['appName'];\n        const filterParam = changes['filterParam'];\n\n        if (appId && (appId.currentValue || appId.currentValue === null)) {\n            this.getFiltersByAppId(appId.currentValue);\n        } else if (appName?.currentValue) {\n            this.getFiltersByAppName(appName.currentValue);\n        } else if (filterParam && filterParam.currentValue !== filterParam.previousValue) {\n            this.selectProcessFilter(filterParam.currentValue);\n        }\n    }\n\n    isActiveRoute(filterActive: ProcessInstanceFilterRepresentation): boolean {\n        return (this.isProcessActive || this.isProcessRoute) && this.currentFilter === filterActive;\n    }\n\n    /**\n     * Return the filter list filtered by appId\n     *\n     * @param appId - optional\n     */\n    getFiltersByAppId(appId?: number) {\n        this.processFilterService.getProcessFilters(appId).subscribe(\n            (res) => {\n                if (res.length === 0 && this.isFilterListEmpty()) {\n                    this.processFilterService.createDefaultFilters(appId).subscribe(\n                        (resDefault) => {\n                            this.resetFilter();\n                            this.filters = resDefault;\n                            this.selectProcessFilter(this.filterParam);\n                            this.success.emit(resDefault);\n                        },\n                        (errDefault) => {\n                            this.error.emit(errDefault);\n                        }\n                    );\n                } else {\n                    this.resetFilter();\n                    this.filters = res;\n                    this.selectProcessFilter(this.filterParam);\n                    this.success.emit(res);\n                }\n            },\n            (err) => {\n                this.error.emit(err);\n            }\n        );\n    }\n\n    /**\n     * Return the filter list filtered by appName\n     *\n     * @param appName application name\n     */\n    getFiltersByAppName(appName: string): void {\n        this.appsProcessService.getDeployedApplicationsByName(appName).subscribe(\n            (application) => {\n                this.getFiltersByAppId(application.id);\n                this.selectProcessFilter(this.filterParam);\n            },\n            (err) => {\n                this.error.emit(err);\n            }\n        );\n    }\n\n    /**\n     * Pass the selected filter as next\n     *\n     * @param filterModel filter model\n     */\n    selectFilter(filterModel: ProcessInstanceFilterRepresentation) {\n        this.currentFilter = filterModel;\n        this.active = true;\n        this.filterClicked.emit(filterModel);\n    }\n\n    /**\n     * Select the first filter of a list if present\n     *\n     * @param filterParam filter parameter\n     */\n    selectProcessFilter(filterParam: UserProcessInstanceFilterRepresentation): void {\n        if (filterParam) {\n            const newFilter = this.filters.find(\n                (processFilter, index) =>\n                    filterParam.index === index ||\n                    filterParam.id === processFilter.id ||\n                    (filterParam.name && filterParam.name.toLocaleLowerCase() === processFilter.name.toLocaleLowerCase())\n            );\n            this.currentFilter = newFilter;\n\n            if (newFilter) {\n                this.filterSelected.emit(newFilter);\n            }\n        }\n    }\n\n    /**\n     * Select the Running filter\n     *\n     * @deprecated in 3.9.0, Use the filterParam Input() with a running filter instance instead\n     */\n    selectRunningFilter() {\n        this.selectProcessFilter(this.processFilterService.getRunningFilterInstance(null));\n    }\n\n    /**\n     * Get the current task\n     *\n     * @returns process instance filter\n     */\n    getCurrentFilter(): ProcessInstanceFilterRepresentation {\n        return this.currentFilter;\n    }\n\n    /**\n     * Check if the filter list is empty\n     *\n     * @returns `true` if filter list is empty, otherwise `false`\n     */\n    isFilterListEmpty(): boolean {\n        return this.filters === undefined || (this.filters && this.filters.length === 0);\n    }\n\n    /**\n     * Get the material icons equivalent of the glyphicon icon\n     *\n     * @param icon glyphicon name\n     * @returns material icons equivalent of the icon\n     */\n    getFilterIcon(icon: string): string {\n        return this.iconsMDL.mapGlyphiconToMaterialDesignIcons(icon);\n    }\n\n    /**\n     * Reset the filters properties\n     */\n    private resetFilter() {\n        this.filters = [];\n        this.currentFilter = undefined;\n    }\n}\n","<div *ngFor=\"let filter of filters\" class=\"adf-filters__entry\" [class.adf-active]=\"isActiveRoute(filter)\">\n    <button\n        (click)=\"selectFilter(filter)\"\n        [attr.aria-label]=\"filter.name | translate\"\n        [id]=\"filter.id\"\n        [attr.data-automation-id]=\"filter.name + '_filter'\"\n        mat-button\n        class=\"adf-filter-action-button adf-full-width\">\n        <adf-icon data-automation-id=\"adf-filter-icon\" *ngIf=\"showIcon\" [value]=\"getFilterIcon(filter.icon)\" />\n        <span data-automation-id=\"adf-filter-label\" class=\"adf-filter-action-button__label\">{{ filter.name | translate }}</span>\n    </button>\n</div>\n"]}
|
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.
|
|
4
|
-
*
|
|
5
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
-
* you may not use this file except in compliance with the License.
|
|
7
|
-
* You may obtain a copy of the License at
|
|
8
|
-
*
|
|
9
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
-
*
|
|
11
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
-
* See the License for the specific language governing permissions and
|
|
15
|
-
* limitations under the License.
|
|
16
|
-
*/
|
|
17
|
-
import { CommonModule, DatePipe } from '@angular/common';
|
|
18
|
-
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
19
|
-
import { ProcessService } from '../../services/process.service';
|
|
20
|
-
import { ProcessInstanceHeaderComponent } from '../process-instance-header/process-instance-header.component';
|
|
21
|
-
import { ProcessInstanceTasksComponent } from '../process-instance-tasks/process-instance-tasks.component';
|
|
22
|
-
import { TranslatePipe } from '@ngx-translate/core';
|
|
23
|
-
import { MatCardModule } from '@angular/material/card';
|
|
24
|
-
import { MatButtonModule } from '@angular/material/button';
|
|
25
|
-
import { ProcessCommentsComponent } from '../../../process-comments';
|
|
26
|
-
import * as i0 from "@angular/core";
|
|
27
|
-
import * as i1 from "../../services/process.service";
|
|
28
|
-
import * as i2 from "@angular/common";
|
|
29
|
-
import * as i3 from "@angular/material/card";
|
|
30
|
-
import * as i4 from "@angular/material/button";
|
|
31
|
-
export class ProcessInstanceDetailsComponent {
|
|
32
|
-
constructor(processService) {
|
|
33
|
-
this.processService = processService;
|
|
34
|
-
/** Toggles whether to show or hide the title. */
|
|
35
|
-
this.showTitle = true;
|
|
36
|
-
/** Toggles whether to show or hide the refresh button. */
|
|
37
|
-
this.showRefreshButton = true;
|
|
38
|
-
/** Emitted when the current process is cancelled by the user from within the component. */
|
|
39
|
-
this.processCancelled = new EventEmitter();
|
|
40
|
-
/** Emitted when an error occurs. */
|
|
41
|
-
this.error = new EventEmitter();
|
|
42
|
-
/** Emitted when a task is clicked. */
|
|
43
|
-
this.taskClick = new EventEmitter();
|
|
44
|
-
/** Emitted when the "show diagram" button is clicked. */
|
|
45
|
-
this.showProcessDiagram = new EventEmitter();
|
|
46
|
-
}
|
|
47
|
-
ngOnChanges(changes) {
|
|
48
|
-
const processInstanceId = changes['processInstanceId'];
|
|
49
|
-
if (processInstanceId && !processInstanceId.currentValue) {
|
|
50
|
-
this.reset();
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
if (processInstanceId?.currentValue) {
|
|
54
|
-
this.load(processInstanceId.currentValue);
|
|
55
|
-
return;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Reset the task detail
|
|
60
|
-
*/
|
|
61
|
-
reset() {
|
|
62
|
-
this.processInstanceDetails = null;
|
|
63
|
-
}
|
|
64
|
-
load(processId) {
|
|
65
|
-
if (processId) {
|
|
66
|
-
this.processService.getProcess(processId).subscribe((res) => {
|
|
67
|
-
this.processInstanceDetails = res;
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
isRunning() {
|
|
72
|
-
return this.processInstanceDetails && !this.processInstanceDetails.ended;
|
|
73
|
-
}
|
|
74
|
-
cancelProcess() {
|
|
75
|
-
this.processService.cancelProcess(this.processInstanceId).subscribe((data) => {
|
|
76
|
-
this.processCancelled.emit(data);
|
|
77
|
-
}, (err) => {
|
|
78
|
-
this.error.emit(err);
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
// bubbles (taskClick) event
|
|
82
|
-
onTaskClicked(event) {
|
|
83
|
-
this.taskClick.emit(event);
|
|
84
|
-
}
|
|
85
|
-
getProcessNameOrDescription(dateFormat) {
|
|
86
|
-
let name = '';
|
|
87
|
-
if (this.processInstanceDetails) {
|
|
88
|
-
name =
|
|
89
|
-
this.processInstanceDetails.name ||
|
|
90
|
-
this.processInstanceDetails.processDefinitionName + ' - ' + this.getFormatDate(this.processInstanceDetails.started, dateFormat);
|
|
91
|
-
}
|
|
92
|
-
return name;
|
|
93
|
-
}
|
|
94
|
-
getFormatDate(value, format) {
|
|
95
|
-
const datePipe = new DatePipe('en-US');
|
|
96
|
-
try {
|
|
97
|
-
return datePipe.transform(value, format);
|
|
98
|
-
}
|
|
99
|
-
catch {
|
|
100
|
-
return undefined;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
onShowProcessDiagram() {
|
|
104
|
-
this.showProcessDiagram.emit({ value: this.processInstanceId });
|
|
105
|
-
}
|
|
106
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProcessInstanceDetailsComponent, deps: [{ token: i1.ProcessService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
107
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ProcessInstanceDetailsComponent, isStandalone: true, selector: "adf-process-instance-details", inputs: { processInstanceId: "processInstanceId", showTitle: "showTitle", showRefreshButton: "showRefreshButton" }, outputs: { processCancelled: "processCancelled", error: "error", taskClick: "taskClick", showProcessDiagram: "showProcessDiagram" }, viewQueries: [{ propertyName: "processInstanceHeader", first: true, predicate: ["processInstanceHeader"], descendants: true }, { propertyName: "tasksList", first: true, predicate: ["processInstanceTasks"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"!processInstanceDetails\">{{ 'ADF_PROCESS_LIST.DETAILS.MESSAGES.NONE' | translate }}</div>\n<mat-card *ngIf=\"processInstanceDetails\">\n <mat-card-header>\n <mat-card-title>{{ getProcessNameOrDescription('medium') }}</mat-card-title>\n </mat-card-header>\n <mat-card-content>\n <adf-process-instance-header\n #processInstanceHeader\n [processInstance]=\"processInstanceDetails\" />\n\n <button\n class=\"adf-in-medias-res-button\"\n id=\"show-diagram-button\"\n type=\"button\"\n mat-button\n mat-raised-button\n [disabled]=\"!isRunning()\"\n (click)=\"onShowProcessDiagram()\">{{ 'ADF_PROCESS_LIST.DETAILS.BUTTON.SHOW_DIAGRAM' | translate }}</button>\n\n <mat-card appearance=\"outlined\">\n <mat-card-content>\n <adf-process-instance-tasks\n #processInstanceTasks\n [processInstanceDetails]=\"processInstanceDetails\"\n (taskClick)=\"onTaskClicked($event)\" />\n </mat-card-content>\n </mat-card>\n\n <div data-automation-id=\"header-status\" *ngIf=\"isRunning()\" class=\"adf-in-medias-res-button\">\n <button mat-button type=\"button\" (click)=\"cancelProcess()\">{{ 'ADF_PROCESS_LIST.DETAILS.BUTTON.CANCEL' | translate }}</button>\n </div>\n\n <mat-card appearance=\"outlined\">\n <mat-card-content>\n <adf-process-instance-comments\n [readOnly]=\"false\"\n [processInstanceId]=\"processInstanceDetails.id\" />\n </mat-card-content>\n </mat-card>\n\n </mat-card-content>\n</mat-card>\n", styles: [":host{width:100%}.activiti-process-container{width:100%;min-height:100px;overflow:visible;padding:10px}.adf-comments-dialog{position:fixed;top:50%;transform:translateY(-50%);width:40%}.adf-in-medias-res-button{margin:16px 0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatCardModule }, { kind: "component", type: i3.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i3.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i3.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i3.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: ProcessCommentsComponent, selector: "adf-process-instance-comments", inputs: ["processInstanceId", "readOnly"] }, { kind: "component", type: ProcessInstanceTasksComponent, selector: "adf-process-instance-tasks", inputs: ["processInstanceDetails", "showRefreshButton"], outputs: ["error", "taskClick"] }, { kind: "component", type: ProcessInstanceHeaderComponent, selector: "adf-process-instance-header", inputs: ["processInstance"] }] }); }
|
|
108
|
-
}
|
|
109
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProcessInstanceDetailsComponent, decorators: [{
|
|
110
|
-
type: Component,
|
|
111
|
-
args: [{ selector: 'adf-process-instance-details', standalone: true, imports: [
|
|
112
|
-
CommonModule,
|
|
113
|
-
TranslatePipe,
|
|
114
|
-
MatCardModule,
|
|
115
|
-
MatButtonModule,
|
|
116
|
-
ProcessCommentsComponent,
|
|
117
|
-
ProcessInstanceTasksComponent,
|
|
118
|
-
ProcessInstanceHeaderComponent
|
|
119
|
-
], template: "<div *ngIf=\"!processInstanceDetails\">{{ 'ADF_PROCESS_LIST.DETAILS.MESSAGES.NONE' | translate }}</div>\n<mat-card *ngIf=\"processInstanceDetails\">\n <mat-card-header>\n <mat-card-title>{{ getProcessNameOrDescription('medium') }}</mat-card-title>\n </mat-card-header>\n <mat-card-content>\n <adf-process-instance-header\n #processInstanceHeader\n [processInstance]=\"processInstanceDetails\" />\n\n <button\n class=\"adf-in-medias-res-button\"\n id=\"show-diagram-button\"\n type=\"button\"\n mat-button\n mat-raised-button\n [disabled]=\"!isRunning()\"\n (click)=\"onShowProcessDiagram()\">{{ 'ADF_PROCESS_LIST.DETAILS.BUTTON.SHOW_DIAGRAM' | translate }}</button>\n\n <mat-card appearance=\"outlined\">\n <mat-card-content>\n <adf-process-instance-tasks\n #processInstanceTasks\n [processInstanceDetails]=\"processInstanceDetails\"\n (taskClick)=\"onTaskClicked($event)\" />\n </mat-card-content>\n </mat-card>\n\n <div data-automation-id=\"header-status\" *ngIf=\"isRunning()\" class=\"adf-in-medias-res-button\">\n <button mat-button type=\"button\" (click)=\"cancelProcess()\">{{ 'ADF_PROCESS_LIST.DETAILS.BUTTON.CANCEL' | translate }}</button>\n </div>\n\n <mat-card appearance=\"outlined\">\n <mat-card-content>\n <adf-process-instance-comments\n [readOnly]=\"false\"\n [processInstanceId]=\"processInstanceDetails.id\" />\n </mat-card-content>\n </mat-card>\n\n </mat-card-content>\n</mat-card>\n", styles: [":host{width:100%}.activiti-process-container{width:100%;min-height:100px;overflow:visible;padding:10px}.adf-comments-dialog{position:fixed;top:50%;transform:translateY(-50%);width:40%}.adf-in-medias-res-button{margin:16px 0}\n"] }]
|
|
120
|
-
}], ctorParameters: () => [{ type: i1.ProcessService }], propDecorators: { processInstanceId: [{
|
|
121
|
-
type: Input,
|
|
122
|
-
args: [{ required: true }]
|
|
123
|
-
}], processInstanceHeader: [{
|
|
124
|
-
type: ViewChild,
|
|
125
|
-
args: ['processInstanceHeader']
|
|
126
|
-
}], tasksList: [{
|
|
127
|
-
type: ViewChild,
|
|
128
|
-
args: ['processInstanceTasks']
|
|
129
|
-
}], showTitle: [{
|
|
130
|
-
type: Input
|
|
131
|
-
}], showRefreshButton: [{
|
|
132
|
-
type: Input
|
|
133
|
-
}], processCancelled: [{
|
|
134
|
-
type: Output
|
|
135
|
-
}], error: [{
|
|
136
|
-
type: Output
|
|
137
|
-
}], taskClick: [{
|
|
138
|
-
type: Output
|
|
139
|
-
}], showProcessDiagram: [{
|
|
140
|
-
type: Output
|
|
141
|
-
}] } });
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process-instance-details.component.js","sourceRoot":"","sources":["../../../../../../../../lib/process-services/src/lib/process-list/components/process-instance-details/process-instance-details.component.ts","../../../../../../../../lib/process-services/src/lib/process-list/components/process-instance-details/process-instance-details.component.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { CommonModule, DatePipe } from '@angular/common';\nimport { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { TaskDetailsEvent } from '../../../task-list';\nimport { ProcessService } from '../../services/process.service';\nimport { ProcessInstanceHeaderComponent } from '../process-instance-header/process-instance-header.component';\nimport { ProcessInstanceTasksComponent } from '../process-instance-tasks/process-instance-tasks.component';\nimport { ProcessInstanceRepresentation } from '@alfresco/js-api';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { MatCardModule } from '@angular/material/card';\nimport { MatButtonModule } from '@angular/material/button';\nimport { ProcessCommentsComponent } from '../../../process-comments';\n\n@Component({\n    selector: 'adf-process-instance-details',\n    standalone: true,\n    imports: [\n        CommonModule,\n        TranslatePipe,\n        MatCardModule,\n        MatButtonModule,\n        ProcessCommentsComponent,\n        ProcessInstanceTasksComponent,\n        ProcessInstanceHeaderComponent\n    ],\n    templateUrl: './process-instance-details.component.html',\n    styleUrls: ['./process-instance-details.component.css']\n})\nexport class ProcessInstanceDetailsComponent implements OnChanges {\n    /** (required) The numeric ID of the process instance to display. */\n    @Input({ required: true })\n    processInstanceId: string;\n\n    @ViewChild('processInstanceHeader')\n    processInstanceHeader: ProcessInstanceHeaderComponent;\n\n    @ViewChild('processInstanceTasks')\n    tasksList: ProcessInstanceTasksComponent;\n\n    /** Toggles whether to show or hide the title. */\n    @Input()\n    showTitle: boolean = true;\n\n    /** Toggles whether to show or hide the refresh button. */\n    @Input()\n    showRefreshButton: boolean = true;\n\n    /** Emitted when the current process is cancelled by the user from within the component. */\n    @Output()\n    processCancelled = new EventEmitter<any>();\n\n    /** Emitted when an error occurs. */\n    @Output()\n    error = new EventEmitter<any>();\n\n    /** Emitted when a task is clicked. */\n    @Output()\n    taskClick = new EventEmitter<TaskDetailsEvent>();\n\n    /** Emitted when the \"show diagram\" button is clicked. */\n    @Output()\n    showProcessDiagram = new EventEmitter<any>();\n\n    processInstanceDetails: ProcessInstanceRepresentation;\n\n    constructor(private processService: ProcessService) {}\n\n    ngOnChanges(changes: SimpleChanges) {\n        const processInstanceId = changes['processInstanceId'];\n        if (processInstanceId && !processInstanceId.currentValue) {\n            this.reset();\n            return;\n        }\n        if (processInstanceId?.currentValue) {\n            this.load(processInstanceId.currentValue);\n            return;\n        }\n    }\n\n    /**\n     * Reset the task detail\n     */\n    reset() {\n        this.processInstanceDetails = null;\n    }\n\n    load(processId: string) {\n        if (processId) {\n            this.processService.getProcess(processId).subscribe((res) => {\n                this.processInstanceDetails = res;\n            });\n        }\n    }\n\n    isRunning(): boolean {\n        return this.processInstanceDetails && !this.processInstanceDetails.ended;\n    }\n\n    cancelProcess() {\n        this.processService.cancelProcess(this.processInstanceId).subscribe(\n            (data) => {\n                this.processCancelled.emit(data);\n            },\n            (err) => {\n                this.error.emit(err);\n            }\n        );\n    }\n\n    // bubbles (taskClick) event\n    onTaskClicked(event: TaskDetailsEvent) {\n        this.taskClick.emit(event);\n    }\n\n    getProcessNameOrDescription(dateFormat: string): string {\n        let name = '';\n        if (this.processInstanceDetails) {\n            name =\n                this.processInstanceDetails.name ||\n                this.processInstanceDetails.processDefinitionName + ' - ' + this.getFormatDate(this.processInstanceDetails.started, dateFormat);\n        }\n        return name;\n    }\n\n    getFormatDate(value: any, format: string): any {\n        const datePipe = new DatePipe('en-US');\n        try {\n            return datePipe.transform(value, format);\n        } catch {\n            return undefined;\n        }\n    }\n\n    onShowProcessDiagram() {\n        this.showProcessDiagram.emit({ value: this.processInstanceId });\n    }\n}\n","<div *ngIf=\"!processInstanceDetails\">{{ 'ADF_PROCESS_LIST.DETAILS.MESSAGES.NONE' | translate }}</div>\n<mat-card *ngIf=\"processInstanceDetails\">\n    <mat-card-header>\n        <mat-card-title>{{ getProcessNameOrDescription('medium') }}</mat-card-title>\n    </mat-card-header>\n    <mat-card-content>\n        <adf-process-instance-header\n            #processInstanceHeader\n            [processInstance]=\"processInstanceDetails\" />\n\n        <button\n            class=\"adf-in-medias-res-button\"\n            id=\"show-diagram-button\"\n            type=\"button\"\n            mat-button\n            mat-raised-button\n            [disabled]=\"!isRunning()\"\n            (click)=\"onShowProcessDiagram()\">{{ 'ADF_PROCESS_LIST.DETAILS.BUTTON.SHOW_DIAGRAM' | translate }}</button>\n\n        <mat-card appearance=\"outlined\">\n            <mat-card-content>\n                <adf-process-instance-tasks\n                    #processInstanceTasks\n                    [processInstanceDetails]=\"processInstanceDetails\"\n                    (taskClick)=\"onTaskClicked($event)\" />\n            </mat-card-content>\n        </mat-card>\n\n        <div data-automation-id=\"header-status\" *ngIf=\"isRunning()\" class=\"adf-in-medias-res-button\">\n            <button mat-button type=\"button\" (click)=\"cancelProcess()\">{{ 'ADF_PROCESS_LIST.DETAILS.BUTTON.CANCEL' | translate }}</button>\n        </div>\n\n        <mat-card appearance=\"outlined\">\n            <mat-card-content>\n                <adf-process-instance-comments\n                    [readOnly]=\"false\"\n                    [processInstanceId]=\"processInstanceDetails.id\" />\n            </mat-card-content>\n        </mat-card>\n\n    </mat-card-content>\n</mat-card>\n"]}
|
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.
|
|
4
|
-
*
|
|
5
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
-
* you may not use this file except in compliance with the License.
|
|
7
|
-
* You may obtain a copy of the License at
|
|
8
|
-
*
|
|
9
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
-
*
|
|
11
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
-
* See the License for the specific language governing permissions and
|
|
15
|
-
* limitations under the License.
|
|
16
|
-
*/
|
|
17
|
-
import { AppConfigService, CardViewComponent, CardViewDateItemModel, CardViewTextItemModel, TranslationService } from '@alfresco/adf-core';
|
|
18
|
-
import { Component, Input } from '@angular/core';
|
|
19
|
-
import { ProcessInstanceRepresentation } from '@alfresco/js-api';
|
|
20
|
-
import { CommonModule } from '@angular/common';
|
|
21
|
-
import { MatCardModule } from '@angular/material/card';
|
|
22
|
-
import * as i0 from "@angular/core";
|
|
23
|
-
import * as i1 from "@alfresco/adf-core";
|
|
24
|
-
import * as i2 from "@angular/common";
|
|
25
|
-
import * as i3 from "@angular/material/card";
|
|
26
|
-
export class ProcessInstanceHeaderComponent {
|
|
27
|
-
constructor(translationService, appConfig) {
|
|
28
|
-
this.translationService = translationService;
|
|
29
|
-
this.appConfig = appConfig;
|
|
30
|
-
this.dateFormat = this.appConfig.get('dateValues.defaultDateFormat');
|
|
31
|
-
this.dateLocale = this.appConfig.get('dateValues.defaultDateLocale');
|
|
32
|
-
}
|
|
33
|
-
ngOnChanges() {
|
|
34
|
-
this.refreshData();
|
|
35
|
-
}
|
|
36
|
-
refreshData() {
|
|
37
|
-
if (this.processInstance) {
|
|
38
|
-
const defaultProperties = this.initDefaultProperties();
|
|
39
|
-
const filteredProperties = this.appConfig.get('adf-process-instance-header.presets.properties');
|
|
40
|
-
this.properties = defaultProperties.filter((cardItem) => this.isValidSelection(filteredProperties, cardItem));
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
getProcessStatus() {
|
|
44
|
-
if (this.processInstance) {
|
|
45
|
-
return this.isRunning() ? 'Running' : 'Completed';
|
|
46
|
-
}
|
|
47
|
-
return 'Unknown';
|
|
48
|
-
}
|
|
49
|
-
getStartedByFullName() {
|
|
50
|
-
let fullName = '';
|
|
51
|
-
if (this.processInstance?.startedBy) {
|
|
52
|
-
fullName += this.processInstance.startedBy.firstName || '';
|
|
53
|
-
fullName += fullName ? ' ' : '';
|
|
54
|
-
fullName += this.processInstance.startedBy.lastName || '';
|
|
55
|
-
}
|
|
56
|
-
return fullName;
|
|
57
|
-
}
|
|
58
|
-
isRunning() {
|
|
59
|
-
return this.processInstance && !this.processInstance.ended;
|
|
60
|
-
}
|
|
61
|
-
initDefaultProperties() {
|
|
62
|
-
return [
|
|
63
|
-
new CardViewTextItemModel({
|
|
64
|
-
label: 'ADF_PROCESS_LIST.PROPERTIES.STATUS',
|
|
65
|
-
value: this.getProcessStatus(),
|
|
66
|
-
key: 'status'
|
|
67
|
-
}),
|
|
68
|
-
new CardViewDateItemModel({
|
|
69
|
-
label: 'ADF_PROCESS_LIST.PROPERTIES.END_DATE',
|
|
70
|
-
value: this.processInstance.ended,
|
|
71
|
-
format: this.dateFormat,
|
|
72
|
-
locale: this.dateLocale,
|
|
73
|
-
key: 'ended',
|
|
74
|
-
default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.END_DATE_DEFAULT')
|
|
75
|
-
}),
|
|
76
|
-
new CardViewTextItemModel({
|
|
77
|
-
label: 'ADF_PROCESS_LIST.PROPERTIES.CATEGORY',
|
|
78
|
-
value: this.processInstance.processDefinitionCategory,
|
|
79
|
-
key: 'category',
|
|
80
|
-
default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.CATEGORY_DEFAULT')
|
|
81
|
-
}),
|
|
82
|
-
new CardViewTextItemModel({
|
|
83
|
-
label: 'ADF_PROCESS_LIST.PROPERTIES.BUSINESS_KEY',
|
|
84
|
-
value: this.processInstance.businessKey,
|
|
85
|
-
key: 'businessKey',
|
|
86
|
-
default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.BUSINESS_KEY_DEFAULT')
|
|
87
|
-
}),
|
|
88
|
-
new CardViewTextItemModel({
|
|
89
|
-
label: 'ADF_PROCESS_LIST.PROPERTIES.CREATED_BY',
|
|
90
|
-
value: this.getStartedByFullName(),
|
|
91
|
-
key: 'createdBy',
|
|
92
|
-
default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.CREATED_BY_DEFAULT')
|
|
93
|
-
}),
|
|
94
|
-
new CardViewDateItemModel({
|
|
95
|
-
label: 'ADF_PROCESS_LIST.PROPERTIES.CREATED',
|
|
96
|
-
value: this.processInstance.started,
|
|
97
|
-
format: this.dateFormat,
|
|
98
|
-
locale: this.dateLocale,
|
|
99
|
-
key: 'created'
|
|
100
|
-
}),
|
|
101
|
-
new CardViewTextItemModel({ label: 'ADF_PROCESS_LIST.PROPERTIES.ID', value: this.processInstance.id, key: 'id' }),
|
|
102
|
-
new CardViewTextItemModel({
|
|
103
|
-
label: 'ADF_PROCESS_LIST.PROPERTIES.DESCRIPTION',
|
|
104
|
-
value: this.processInstance.processDefinitionDescription,
|
|
105
|
-
key: 'description',
|
|
106
|
-
default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.DESCRIPTION_DEFAULT')
|
|
107
|
-
})
|
|
108
|
-
];
|
|
109
|
-
}
|
|
110
|
-
isValidSelection(filteredProperties, cardItem) {
|
|
111
|
-
return filteredProperties ? filteredProperties.indexOf(cardItem.key) >= 0 : true;
|
|
112
|
-
}
|
|
113
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProcessInstanceHeaderComponent, deps: [{ token: i1.TranslationService }, { token: i1.AppConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
114
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ProcessInstanceHeaderComponent, isStandalone: true, selector: "adf-process-instance-header", inputs: { processInstance: "processInstance" }, usesOnChanges: true, ngImport: i0, template: "<mat-card appearance=\"outlined\" *ngIf=\"processInstance\" class=\"adf-card-container\">\n <mat-card-content>\n <adf-card-view [properties]=\"properties\" />\n </mat-card-content>\n</mat-card>\n", styles: [":host{width:100%}.adf-card-container{font-family:inherit}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatCardModule }, { kind: "component", type: i3.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i3.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: CardViewComponent, selector: "adf-card-view", inputs: ["properties", "editable", "displayEmpty", "displayNoneOption", "displayClearAction", "copyToClipboardAction", "useChipsForMultiValueProperty", "multiValueSeparator", "displayLabelForChips"] }] }); }
|
|
115
|
-
}
|
|
116
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProcessInstanceHeaderComponent, decorators: [{
|
|
117
|
-
type: Component,
|
|
118
|
-
args: [{ selector: 'adf-process-instance-header', standalone: true, imports: [CommonModule, MatCardModule, CardViewComponent], template: "<mat-card appearance=\"outlined\" *ngIf=\"processInstance\" class=\"adf-card-container\">\n <mat-card-content>\n <adf-card-view [properties]=\"properties\" />\n </mat-card-content>\n</mat-card>\n", styles: [":host{width:100%}.adf-card-container{font-family:inherit}\n"] }]
|
|
119
|
-
}], ctorParameters: () => [{ type: i1.TranslationService }, { type: i1.AppConfigService }], propDecorators: { processInstance: [{
|
|
120
|
-
type: Input,
|
|
121
|
-
args: [{ required: true }]
|
|
122
|
-
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process-instance-header.component.js","sourceRoot":"","sources":["../../../../../../../../lib/process-services/src/lib/process-list/components/process-instance-header/process-instance-header.component.ts","../../../../../../../../lib/process-services/src/lib/process-list/components/process-instance-header/process-instance-header.component.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n    AppConfigService,\n    CardViewBaseItemModel,\n    CardViewComponent,\n    CardViewDateItemModel,\n    CardViewItem,\n    CardViewTextItemModel,\n    TranslationService\n} from '@alfresco/adf-core';\nimport { Component, Input, OnChanges } from '@angular/core';\nimport { ProcessInstanceRepresentation } from '@alfresco/js-api';\nimport { CommonModule } from '@angular/common';\nimport { MatCardModule } from '@angular/material/card';\n\n@Component({\n    selector: 'adf-process-instance-header',\n    standalone: true,\n    imports: [CommonModule, MatCardModule, CardViewComponent],\n    templateUrl: './process-instance-header.component.html',\n    styleUrls: ['./process-instance-header.component.css']\n})\nexport class ProcessInstanceHeaderComponent implements OnChanges {\n    /** (**required**) Full details of the process instance to display information about. */\n    @Input({ required: true })\n    processInstance: ProcessInstanceRepresentation;\n\n    properties: CardViewItem[];\n    dateFormat: string;\n    dateLocale: string;\n\n    constructor(private translationService: TranslationService, private appConfig: AppConfigService) {\n        this.dateFormat = this.appConfig.get('dateValues.defaultDateFormat');\n        this.dateLocale = this.appConfig.get('dateValues.defaultDateLocale');\n    }\n\n    ngOnChanges() {\n        this.refreshData();\n    }\n\n    refreshData(): void {\n        if (this.processInstance) {\n            const defaultProperties = this.initDefaultProperties();\n            const filteredProperties: string[] = this.appConfig.get('adf-process-instance-header.presets.properties');\n            this.properties = defaultProperties.filter((cardItem) => this.isValidSelection(filteredProperties, cardItem));\n        }\n    }\n\n    getProcessStatus(): string {\n        if (this.processInstance) {\n            return this.isRunning() ? 'Running' : 'Completed';\n        }\n        return 'Unknown';\n    }\n\n    getStartedByFullName(): string {\n        let fullName = '';\n        if (this.processInstance?.startedBy) {\n            fullName += this.processInstance.startedBy.firstName || '';\n            fullName += fullName ? ' ' : '';\n            fullName += this.processInstance.startedBy.lastName || '';\n        }\n        return fullName;\n    }\n\n    isRunning(): boolean {\n        return this.processInstance && !this.processInstance.ended;\n    }\n\n    private initDefaultProperties(): any[] {\n        return [\n            new CardViewTextItemModel({\n                label: 'ADF_PROCESS_LIST.PROPERTIES.STATUS',\n                value: this.getProcessStatus(),\n                key: 'status'\n            }),\n            new CardViewDateItemModel({\n                label: 'ADF_PROCESS_LIST.PROPERTIES.END_DATE',\n                value: this.processInstance.ended,\n                format: this.dateFormat,\n                locale: this.dateLocale,\n                key: 'ended',\n                default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.END_DATE_DEFAULT')\n            }),\n            new CardViewTextItemModel({\n                label: 'ADF_PROCESS_LIST.PROPERTIES.CATEGORY',\n                value: this.processInstance.processDefinitionCategory,\n                key: 'category',\n                default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.CATEGORY_DEFAULT')\n            }),\n            new CardViewTextItemModel({\n                label: 'ADF_PROCESS_LIST.PROPERTIES.BUSINESS_KEY',\n                value: this.processInstance.businessKey,\n                key: 'businessKey',\n                default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.BUSINESS_KEY_DEFAULT')\n            }),\n            new CardViewTextItemModel({\n                label: 'ADF_PROCESS_LIST.PROPERTIES.CREATED_BY',\n                value: this.getStartedByFullName(),\n                key: 'createdBy',\n                default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.CREATED_BY_DEFAULT')\n            }),\n            new CardViewDateItemModel({\n                label: 'ADF_PROCESS_LIST.PROPERTIES.CREATED',\n                value: this.processInstance.started,\n                format: this.dateFormat,\n                locale: this.dateLocale,\n                key: 'created'\n            }),\n            new CardViewTextItemModel({ label: 'ADF_PROCESS_LIST.PROPERTIES.ID', value: this.processInstance.id, key: 'id' }),\n            new CardViewTextItemModel({\n                label: 'ADF_PROCESS_LIST.PROPERTIES.DESCRIPTION',\n                value: this.processInstance.processDefinitionDescription,\n                key: 'description',\n                default: this.translationService.instant('ADF_PROCESS_LIST.PROPERTIES.DESCRIPTION_DEFAULT')\n            })\n        ];\n    }\n\n    private isValidSelection(filteredProperties: string[], cardItem: CardViewBaseItemModel): boolean {\n        return filteredProperties ? filteredProperties.indexOf(cardItem.key) >= 0 : true;\n    }\n}\n","<mat-card appearance=\"outlined\" *ngIf=\"processInstance\" class=\"adf-card-container\">\n    <mat-card-content>\n        <adf-card-view [properties]=\"properties\" />\n    </mat-card-content>\n</mat-card>\n"]}
|