verben-workflow-ui 0.5.45 → 0.5.47
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/esm2022/public-api.mjs +3 -1
- package/esm2022/src/lib/components/flowable-status/flowable-status.columns.mjs +21 -0
- package/esm2022/src/lib/components/flowable-status/flowable-status.component.mjs +122 -0
- package/esm2022/src/lib/components/flowable-status/flowable-status.facade.mjs +207 -0
- package/esm2022/src/lib/components/flowable-status/flowable-status.form.component.mjs +52 -0
- package/esm2022/src/lib/components/flowable-status/flowable-status.module.mjs +21 -0
- package/esm2022/src/lib/components/flowable-status/flowable-status.service.mjs +55 -0
- package/esm2022/src/lib/components/flowable-status/flowable-status.state.mjs +85 -0
- package/esm2022/src/lib/components/flowable-status/index.mjs +2 -0
- package/esm2022/src/lib/components/flowable-status/public-api.mjs +3 -0
- package/esm2022/src/lib/components/flowable-status/verben-workflow-ui-src-lib-components-flowable-status.mjs +5 -0
- package/esm2022/src/lib/components/workflow-designer/action-dialog/action-dialog.component.mjs +14 -4
- package/esm2022/src/lib/components/workflow-designer/designer-canvas/designer-canvas.component.mjs +3 -1
- package/esm2022/src/lib/components/workflow-designer/workflow-data.service.mjs +6 -1
- package/esm2022/src/lib/components/workflow-designer/workflow-designer.component.mjs +2 -1
- package/esm2022/src/lib/components/workflow-designer/workflow-designer.state.mjs +5 -1
- package/esm2022/src/lib/components/workflow-designer/workflow-designer.types.mjs +1 -1
- package/esm2022/src/lib/models/FlowableStatus.mjs +2 -0
- package/esm2022/src/lib/models/WorkflowAction.mjs +1 -1
- package/esm2022/src/lib/models/public-api.mjs +2 -1
- package/fesm2022/verben-workflow-ui-src-lib-components-flowable-status.mjs +545 -0
- package/fesm2022/verben-workflow-ui-src-lib-components-flowable-status.mjs.map +1 -0
- package/fesm2022/verben-workflow-ui-src-lib-components-workflow-designer.mjs +25 -3
- package/fesm2022/verben-workflow-ui-src-lib-components-workflow-designer.mjs.map +1 -1
- package/fesm2022/verben-workflow-ui.mjs +1 -3
- package/fesm2022/verben-workflow-ui.mjs.map +1 -1
- package/package.json +18 -12
- package/public-api.d.ts +1 -0
- package/src/lib/components/flowable-status/flowable-status.columns.d.ts +3 -0
- package/src/lib/components/flowable-status/flowable-status.component.d.ts +34 -0
- package/src/lib/components/flowable-status/flowable-status.facade.d.ts +32 -0
- package/src/lib/components/flowable-status/flowable-status.form.component.d.ts +18 -0
- package/src/lib/components/flowable-status/flowable-status.module.d.ts +11 -0
- package/src/lib/components/flowable-status/flowable-status.service.d.ts +36 -0
- package/src/lib/components/flowable-status/flowable-status.state.d.ts +30 -0
- package/src/lib/components/flowable-status/index.d.ts +1 -0
- package/src/lib/components/flowable-status/public-api.d.ts +2 -0
- package/src/lib/components/workflow-designer/action-dialog/action-dialog.component.d.ts +3 -1
- package/src/lib/components/workflow-designer/workflow-data.service.d.ts +3 -1
- package/src/lib/components/workflow-designer/workflow-designer.types.d.ts +2 -2
- package/src/lib/models/FlowableStatus.d.ts +5 -0
- package/src/lib/models/WorkflowAction.d.ts +1 -0
- package/src/lib/models/public-api.d.ts +1 -0
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "verben-workflow-ui/src/lib/services";
|
|
4
|
+
export class FlowableStatusService {
|
|
5
|
+
httpService;
|
|
6
|
+
envSvc;
|
|
7
|
+
BASE_URL = 'Status';
|
|
8
|
+
constructor(httpService, envSvc) {
|
|
9
|
+
this.httpService = httpService;
|
|
10
|
+
this.envSvc = envSvc;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Get data with pagination and sorting
|
|
14
|
+
* @param skip Number of records to skip
|
|
15
|
+
* @param limit Number of records to take
|
|
16
|
+
* @param sortParam Sort parameter
|
|
17
|
+
* @param sortOrder Sort order ('asc' or 'desc')
|
|
18
|
+
* @returns Promise containing the data
|
|
19
|
+
*/
|
|
20
|
+
getData(skip, limit, sortParam, sortOrder) {
|
|
21
|
+
const url = `${this.BASE_URL}/GetFlowableStatus/${skip}/${limit}/${sortParam}/${sortOrder}`;
|
|
22
|
+
return this.httpService.get(url);
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Get data with additional parameter, pagination and sorting
|
|
26
|
+
* @param param Search parameter
|
|
27
|
+
* @param skip Number of records to skip
|
|
28
|
+
* @param limit Number of records to take
|
|
29
|
+
* @param sortParam Sort parameter
|
|
30
|
+
* @param sortOrder Sort order ('asc' or 'desc')
|
|
31
|
+
* @returns Promise containing the filtered data
|
|
32
|
+
*/
|
|
33
|
+
getFlowableStatusWithParam(param, skip, limit, sortParam, sortOrder) {
|
|
34
|
+
const url = `${this.BASE_URL}/GetFlowableStatusWithParam/${param}/${skip}/${limit}/${sortParam}/${sortOrder}`;
|
|
35
|
+
return this.httpService.get(url);
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Save multiple data
|
|
39
|
+
* @param requests Array of data to save
|
|
40
|
+
* @returns Promise containing the save operation result
|
|
41
|
+
*/
|
|
42
|
+
saveFlowableStatuses(requests) {
|
|
43
|
+
const url = `${this.BASE_URL}/SaveFlowableStatus`;
|
|
44
|
+
return this.httpService.post(url, requests);
|
|
45
|
+
}
|
|
46
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FlowableStatusService, deps: [{ token: i1.HttpWebRequestService }, { token: i1.EnvironmentService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
47
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FlowableStatusService, providedIn: 'root' });
|
|
48
|
+
}
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FlowableStatusService, decorators: [{
|
|
50
|
+
type: Injectable,
|
|
51
|
+
args: [{
|
|
52
|
+
providedIn: 'root',
|
|
53
|
+
}]
|
|
54
|
+
}], ctorParameters: () => [{ type: i1.HttpWebRequestService }, { type: i1.EnvironmentService }] });
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvd2FibGUtc3RhdHVzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4td29ya2Zsb3ctdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zsb3dhYmxlLXN0YXR1cy9mbG93YWJsZS1zdGF0dXMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFPM0MsTUFBTSxPQUFPLHFCQUFxQjtJQUl0QjtJQUNBO0lBSk8sUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUVyQyxZQUNVLFdBQWtDLEVBQ2xDLE1BQTBCO1FBRDFCLGdCQUFXLEdBQVgsV0FBVyxDQUF1QjtRQUNsQyxXQUFNLEdBQU4sTUFBTSxDQUFvQjtJQUNoQyxDQUFDO0lBRUw7Ozs7Ozs7T0FPRztJQUNILE9BQU8sQ0FDTCxJQUFZLEVBQ1osS0FBYSxFQUNiLFNBQWlCLEVBQ2pCLFNBQWlCO1FBRWpCLE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsc0JBQXNCLElBQUksSUFBSSxLQUFLLElBQUksU0FBUyxJQUFJLFNBQVMsRUFBRSxDQUFDO1FBQzVGLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFtRCxDQUFDO0lBQ3JGLENBQUM7SUFFRDs7Ozs7Ozs7T0FRRztJQUNILDBCQUEwQixDQUN4QixLQUFhLEVBQ2IsSUFBWSxFQUNaLEtBQWEsRUFDYixTQUFpQixFQUNqQixTQUFpQjtRQUVqQixNQUFNLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxRQUFRLCtCQUErQixLQUFLLElBQUksSUFBSSxJQUFJLEtBQUssSUFBSSxTQUFTLElBQUksU0FBUyxFQUFFLENBQUM7UUFDOUcsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQW1ELENBQUM7SUFDckYsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxvQkFBb0IsQ0FBQyxRQUEwQjtRQUM3QyxNQUFNLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxRQUFRLHFCQUFxQixDQUFDO1FBQ2xELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzlDLENBQUM7d0dBdERVLHFCQUFxQjs0R0FBckIscUJBQXFCLGNBRnBCLE1BQU07OzRGQUVQLHFCQUFxQjtrQkFIakMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBFcnJvclJlc3BvbnNlLCBGbG93YWJsZVN0YXR1cywgUGFnZWQgfSBmcm9tICd2ZXJiZW4td29ya2Zsb3ctdWkvc3JjL2xpYi9tb2RlbHMnO1xuaW1wb3J0IHsgRW52aXJvbm1lbnRTZXJ2aWNlLCBIdHRwV2ViUmVxdWVzdFNlcnZpY2UgfSBmcm9tICd2ZXJiZW4td29ya2Zsb3ctdWkvc3JjL2xpYi9zZXJ2aWNlcyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBGbG93YWJsZVN0YXR1c1NlcnZpY2Uge1xuICBwcml2YXRlIHJlYWRvbmx5IEJBU0VfVVJMID0gJ1N0YXR1cyc7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBodHRwU2VydmljZTogSHR0cFdlYlJlcXVlc3RTZXJ2aWNlLFxuICAgIHByaXZhdGUgZW52U3ZjOiBFbnZpcm9ubWVudFNlcnZpY2VcbiAgKSB7IH1cblxuICAvKipcbiAgICogR2V0IGRhdGEgd2l0aCBwYWdpbmF0aW9uIGFuZCBzb3J0aW5nXG4gICAqIEBwYXJhbSBza2lwIE51bWJlciBvZiByZWNvcmRzIHRvIHNraXBcbiAgICogQHBhcmFtIGxpbWl0IE51bWJlciBvZiByZWNvcmRzIHRvIHRha2VcbiAgICogQHBhcmFtIHNvcnRQYXJhbSBTb3J0IHBhcmFtZXRlclxuICAgKiBAcGFyYW0gc29ydE9yZGVyIFNvcnQgb3JkZXIgKCdhc2MnIG9yICdkZXNjJylcbiAgICogQHJldHVybnMgUHJvbWlzZSBjb250YWluaW5nIHRoZSBkYXRhXG4gICAqL1xuICBnZXREYXRhKFxuICAgIHNraXA6IG51bWJlcixcbiAgICBsaW1pdDogbnVtYmVyLFxuICAgIHNvcnRQYXJhbTogc3RyaW5nLFxuICAgIHNvcnRPcmRlcjogc3RyaW5nXG4gICk6IFByb21pc2U8UGFnZWQ8Rmxvd2FibGVTdGF0dXM+IHwgRXJyb3JSZXNwb25zZT4ge1xuICAgIGNvbnN0IHVybCA9IGAke3RoaXMuQkFTRV9VUkx9L0dldEZsb3dhYmxlU3RhdHVzLyR7c2tpcH0vJHtsaW1pdH0vJHtzb3J0UGFyYW19LyR7c29ydE9yZGVyfWA7XG4gICAgcmV0dXJuIHRoaXMuaHR0cFNlcnZpY2UuZ2V0KHVybCkgYXMgUHJvbWlzZTxQYWdlZDxGbG93YWJsZVN0YXR1cz4gfCBFcnJvclJlc3BvbnNlPjtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgZGF0YSB3aXRoIGFkZGl0aW9uYWwgcGFyYW1ldGVyLCBwYWdpbmF0aW9uIGFuZCBzb3J0aW5nXG4gICAqIEBwYXJhbSBwYXJhbSBTZWFyY2ggcGFyYW1ldGVyXG4gICAqIEBwYXJhbSBza2lwIE51bWJlciBvZiByZWNvcmRzIHRvIHNraXBcbiAgICogQHBhcmFtIGxpbWl0IE51bWJlciBvZiByZWNvcmRzIHRvIHRha2VcbiAgICogQHBhcmFtIHNvcnRQYXJhbSBTb3J0IHBhcmFtZXRlclxuICAgKiBAcGFyYW0gc29ydE9yZGVyIFNvcnQgb3JkZXIgKCdhc2MnIG9yICdkZXNjJylcbiAgICogQHJldHVybnMgUHJvbWlzZSBjb250YWluaW5nIHRoZSBmaWx0ZXJlZCBkYXRhXG4gICAqL1xuICBnZXRGbG93YWJsZVN0YXR1c1dpdGhQYXJhbShcbiAgICBwYXJhbTogc3RyaW5nLFxuICAgIHNraXA6IG51bWJlcixcbiAgICBsaW1pdDogbnVtYmVyLFxuICAgIHNvcnRQYXJhbTogc3RyaW5nLFxuICAgIHNvcnRPcmRlcjogc3RyaW5nXG4gICk6IFByb21pc2U8UGFnZWQ8Rmxvd2FibGVTdGF0dXM+IHwgRXJyb3JSZXNwb25zZT4ge1xuICAgIGNvbnN0IHVybCA9IGAke3RoaXMuQkFTRV9VUkx9L0dldEZsb3dhYmxlU3RhdHVzV2l0aFBhcmFtLyR7cGFyYW19LyR7c2tpcH0vJHtsaW1pdH0vJHtzb3J0UGFyYW19LyR7c29ydE9yZGVyfWA7XG4gICAgcmV0dXJuIHRoaXMuaHR0cFNlcnZpY2UuZ2V0KHVybCkgYXMgUHJvbWlzZTxQYWdlZDxGbG93YWJsZVN0YXR1cz4gfCBFcnJvclJlc3BvbnNlPjtcbiAgfVxuXG4gIC8qKlxuICAgKiBTYXZlIG11bHRpcGxlIGRhdGFcbiAgICogQHBhcmFtIHJlcXVlc3RzIEFycmF5IG9mIGRhdGEgdG8gc2F2ZVxuICAgKiBAcmV0dXJucyBQcm9taXNlIGNvbnRhaW5pbmcgdGhlIHNhdmUgb3BlcmF0aW9uIHJlc3VsdFxuICAgKi9cbiAgc2F2ZUZsb3dhYmxlU3RhdHVzZXMocmVxdWVzdHM6IEZsb3dhYmxlU3RhdHVzW10pOiBQcm9taXNlPGFueSB8IEVycm9yUmVzcG9uc2U+IHtcbiAgICBjb25zdCB1cmwgPSBgJHt0aGlzLkJBU0VfVVJMfS9TYXZlRmxvd2FibGVTdGF0dXNgO1xuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLnBvc3QodXJsLCByZXF1ZXN0cyk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
|
+
import { SortDirection } from 'verben-workflow-ui/src/lib/models';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class FlowableStatusState {
|
|
6
|
+
updating$ = new BehaviorSubject(false);
|
|
7
|
+
data$ = new BehaviorSubject([]);
|
|
8
|
+
searchTerm$ = new BehaviorSubject('');
|
|
9
|
+
queryParams$ = new BehaviorSubject({
|
|
10
|
+
skip: 0,
|
|
11
|
+
limit: 20,
|
|
12
|
+
sortParam: 'CreatedAt',
|
|
13
|
+
sortOrder: SortDirection.Desc,
|
|
14
|
+
});
|
|
15
|
+
filterParams$ = new BehaviorSubject([]);
|
|
16
|
+
isUpdating$() {
|
|
17
|
+
return this.updating$.asObservable();
|
|
18
|
+
}
|
|
19
|
+
setUpdating(isUpdating) {
|
|
20
|
+
this.updating$.next(isUpdating);
|
|
21
|
+
}
|
|
22
|
+
getRequests$() {
|
|
23
|
+
return this.data$.asObservable();
|
|
24
|
+
}
|
|
25
|
+
setRequests(data) {
|
|
26
|
+
this.data$.next(data);
|
|
27
|
+
}
|
|
28
|
+
getSearchTerm$() {
|
|
29
|
+
return this.searchTerm$.asObservable();
|
|
30
|
+
}
|
|
31
|
+
getSearchTermValue() {
|
|
32
|
+
return this.searchTerm$.getValue();
|
|
33
|
+
}
|
|
34
|
+
setSearchTerm(term) {
|
|
35
|
+
this.searchTerm$.next(term);
|
|
36
|
+
}
|
|
37
|
+
getFilterParams$() {
|
|
38
|
+
return this.filterParams$.asObservable();
|
|
39
|
+
}
|
|
40
|
+
setFilterParams(params) {
|
|
41
|
+
this.filterParams$.next(params);
|
|
42
|
+
}
|
|
43
|
+
getQueryParams$() {
|
|
44
|
+
return this.queryParams$.asObservable();
|
|
45
|
+
}
|
|
46
|
+
getQueryParamsValue() {
|
|
47
|
+
return this.queryParams$.getValue();
|
|
48
|
+
}
|
|
49
|
+
updateQueryParams(params) {
|
|
50
|
+
this.queryParams$.next({ ...this.queryParams$.getValue(), ...params });
|
|
51
|
+
}
|
|
52
|
+
addRequest(task) {
|
|
53
|
+
const currentValue = this.data$.getValue();
|
|
54
|
+
this.data$.next([task, ...currentValue]);
|
|
55
|
+
}
|
|
56
|
+
resetPagination() {
|
|
57
|
+
const currentParams = this.queryParams$.getValue();
|
|
58
|
+
this.queryParams$.next({ ...currentParams, skip: 0 });
|
|
59
|
+
}
|
|
60
|
+
updateRequest(updatedRequest) {
|
|
61
|
+
const data = this.data$.getValue();
|
|
62
|
+
const index = data.findIndex((r) => r.Code === updatedRequest.Code);
|
|
63
|
+
if (index !== -1) {
|
|
64
|
+
data[index] = updatedRequest;
|
|
65
|
+
this.data$.next([...data]);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
removeRequest(code) {
|
|
69
|
+
const currentValue = this.data$.getValue();
|
|
70
|
+
this.data$.next(currentValue.filter((r) => r.Code !== code));
|
|
71
|
+
}
|
|
72
|
+
appendRequests(newRequests) {
|
|
73
|
+
const currentRequests = this.data$.getValue();
|
|
74
|
+
this.data$.next([...currentRequests, ...newRequests]);
|
|
75
|
+
}
|
|
76
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FlowableStatusState, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
77
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FlowableStatusState, providedIn: 'root' });
|
|
78
|
+
}
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FlowableStatusState, decorators: [{
|
|
80
|
+
type: Injectable,
|
|
81
|
+
args: [{
|
|
82
|
+
providedIn: 'root',
|
|
83
|
+
}]
|
|
84
|
+
}] });
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvd2FibGUtc3RhdHVzLnN0YXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmVyYmVuLXdvcmtmbG93LXVpL3NyYy9saWIvY29tcG9uZW50cy9mbG93YWJsZS1zdGF0dXMvZmxvd2FibGUtc3RhdHVzLnN0YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUVuRCxPQUFPLEVBQStCLGFBQWEsRUFBRSxNQUFNLG1DQUFtQyxDQUFDOztBQUsvRixNQUFNLE9BQU8sbUJBQW1CO0lBQ3RCLFNBQVMsR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztJQUNoRCxLQUFLLEdBQUcsSUFBSSxlQUFlLENBQW1CLEVBQUUsQ0FBQyxDQUFDO0lBQ2xELFdBQVcsR0FBRyxJQUFJLGVBQWUsQ0FBUyxFQUFFLENBQUMsQ0FBQztJQUM5QyxZQUFZLEdBQUcsSUFBSSxlQUFlLENBQThCO1FBQ3RFLElBQUksRUFBRSxDQUFDO1FBQ1AsS0FBSyxFQUFFLEVBQUU7UUFDVCxTQUFTLEVBQUUsV0FBVztRQUN0QixTQUFTLEVBQUUsYUFBYSxDQUFDLElBQUk7S0FDOUIsQ0FBQyxDQUFDO0lBQ0ssYUFBYSxHQUFHLElBQUksZUFBZSxDQUFnQixFQUFFLENBQUMsQ0FBQztJQUUvRCxXQUFXO1FBQ1QsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3ZDLENBQUM7SUFFRCxXQUFXLENBQUMsVUFBbUI7UUFDN0IsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELFlBQVk7UUFDVixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDbkMsQ0FBQztJ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R0FBbkIsbUJBQW1CLGNBRmxCLE1BQU07OzRGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IElEYXRhRmlsdGVyIH0gZnJvbSAndmVyYmVuLW5nLXVpJztcbmltcG9ydCB7IEZsb3dhYmxlU3RhdHVzLCBRdWVyeVBhcmFtcywgU29ydERpcmVjdGlvbiB9IGZyb20gJ3ZlcmJlbi13b3JrZmxvdy11aS9zcmMvbGliL21vZGVscyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBGbG93YWJsZVN0YXR1c1N0YXRlIHtcbiAgcHJpdmF0ZSB1cGRhdGluZyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcHJpdmF0ZSBkYXRhJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Rmxvd2FibGVTdGF0dXNbXT4oW10pO1xuICBwcml2YXRlIHNlYXJjaFRlcm0kID0gbmV3IEJlaGF2aW9yU3ViamVjdDxzdHJpbmc+KCcnKTtcbiAgcHJpdmF0ZSBxdWVyeVBhcmFtcyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFF1ZXJ5UGFyYW1zPEZsb3dhYmxlU3RhdHVzPj4oe1xuICAgIHNraXA6IDAsXG4gICAgbGltaXQ6IDIwLFxuICAgIHNvcnRQYXJhbTogJ0NyZWF0ZWRBdCcsXG4gICAgc29ydE9yZGVyOiBTb3J0RGlyZWN0aW9uLkRlc2MsXG4gIH0pO1xuICBwcml2YXRlIGZpbHRlclBhcmFtcyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PElEYXRhRmlsdGVyW10+KFtdKTtcblxuICBpc1VwZGF0aW5nJCgpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy51cGRhdGluZyQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBzZXRVcGRhdGluZyhpc1VwZGF0aW5nOiBib29sZWFuKTogdm9pZCB7XG4gICAgdGhpcy51cGRhdGluZyQubmV4dChpc1VwZGF0aW5nKTtcbiAgfVxuXG4gIGdldFJlcXVlc3RzJCgpOiBPYnNlcnZhYmxlPEZsb3dhYmxlU3RhdHVzW10+IHtcbiAgICByZXR1cm4gdGhpcy5kYXRhJC5hc09ic2VydmFibGUoKTtcbiAgfVxuXG4gIHNldFJlcXVlc3RzKGRhdGE6IEZsb3dhYmxlU3RhdHVzW10pOiB2b2lkIHtcbiAgICB0aGlzLmRhdGEkLm5leHQoZGF0YSk7XG4gIH1cblxuICBnZXRTZWFyY2hUZXJtJCgpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuICAgIHJldHVybiB0aGlzLnNlYXJjaFRlcm0kLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgZ2V0U2VhcmNoVGVybVZhbHVlKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuc2VhcmNoVGVybSQuZ2V0VmFsdWUoKTtcbiAgfVxuXG4gIHNldFNlYXJjaFRlcm0odGVybTogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5zZWFyY2hUZXJtJC5uZXh0KHRlcm0pO1xuICB9XG5cbiAgZ2V0RmlsdGVyUGFyYW1zJCgpOiBPYnNlcnZhYmxlPElEYXRhRmlsdGVyW10+IHtcbiAgICByZXR1cm4gdGhpcy5maWx0ZXJQYXJhbXMkLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgc2V0RmlsdGVyUGFyYW1zKHBhcmFtczogSURhdGFGaWx0ZXJbXSk6IHZvaWQge1xuICAgIHRoaXMuZmlsdGVyUGFyYW1zJC5uZXh0KHBhcmFtcyk7XG4gIH1cblxuICBnZXRRdWVyeVBhcmFtcyQoKTogT2JzZXJ2YWJsZTxRdWVyeVBhcmFtczxGbG93YWJsZVN0YXR1cz4+IHtcbiAgICByZXR1cm4gdGhpcy5xdWVyeVBhcmFtcyQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBnZXRRdWVyeVBhcmFtc1ZhbHVlKCk6IFF1ZXJ5UGFyYW1zPEZsb3dhYmxlU3RhdHVzPiB7XG4gICAgcmV0dXJuIHRoaXMucXVlcnlQYXJhbXMkLmdldFZhbHVlKCk7XG4gIH1cblxuICB1cGRhdGVRdWVyeVBhcmFtcyhwYXJhbXM6IFBhcnRpYWw8UXVlcnlQYXJhbXM8Rmxvd2FibGVTdGF0dXM+Pik6IHZvaWQge1xuICAgIHRoaXMucXVlcnlQYXJhbXMkLm5leHQoeyAuLi50aGlzLnF1ZXJ5UGFyYW1zJC5nZXRWYWx1ZSgpLCAuLi5wYXJhbXMgfSk7XG4gIH1cblxuICBhZGRSZXF1ZXN0KHRhc2s6IEZsb3dhYmxlU3RhdHVzKTogdm9pZCB7XG4gICAgY29uc3QgY3VycmVudFZhbHVlID0gdGhpcy5kYXRhJC5nZXRWYWx1ZSgpO1xuICAgIHRoaXMuZGF0YSQubmV4dChbdGFzaywgLi4uY3VycmVudFZhbHVlXSk7XG4gIH1cblxuICByZXNldFBhZ2luYXRpb24oKTogdm9pZCB7XG4gICAgY29uc3QgY3VycmVudFBhcmFtcyA9IHRoaXMucXVlcnlQYXJhbXMkLmdldFZhbHVlKCk7XG4gICAgdGhpcy5xdWVyeVBhcmFtcyQubmV4dCh7IC4uLmN1cnJlbnRQYXJhbXMsIHNraXA6IDAgfSk7XG4gIH1cblxuICB1cGRhdGVSZXF1ZXN0KHVwZGF0ZWRSZXF1ZXN0OiBGbG93YWJsZVN0YXR1cyk6IHZvaWQge1xuICAgIGNvbnN0IGRhdGEgPSB0aGlzLmRhdGEkLmdldFZhbHVlKCk7XG4gICAgY29uc3QgaW5kZXggPSBkYXRhLmZpbmRJbmRleCgocikgPT4gci5Db2RlID09PSB1cGRhdGVkUmVxdWVzdC5Db2RlKTtcbiAgICBpZiAoaW5kZXggIT09IC0xKSB7XG4gICAgICBkYXRhW2luZGV4XSA9IHVwZGF0ZWRSZXF1ZXN0O1xuICAgICAgdGhpcy5kYXRhJC5uZXh0KFsuLi5kYXRhXSk7XG4gICAgfVxuICB9XG5cbiAgcmVtb3ZlUmVxdWVzdChjb2RlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBjb25zdCBjdXJyZW50VmFsdWUgPSB0aGlzLmRhdGEkLmdldFZhbHVlKCk7XG4gICAgdGhpcy5kYXRhJC5uZXh0KGN1cnJlbnRWYWx1ZS5maWx0ZXIoKHIpID0+IHIuQ29kZSAhPT0gY29kZSkpO1xuICB9XG5cbiAgYXBwZW5kUmVxdWVzdHMobmV3UmVxdWVzdHM6IEZsb3dhYmxlU3RhdHVzW10pOiB2b2lkIHtcbiAgICBjb25zdCBjdXJyZW50UmVxdWVzdHMgPSB0aGlzLmRhdGEkLmdldFZhbHVlKCk7XG4gICAgdGhpcy5kYXRhJC5uZXh0KFsuLi5jdXJyZW50UmVxdWVzdHMsIC4uLm5ld1JlcXVlc3RzXSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4td29ya2Zsb3ctdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zsb3dhYmxlLXN0YXR1cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './flowable-status.component';
|
|
2
|
+
export * from './flowable-status.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZlcmJlbi13b3JrZmxvdy11aS9zcmMvbGliL2NvbXBvbmVudHMvZmxvd2FibGUtc3RhdHVzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9mbG93YWJsZS1zdGF0dXMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmxvd2FibGUtc3RhdHVzLm1vZHVsZSc7XG5cbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyYmVuLXdvcmtmbG93LXVpLXNyYy1saWItY29tcG9uZW50cy1mbG93YWJsZS1zdGF0dXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4td29ya2Zsb3ctdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zsb3dhYmxlLXN0YXR1cy92ZXJiZW4td29ya2Zsb3ctdWktc3JjLWxpYi1jb21wb25lbnRzLWZsb3dhYmxlLXN0YXR1cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
package/esm2022/src/lib/components/workflow-designer/action-dialog/action-dialog.component.mjs
CHANGED
|
@@ -13,6 +13,7 @@ export class ActionDialogComponent {
|
|
|
13
13
|
saved = new EventEmitter();
|
|
14
14
|
actionForm;
|
|
15
15
|
operationActions = signal([]);
|
|
16
|
+
flowableStatuses = signal([]);
|
|
16
17
|
// selectedOperationAction: BehaviorSubject<OperationAction["Code"] | null> = new BehaviorSubject<OperationAction["Code"] | null>(null);
|
|
17
18
|
constructor(fb, dataService) {
|
|
18
19
|
this.fb = fb;
|
|
@@ -20,6 +21,7 @@ export class ActionDialogComponent {
|
|
|
20
21
|
this.actionForm = this.fb.group({
|
|
21
22
|
Name: ['', Validators.required],
|
|
22
23
|
OperationAction: [null],
|
|
24
|
+
TargetStatus: [null],
|
|
23
25
|
});
|
|
24
26
|
effect(() => {
|
|
25
27
|
// If actionData changes, update the form
|
|
@@ -29,12 +31,14 @@ export class ActionDialogComponent {
|
|
|
29
31
|
this.actionForm.patchValue({
|
|
30
32
|
Name: actionData.label || '',
|
|
31
33
|
OperationAction: actionData.action || null,
|
|
34
|
+
TargetStatus: actionData.targetStatus || null,
|
|
32
35
|
});
|
|
33
36
|
}
|
|
34
37
|
});
|
|
35
38
|
}
|
|
36
39
|
ngOnInit() {
|
|
37
40
|
this.loadOperationActions();
|
|
41
|
+
this.loadFlowableStatuses();
|
|
38
42
|
}
|
|
39
43
|
saveAction() {
|
|
40
44
|
if (this.actionForm.valid) {
|
|
@@ -49,7 +53,8 @@ export class ActionDialogComponent {
|
|
|
49
53
|
this.saved.emit({
|
|
50
54
|
...prevData,
|
|
51
55
|
label: formData.Name,
|
|
52
|
-
action: formData.OperationAction
|
|
56
|
+
action: formData.OperationAction,
|
|
57
|
+
targetStatus: formData.TargetStatus
|
|
53
58
|
});
|
|
54
59
|
}
|
|
55
60
|
}
|
|
@@ -59,6 +64,11 @@ export class ActionDialogComponent {
|
|
|
59
64
|
this.operationActions.set(data.Result);
|
|
60
65
|
});
|
|
61
66
|
}
|
|
67
|
+
loadFlowableStatuses() {
|
|
68
|
+
this.dataService.getFlowableStatuses().then((data) => {
|
|
69
|
+
this.flowableStatuses.set(data.Result);
|
|
70
|
+
});
|
|
71
|
+
}
|
|
62
72
|
onDialogClose(eventData) {
|
|
63
73
|
console.log('Dialog closed, received data:', eventData);
|
|
64
74
|
this.closed.emit();
|
|
@@ -67,14 +77,14 @@ export class ActionDialogComponent {
|
|
|
67
77
|
console.log('Dialog opened, received data:', eventData);
|
|
68
78
|
}
|
|
69
79
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionDialogComponent, deps: [{ token: i1.FormBuilder }, { token: i2.WorkflowDataService }], target: i0.ɵɵFactoryTarget.Component });
|
|
70
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: ActionDialogComponent, selector: "lib-action-dialog", inputs: { visible: { classPropertyName: "visible", publicName: "visible", isSignal: true, isRequired: false, transformFunction: null }, actionData: { classPropertyName: "actionData", publicName: "actionData", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { closed: "closed", saved: "saved" }, ngImport: i0, template: "<verben-dialogue
|
|
80
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: ActionDialogComponent, selector: "lib-action-dialog", inputs: { visible: { classPropertyName: "visible", publicName: "visible", isSignal: true, isRequired: false, transformFunction: null }, actionData: { classPropertyName: "actionData", publicName: "actionData", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { closed: "closed", saved: "saved" }, ngImport: i0, template: "<verben-dialogue [showCloseIcon]=\"true\" [dismissOutsideClick]=\"true\" [closeOnEscape]=\"true\" [size]=\"'medium'\"\n [mode]=\"'drawer'\" [disableFooter]=\"false\" [isVisible]=\"visible()\" [headerTemplate]=\"headerTemplate\"\n [bodyTemplate]=\"bodyTemplate\" [footerTemplate]=\"footerTemplate\" (openModal)=\"onDialogOpen($event)\"\n (closeModal)=\"onDialogClose($event)\">\n</verben-dialogue>\n\n<ng-template #headerTemplate>\n <div class=\"flex items-center justify-between p-3 text-xs border-b-4 border-[#FFE681]\">\n <button class=\"mr-4\" type=\"button\" (click)=\"onDialogClose($event)\">\n <span class=\"block w-2.5 h-2.5 border-t border-l border-[#3E3E3E]/70 transform -rotate-45\"></span>\n </button>\n </div>\n</ng-template>\n\n<ng-template #bodyTemplate>\n <form [formGroup]=\"actionForm\" class=\"mb-4 space-y-4\">\n <verbena-input name=\"Name\" label=\"Name\" formControlName=\"Name\" placeHolder=\"Enter Name\" />\n\n <div class=\"space-y-1\">\n <label for=\"operation-action\" class=\"text-sm font-semibold text-[#3E3E3E]\">\n Operation Action\n </label>\n <verben-drop-down id=\"operation-action\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\"\n placeholder=\"Select Operation Action\" [options]=\"operationActions()\" optionLabel=\"Name\" optionValue=\"Code\"\n formControlName=\"OperationAction\" class=\"form-control\"></verben-drop-down>\n </div>\n\n <div class=\"space-y-1\">\n <label for=\"target-status\" class=\"text-sm font-semibold text-[#3E3E3E]\">\n Target Status\n </label>\n <verben-drop-down id=\"target-status\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\"\n placeholder=\"Select Target Status\" [options]=\"flowableStatuses()\" optionLabel=\"Description\" optionValue=\"Name\"\n formControlName=\"TargetStatus\" class=\"form-control\"></verben-drop-down>\n </div>\n </form>\n</ng-template>\n\n<ng-template #footerTemplate>\n <div class=\"flex gap-2 items-center justify-end\">\n <verbena-button (click)=\"onDialogClose($event)\" text=\"Cancel\" styleType=\"ylw-outline\"\n class=\"ml-auto\"></verbena-button>\n <verbena-button type=\"submit\" text=\"Save\" bgColor=\"#FFE681\" textColor=\"#404040\" borderRadius=\"10px\" pd=\"10px 20px\"\n width=\"114px\" height=\"39px\" (click)=\"saveAction()\" [disable]=\"actionForm.invalid\"></verbena-button>\n </div>\n</ng-template>\n", styles: ["::ng-deep .modal-footer{display:flex;justify-content:space-between!important}::ng-deep button,button{cursor:pointer}\n"], dependencies: [{ kind: "component", type: i3.VerbenDialogueComponent, selector: "verben-dialogue", inputs: ["dialogueWidth", "headerTemplate", "bodyTemplate", "footerTemplate", "showCloseIcon", "dismissOutsideClick", "closeOnEscape", "isVisible", "size", "backdropColor", "customClass", "disableFooter", "margin", "padding", "borderRadius", "dialogueBgColor", "width", "closeIconClass", "boxShadow", "enableTransition", "modalData", "mode", "position", "drawerWidth"], outputs: ["openModal", "closeModal"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "useIcon", "svgPosition", "iconPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "svgSize", "weight", "variant", "styleType", "svg", "svgWidth", "svgHeight", "iconColor", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }, { kind: "component", type: i3.DropDownComponent, selector: "verben-drop-down", inputs: ["options", "width", "showHorizontalLine", "horizontalLineColor", "optionLabel", "optionSubLabel", "optionValue", "placeholder", "invalidMessage", "errorPosition", "loadMoreCaption", "display", "showClear", "lazyLoad", "selectKey", "styleClass", "group", "multiselect", "filter", "avoidDuplication", "filterBy", "debounceTime", "minChar", "disabled", "required", "load", "asyncLabel", "search"], outputs: ["optionsChange", "onChange", "onClick", "onClear"] }, { kind: "component", type: i3.VerbenaInputComponent, selector: "verbena-input", inputs: ["label", "placeHolder", "required", "svgPosition", "minLength", "maxLength", "type", "bgColor", "border", "borderRadius", "textColor", "value", "labelPosition", "labelColor", "disable", "readOnly", "min", "max", "showBorder", "showErrorMessage", "errorMessageColor", "errorBorderColor", "errorPosition", "svg", "fontSize", "svgWidth", "svgHeight", "svgColor", "capitalization", "inputContainerClass", "inputFieldClass", "passLength", "inputWrapperClass", "passwordToggle", "customErrorMessages", "icon", "textPass"], outputs: ["valueChange"] }] });
|
|
71
81
|
}
|
|
72
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionDialogComponent, decorators: [{
|
|
73
83
|
type: Component,
|
|
74
|
-
args: [{ selector: 'lib-action-dialog', template: "<verben-dialogue
|
|
84
|
+
args: [{ selector: 'lib-action-dialog', template: "<verben-dialogue [showCloseIcon]=\"true\" [dismissOutsideClick]=\"true\" [closeOnEscape]=\"true\" [size]=\"'medium'\"\n [mode]=\"'drawer'\" [disableFooter]=\"false\" [isVisible]=\"visible()\" [headerTemplate]=\"headerTemplate\"\n [bodyTemplate]=\"bodyTemplate\" [footerTemplate]=\"footerTemplate\" (openModal)=\"onDialogOpen($event)\"\n (closeModal)=\"onDialogClose($event)\">\n</verben-dialogue>\n\n<ng-template #headerTemplate>\n <div class=\"flex items-center justify-between p-3 text-xs border-b-4 border-[#FFE681]\">\n <button class=\"mr-4\" type=\"button\" (click)=\"onDialogClose($event)\">\n <span class=\"block w-2.5 h-2.5 border-t border-l border-[#3E3E3E]/70 transform -rotate-45\"></span>\n </button>\n </div>\n</ng-template>\n\n<ng-template #bodyTemplate>\n <form [formGroup]=\"actionForm\" class=\"mb-4 space-y-4\">\n <verbena-input name=\"Name\" label=\"Name\" formControlName=\"Name\" placeHolder=\"Enter Name\" />\n\n <div class=\"space-y-1\">\n <label for=\"operation-action\" class=\"text-sm font-semibold text-[#3E3E3E]\">\n Operation Action\n </label>\n <verben-drop-down id=\"operation-action\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\"\n placeholder=\"Select Operation Action\" [options]=\"operationActions()\" optionLabel=\"Name\" optionValue=\"Code\"\n formControlName=\"OperationAction\" class=\"form-control\"></verben-drop-down>\n </div>\n\n <div class=\"space-y-1\">\n <label for=\"target-status\" class=\"text-sm font-semibold text-[#3E3E3E]\">\n Target Status\n </label>\n <verben-drop-down id=\"target-status\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\"\n placeholder=\"Select Target Status\" [options]=\"flowableStatuses()\" optionLabel=\"Description\" optionValue=\"Name\"\n formControlName=\"TargetStatus\" class=\"form-control\"></verben-drop-down>\n </div>\n </form>\n</ng-template>\n\n<ng-template #footerTemplate>\n <div class=\"flex gap-2 items-center justify-end\">\n <verbena-button (click)=\"onDialogClose($event)\" text=\"Cancel\" styleType=\"ylw-outline\"\n class=\"ml-auto\"></verbena-button>\n <verbena-button type=\"submit\" text=\"Save\" bgColor=\"#FFE681\" textColor=\"#404040\" borderRadius=\"10px\" pd=\"10px 20px\"\n width=\"114px\" height=\"39px\" (click)=\"saveAction()\" [disable]=\"actionForm.invalid\"></verbena-button>\n </div>\n</ng-template>\n", styles: ["::ng-deep .modal-footer{display:flex;justify-content:space-between!important}::ng-deep button,button{cursor:pointer}\n"] }]
|
|
75
85
|
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.WorkflowDataService }], propDecorators: { closed: [{
|
|
76
86
|
type: Output
|
|
77
87
|
}], saved: [{
|
|
78
88
|
type: Output
|
|
79
89
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/verben-workflow-ui/src/lib/components/workflow-designer/action-dialog/action-dialog.component.ts","../../../../../../../../projects/verben-workflow-ui/src/lib/components/workflow-designer/action-dialog/action-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  effect,\n  EventEmitter,\n  input,\n  OnInit,\n  Output,\n  signal,\n  WritableSignal\n} from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { OperationAction, WorkflowAction } from 'verben-workflow-ui/src/lib/models';\nimport { WorkflowDataService } from '../workflow-data.service';\nimport {\n  Connection,\n} from '../workflow-designer.types';\n\n@Component({\n  selector: 'lib-action-dialog',\n  templateUrl: './action-dialog.component.html',\n  styleUrl: './action-dialog.component.css',\n})\nexport class ActionDialogComponent implements OnInit {\n  visible = input<boolean>(false);\n  actionData = input.required<Connection | null>(); // For editing existing stages\n  @Output() closed = new EventEmitter();\n  @Output() saved = new EventEmitter<Connection>();\n\n  actionForm: FormGroup;\n\n  operationActions: WritableSignal<OperationAction[]> = signal([]);\n\n  // selectedOperationAction: BehaviorSubject<OperationAction[\"Code\"] | null> = new BehaviorSubject<OperationAction[\"Code\"] | null>(null);\n\n  constructor(\n    private fb: FormBuilder,\n    private dataService: WorkflowDataService\n  ) {\n    this.actionForm = this.fb.group({\n      Name: ['', Validators.required],\n      OperationAction: [null],\n    });\n\n    effect(() => {\n      // If actionData changes, update the form\n      const actionData = this.actionData();\n      if (actionData) {\n        console.log(\"ACTION_DATA\", actionData);\n        this.actionForm.patchValue({\n          Name: actionData.label || '',\n          OperationAction: actionData.action || null,\n        });\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    this.loadOperationActions();\n  }\n\n  saveAction(): void {\n    if (this.actionForm.valid) {\n\n      const formData = this.actionForm.value as Pick<WorkflowAction, \"Name\" | \"OperationAction\">;\n\n      // Reset form after saving\n      this.actionForm.reset();\n\n      // Emit the saved data to the parent component\n\n      const prevData = this.actionData();\n\n      console.log(\"PREV_DATA\", prevData);\n      console.log(\"FORM_DATA\", formData);\n\n      if (prevData) {\n        this.saved.emit({\n          ...prevData,\n          label: formData.Name,\n          action: formData.OperationAction\n        });\n      }\n    }\n  }\n\n  private loadOperationActions(): void {\n    this.dataService.getOperationActions().then((data) => {\n      this.operationActions.set(data.Result);\n    });\n  }\n\n  onDialogClose(eventData: any) {\n    console.log('Dialog closed, received data:', eventData);\n    this.closed.emit();\n  }\n\n  onDialogOpen(eventData: any) {\n    console.log('Dialog opened, received data:', eventData);\n  }\n}\n","<verben-dialogue\n  [showCloseIcon]=\"true\"\n  [dismissOutsideClick]=\"true\"\n  [closeOnEscape]=\"true\"\n  [size]=\"'medium'\"\n  [mode]=\"'drawer'\"\n  [disableFooter]=\"false\"\n  [isVisible]=\"visible()\"\n  [headerTemplate]=\"headerTemplate\"\n  [bodyTemplate]=\"bodyTemplate\"\n  [footerTemplate]=\"footerTemplate\"\n  (openModal)=\"onDialogOpen($event)\"\n  (closeModal)=\"onDialogClose($event)\"\n>\n</verben-dialogue>\n\n<ng-template #headerTemplate>\n  <div\n    class=\"flex items-center justify-between p-3 text-xs border-b-4 border-[#FFE681]\"\n  >\n    <button class=\"mr-4\" type=\"button\" (click)=\"onDialogClose($event)\">\n      <span\n        class=\"block w-2.5 h-2.5 border-t border-l border-[#3E3E3E]/70 transform -rotate-45\"\n      ></span>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #bodyTemplate>\n  <form [formGroup]=\"actionForm\" class=\"mb-4 space-y-4\">\n    <verbena-input\n      name=\"Name\"\n      label=\"Name\"\n      formControlName=\"Name\"\n      placeHolder=\"Enter Name\"\n    />\n\n    <div class=\"space-y-1\">\n      <label\n        for=\"operation-action\"\n        class=\"text-sm font-semibold text-[#3E3E3E]\"\n      >\n        Operation Action\n      </label>\n      <verben-drop-down\n        id=\"operation-action\"\n        styleClass=\"w-full\"\n        width=\"100%\"\n        [multiselect]=\"false\"\n        placeholder=\"Select Operation Action\"\n        [options]=\"operationActions()\"\n        optionLabel=\"Name\"\n        optionValue=\"Code\"\n        formControlName=\"OperationAction\"\n        class=\"form-control\"\n      ></verben-drop-down>\n    </div>\n  </form>\n</ng-template>\n\n<ng-template #footerTemplate>\n    <div class=\"flex gap-2 items-center justify-end\">\n      <verbena-button\n        (click)=\"onDialogClose($event)\"\n        text=\"Cancel\"\n        styleType=\"ylw-outline\"\n        class=\"ml-auto\"\n      ></verbena-button>\n      <verbena-button\n        type=\"submit\"\n        text=\"Save\"\n        bgColor=\"#FFE681\"\n        textColor=\"#404040\"\n        borderRadius=\"10px\"\n        pd=\"10px 20px\"\n        width=\"114px\"\n        height=\"39px\"\n        (click)=\"saveAction()\"\n        [disable]=\"actionForm.invalid\"\n      ></verbena-button>\n    </div>\n</ng-template>\n"]}
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/verben-workflow-ui/src/lib/components/workflow-designer/action-dialog/action-dialog.component.ts","../../../../../../../../projects/verben-workflow-ui/src/lib/components/workflow-designer/action-dialog/action-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  effect,\n  EventEmitter,\n  input,\n  OnInit,\n  Output,\n  signal,\n  WritableSignal\n} from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { FlowableStatus, OperationAction, WorkflowAction } from 'verben-workflow-ui/src/lib/models';\nimport { WorkflowDataService } from '../workflow-data.service';\nimport {\n  Connection,\n} from '../workflow-designer.types';\n\n@Component({\n  selector: 'lib-action-dialog',\n  templateUrl: './action-dialog.component.html',\n  styleUrl: './action-dialog.component.css',\n})\nexport class ActionDialogComponent implements OnInit {\n  visible = input<boolean>(false);\n  actionData = input.required<Connection | null>(); // For editing existing stages\n  @Output() closed = new EventEmitter();\n  @Output() saved = new EventEmitter<Connection>();\n\n  actionForm: FormGroup;\n\n  operationActions: WritableSignal<OperationAction[]> = signal([]);\n  flowableStatuses: WritableSignal<FlowableStatus[]> = signal([]);\n\n  // selectedOperationAction: BehaviorSubject<OperationAction[\"Code\"] | null> = new BehaviorSubject<OperationAction[\"Code\"] | null>(null);\n\n  constructor(\n    private fb: FormBuilder,\n    private dataService: WorkflowDataService\n  ) {\n    this.actionForm = this.fb.group({\n      Name: ['', Validators.required],\n      OperationAction: [null],\n      TargetStatus: [null],\n    });\n\n    effect(() => {\n      // If actionData changes, update the form\n      const actionData = this.actionData();\n      if (actionData) {\n        console.log(\"ACTION_DATA\", actionData);\n        this.actionForm.patchValue({\n          Name: actionData.label || '',\n          OperationAction: actionData.action || null,\n          TargetStatus: actionData.targetStatus || null,\n        });\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    this.loadOperationActions();\n    this.loadFlowableStatuses();\n  }\n\n  saveAction(): void {\n    if (this.actionForm.valid) {\n\n      const formData = this.actionForm.value as Pick<WorkflowAction, \"Name\" | \"OperationAction\" | \"TargetStatus\">;\n\n      // Reset form after saving\n      this.actionForm.reset();\n\n      // Emit the saved data to the parent component\n\n      const prevData = this.actionData();\n\n      console.log(\"PREV_DATA\", prevData);\n      console.log(\"FORM_DATA\", formData);\n\n      if (prevData) {\n        this.saved.emit({\n          ...prevData,\n          label: formData.Name,\n          action: formData.OperationAction,\n          targetStatus: formData.TargetStatus\n        });\n      }\n    }\n  }\n\n  private loadOperationActions(): void {\n    this.dataService.getOperationActions().then((data) => {\n      this.operationActions.set(data.Result);\n    });\n  }\n\n  private loadFlowableStatuses(): void {\n    this.dataService.getFlowableStatuses().then((data) => {\n      this.flowableStatuses.set(data.Result);\n    });\n  }\n\n  onDialogClose(eventData: any) {\n    console.log('Dialog closed, received data:', eventData);\n    this.closed.emit();\n  }\n\n  onDialogOpen(eventData: any) {\n    console.log('Dialog opened, received data:', eventData);\n  }\n}\n","<verben-dialogue [showCloseIcon]=\"true\" [dismissOutsideClick]=\"true\" [closeOnEscape]=\"true\" [size]=\"'medium'\"\n  [mode]=\"'drawer'\" [disableFooter]=\"false\" [isVisible]=\"visible()\" [headerTemplate]=\"headerTemplate\"\n  [bodyTemplate]=\"bodyTemplate\" [footerTemplate]=\"footerTemplate\" (openModal)=\"onDialogOpen($event)\"\n  (closeModal)=\"onDialogClose($event)\">\n</verben-dialogue>\n\n<ng-template #headerTemplate>\n  <div class=\"flex items-center justify-between p-3 text-xs border-b-4 border-[#FFE681]\">\n    <button class=\"mr-4\" type=\"button\" (click)=\"onDialogClose($event)\">\n      <span class=\"block w-2.5 h-2.5 border-t border-l border-[#3E3E3E]/70 transform -rotate-45\"></span>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #bodyTemplate>\n  <form [formGroup]=\"actionForm\" class=\"mb-4 space-y-4\">\n    <verbena-input name=\"Name\" label=\"Name\" formControlName=\"Name\" placeHolder=\"Enter Name\" />\n\n    <div class=\"space-y-1\">\n      <label for=\"operation-action\" class=\"text-sm font-semibold text-[#3E3E3E]\">\n        Operation Action\n      </label>\n      <verben-drop-down id=\"operation-action\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\"\n        placeholder=\"Select Operation Action\" [options]=\"operationActions()\" optionLabel=\"Name\" optionValue=\"Code\"\n        formControlName=\"OperationAction\" class=\"form-control\"></verben-drop-down>\n    </div>\n\n    <div class=\"space-y-1\">\n      <label for=\"target-status\" class=\"text-sm font-semibold text-[#3E3E3E]\">\n        Target Status\n      </label>\n      <verben-drop-down id=\"target-status\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\"\n        placeholder=\"Select Target Status\" [options]=\"flowableStatuses()\" optionLabel=\"Description\" optionValue=\"Name\"\n        formControlName=\"TargetStatus\" class=\"form-control\"></verben-drop-down>\n    </div>\n  </form>\n</ng-template>\n\n<ng-template #footerTemplate>\n  <div class=\"flex gap-2 items-center justify-end\">\n    <verbena-button (click)=\"onDialogClose($event)\" text=\"Cancel\" styleType=\"ylw-outline\"\n      class=\"ml-auto\"></verbena-button>\n    <verbena-button type=\"submit\" text=\"Save\" bgColor=\"#FFE681\" textColor=\"#404040\" borderRadius=\"10px\" pd=\"10px 20px\"\n      width=\"114px\" height=\"39px\" (click)=\"saveAction()\" [disable]=\"actionForm.invalid\"></verbena-button>\n  </div>\n</ng-template>\n"]}
|