verben-authentication-ui 1.0.23 → 1.0.26
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/src/lib/components/user-management/services/user-management.service.mjs +24 -2
- package/esm2022/src/lib/components/user-management/user-management-form/user-management-form.component.mjs +41 -8
- package/esm2022/src/lib/components/user-management/user-management.component.mjs +5 -7
- package/esm2022/src/lib/models/user.mjs +1 -1
- package/esm2022/src/lib/services/environment.service.mjs +2 -2
- package/fesm2022/verben-authentication-ui-src-lib-components-user-management.mjs +126 -72
- package/fesm2022/verben-authentication-ui-src-lib-components-user-management.mjs.map +1 -1
- package/fesm2022/verben-authentication-ui-src-lib-services.mjs.map +1 -1
- package/package.json +25 -25
- package/src/lib/components/user-management/services/user-management.service.d.ts +3 -3
- package/src/lib/components/user-management/user-management-form/user-management-form.component.d.ts +15 -6
- package/src/lib/components/user-management/user-management.component.d.ts +7 -12
- package/src/lib/models/user.d.ts +1 -0
- package/src/lib/services/environment.service.d.ts +1 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
-
import { ErrorResponse } from 'verben-authentication-ui/src/lib/models';
|
|
2
|
+
import { ErrorResponse, SearchOperator, SearchPropertySign, SortDirection } from 'verben-authentication-ui/src/lib/models';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "verben-authentication-ui/src/lib/services";
|
|
5
5
|
export class UserManagementService {
|
|
@@ -76,6 +76,28 @@ export class UserManagementService {
|
|
|
76
76
|
const url = `User/DeleteUsers`;
|
|
77
77
|
return this.httpService.delete(`${url}?data=${userIds.join(',')}`);
|
|
78
78
|
}
|
|
79
|
+
async loadEntities(entity, fields, env, event = null) {
|
|
80
|
+
var payload = {
|
|
81
|
+
Fields: fields,
|
|
82
|
+
SearchKeyValues: [
|
|
83
|
+
{
|
|
84
|
+
PropertyName: 'Code',
|
|
85
|
+
EntityValue: '',
|
|
86
|
+
Operator: SearchOperator.And,
|
|
87
|
+
Sign: SearchPropertySign.EQ,
|
|
88
|
+
Sort: SortDirection.Asc,
|
|
89
|
+
},
|
|
90
|
+
],
|
|
91
|
+
};
|
|
92
|
+
const res = await this.httpService.post(`SearchDynamic${entity}/0/0`, payload, env);
|
|
93
|
+
if (res instanceof ErrorResponse) {
|
|
94
|
+
return [];
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
var result = res.Result;
|
|
98
|
+
return result;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
79
101
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserManagementService, deps: [{ token: i1.HttpWebRequestService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
80
102
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserManagementService, providedIn: 'root' });
|
|
81
103
|
}
|
|
@@ -85,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
85
107
|
providedIn: 'root',
|
|
86
108
|
}]
|
|
87
109
|
}], ctorParameters: () => [{ type: i1.HttpWebRequestService }] });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-management.service.js","sourceRoot":"","sources":["../../../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/services/user-management.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,aAAa,EAAqC,cAAc,EAAE,kBAAkB,EAAE,aAAa,EAAQ,MAAM,yCAAyC,CAAC;;;AAOpK,MAAM,OAAO,qBAAqB;IAGZ;IAFpB,gEAAgE;IAEhE,YAAoB,WAAkC;QAAlC,gBAAW,GAAX,WAAW,CAAuB;IAAI,CAAC;IAE3D;;;;;;;OAOG;IACH,KAAK,CAAC,QAAQ,CACZ,IAAY,EACZ,KAAa,EACb,SAAiB,EACjB,SAAiB;QAEjB,yCAAyC;QACzC,MAAM,GAAG,GAAG,iBAAiB,IAAI,IAAI,KAAK,IAAI,SAAS,IAAI,SAAS,EAAE,CAAC;QACvE,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAE5C,IAAI,GAAG,YAAY,aAAa,EAAE,CAAC;YACjC,OAAO,GAAG,CAAC;QACb,CAAC;aAAM,CAAC;YACN,OAAQ,GAAyB,CAAC,MAAM,CAAC;QAC3C,CAAC;IACH,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,iBAAiB,CACrB,KAAa,EACb,IAAY,EACZ,KAAa,EACb,SAAiB,EACjB,SAAiB;QAEjB,MAAM,GAAG,GAAG,yBAAyB,KAAK,IAAI,IAAI,IAAI,KAAK,IAAI,SAAS,IAAI,SAAS,EAAE,CAAC;QACxF,OAAO,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAW,CAAC;IACrD,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,IAAmB,EACnB,IAAY,EACZ,KAAa,EACb,SAAiB,EACjB,SAAiB;QAEjB,IAAI,GAAW,CAAC;QAEhB,IAAI,IAAI,EAAE,CAAC;YACT,wDAAwD;YACxD,GAAG,GAAG,yBAAyB,IAAI,IAAI,IAAI,IAAI,KAAK,IAAI,SAAS,IAAI,SAAS,EAAE,CAAC;QACnF,CAAC;aAAM,CAAC;YACN,4CAA4C;YAC5C,GAAG,GAAG,iBAAiB,IAAI,IAAI,KAAK,IAAI,SAAS,IAAI,SAAS,EAAE,CAAC;QACnE,CAAC;QAED,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAE5C,IAAI,GAAG,YAAY,aAAa,EAAE,CAAC;YACjC,OAAO,GAAG,CAAC;QACb,CAAC;aAAM,CAAC;YACN,OAAO,GAAwB,CAAC;QAClC,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,SAAS,CAAC,KAAa;QACrB,MAAM,GAAG,GAAG,gBAAgB,CAAC;QAC7B,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,OAAiB;QAC3B,MAAM,GAAG,GAAG,kBAAkB,CAAC;QAC/B,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,GAAG,SAAS,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,MAAc,EACd,MAAgB,EAChB,GAAW,EACX,QAAkC,IAAI;QAEtC,IAAI,OAAO,GAAyB;YAClC,MAAM,EAAE,MAAM;YACd,eAAe,EAAE;gBACf;oBACE,YAAY,EAAE,MAAM;oBACpB,WAAW,EAAE,EAAE;oBACf,QAAQ,EAAE,cAAc,CAAC,GAAG;oBAC5B,IAAI,EAAE,kBAAkB,CAAC,EAAE;oBAC3B,IAAI,EAAE,aAAa,CAAC,GAAG;iBACxB;aACF;SACF,CAAC;QAEF,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,IAAI,CACrC,gBAAgB,MAAM,MAAM,EAC5B,OAAO,EACP,GAAG,CACJ,CAAC;QACF,IAAI,GAAG,YAAY,aAAa,EAAE,CAAC;YACjC,OAAO,EAAE,CAAC;QACZ,CAAC;aAAM,CAAC;YACN,IAAI,MAAM,GAAI,GAAsB,CAAC,MAAM,CAAC;YAC5C,OAAO,MAAM,CAAC;QAChB,CAAC;IACH,CAAC;wGA9HU,qBAAqB;4GAArB,qBAAqB,cAFpB,MAAM;;4FAEP,qBAAqB;kBAHjC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { ErrorResponse, PagedResult, SearchDynamicWrapper, SearchOperator, SearchPropertySign, SortDirection, User } from 'verben-authentication-ui/src/lib/models';\nimport { HttpWebRequestService } from 'verben-authentication-ui/src/lib/services';\nimport { DropdownLoadEvent } from 'verben-ng-ui';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class UserManagementService {\n  // private readonly BASE_URL = 'https://auth.white360.net/User';\n\n  constructor(private httpService: HttpWebRequestService) { }\n\n  /**\n   * Get users with pagination and sorting\n   * @param skip Number of records to skip\n   * @param limit Number of records to take\n   * @param sortParam Sort parameter\n   * @param sortOrder Sort order ('asc' or 'desc')\n   * @returns Promise containing the list of users\n   */\n  async getUsers(\n    skip: number,\n    limit: number,\n    sortParam: string,\n    sortOrder: string\n  ): Promise<User[] | ErrorResponse> {\n    // var response : User[] | ErrorResponse;\n    const url = `User/GetUsers/${skip}/${limit}/${sortParam}/${sortOrder}`;\n    const res = await this.httpService.get(url);\n\n    if (res instanceof ErrorResponse) {\n      return res;\n    } else {\n      return (res as PagedResult<User>).Result;\n    }\n  }\n\n  /**\n   * Get users with an additional search parameter, pagination, and sorting\n   * @param param Search parameter\n   * @param skip Number of records to skip\n   * @param limit Number of records to take\n   * @param sortParam Sort parameter\n   * @param sortOrder Sort order ('asc' or 'desc')\n   * @returns Promise containing the filtered list of users\n   */\n  async getUsersWithParam(\n    param: string,\n    skip: number,\n    limit: number,\n    sortParam: string,\n    sortOrder: string\n  ): Promise<User[]> {\n    const url = `User/GetUserWithParam/${param}/${skip}/${limit}/${sortParam}/${sortOrder}`;\n    return (await this.httpService.get(url)) as User[];\n  }\n\n  async getRealUsers(\n    role: string | null,\n    skip: number,\n    limit: number,\n    sortParam: string,\n    sortOrder: string\n  ) {\n    let url: string;\n\n    if (role) {\n      // Role is provided, use the \"GetUserWithParam\" endpoint\n      url = `User/GetUserWithParam/${role}/${skip}/${limit}/${sortParam}/${sortOrder}`;\n    } else {\n      // Role is null, use the \"GetUsers\" endpoint\n      url = `User/GetUsers/${skip}/${limit}/${sortParam}/${sortOrder}`;\n    }\n\n    const res = await this.httpService.get(url);\n\n    if (res instanceof ErrorResponse) {\n      return res;\n    } else {\n      return res as PagedResult<User>;\n    }\n  }\n\n  /**\n   * Save multiple users\n   * @param users Array of users to save\n   * @returns Promise containing the save operation result\n   */\n  saveUsers(users: User[]): Promise<any> {\n    const url = `User/SaveUsers`;\n    return this.httpService.post(url, users);\n  }\n\n  /**\n   * Delete multiple users\n   * @param userIds Array of user IDs to delete\n   * @returns Observable containing the delete operation result\n   */\n  deleteUsers(userIds: string[]): Observable<any> {\n    const url = `User/DeleteUsers`;\n    return this.httpService.delete(`${url}?data=${userIds.join(',')}`);\n  }\n\n  async loadEntities<T>(\n    entity: string,\n    fields: string[],\n    env: string,\n    event: DropdownLoadEvent | null = null\n  ): Promise<T[]> {\n    var payload: SearchDynamicWrapper = {\n      Fields: fields,\n      SearchKeyValues: [\n        {\n          PropertyName: 'Code',\n          EntityValue: '',\n          Operator: SearchOperator.And,\n          Sign: SearchPropertySign.EQ,\n          Sort: SortDirection.Asc,\n        },\n      ],\n    };\n\n    const res = await this.httpService.post(\n      `SearchDynamic${entity}/0/0`,\n      payload,\n      env\n    );\n    if (res instanceof ErrorResponse) {\n      return [];\n    } else {\n      var result = (res as PagedResult<T>).Result;\n      return result;\n    }\n  }\n}\n"]}
|
|
@@ -2,13 +2,21 @@ import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
|
2
2
|
import { Status } from 'verben-authentication-ui/src/lib/models';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/forms";
|
|
5
|
-
import * as i2 from "
|
|
5
|
+
import * as i2 from "../services/user-management.service";
|
|
6
|
+
import * as i3 from "verben-authentication-ui/src/lib/services";
|
|
7
|
+
import * as i4 from "verben-ng-ui";
|
|
6
8
|
export class UserManagementFormComponent {
|
|
7
9
|
fb;
|
|
10
|
+
userManagementService;
|
|
11
|
+
envService;
|
|
8
12
|
// @Input() roles: Role[] = [];
|
|
9
13
|
// @Input() status: Status[] = [];
|
|
10
14
|
set currentData(value) {
|
|
11
15
|
if (value?.data) {
|
|
16
|
+
// Convert comma-separated warehouse codes back to array for dropdown
|
|
17
|
+
const warehouseCodes = value.data.Warehouses
|
|
18
|
+
? value.data.Warehouses.split(',').filter((code) => code.trim())
|
|
19
|
+
: [];
|
|
12
20
|
this.form.patchValue({
|
|
13
21
|
MailAddress: value.data.MailAddress || '',
|
|
14
22
|
FirstName: value.data.FirstName || '',
|
|
@@ -17,6 +25,7 @@ export class UserManagementFormComponent {
|
|
|
17
25
|
RoleID: value.data.RoleID || '',
|
|
18
26
|
Tags: value.data.Tags || [],
|
|
19
27
|
Status: value.data.Status || Status.Active,
|
|
28
|
+
Warehouses: warehouseCodes,
|
|
20
29
|
});
|
|
21
30
|
}
|
|
22
31
|
else {
|
|
@@ -29,8 +38,11 @@ export class UserManagementFormComponent {
|
|
|
29
38
|
onFormSave = new EventEmitter();
|
|
30
39
|
form;
|
|
31
40
|
statusOptions = Object.values(Status);
|
|
32
|
-
|
|
41
|
+
warehouses = [];
|
|
42
|
+
constructor(fb, userManagementService, envService) {
|
|
33
43
|
this.fb = fb;
|
|
44
|
+
this.userManagementService = userManagementService;
|
|
45
|
+
this.envService = envService;
|
|
34
46
|
this.form = this.fb.group({
|
|
35
47
|
MailAddress: ['', { readonly: true }],
|
|
36
48
|
FirstName: ['', { readonly: true }],
|
|
@@ -39,9 +51,30 @@ export class UserManagementFormComponent {
|
|
|
39
51
|
Status: ['', { readonly: true }],
|
|
40
52
|
RoleID: [''],
|
|
41
53
|
Tags: [[]],
|
|
54
|
+
Warehouses: [[]],
|
|
42
55
|
});
|
|
43
56
|
}
|
|
44
|
-
ngOnInit() {
|
|
57
|
+
ngOnInit() {
|
|
58
|
+
this.loadWarehouses();
|
|
59
|
+
}
|
|
60
|
+
async loadWarehouses() {
|
|
61
|
+
try {
|
|
62
|
+
this.warehouses = await this.userManagementService.loadEntities('Warehouse', ['Name', 'Code'], this.envService.environment.RevenueAPI);
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
console.error('Error loading warehouses:', error);
|
|
66
|
+
this.warehouses = [];
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
onWarehouseChange(event) {
|
|
70
|
+
// Convert array of warehouse codes to comma-separated string
|
|
71
|
+
const selectedCodes = event.value;
|
|
72
|
+
const commaSeparated = selectedCodes ? selectedCodes.join(',') : '';
|
|
73
|
+
// Update the form with the comma-separated value for saving
|
|
74
|
+
this.form.patchValue({
|
|
75
|
+
Warehouses: commaSeparated
|
|
76
|
+
}, { emitEvent: false });
|
|
77
|
+
}
|
|
45
78
|
onSave() {
|
|
46
79
|
if (this.form.valid) {
|
|
47
80
|
// Emit save event with form value
|
|
@@ -53,13 +86,13 @@ export class UserManagementFormComponent {
|
|
|
53
86
|
// Emit delete event
|
|
54
87
|
console.log('Delete requested');
|
|
55
88
|
}
|
|
56
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserManagementFormComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
57
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UserManagementFormComponent, selector: "lib-user-request-form", inputs: { currentData: "currentData", roles: "roles", tags: "tags" }, outputs: { switchView: "switchView", onFormSave: "onFormSave" }, ngImport: i0, template: "<form
|
|
89
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserManagementFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.UserManagementService }, { token: i3.EnvironmentService }], target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UserManagementFormComponent, selector: "lib-user-request-form", inputs: { currentData: "currentData", roles: "roles", tags: "tags" }, outputs: { switchView: "switchView", onFormSave: "onFormSave" }, ngImport: i0, template: "<form [formGroup]=\"form\" class=\"flex flex-col px-3 pb-3 rounded-xl h-full w-full relative space-y-4\">\n <verbena-input label=\"Name:\" name=\"FirstName\" type=\"text\" formControlName=\"FirstName\" />\n <verbena-input label=\"Phone Number:\" name=\"PhoneNumber\" type=\"tel\" formControlName=\"PhoneNumber\" />\n <verbena-input name=\"MailAddress\" label=\"E-Mail Address:\" [type]=\"'email'\" formControlName=\"MailAddress\" />\n <!-- <verbena-input\n label=\"Address\"\n name=\"Address\"\n type=\"text\"\n formControlName=\"Address\"\n /> -->\n\n <div class=\"space-y-1\">\n <label for=\"role\">Role</label>\n\n <verben-drop-down label=\"Role\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\" [filter]=\"true\"\n [showClear]=\"true\" placeholder=\"\" [(options)]=\"roles\" id=\"role\" optionLabel=\"Name\" optionValue=\"Code\"\n formControlName=\"RoleID\" class=\"form-control\">\n </verben-drop-down>\n </div>\n\n <div class=\"space-y-1\">\n <label for=\"tags\">Tags</label>\n\n <verben-drop-down label=\"Tags\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"true\" [filter]=\"true\"\n [showClear]=\"true\" placeholder=\"\" [(options)]=\"tags\" id=\"tags\" optionLabel=\"Name\" optionValue=\"Code\"\n formControlName=\"Tags\" class=\"form-control\">\n </verben-drop-down>\n </div>\n\n <div class=\"space-y-1\">\n <label for=\"warehouses\">Warehouses</label>\n\n <verben-drop-down label=\"Warehouses\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"true\" [filter]=\"true\"\n [showClear]=\"true\" placeholder=\"\" [(options)]=\"warehouses\" id=\"warehouses\" optionLabel=\"Name\" optionValue=\"Code\"\n formControlName=\"Warehouses\" (onChange)=\"onWarehouseChange($event)\" class=\"form-control\">\n </verben-drop-down>\n </div>\n\n <div class=\"space-y-1\">\n <label for=\"status\">Status</label>\n\n <verben-drop-down styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\" [filter]=\"false\" [showClear]=\"false\"\n placeholder=\"\" [(options)]=\"statusOptions\" id=\"status\" formControlName=\"Status\" class=\"form-control\">\n </verben-drop-down>\n </div>\n</form>\n", styles: [""], dependencies: [{ 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: i4.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"] }, { kind: "component", type: i4.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"] }] });
|
|
58
91
|
}
|
|
59
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserManagementFormComponent, decorators: [{
|
|
60
93
|
type: Component,
|
|
61
|
-
args: [{ selector: 'lib-user-request-form', template: "<form
|
|
62
|
-
}], ctorParameters: () => [{ type: i1.FormBuilder }], propDecorators: { currentData: [{
|
|
94
|
+
args: [{ selector: 'lib-user-request-form', template: "<form [formGroup]=\"form\" class=\"flex flex-col px-3 pb-3 rounded-xl h-full w-full relative space-y-4\">\n <verbena-input label=\"Name:\" name=\"FirstName\" type=\"text\" formControlName=\"FirstName\" />\n <verbena-input label=\"Phone Number:\" name=\"PhoneNumber\" type=\"tel\" formControlName=\"PhoneNumber\" />\n <verbena-input name=\"MailAddress\" label=\"E-Mail Address:\" [type]=\"'email'\" formControlName=\"MailAddress\" />\n <!-- <verbena-input\n label=\"Address\"\n name=\"Address\"\n type=\"text\"\n formControlName=\"Address\"\n /> -->\n\n <div class=\"space-y-1\">\n <label for=\"role\">Role</label>\n\n <verben-drop-down label=\"Role\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\" [filter]=\"true\"\n [showClear]=\"true\" placeholder=\"\" [(options)]=\"roles\" id=\"role\" optionLabel=\"Name\" optionValue=\"Code\"\n formControlName=\"RoleID\" class=\"form-control\">\n </verben-drop-down>\n </div>\n\n <div class=\"space-y-1\">\n <label for=\"tags\">Tags</label>\n\n <verben-drop-down label=\"Tags\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"true\" [filter]=\"true\"\n [showClear]=\"true\" placeholder=\"\" [(options)]=\"tags\" id=\"tags\" optionLabel=\"Name\" optionValue=\"Code\"\n formControlName=\"Tags\" class=\"form-control\">\n </verben-drop-down>\n </div>\n\n <div class=\"space-y-1\">\n <label for=\"warehouses\">Warehouses</label>\n\n <verben-drop-down label=\"Warehouses\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"true\" [filter]=\"true\"\n [showClear]=\"true\" placeholder=\"\" [(options)]=\"warehouses\" id=\"warehouses\" optionLabel=\"Name\" optionValue=\"Code\"\n formControlName=\"Warehouses\" (onChange)=\"onWarehouseChange($event)\" class=\"form-control\">\n </verben-drop-down>\n </div>\n\n <div class=\"space-y-1\">\n <label for=\"status\">Status</label>\n\n <verben-drop-down styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\" [filter]=\"false\" [showClear]=\"false\"\n placeholder=\"\" [(options)]=\"statusOptions\" id=\"status\" formControlName=\"Status\" class=\"form-control\">\n </verben-drop-down>\n </div>\n</form>\n" }]
|
|
95
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.UserManagementService }, { type: i3.EnvironmentService }], propDecorators: { currentData: [{
|
|
63
96
|
type: Input
|
|
64
97
|
}], roles: [{
|
|
65
98
|
type: Input
|
|
@@ -70,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
70
103
|
}], onFormSave: [{
|
|
71
104
|
type: Output
|
|
72
105
|
}] } });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-management-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/user-management-form/user-management-form.component.ts","../../../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/user-management-form/user-management-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAKvE,OAAO,EAAE,MAAM,EAAE,MAAM,yCAAyC,CAAC;;;;AAcjE,MAAM,OAAO,2BAA2B;IA4BlB;IA3BpB,+BAA+B;IAC/B,kCAAkC;IAElC,IAAa,WAAW,CAAC,KAAsB;QAC7C,IAAI,KAAK,EAAE,IAAI,EAAE,CAAC;YAChB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;gBACnB,WAAW,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE;gBACzC,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,IAAI,EAAE;gBACrC,WAAW,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE;gBACzC,qCAAqC;gBACrC,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE;gBAC/B,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE;gBAC3B,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM;aAC3C,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IACQ,KAAK,GAAW,EAAE,CAAC;IACnB,IAAI,GAAU,EAAE,CAAC;IAEhB,UAAU,GAAG,IAAI,YAAY,EAAa,CAAC;IAC3C,UAAU,GAAG,IAAI,YAAY,EAAiB,CAAC;IAEzD,IAAI,CAAY;IAChB,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAEtC,YAAoB,EAAe;QAAf,OAAE,GAAF,EAAE,CAAa;QACjC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YACxB,WAAW,EAAE,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YACrC,SAAS,EAAE,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YACnC,WAAW,EAAE,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YACrC,qCAAqC;YACrC,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAChC,MAAM,EAAE,CAAC,EAAE,CAAC;YACZ,IAAI,EAAE,CAAC,EAAE,CAAC;SACX,CAAC,CAAC;IACL,CAAC;IAED,QAAQ,KAAU,CAAC;IAEnB,MAAM;QACJ,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACpB,kCAAkC;YAClC,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC5C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED,QAAQ;QACN,oBAAoB;QACpB,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;IAClC,CAAC;wGArDU,2BAA2B;4FAA3B,2BAA2B,oMCnBxC,4/DAyFA;;4FDtEa,2BAA2B;kBALvC,SAAS;+BACE,uBAAuB;gFAQpB,WAAW;sBAAvB,KAAK;gBAeG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEI,UAAU;sBAAnB,MAAM;gBACG,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { CardData } from 'verben-ng-ui';\nimport { Role } from 'verben-authentication-ui/src/lib/models';\nimport { Tag } from 'verben-authentication-ui/src/lib/models';\nimport { Status } from 'verben-authentication-ui/src/lib/models';\nimport { User } from 'verben-authentication-ui/src/lib/models';\n\ninterface UserFormData {\n  MailAddress: string;\n  FirstName: string;\n  PhoneNumber: string;\n}\n\n@Component({\n  selector: 'lib-user-request-form',\n  templateUrl: './user-management-form.component.html',\n  styleUrl: './user-management-form.component.css',\n})\nexport class UserManagementFormComponent {\n  // @Input() roles: Role[] = [];\n  // @Input() status: Status[] = [];\n\n  @Input() set currentData(value: CardData | null) {\n    if (value?.data) {\n      this.form.patchValue({\n        MailAddress: value.data.MailAddress || '',\n        FirstName: value.data.FirstName || '',\n        PhoneNumber: value.data.PhoneNumber || '',\n        // Address: value.data.Address || '',\n        RoleID: value.data.RoleID || '',\n        Tags: value.data.Tags || [],\n        Status: value.data.Status || Status.Active,\n      });\n    } else {\n      this.form.reset();\n    }\n  }\n  @Input() roles: Role[] = [];\n  @Input() tags: Tag[] = [];\n\n  @Output() switchView = new EventEmitter<undefined>();\n  @Output() onFormSave = new EventEmitter<Partial<User>>();\n\n  form: FormGroup;\n  statusOptions = Object.values(Status);\n\n  constructor(private fb: FormBuilder) {\n    this.form = this.fb.group({\n      MailAddress: ['', { readonly: true }],\n      FirstName: ['', { readonly: true }],\n      PhoneNumber: ['', { readonly: true }],\n      // Address: ['', { readonly: true }],\n      Status: ['', { readonly: true }],\n      RoleID: [''],\n      Tags: [[]],\n    });\n  }\n\n  ngOnInit(): void {}\n\n  onSave(): void {\n    if (this.form.valid) {\n      // Emit save event with form value\n      console.log('Form saved:', this.form.value);\n      this.onFormSave.emit(this.form.value);\n    }\n  }\n\n  onDelete(): void {\n    // Emit delete event\n    console.log('Delete requested');\n  }\n}\n","<form\n  [formGroup]=\"form\"\n  class=\"flex flex-col px-3 pb-3 rounded-xl h-full w-full relative space-y-4\"\n>\n  <verbena-input\n    label=\"Name:\"\n    name=\"FirstName\"\n    type=\"text\"\n    formControlName=\"FirstName\"\n  />\n  <verbena-input\n    label=\"Phone Number:\"\n    name=\"PhoneNumber\"\n    type=\"tel\"\n    formControlName=\"PhoneNumber\"\n  />\n  <verbena-input\n    name=\"MailAddress\"\n    label=\"E-Mail Address:\"\n    [type]=\"'email'\"\n    formControlName=\"MailAddress\"\n  />\n  <!-- <verbena-input\n    label=\"Address\"\n    name=\"Address\"\n    type=\"text\"\n    formControlName=\"Address\"\n  /> -->\n\n  <div class=\"space-y-1\">\n    <label for=\"role\">Role</label>\n\n    <verben-drop-down\n      label=\"Role\"\n      styleClass=\"w-full\"\n      width=\"100%\"\n      [multiselect]=\"false\"\n      [filter]=\"true\"\n      [showClear]=\"true\"\n      placeholder=\"\"\n      [(options)]=\"roles\"\n      id=\"role\"\n      optionLabel=\"Name\"\n      optionValue=\"Code\"\n      formControlName=\"RoleID\"\n      class=\"form-control\"\n    >\n    </verben-drop-down>\n  </div>\n\n  <div class=\"space-y-1\">\n    <label for=\"tags\">Tags</label>\n\n    <verben-drop-down\n      label=\"Tags\"\n      styleClass=\"w-full\"\n      width=\"100%\"\n      [multiselect]=\"true\"\n      [filter]=\"true\"\n      [showClear]=\"true\"\n      placeholder=\"\"\n      [(options)]=\"tags\"\n      id=\"tags\"\n      optionLabel=\"Name\"\n      optionValue=\"Code\"\n      formControlName=\"Tags\"\n      class=\"form-control\"\n    >\n    </verben-drop-down>\n  </div>\n\n  <div class=\"space-y-1\">\n    <label for=\"status\">Status</label>\n\n    <verben-drop-down\n      styleClass=\"w-full\"\n      width=\"100%\"\n      [multiselect]=\"false\"\n      [filter]=\"false\"\n      [showClear]=\"false\"\n      placeholder=\"\"\n      [(options)]=\"statusOptions\"\n      id=\"status\"\n      formControlName=\"Status\"\n      class=\"form-control\"\n    >\n    </verben-drop-down>\n  </div>\n</form>\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-management-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/user-management-form/user-management-form.component.ts","../../../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/user-management-form/user-management-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { Role, Status, Tag, User } from 'verben-authentication-ui/src/lib/models';\nimport { EnvironmentService } from 'verben-authentication-ui/src/lib/services';\nimport { CardData, DropdownChangeEvent } from 'verben-ng-ui';\nimport { UserManagementService } from '../services/user-management.service';\n\ninterface UserFormData {\n  MailAddress: string;\n  FirstName: string;\n  PhoneNumber: string;\n}\n\ninterface Warehouse {\n  Name: string;\n  Code: string;\n}\n\n@Component({\n  selector: 'lib-user-request-form',\n  templateUrl: './user-management-form.component.html',\n  styleUrl: './user-management-form.component.css',\n})\nexport class UserManagementFormComponent {\n  // @Input() roles: Role[] = [];\n  // @Input() status: Status[] = [];\n\n  @Input() set currentData(value: CardData | null) {\n    if (value?.data) {\n      // Convert comma-separated warehouse codes back to array for dropdown\n      const warehouseCodes = value.data.Warehouses\n        ? value.data.Warehouses.split(',').filter((code: string) => code.trim())\n        : [];\n\n      this.form.patchValue({\n        MailAddress: value.data.MailAddress || '',\n        FirstName: value.data.FirstName || '',\n        PhoneNumber: value.data.PhoneNumber || '',\n        // Address: value.data.Address || '',\n        RoleID: value.data.RoleID || '',\n        Tags: value.data.Tags || [],\n        Status: value.data.Status || Status.Active,\n        Warehouses: warehouseCodes,\n      });\n    } else {\n      this.form.reset();\n    }\n  }\n  @Input() roles: Role[] = [];\n  @Input() tags: Tag[] = [];\n\n  @Output() switchView = new EventEmitter<undefined>();\n  @Output() onFormSave = new EventEmitter<Partial<User>>();\n\n  form: FormGroup;\n  statusOptions = Object.values(Status);\n  warehouses: Warehouse[] = [];\n\n  constructor(\n    private fb: FormBuilder,\n    private userManagementService: UserManagementService,\n    private envService: EnvironmentService\n  ) {\n    this.form = this.fb.group({\n      MailAddress: ['', { readonly: true }],\n      FirstName: ['', { readonly: true }],\n      PhoneNumber: ['', { readonly: true }],\n      // Address: ['', { readonly: true }],\n      Status: ['', { readonly: true }],\n      RoleID: [''],\n      Tags: [[]],\n      Warehouses: [[]],\n    });\n  }\n\n  ngOnInit(): void {\n    this.loadWarehouses();\n  }\n\n  async loadWarehouses(): Promise<void> {\n    try {\n      this.warehouses = await this.userManagementService.loadEntities<Warehouse>(\n        'Warehouse',\n        ['Name', 'Code'],\n        this.envService.environment.RevenueAPI\n      );\n    } catch (error) {\n      console.error('Error loading warehouses:', error);\n      this.warehouses = [];\n    }\n  }\n\n  onWarehouseChange(event: DropdownChangeEvent): void {\n    // Convert array of warehouse codes to comma-separated string\n    const selectedCodes = event.value as string[];\n    const commaSeparated = selectedCodes ? selectedCodes.join(',') : '';\n\n    // Update the form with the comma-separated value for saving\n    this.form.patchValue({\n      Warehouses: commaSeparated\n    }, { emitEvent: false });\n  }\n\n  onSave(): void {\n    if (this.form.valid) {\n      // Emit save event with form value\n      console.log('Form saved:', this.form.value);\n      this.onFormSave.emit(this.form.value);\n    }\n  }\n\n  onDelete(): void {\n    // Emit delete event\n    console.log('Delete requested');\n  }\n}\n","<form [formGroup]=\"form\" class=\"flex flex-col px-3 pb-3 rounded-xl h-full w-full relative space-y-4\">\n  <verbena-input label=\"Name:\" name=\"FirstName\" type=\"text\" formControlName=\"FirstName\" />\n  <verbena-input label=\"Phone Number:\" name=\"PhoneNumber\" type=\"tel\" formControlName=\"PhoneNumber\" />\n  <verbena-input name=\"MailAddress\" label=\"E-Mail Address:\" [type]=\"'email'\" formControlName=\"MailAddress\" />\n  <!-- <verbena-input\n    label=\"Address\"\n    name=\"Address\"\n    type=\"text\"\n    formControlName=\"Address\"\n  /> -->\n\n  <div class=\"space-y-1\">\n    <label for=\"role\">Role</label>\n\n    <verben-drop-down label=\"Role\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\" [filter]=\"true\"\n      [showClear]=\"true\" placeholder=\"\" [(options)]=\"roles\" id=\"role\" optionLabel=\"Name\" optionValue=\"Code\"\n      formControlName=\"RoleID\" class=\"form-control\">\n    </verben-drop-down>\n  </div>\n\n  <div class=\"space-y-1\">\n    <label for=\"tags\">Tags</label>\n\n    <verben-drop-down label=\"Tags\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"true\" [filter]=\"true\"\n      [showClear]=\"true\" placeholder=\"\" [(options)]=\"tags\" id=\"tags\" optionLabel=\"Name\" optionValue=\"Code\"\n      formControlName=\"Tags\" class=\"form-control\">\n    </verben-drop-down>\n  </div>\n\n  <div class=\"space-y-1\">\n    <label for=\"warehouses\">Warehouses</label>\n\n    <verben-drop-down label=\"Warehouses\" styleClass=\"w-full\" width=\"100%\" [multiselect]=\"true\" [filter]=\"true\"\n      [showClear]=\"true\" placeholder=\"\" [(options)]=\"warehouses\" id=\"warehouses\" optionLabel=\"Name\" optionValue=\"Code\"\n      formControlName=\"Warehouses\" (onChange)=\"onWarehouseChange($event)\" class=\"form-control\">\n    </verben-drop-down>\n  </div>\n\n  <div class=\"space-y-1\">\n    <label for=\"status\">Status</label>\n\n    <verben-drop-down styleClass=\"w-full\" width=\"100%\" [multiselect]=\"false\" [filter]=\"false\" [showClear]=\"false\"\n      placeholder=\"\" [(options)]=\"statusOptions\" id=\"status\" formControlName=\"Status\" class=\"form-control\">\n    </verben-drop-down>\n  </div>\n</form>\n"]}
|