@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.
Files changed (125) hide show
  1. package/fesm2022/adf-process-services.mjs +297 -301
  2. package/fesm2022/adf-process-services.mjs.map +1 -1
  3. package/package.json +4 -6
  4. package/esm2022/adf-process-services.mjs +0 -5
  5. package/esm2022/lib/app-list/apps-list.component.mjs +0 -195
  6. package/esm2022/lib/app-list/icon.model.mjs +0 -166
  7. package/esm2022/lib/app-list/index.mjs +0 -18
  8. package/esm2022/lib/app-list/public-api.mjs +0 -23
  9. package/esm2022/lib/app-list/select-apps-dialog/select-apps-dialog.component.mjs +0 -53
  10. package/esm2022/lib/attachment/create-process-attachment/create-process-attachment.component.mjs +0 -73
  11. package/esm2022/lib/attachment/create-task-attachment/create-task-attachment.component.mjs +0 -73
  12. package/esm2022/lib/attachment/index.mjs +0 -18
  13. package/esm2022/lib/attachment/process-attachment-list/process-attachment-list.component.mjs +0 -197
  14. package/esm2022/lib/attachment/public-api.mjs +0 -31
  15. package/esm2022/lib/attachment/task-attachment-list/task-attachment-list.component.mjs +0 -196
  16. package/esm2022/lib/compat/types.mjs +0 -18
  17. package/esm2022/lib/form/events/validate-dynamic-table-row.event.mjs +0 -26
  18. package/esm2022/lib/form/form-custom-outcomes.component.mjs +0 -31
  19. package/esm2022/lib/form/form-list/form-list.component.mjs +0 -50
  20. package/esm2022/lib/form/form.component.mjs +0 -346
  21. package/esm2022/lib/form/index.mjs +0 -18
  22. package/esm2022/lib/form/model/form-definition.model.mjs +0 -92
  23. package/esm2022/lib/form/process-form-rendering.service.mjs +0 -55
  24. package/esm2022/lib/form/public-api.mjs +0 -32
  25. package/esm2022/lib/form/services/activiti-alfresco.service.mjs +0 -113
  26. package/esm2022/lib/form/services/ecm-model.service.mjs +0 -156
  27. package/esm2022/lib/form/services/editor.service.mjs +0 -87
  28. package/esm2022/lib/form/services/external-alfresco-api.service.mjs +0 -57
  29. package/esm2022/lib/form/services/index.mjs +0 -26
  30. package/esm2022/lib/form/services/model.service.mjs +0 -130
  31. package/esm2022/lib/form/services/process-content.service.mjs +0 -223
  32. package/esm2022/lib/form/services/process-definition.service.mjs +0 -93
  33. package/esm2022/lib/form/services/task-form.service.mjs +0 -127
  34. package/esm2022/lib/form/services/task.service.mjs +0 -77
  35. package/esm2022/lib/form/start-form/start-form.component.mjs +0 -141
  36. package/esm2022/lib/form/widgets/content-widget/attach-file-widget-dialog-component.interface.mjs +0 -18
  37. package/esm2022/lib/form/widgets/content-widget/attach-file-widget-dialog.component.mjs +0 -115
  38. package/esm2022/lib/form/widgets/content-widget/attach-file-widget-dialog.service.mjs +0 -100
  39. package/esm2022/lib/form/widgets/content-widget/attach-file-widget.component.mjs +0 -254
  40. package/esm2022/lib/form/widgets/content-widget/attach-folder-widget.component.mjs +0 -93
  41. package/esm2022/lib/form/widgets/content-widget/index.mjs +0 -18
  42. package/esm2022/lib/form/widgets/content-widget/public-api.mjs +0 -22
  43. package/esm2022/lib/form/widgets/document/content.widget.mjs +0 -125
  44. package/esm2022/lib/form/widgets/document/document.widget.mjs +0 -61
  45. package/esm2022/lib/form/widgets/dropdown/dropdown.widget.mjs +0 -182
  46. package/esm2022/lib/form/widgets/dynamic-table/dynamic-table.widget.mjs +0 -192
  47. package/esm2022/lib/form/widgets/dynamic-table/editors/amount/amount.editor.mjs +0 -47
  48. package/esm2022/lib/form/widgets/dynamic-table/editors/boolean/boolean.editor.mjs +0 -42
  49. package/esm2022/lib/form/widgets/dynamic-table/editors/date/date.editor.mjs +0 -84
  50. package/esm2022/lib/form/widgets/dynamic-table/editors/datetime/datetime.editor.mjs +0 -84
  51. package/esm2022/lib/form/widgets/dynamic-table/editors/dropdown/dropdown.editor.mjs +0 -95
  52. package/esm2022/lib/form/widgets/dynamic-table/editors/models/cell-validator.model.mjs +0 -18
  53. package/esm2022/lib/form/widgets/dynamic-table/editors/models/date-cell-validator-model.mjs +0 -47
  54. package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-row-validation-summary.model.mjs +0 -24
  55. package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-table-column-option.model.mjs +0 -18
  56. package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-table-column.model.mjs +0 -18
  57. package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-table-row.model.mjs +0 -18
  58. package/esm2022/lib/form/widgets/dynamic-table/editors/models/dynamic-table.widget.model.mjs +0 -159
  59. package/esm2022/lib/form/widgets/dynamic-table/editors/models/number-cell-validator.model.mjs +0 -45
  60. package/esm2022/lib/form/widgets/dynamic-table/editors/models/required-cell-validator.model.mjs +0 -40
  61. package/esm2022/lib/form/widgets/dynamic-table/editors/row-editor/row.editor.mjs +0 -89
  62. package/esm2022/lib/form/widgets/dynamic-table/editors/text/text.editor.mjs +0 -47
  63. package/esm2022/lib/form/widgets/dynamic-table/index.mjs +0 -18
  64. package/esm2022/lib/form/widgets/dynamic-table/public-api.mjs +0 -44
  65. package/esm2022/lib/form/widgets/file-viewer/file-viewer.widget.mjs +0 -46
  66. package/esm2022/lib/form/widgets/functional-group/functional-group.widget.mjs +0 -167
  67. package/esm2022/lib/form/widgets/index.mjs +0 -18
  68. package/esm2022/lib/form/widgets/people/people.widget.mjs +0 -169
  69. package/esm2022/lib/form/widgets/public-api.mjs +0 -54
  70. package/esm2022/lib/form/widgets/radio-buttons/radio-buttons.widget.mjs +0 -97
  71. package/esm2022/lib/form/widgets/typeahead/typeahead.widget.mjs +0 -152
  72. package/esm2022/lib/form/widgets/upload/upload.widget.mjs +0 -128
  73. package/esm2022/lib/people/components/people/people.component.mjs +0 -124
  74. package/esm2022/lib/people/components/people-list/people-list.component.mjs +0 -74
  75. package/esm2022/lib/people/components/people-search/people-search.component.mjs +0 -83
  76. package/esm2022/lib/people/components/people-search-field/people-search-field.component.mjs +0 -90
  77. package/esm2022/lib/people/components/people-selector/people-selector.component.mjs +0 -76
  78. package/esm2022/lib/people/helpers/get-display-user.mjs +0 -22
  79. package/esm2022/lib/people/index.mjs +0 -18
  80. package/esm2022/lib/people/interfaces/perform-search-callback.interface.mjs +0 -18
  81. package/esm2022/lib/people/public-api.mjs +0 -35
  82. package/esm2022/lib/process-comments/index.mjs +0 -21
  83. package/esm2022/lib/process-comments/process-comments.component.mjs +0 -45
  84. package/esm2022/lib/process-comments/services/comment-process.service.mjs +0 -77
  85. package/esm2022/lib/process-list/components/process-audit/process-audit.directive.mjs +0 -105
  86. package/esm2022/lib/process-list/components/process-filters/process-filters.component.mjs +0 -211
  87. package/esm2022/lib/process-list/components/process-instance-details/process-instance-details.component.mjs +0 -142
  88. package/esm2022/lib/process-list/components/process-instance-header/process-instance-header.component.mjs +0 -123
  89. package/esm2022/lib/process-list/components/process-instance-tasks/process-instance-tasks.component.mjs +0 -163
  90. package/esm2022/lib/process-list/components/process-list/process-list.component.mjs +0 -327
  91. package/esm2022/lib/process-list/components/start-process/start-process.component.mjs +0 -423
  92. package/esm2022/lib/process-list/index.mjs +0 -18
  93. package/esm2022/lib/process-list/public-api.mjs +0 -44
  94. package/esm2022/lib/process-list/services/process-filter.service.mjs +0 -182
  95. package/esm2022/lib/process-list/services/process.service.mjs +0 -259
  96. package/esm2022/lib/process.module.mjs +0 -132
  97. package/esm2022/lib/services/apps-process.service.mjs +0 -58
  98. package/esm2022/lib/services/people-process.service.mjs +0 -124
  99. package/esm2022/lib/services/task-comments.service.mjs +0 -65
  100. package/esm2022/lib/task-comments/index.mjs +0 -21
  101. package/esm2022/lib/task-comments/task-comments.component.mjs +0 -44
  102. package/esm2022/lib/task-list/components/attach-form/attach-form.component.mjs +0 -127
  103. package/esm2022/lib/task-list/components/checklist/checklist.component.mjs +0 -140
  104. package/esm2022/lib/task-list/components/start-task/start-task.component.mjs +0 -221
  105. package/esm2022/lib/task-list/components/task-details/task-details.component.mjs +0 -360
  106. package/esm2022/lib/task-list/components/task-filters/task-filters.component.mjs +0 -261
  107. package/esm2022/lib/task-list/components/task-form/claim-task.directive.mjs +0 -77
  108. package/esm2022/lib/task-list/components/task-form/task-form.component.mjs +0 -313
  109. package/esm2022/lib/task-list/components/task-form/unclaim-task.directive.mjs +0 -77
  110. package/esm2022/lib/task-list/components/task-header/task-header.component.mjs +0 -361
  111. package/esm2022/lib/task-list/components/task-list/task-list.component.mjs +0 -359
  112. package/esm2022/lib/task-list/components/task-standalone/task-standalone.component.mjs +0 -82
  113. package/esm2022/lib/task-list/index.mjs +0 -18
  114. package/esm2022/lib/task-list/models/form.model.mjs +0 -26
  115. package/esm2022/lib/task-list/models/task-details.event.mjs +0 -32
  116. package/esm2022/lib/task-list/models/task-preset.model.mjs +0 -41
  117. package/esm2022/lib/task-list/models/user-event.model.mjs +0 -18
  118. package/esm2022/lib/task-list/models/user-group.model.mjs +0 -18
  119. package/esm2022/lib/task-list/public-api.mjs +0 -60
  120. package/esm2022/lib/task-list/services/process-upload.service.mjs +0 -42
  121. package/esm2022/lib/task-list/services/task-filter.service.mjs +0 -249
  122. package/esm2022/lib/task-list/services/task-upload.service.mjs +0 -42
  123. package/esm2022/lib/task-list/services/tasklist.service.mjs +0 -251
  124. package/esm2022/lib/task-list/validators/task-description.validator.mjs +0 -26
  125. 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"]}