verben-authentication-ui 1.0.22 → 1.0.25
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/sign-in/sign-in.component.mjs +2 -1
- 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-sign-in.mjs +1 -0
- package/fesm2022/verben-authentication-ui-src-lib-components-sign-in.mjs.map +1 -1
- 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 +19 -19
- 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
|
@@ -156,6 +156,7 @@ export class SignInComponent {
|
|
|
156
156
|
AuthCode: this.code,
|
|
157
157
|
Tenant: this.apiKey,
|
|
158
158
|
AuthMechanism: data.AuthMechanism,
|
|
159
|
+
RedirectUrl: this.authCallbackUrl ? this.authCallbackUrl : undefined,
|
|
159
160
|
};
|
|
160
161
|
this.utilService.sendBI(true);
|
|
161
162
|
const res = await this.server.post(`Authentication/GetUserDetails`, payload);
|
|
@@ -326,4 +327,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
326
327
|
}], appleClick: [{
|
|
327
328
|
type: Output
|
|
328
329
|
}] } });
|
|
329
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sign-in.component.js","sourceRoot":"","sources":["../../../../../../../projects/verben-authentication-ui/src/lib/components/sign-in/sign-in.component.ts","../../../../../../../projects/verben-authentication-ui/src/lib/components/sign-in/sign-in.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  ValidationErrors,\n  Validators,\n} from '@angular/forms';\nimport {\n  KeyValueParam,\n  LoginData,\n} from 'verben-authentication-ui/src/lib/models';\nimport { HttpWebRequestService } from 'verben-authentication-ui/src/lib/services';\nimport { UtilService } from 'verben-authentication-ui/src/lib/services';\nimport { ErrorResponse } from 'verben-authentication-ui/src/lib/models';\nimport { ResponseKeyValue } from 'verben-authentication-ui/src/lib/models';\nimport { EnvironmentService } from 'verben-authentication-ui/src/lib/services';\nimport {\n  AuthMechanism,\n  MechanismType,\n} from 'verben-authentication-ui/src/lib/models';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { IOauthResp } from 'verben-authentication-ui/src/lib/models';\nimport { TenantConfig } from 'verben-authentication-ui/src/lib/models';\nimport { EncryptionService } from 'verben-authentication-ui/src/lib/services';\nimport CryptoJS from 'crypto-js';\nimport { UserAgentType } from 'verben-authentication-ui/src/lib/models';\n@Component({\n  selector: 'verben-sign-in',\n  templateUrl: './sign-in.component.html',\n  styleUrl: './sign-in.component.css',\n})\nexport class SignInComponent implements OnInit {\n  @Input() headlingText: string = 'Sign in';\n  @Input() width: string = '';\n  @Input() maxWidth: string = '';\n  @Input() margin: string = '';\n  @Input() pd: string = '';\n  @Input() customClass: string = '';\n  @Input() headlingClass: string = '';\n  @Input() bgColor: string = '#fff';\n  @Input() boxShadow: string = '4px 4px 4px rgba(0, 0, 0, 0.25)';\n  @Input() border: string = '1px solid #66666680';\n  @Input() borderRadius: string = '24px';\n  @Input() textColor: string = '#333';\n  @Input() height: string = 'auto';\n  @Input() forgetPasswordClass: string = '';\n  @Input() requestAccessClass: string = '';\n  @Input() createAccountClass: string = '';\n  @Input() createAccountLinkClass: string = '';\n\n  // links\n  @Input() forgetPasswordLink: string = '';\n  @Input() createAccountLink: string = '';\n  @Input() requestAccessLink: string = '';\n  // button styles\n  @Input() btnClass: string = '';\n  @Input() btnBgColor: string = '#FFE681';\n  @Input() btnColor: string = '';\n  @Input() btnBorder: string = '';\n  @Input() btnBorderRadius: string = '24px';\n  @Input() btnPd: string = '';\n  @Input() btnText: string = 'Log in';\n\n  //inputStyles\n  @Input() inputLabelColor: string = '';\n  @Input() inputBgColor: string = 'transparent';\n  @Input() inputBorder: string = '1px solid #66666659';\n  @Input() inputBorderRadius: string = '12px';\n  @Input() termsErrorText: string =\n    'Please agree to the terms of use and privacy policy.';\n  @Input() urlKeyOverride: string | null = null;\n  @Input() authCallbackUrl: string | null = null;\n\n  @Output() formSubmit = new EventEmitter<LoginData>();\n  @Output() onSubmitEnd: EventEmitter<ResponseKeyValue | ErrorResponse> =\n    new EventEmitter();\n  @Output() onGoogleAuthResponse: EventEmitter<\n    ResponseKeyValue | ErrorResponse\n  > = new EventEmitter();\n  @Output() onSubmitGoogleAuth: EventEmitter<ResponseKeyValue | ErrorResponse> =\n    new EventEmitter();\n  @Output() tenantConfigLoaded = new EventEmitter<TenantConfig | null>();\n  @Output() googleClick = new EventEmitter();\n  @Output() microsoftClick = new EventEmitter();\n  @Output() appleClick = new EventEmitter();\n\n  tenantDetails: any | null = null;\n  AuthMechanisms: AuthMechanism[] | null = null;\n  showform: boolean = false;\n  loginForm: FormGroup;\n  apiKey: string = '';\n  secret: string;\n  isLoading: boolean = false;\n  code: string = '';\n  type: string = '';\n  mechanismType: string = '';\n  OauthData: IOauthResp = {\n    AccessToken: '',\n    Email: '',\n    FirstName: '',\n    LastName: '',\n  };\n  configData: TenantConfig | null = null;\n\n  constructor(\n    private fb: FormBuilder,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private envSvc: EnvironmentService,\n    private route: ActivatedRoute,\n    private router: Router,\n    private encryptionService: EncryptionService\n  ) {\n    this.loginForm = this.fb.group({\n      Email: new FormControl<string | null>(null, [\n        Validators.required,\n        Validators.email,\n      ]),\n      Password: new FormControl<string | null>(null, [\n        Validators.required,\n        Validators.minLength(5),\n      ]),\n    });\n    this.secret = this.envSvc.environment.Secret;\n  }\n\n  async ngOnInit() {\n    await this.getTenantConfig();\n    this.route.queryParams.subscribe((params) => {\n      this.code = params['code'];\n      this.type = params['type'];\n      if (this.code) {\n        this.verifyUserDetails();\n      }\n    });\n  }\n\n  async getTenantConfig() {\n    const isLocalhost = window?.location?.hostname === 'localhost';\n    const payload: KeyValueParam | undefined = this.urlKeyOverride\n      ? {\n          Key: 'UrlKey',\n          Value: this.urlKeyOverride,\n          Other: this.authCallbackUrl ? this.authCallbackUrl : undefined,\n        }\n      : isLocalhost\n      ? {\n          Key: 'UrlKey',\n          Value: 'https://bovas.white360.net',\n          Other: this.authCallbackUrl ? this.authCallbackUrl : undefined,\n        }\n      : undefined;\n\n    try {\n      const res = await this.server.post<TenantConfig>(\n        `Tenant/GetTenantConfigByUrlKey`,\n        payload\n      );\n      this.tenantDetails = res;\n      this.apiKey = this.tenantDetails.TenantId;\n      this.configData = res;\n\n      this.AuthMechanisms = this.tenantDetails?.AuthMechanisms?.filter(\n        (m: AuthMechanism) => m.UserAgent === UserAgentType.Web\n      );\n\n      if (\n        !this.AuthMechanisms?.length ||\n        !this.AuthMechanisms.some(\n          (m) => m.AuthMechanism === MechanismType.InApp\n        )\n      ) {\n        this.showform = false;\n      } else {\n        this.showform = true;\n      }\n\n      this.tenantConfigLoaded.emit(this.configData);\n    } catch (err) {\n      this.tenantConfigLoaded.emit(null);\n    }\n  }\n\n  checkForm(): boolean {\n    return this.loginForm.valid;\n  }\n\n  async verifyUserDetails() {\n    if (this.AuthMechanisms !== null && this.apiKey) {\n      const data: any = this.AuthMechanisms.find((item) =>\n        item.AuthMechanism.includes(this.type)\n      );\n      const payload = {\n        AuthCode: this.code,\n        Tenant: this.apiKey,\n        AuthMechanism: data.AuthMechanism,\n      };\n\n      this.utilService.sendBI(true);\n      const res = await this.server.post(\n        `Authentication/GetUserDetails`,\n        payload\n      );\n      this.utilService.sendBI(false);\n      if (res instanceof ErrorResponse) {\n        return;\n      } else {\n        var result = res as IOauthResp;\n        this.OauthData = {\n          AccessToken: result?.AccessToken,\n          Email: result?.Email,\n          FirstName: result?.FirstName,\n          LastName: result?.LastName,\n        };\n\n        this.submit(data.AuthMechanism);\n      }\n    }\n  }\n\n  async submit(type: string) {\n    let data: LoginData = {\n      MailAddress: '',\n      Password: '',\n      LoginType: type,\n      Tenant: this.tenantDetails.TenantId,\n      Secrete: this.secret,\n      Token: '',\n    };\n\n    if (type === MechanismType.InApp && this.checkForm()) {\n      data = {\n        ...data,\n        MailAddress: this.loginForm.controls['Email'].value,\n        Password: String(\n          CryptoJS.MD5(this.loginForm.controls['Password'].value)\n        ),\n      };\n    } else if (\n      type === MechanismType.Google ||\n      type === MechanismType.Microsoft\n    ) {\n      data = {\n        ...data,\n        MailAddress: this.OauthData?.Email,\n        Token: this.OauthData?.AccessToken,\n      };\n    }\n\n    this.formSubmit.emit(data);\n    this.utilService.sendBI(true); // Preserving your utilService call\n    this.isLoading = true;\n\n    try {\n      const res = await this.server.post(`Authentication/Login`, data);\n      console.log('Response:', res);\n      this.utilService.sendBI(false); // Stop utilService tracking on success/failure\n      this.isLoading = false;\n\n      if (res instanceof ErrorResponse) {\n        this.onSubmitEnd.emit(res);\n      } else {\n        const result = res as ResponseKeyValue;\n        this.onSubmitEnd.emit(result);\n      }\n    } catch (error) {\n      this.utilService.sendBI(false); // Stop utilService tracking on error\n      this.isLoading = false;\n      console.error('Error during login:', error);\n    }\n  }\n\n  get styles() {\n    return {\n      'background-color': this.bgColor,\n      'box-shadow': this.boxShadow,\n      border: this.border,\n      'border-radius': this.borderRadius,\n      color: this.textColor,\n      width: this.width,\n      'max-width': this.maxWidth,\n      margin: this.margin,\n      height: this.height,\n      padding: this.pd,\n    };\n  }\n}\n","<section\n[ngStyle]=\"styles\"\nclass=\"{{ customClass }}\"\n>\n    <h2 class=\"{{headlingClass}}\">{{headlingText}}</h2>\n    <form [formGroup]=\"loginForm\" (ngSubmit)=\"submit('InApp')\" class=\"flexWrapper\"> \n      <div class=\"formWrapper\" *ngIf=\"showform\"> \n      <verbena-input\n        [label]=\"'Email'\"\n        [labelColor]=\"inputLabelColor\"\n        [placeHolder]=\"''\"\n        [required]=\"true\"\n        [type]=\"'email'\"\n        formControlName=\"Email\"\n        [showBorder]=\"true\"\n        [bgColor]=\"inputBgColor\"\n        [border]=\"inputBorder\"\n        [borderRadius]=\"inputBorderRadius\"\n        [showErrorMessage]=\"true\"\n        [errorMessageColor]=\"'red'\"\n        [errorBorderColor]=\"'red'\"\n        [errorPosition]=\"'bottom'\"\n        class=\"outline-none focus-none\"\n      ></verbena-input>\n      <div> \n        <verbena-input\n        [label]=\"'Password'\"\n        [labelColor]=\"inputLabelColor\"\n        [placeHolder]=\"''\"\n        [required]=\"true\"\n        [type]=\"'password'\"\n        formControlName=\"Password\"\n        [showBorder]=\"true\"\n        [bgColor]=\"inputBgColor\"\n        [border]=\"inputBorder\"\n        [borderRadius]=\"inputBorderRadius\"\n        [showErrorMessage]=\"true\"\n        [errorMessageColor]=\"'red'\"\n        [errorBorderColor]=\"'red'\"\n        [errorPosition]=\"'bottom'\"\n        [passwordToggle]=\"true\"\n        [passLength]=\"5\"\n        [customErrorMessages]=\"{\n          password:'Password is required'\n        }\"\n        class=\"outline-none focus-none\"\n      ></verbena-input>\n      <div class=\"pwdWrapper\"> \n          <p clas=\"mb-0\"> <a [routerLink]=\"forgetPasswordLink\" class=\"{{forgetPasswordClass}}\">Forgot password</a></p>\n      </div>\n      </div>\n      <lib-button \n      [buttonClass]=\"btnClass\"\n      [color]=\"btnColor\"\n      [border]=\"btnBorder\"\n      [borderRadius]=\"btnBorderRadius\"\n      [bgColor]=\"btnBgColor\"\n      [pd]=\"btnPd\"\n      [text]=\"btnText\" \n      type=\"submit\" \n      [disabled]=\"!this.checkForm()\"\n      ></lib-button>\n    </div>\n    <div> \n      <p *ngIf=\"requestAccessLink\">\n        <a [routerLink]=\"requestAccessLink\"  class=\"{{requestAccessClass}}\">Click here to request user access</a>\n      </p>\n     \n    </div>\n  </form>\n  <div> \n    <div *ngIf=\"AuthMechanisms !== null\"> \n      <verben-o-auth \n        [authMechanisms]=\"AuthMechanisms\"\n      ></verben-o-auth>\n    </div>\n      <p class=\"{{createAccountClass}}\" *ngIf=\"createAccountLink\">\n        Don't have an account?\n        <a [routerLink]=\"createAccountLink\"  class=\"{{createAccountLinkClass}}\">Create an account</a>\n      </p>\n  </div>\n  </section>\n  "]}
|
|
330
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sign-in.component.js","sourceRoot":"","sources":["../../../../../../../projects/verben-authentication-ui/src/lib/components/sign-in/sign-in.component.ts","../../../../../../../projects/verben-authentication-ui/src/lib/components/sign-in/sign-in.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  ValidationErrors,\n  Validators,\n} from '@angular/forms';\nimport {\n  KeyValueParam,\n  LoginData,\n} from 'verben-authentication-ui/src/lib/models';\nimport { HttpWebRequestService } from 'verben-authentication-ui/src/lib/services';\nimport { UtilService } from 'verben-authentication-ui/src/lib/services';\nimport { ErrorResponse } from 'verben-authentication-ui/src/lib/models';\nimport { ResponseKeyValue } from 'verben-authentication-ui/src/lib/models';\nimport { EnvironmentService } from 'verben-authentication-ui/src/lib/services';\nimport {\n  AuthMechanism,\n  MechanismType,\n} from 'verben-authentication-ui/src/lib/models';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { IOauthResp } from 'verben-authentication-ui/src/lib/models';\nimport { TenantConfig } from 'verben-authentication-ui/src/lib/models';\nimport { EncryptionService } from 'verben-authentication-ui/src/lib/services';\nimport CryptoJS from 'crypto-js';\nimport { UserAgentType } from 'verben-authentication-ui/src/lib/models';\n@Component({\n  selector: 'verben-sign-in',\n  templateUrl: './sign-in.component.html',\n  styleUrl: './sign-in.component.css',\n})\nexport class SignInComponent implements OnInit {\n  @Input() headlingText: string = 'Sign in';\n  @Input() width: string = '';\n  @Input() maxWidth: string = '';\n  @Input() margin: string = '';\n  @Input() pd: string = '';\n  @Input() customClass: string = '';\n  @Input() headlingClass: string = '';\n  @Input() bgColor: string = '#fff';\n  @Input() boxShadow: string = '4px 4px 4px rgba(0, 0, 0, 0.25)';\n  @Input() border: string = '1px solid #66666680';\n  @Input() borderRadius: string = '24px';\n  @Input() textColor: string = '#333';\n  @Input() height: string = 'auto';\n  @Input() forgetPasswordClass: string = '';\n  @Input() requestAccessClass: string = '';\n  @Input() createAccountClass: string = '';\n  @Input() createAccountLinkClass: string = '';\n\n  // links\n  @Input() forgetPasswordLink: string = '';\n  @Input() createAccountLink: string = '';\n  @Input() requestAccessLink: string = '';\n  // button styles\n  @Input() btnClass: string = '';\n  @Input() btnBgColor: string = '#FFE681';\n  @Input() btnColor: string = '';\n  @Input() btnBorder: string = '';\n  @Input() btnBorderRadius: string = '24px';\n  @Input() btnPd: string = '';\n  @Input() btnText: string = 'Log in';\n\n  //inputStyles\n  @Input() inputLabelColor: string = '';\n  @Input() inputBgColor: string = 'transparent';\n  @Input() inputBorder: string = '1px solid #66666659';\n  @Input() inputBorderRadius: string = '12px';\n  @Input() termsErrorText: string =\n    'Please agree to the terms of use and privacy policy.';\n  @Input() urlKeyOverride: string | null = null;\n  @Input() authCallbackUrl: string | null = null;\n\n  @Output() formSubmit = new EventEmitter<LoginData>();\n  @Output() onSubmitEnd: EventEmitter<ResponseKeyValue | ErrorResponse> =\n    new EventEmitter();\n  @Output() onGoogleAuthResponse: EventEmitter<\n    ResponseKeyValue | ErrorResponse\n  > = new EventEmitter();\n  @Output() onSubmitGoogleAuth: EventEmitter<ResponseKeyValue | ErrorResponse> =\n    new EventEmitter();\n  @Output() tenantConfigLoaded = new EventEmitter<TenantConfig | null>();\n  @Output() googleClick = new EventEmitter();\n  @Output() microsoftClick = new EventEmitter();\n  @Output() appleClick = new EventEmitter();\n\n  tenantDetails: any | null = null;\n  AuthMechanisms: AuthMechanism[] | null = null;\n  showform: boolean = false;\n  loginForm: FormGroup;\n  apiKey: string = '';\n  secret: string;\n  isLoading: boolean = false;\n  code: string = '';\n  type: string = '';\n  mechanismType: string = '';\n  OauthData: IOauthResp = {\n    AccessToken: '',\n    Email: '',\n    FirstName: '',\n    LastName: '',\n  };\n  configData: TenantConfig | null = null;\n\n  constructor(\n    private fb: FormBuilder,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private envSvc: EnvironmentService,\n    private route: ActivatedRoute,\n    private router: Router,\n    private encryptionService: EncryptionService\n  ) {\n    this.loginForm = this.fb.group({\n      Email: new FormControl<string | null>(null, [\n        Validators.required,\n        Validators.email,\n      ]),\n      Password: new FormControl<string | null>(null, [\n        Validators.required,\n        Validators.minLength(5),\n      ]),\n    });\n    this.secret = this.envSvc.environment.Secret;\n  }\n\n  async ngOnInit() {\n    await this.getTenantConfig();\n    this.route.queryParams.subscribe((params) => {\n      this.code = params['code'];\n      this.type = params['type'];\n      if (this.code) {\n        this.verifyUserDetails();\n      }\n    });\n  }\n\n  async getTenantConfig() {\n    const isLocalhost = window?.location?.hostname === 'localhost';\n    const payload: KeyValueParam | undefined = this.urlKeyOverride\n      ? {\n          Key: 'UrlKey',\n          Value: this.urlKeyOverride,\n          Other: this.authCallbackUrl ? this.authCallbackUrl : undefined,\n        }\n      : isLocalhost\n      ? {\n          Key: 'UrlKey',\n          Value: 'https://bovas.white360.net',\n          Other: this.authCallbackUrl ? this.authCallbackUrl : undefined,\n        }\n      : undefined;\n\n    try {\n      const res = await this.server.post<TenantConfig>(\n        `Tenant/GetTenantConfigByUrlKey`,\n        payload\n      );\n      this.tenantDetails = res;\n      this.apiKey = this.tenantDetails.TenantId;\n      this.configData = res;\n\n      this.AuthMechanisms = this.tenantDetails?.AuthMechanisms?.filter(\n        (m: AuthMechanism) => m.UserAgent === UserAgentType.Web\n      );\n\n      if (\n        !this.AuthMechanisms?.length ||\n        !this.AuthMechanisms.some(\n          (m) => m.AuthMechanism === MechanismType.InApp\n        )\n      ) {\n        this.showform = false;\n      } else {\n        this.showform = true;\n      }\n\n      this.tenantConfigLoaded.emit(this.configData);\n    } catch (err) {\n      this.tenantConfigLoaded.emit(null);\n    }\n  }\n\n  checkForm(): boolean {\n    return this.loginForm.valid;\n  }\n\n  async verifyUserDetails() {\n    if (this.AuthMechanisms !== null && this.apiKey) {\n      const data: any = this.AuthMechanisms.find((item) =>\n        item.AuthMechanism.includes(this.type)\n      );\n      const payload = {\n        AuthCode: this.code,\n        Tenant: this.apiKey,\n        AuthMechanism: data.AuthMechanism,\n        RedirectUrl: this.authCallbackUrl ? this.authCallbackUrl : undefined,\n      };\n\n      this.utilService.sendBI(true);\n      const res = await this.server.post(\n        `Authentication/GetUserDetails`,\n        payload\n      );\n      this.utilService.sendBI(false);\n      if (res instanceof ErrorResponse) {\n        return;\n      } else {\n        var result = res as IOauthResp;\n        this.OauthData = {\n          AccessToken: result?.AccessToken,\n          Email: result?.Email,\n          FirstName: result?.FirstName,\n          LastName: result?.LastName,\n        };\n\n        this.submit(data.AuthMechanism);\n      }\n    }\n  }\n\n  async submit(type: string) {\n    let data: LoginData = {\n      MailAddress: '',\n      Password: '',\n      LoginType: type,\n      Tenant: this.tenantDetails.TenantId,\n      Secrete: this.secret,\n      Token: '',\n    };\n\n    if (type === MechanismType.InApp && this.checkForm()) {\n      data = {\n        ...data,\n        MailAddress: this.loginForm.controls['Email'].value,\n        Password: String(\n          CryptoJS.MD5(this.loginForm.controls['Password'].value)\n        ),\n      };\n    } else if (\n      type === MechanismType.Google ||\n      type === MechanismType.Microsoft\n    ) {\n      data = {\n        ...data,\n        MailAddress: this.OauthData?.Email,\n        Token: this.OauthData?.AccessToken,\n      };\n    }\n\n    this.formSubmit.emit(data);\n    this.utilService.sendBI(true); // Preserving your utilService call\n    this.isLoading = true;\n\n    try {\n      const res = await this.server.post(`Authentication/Login`, data);\n      console.log('Response:', res);\n      this.utilService.sendBI(false); // Stop utilService tracking on success/failure\n      this.isLoading = false;\n\n      if (res instanceof ErrorResponse) {\n        this.onSubmitEnd.emit(res);\n      } else {\n        const result = res as ResponseKeyValue;\n        this.onSubmitEnd.emit(result);\n      }\n    } catch (error) {\n      this.utilService.sendBI(false); // Stop utilService tracking on error\n      this.isLoading = false;\n      console.error('Error during login:', error);\n    }\n  }\n\n  get styles() {\n    return {\n      'background-color': this.bgColor,\n      'box-shadow': this.boxShadow,\n      border: this.border,\n      'border-radius': this.borderRadius,\n      color: this.textColor,\n      width: this.width,\n      'max-width': this.maxWidth,\n      margin: this.margin,\n      height: this.height,\n      padding: this.pd,\n    };\n  }\n}\n","<section\n[ngStyle]=\"styles\"\nclass=\"{{ customClass }}\"\n>\n    <h2 class=\"{{headlingClass}}\">{{headlingText}}</h2>\n    <form [formGroup]=\"loginForm\" (ngSubmit)=\"submit('InApp')\" class=\"flexWrapper\"> \n      <div class=\"formWrapper\" *ngIf=\"showform\"> \n      <verbena-input\n        [label]=\"'Email'\"\n        [labelColor]=\"inputLabelColor\"\n        [placeHolder]=\"''\"\n        [required]=\"true\"\n        [type]=\"'email'\"\n        formControlName=\"Email\"\n        [showBorder]=\"true\"\n        [bgColor]=\"inputBgColor\"\n        [border]=\"inputBorder\"\n        [borderRadius]=\"inputBorderRadius\"\n        [showErrorMessage]=\"true\"\n        [errorMessageColor]=\"'red'\"\n        [errorBorderColor]=\"'red'\"\n        [errorPosition]=\"'bottom'\"\n        class=\"outline-none focus-none\"\n      ></verbena-input>\n      <div> \n        <verbena-input\n        [label]=\"'Password'\"\n        [labelColor]=\"inputLabelColor\"\n        [placeHolder]=\"''\"\n        [required]=\"true\"\n        [type]=\"'password'\"\n        formControlName=\"Password\"\n        [showBorder]=\"true\"\n        [bgColor]=\"inputBgColor\"\n        [border]=\"inputBorder\"\n        [borderRadius]=\"inputBorderRadius\"\n        [showErrorMessage]=\"true\"\n        [errorMessageColor]=\"'red'\"\n        [errorBorderColor]=\"'red'\"\n        [errorPosition]=\"'bottom'\"\n        [passwordToggle]=\"true\"\n        [passLength]=\"5\"\n        [customErrorMessages]=\"{\n          password:'Password is required'\n        }\"\n        class=\"outline-none focus-none\"\n      ></verbena-input>\n      <div class=\"pwdWrapper\"> \n          <p clas=\"mb-0\"> <a [routerLink]=\"forgetPasswordLink\" class=\"{{forgetPasswordClass}}\">Forgot password</a></p>\n      </div>\n      </div>\n      <lib-button \n      [buttonClass]=\"btnClass\"\n      [color]=\"btnColor\"\n      [border]=\"btnBorder\"\n      [borderRadius]=\"btnBorderRadius\"\n      [bgColor]=\"btnBgColor\"\n      [pd]=\"btnPd\"\n      [text]=\"btnText\" \n      type=\"submit\" \n      [disabled]=\"!this.checkForm()\"\n      ></lib-button>\n    </div>\n    <div> \n      <p *ngIf=\"requestAccessLink\">\n        <a [routerLink]=\"requestAccessLink\"  class=\"{{requestAccessClass}}\">Click here to request user access</a>\n      </p>\n     \n    </div>\n  </form>\n  <div> \n    <div *ngIf=\"AuthMechanisms !== null\"> \n      <verben-o-auth \n        [authMechanisms]=\"AuthMechanisms\"\n      ></verben-o-auth>\n    </div>\n      <p class=\"{{createAccountClass}}\" *ngIf=\"createAccountLink\">\n        Don't have an account?\n        <a [routerLink]=\"createAccountLink\"  class=\"{{createAccountLinkClass}}\">Create an account</a>\n      </p>\n  </div>\n  </section>\n  "]}
|
|
@@ -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":"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","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"]}
|