verben-authentication-ui 0.9.7 → 0.9.9

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.
@@ -225,19 +225,21 @@ export class UserManagementComponent {
225
225
  if (this.childComponent.form.valid) {
226
226
  // const userData: User = this.childComponent.form.value;
227
227
  // console.log('Payload:', [userData]); // Log the payload to check its structure
228
+ this.utilService.sendBI(true);
228
229
  this.userManagementService.saveUsers([{
229
230
  ...this.currentData?.data,
230
231
  ...this.childComponent.form.value,
231
232
  DataState: this.currentData?.data.DataState === ObjectState.Unchanged ? ObjectState.Changed : this.currentData?.data.DataState,
232
233
  }]).then((result) => {
233
234
  if (result instanceof ErrorResponse) {
234
- console.error('ErrorResponse from server:', result.ErrorMsg);
235
235
  }
236
236
  else {
237
- console.log('User saved successfully:', result);
237
+ this.utilService.showSuccess("User saved successfully");
238
238
  }
239
239
  }, (error) => {
240
240
  console.error('Unexpected error saving user:', error);
241
+ }).finally(() => {
242
+ this.utilService.sendBI(false);
241
243
  });
242
244
  console.log(this.childComponent.form.value);
243
245
  }
@@ -470,4 +472,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
470
472
  }], pageSize: [{
471
473
  type: Input
472
474
  }] } });
473
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-management.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/user-management.component.ts","../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/user-management.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, signal, ViewChild, WritableSignal } from '@angular/core';\nimport { columns } from './user-management.columns';\n\nimport { SearchPropertySign } from '../../models/SearchPropertySign';\nimport { UtilService } from '../../services/util.service';\nimport { PagedResult } from '../../models/PagedResult';\nimport { baseStyle } from './base-table-style';\nimport { HttpWebRequestService } from '../../services/http-web-request.service';\n\n\nimport {\n  CardData,\n  DataFilterType,\n  IDataFilter,\n  DropdownLoadEvent,\n  DropdownChangeEvent,\n  ColumnDefinition,\n  ConditionalOptions,\n  CardDataViewComponent,\n  DataViewComponent,\n} from 'verben-ng-ui';\nimport { UserAccessRequestStatus } from '../../models/user-access-request-status';\nimport { ObjectState } from '../../models/object-state';\nimport { EnvironmentService } from '../../services/environment.service';\nimport { UserManagementService } from './services/user-management.service';\nimport { User } from '../../models/user';\nimport { ErrorResponse } from '../../models/ErrorResponse';\nimport { UserManagementFormComponent } from './user-management-form/use-management-form.component';\nimport { Subject, debounceTime, BehaviorSubject } from 'rxjs';\nimport { ConditionOptions } from '../../models/conditions';\nimport { ActivatedRoute } from '@angular/router';\nimport { UserAccessRequestService } from '../user-request-approval/services/user-access-request.service';\nimport { Role } from '../../models/Role';\nimport { Tag } from '../../models/Tag';\n\n\nenum DateFilterTypes {\n  Before = SearchPropertySign.LT,\n  On = SearchPropertySign.EQ,\n  After = SearchPropertySign.GT,\n}\n\n\ninterface TestParentObject {\n  Id: string;\n  Name: string;\n}\n\n\n@Component({\n  selector: 'lib-user-management',\n  templateUrl: './user-management.component.html',\n  styleUrl: './user-management.component.css',\n})\nexport class UserManagementComponent {\n  @ViewChild('vdcv') cardDataView!: CardDataViewComponent;\n  @ViewChild('vdv') dataView!: DataViewComponent;\n  @ViewChild(UserManagementFormComponent) childComponent!: UserManagementFormComponent;\n  private currentSearchTerm: string = '';\n\n\n  filteredColumns: ColumnDefinition<User>[] =columns\n  skip: number = 0;\n  users:User[]=[]\n  searchTerm$ = new Subject<string>();\n  @Input() searchDebounceTime: number = 500;\n  @Input() pageSize: number = 1;\n  pageState: PagedResult<User> | null = null;\n  errorMessage: string = '';\n  appliedFilters: boolean = false;\n  isLoading: boolean = false;\n  hasMore: boolean = true;\n  limit: number = 20;\n  sortParam: string = 'name';\n  sortOrder: string = 'asc';\n Roles:Role[]=[]\n Tags: WritableSignal<Tag[]> = signal([]);\n  dataFit: PagedResult<User> = {\n    PageSize: 1,\n    Skip: 0,\n    Total: 0,\n    Result: [],\n    LastItem: [''],\n    IsLoadingResults: false\n  };\n\n  \n\n  currentFilters: IDataFilter[] = [];\n  currentSorts: IDataFilter[] = [];\n\n\n\n  role: string = '';\n\n  cardContextHistory: CardData[] = [];\n  param: string | null | undefined;\n\n  constructor(\n    private route: ActivatedRoute,\n    private userManagementService: UserManagementService,\n    private userRole: UserAccessRequestService,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private envSvc: EnvironmentService\n  ) {}\n\n  async ngOnInit(): Promise<void> {\n\n  this.getRoles()\n  this.getTags();\n    this.route.paramMap.subscribe(params => {\n      this.role = params.get('role') || '';  // Default to an empty string if no role\n      this.fetchUsers();\n    });\n    \n\n         \n  }\n\n  \n  cardData: CardData[] = [];\n\n  data: any[] = []; \n\n  \n\n\n\n\n  async fetchUsers(sortValue: string = 'CreatedAt', order: string = 'asc') {\n    this.isLoading = true;\n    this.utilService.sendBI(true);\n\n    try {\n      const res = await this.userManagementService.getRealUsers(this.role, this.skip,this.limit, this.sortParam, this.sortOrder)\n      this.utilService.sendBI(false);\n\n      if (res instanceof ErrorResponse) {\n        // Handle error response\n        console.error('Error fetching logs:', res);\n      } else {\n        const response = res as PagedResult<User>;\n        this.dataFit = response;\n        this.users = [...this.users, ...response.Result];\n        this.cardData = this.formatCardData(this.users);\n        this.skip += this.pageSize;\n        this.hasMore = this.skip < response.Total;\n      }\n    } catch (error) {\n      console.error('Error:', error);\n    } finally {\n      this.isLoading = false;\n    }\n  }\n\n\n  async getRoles() {\n    this.utilService.sendBI(true);\n  \n    try {\n      const res = await this.userRole.getRoles();\n      this.utilService.sendBI(false);\n  \n      if (res instanceof ErrorResponse) {\n        console.error('Error fetching roles:', res);\n        return undefined;\n      } \n  \n      const response = res as PagedResult<Role>;\n      this.Roles = response.Result;\n  \n    } catch (error) {\n      console.error('Error fetching roles:', error);\n      return undefined;\n    }\n  }\n\n  async getTags() {\n    this.utilService.sendBI(true);\n  \n    try {\n      const res = await this.userRole.getTags();\n      this.utilService.sendBI(false);\n  \n      if (res instanceof ErrorResponse) {\n        console.error('Error fetching roles:', res);\n        return undefined;\n      } \n      const response = res as PagedResult<Tag>;\n      this.Tags.set(response.Result);\n    } catch (error) {\n      console.error('Error fetching roles:', error);\n      return undefined;\n    }\n  }\n  \nhandleRoleId(value:string){\n  const matchedRole = this.Roles.filter((role) => role.Name === value);\n  return matchedRole[0]?.Code;\n}\n  /**\n   * Format users into CardData for the UI library\n   * @param users Array of users to format\n   * @returns Array of CardData\n   */\n  private formatCardData(users: User[]): CardData[] {\n    return users.map(user => ({\n      selected: false, // Default selection state\n      title: `${user.FirstName} ${user.LastName}`, // Display user's name as title\n      data: { ...user }, // Pass the entire user object\n      body: [\n        { title: 'Name', value: `${user.FirstName} ${user.LastName}` },\n        { title: 'E-Mail Address', value: user.MailAddress },\n        { title: 'Phone Number', value: user.PhoneNumber || 'N/A' },\n      ],\n      children: [], // Add child data if necessary\n    }));\n  }\n\n\n\n\n\n\n\n\n\n\n\n\n  \n\n\n\n  columns = columns;\n  styles = baseStyle;\n\n  selectedParent?: string;\n  basicOption?: string;\n  selectedOption: string[] = [];\n  selectedOptionTwo: string[] = [];\n  selectedOptionThree?: string;\n  missingObject: any;\n\n\n\n  // clearLogs(sortValue: string = 'CreatedAt', order: string = 'asc') {\n  //   this.User = []; // Clear the logs array\n  //   this.skip = 0; // Reset the skip value\n  //   this.hasMore = true; // Reset the flag to allow fetching more logs\n  //   this.appliedFilters = false;\n  //   this.fetchUsers();\n  // }\n\n\n \n\n  // Grid view properties\n  isGridView: boolean = true;\n  currentData!: CardData;\n  selectedColumnCount: number = 0;\n  selectedFilterTableCount: number = 0;\n  isOPen: boolean = true;\n  selectedSortCount: number = 0;\n  showFilter: boolean = false;\n  searchTerm: string = '';\n  showColumn: boolean = false;\n  showSort: boolean = false;\n  selectedAll: boolean = false;\n  visibleColumns: IDataFilter[] = columns.map((col) => ({\n    checked: false,\n    name: typeof col.header === 'string' ? col.header : col.id,\n    type: DataFilterType.Bool,\n  }));\n\n  filterArray: IDataFilter[] = [\n    { name: 'FirstName', type: DataFilterType.String, checked: false },\n    { name: 'LastName', type: DataFilterType.String, checked: false },\n    { name: 'MailAddress', type: DataFilterType.String, checked: false },\n    { name: 'Status', type: DataFilterType.String, checked: false },\n    { name: 'PhoneNumber', type: DataFilterType.String, checked: false },\n    { name: 'CreatedAt', type: DataFilterType.Date, checked: false },\n    { name: 'Role', type: DataFilterType.String, checked: false },\n  ];\n\n\n\n  sortOptions: IDataFilter[] = [\n    { name: 'Name', type: DataFilterType.String, checked: false },\n    { name: 'MailAddress', type: DataFilterType.String, checked: false },\n    { name: 'PhoneNumber', type: DataFilterType.String, checked: false },\n    { name: 'CreatedAt', type: DataFilterType.Date, checked: false },\n  ];\n\n  testParents: TestParentObject[] = [\n    { Id: '1', Name: 'Manager' },\n    { Id: '2', Name: 'Administrator' },\n    { Id: '3', Name: 'Jelom' },\n  ];\n\n  getParentLabel(context: any): string {\n    console.log({ MissingObj: this.missingObject });\n    return this.missingObject.Name;\n  }\n\n  onSave(): void {\n    if (this.childComponent.form.valid) {\n      // const userData: User = this.childComponent.form.value;\n      // console.log('Payload:', [userData]); // Log the payload to check its structure\n  \n      this.userManagementService.saveUsers([{\n        ...this.currentData?.data,\n        ...this.childComponent.form.value,\n        DataState: this.currentData?.data.DataState === ObjectState.Unchanged ? ObjectState.Changed : this.currentData?.data.DataState,\n      }]).then(\n        (result) => {\n          if (result instanceof ErrorResponse) {\n            console.error('ErrorResponse from server:', result.ErrorMsg);\n          } else {\n            console.log('User saved successfully:', result);\n          }\n        },\n        (error) => {\n          console.error('Unexpected error saving user:', error);\n        }\n      );\n      console.log(this.childComponent.form.value);\n      \n    } else {\n      console.error('Form is invalid');\n    }\n  }\n\n  onDelete(): void {\n    console.log('Child form delete triggered');\n    // Perform delete logic here\n  }\n  onDropdownChange(event: DropdownChangeEvent): void {\n    // console.log({\n    //   'Test Parent Value': this.selectedParent,\n    //   ...\n    // });\n  }\n\n  onSelectionChange(selectedRows: User[]) {\n    console.log('Selection changed:', selectedRows);\n    // Handle the selection change\n  }\n\n  handleExport(exportedData: Partial<any>[]) {\n    console.log('Exported data:', exportedData);\n    this.downloadCSV(exportedData);\n  }\n\n  private downloadCSV(data: Partial<any>[]) {\n    const headers = Object.keys(data[0]);\n    const csvContent = [\n      headers.join(','),\n      ...data.map((row) => headers.map((header) => row[header]).join(',')),\n    ].join('\\n');\n\n    const blob = new Blob([csvContent], { type: 'text/csv;charset=utf-8;' });\n    const link = document.createElement('a');\n    if (link.download !== undefined) {\n      const url = URL.createObjectURL(blob);\n      link.setAttribute('href', url);\n      link.setAttribute('download', 'export.csv');\n      link.style.visibility = 'hidden';\n      document.body.appendChild(link);\n      link.click();\n      document.body.removeChild(link);\n    }\n  }\n\n\n  getCardDataByMailAddress(mailAddress: string): CardData | undefined {\n    console.log('cardData array:', this.cardData);\n    console.log(mailAddress);\n\n    return this.cardData.find(({ data }) => data?.MailAddress === mailAddress);\n  }\n\n  openDetailView(mailAddress: string) {\n    const cardItem = this.getCardDataByMailAddress(mailAddress);\n    console.log(cardItem);\n\n    if (cardItem && this.cardDataView) {\n      this.dataView.toggleView();\n      // First reset all selections\n      this.cardData.forEach((item) => {\n        item.selected = false;\n        if (item.children) {\n          item.children.forEach((child) => (child.selected = false));\n        }\n      });\n\n      // Set the selected item\n      cardItem.selected = true;\n      this.currentData = this.cardDataView.onItemClick(cardItem);\n\n      // Force change detection if needed\n      // this.changeDetectorRef.detectChanges();\n    }\n  }\n\n\n\n\n  \n\n\n\n  reset() {\n    this.skip = 0;\n    this.pageSize = 20;\n  }\n\n\n  clearData() {\n    this.currentData = {} as CardData;\n  }\n\n  \n  loadMore() {\n    if (this.hasMore) {\n      this.fetchUsers();\n    }\n  }\n\n  onColumnChange(event: boolean) {\n    this.showColumn = event;\n  }\n\n  onSortChange(event: boolean) {\n    this.showSort = event;\n    console.log(event);\n  }\n\n  onColumnsUpdated(updatedColumns: IDataFilter[]) {\n    this.onColumnChange(false);\n    this.selectedColumnCount = updatedColumns.length;\n\n    if (updatedColumns) {\n      // Filter columns to include only visible ones\n      this.filteredColumns = this.columns.filter((col) =>\n        this.visibleColumns.find(\n          (filter) => filter.name === col.header && filter.checked\n        )\n      );\n  \n      // Reorder columns based on the order in visibleColumns\n      const visibleColumnOrder = this.visibleColumns\n        .filter((filter) => filter.checked)\n        .map((filter) => filter.name);\n  \n      this.columns.sort((a, b) => {\n        const indexA = visibleColumnOrder.indexOf(a.header as string);\n        const indexB = visibleColumnOrder.indexOf(b.header as string);\n        return indexA - indexB;\n      });\n    }\n  }\n\n  async postSearch(payload: any) {\n    this.utilService.sendBI(true);\n    const res = await this.server.post(\n      `User/SearchUsers/0/10/CreatedAt/asc`,\n      payload\n    );\n\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n      this.appliedFilters = false;\n      return;\n    } else {\n      this.appliedFilters = true;\n      const response = res as PagedResult<User>;\n      this.dataFit = response;\n      this.users = response.Result;\n      this.cardData = this.formatCardData(this.users)      ;\n    }\n  }\n\n\n  \n  onFilterApplied(appliedFilter: IDataFilter[]) {\n    this.showFilter = false;\n    if (Array.isArray(appliedFilter)) {\n      this.selectedFilterTableCount = appliedFilter.length;\n      console.log(appliedFilter);\n\n      const queryParams = appliedFilter\n        .filter((filter) => filter.checked)\n        .map((filter) => ({\n          PropertyName: filter.name,\n          EntityValue: filter.name==='Role'?this.handleRoleId(filter.value):filter.value,\n          Type: filter.type,\n          Operator: 'And',\n          Sign: this.getCondition(filter.condition),\n        }));\n\n      this.postSearch(queryParams);\n    }\n  }\n\n  getCondition(value: any): ConditionOptions | undefined {\n    switch (value) {\n      case ConditionalOptions.On:\n        return ConditionOptions.On;\n      case ConditionalOptions.After:\n        return ConditionOptions.After;\n      case ConditionalOptions.Before:\n        return ConditionOptions.Before;\n      case ConditionalOptions.NotEqual:\n        return ConditionOptions.NotEqual;\n      default:\n        return undefined; // Explicitly return undefined for invalid cases\n    }\n  }\n  \n  onSortUpdated(updatedSorts: IDataFilter[]): void {\n    this.currentSorts = updatedSorts;\n    \n  }\n\n  async onSearch(event: { key: string; value: string }) {\n    this.searchTerm = event.value;\n    this.reset();\n    if (!this.searchTerm) {\n      this.clearLogs('CreatedAt', 'asc');\n      return;\n    }\n\n    this.isLoading = true;\n    this.utilService.sendBI(true);\n\n    try {\n      const res = await this.server.get(\n        `User/GetUserWithParam/${this.searchTerm}/${this.skip}/${this.pageSize}/CreatedAt/asc`\n      );\n\n      this.utilService.sendBI(false);\n\n      if (res instanceof ErrorResponse) {\n        console.error('Error during search:', res);\n        this.appliedFilters = false;\n      } else {\n        const response = res as PagedResult<User>;\n        this.dataFit = response;\n        this.users = response.Result;\n        this.cardData = this.formatCardData(this.users);\n\n      }\n    } catch (error) {\n      console.error('Search error:', error);\n      this.appliedFilters = false;\n    } finally {\n      this.isLoading = false;\n    }\n  }\n\n  clearLogs(sortValue: string = 'CreatedAt', order: string = 'asc') {\n    this.users= []; // Clear the logs array\n    this.skip = 0; // Reset the skip value\n    this.hasMore = true; // Reset the flag to allow fetching more logs\n    this.appliedFilters = false;\n    this.fetchUsers(sortValue, order);\n  }\n\n\n    \n\n  onViewChange(isGridView: boolean): void {}\n\n  onStateChange(event: { key: string; value: boolean }): void {\n    console.log(`State changed for ${event.key}:`, event.value);\n    if (event.key === 'create') {\n      console.log('peace is a boy');\n\n      \n\n      // const newUser = this.newItem()\n\n      // if ( newUser && this.cardDataView) {\n      //   this.dataView.toggleView();\n      //   // First reset all selections\n      //   this.cardData.forEach((item) => {\n      //     item.selected = false;\n      //     if (item.children) {\n      //       item.children.forEach((child) => (child.selected = false));\n      //     }\n      //   });\n\n      //   this.currentData = this.cardDataView.onItemClick(newUser);\n\n      //   // Force change detection if needed\n      //   // this.changeDetectorRef.detectChanges();\n      // }\n    }\n  }\n}\n","<div class=\"flex flex-col gap-4 message-log-container\">\n  <verben-data-view\n    #vdv\n    [viewState]=\"{\n      isSearch: true,\n      isColumn: true,\n      isFilter: true,\n      isSort: true,\n      isExport: true,\n      isSelect: true,\n     \n      isToggle:true\n    }\"\n    [buttonClass]=\"'my-custom-button-class'\"\n    [iconClass]=\"'my-icon-class'\"\n    [activeIconClass]=\"'my-active-icon-class'\"\n    [selectedColumnCount]=\"0\"\n    (onSearchChange)=\"onSearch($event)\"\n    [searchValue]=\"searchTerm\"\n  \n    [searchValue]=\"searchTerm\"\n    [selectedSortCount]=\"0\"\n    [showFilterChild]=\"showFilter\"\n    [selectedFilterTableCount]=\"0\"\n    (viewChange)=\"onViewChange($event)\"\n    (stateChange)=\"onStateChange($event)\"\n    [isTableView]=\"false\"\n  >\n    <div class=\"mt-2\" table-content>\n      <lib-data-table\n        [data]=\"users\"\n        [columns]=\"filteredColumns\"\n        [styleConfig]=\"styles\"\n        (selectionChange)=\"onSelectionChange($event)\"\n      >\n      <ng-container libColumn=\"select\">\n        <ng-template #cell let-isSelected=\"isSelected\" let-toggleRowSelection=\"toggleRowSelection\">\n          <input type=\"checkbox\" [checked]=\"isSelected\" (change)=\"toggleRowSelection()\" />\n        </ng-template>\n        <ng-template #header let-allRowsSelected=\"allRowsSelected\" let-someRowsSelected=\"someRowsSelected\"\n          let-toggleAllRows=\"toggleAllRows\">\n          <input type=\"checkbox\" [checked]=\"allRowsSelected()\" [indeterminate]=\"someRowsSelected()\"\n            (change)=\"toggleAllRows()\" />\n        </ng-template>\n      </ng-container>\n        <ng-container libColumn=\"createdAt\">\n          <ng-template #cell let-value>\n            {{ value | date }}\n          </ng-template>\n        </ng-container>\n        <ng-container libColumn=\"actions\">\n          <ng-template #cell let-value let-deleteRow >\n            <div class=\"flex gap-6\">\n              <verben-svg\n                (click)=\"openDetailView(value)\"\n                icon=\"edit\"\n                [width]=\"15\"\n                [height]=\"15\"\n                class=\"cursor-pointer\"\n              ></verben-svg>\n\n              <verben-svg\n                icon=\"delete\"\n                [width]=\"15\"\n                [height]=\"15\"\n                (click)=\"deleteRow()\"\n                class=\"cursor-pointer\"\n              ></verben-svg>\n            </div>\n          </ng-template>\n          <ng-template #header>\n            <strong>Actions</strong>\n          </ng-template>\n        </ng-container>\n        <ng-container libColumn=\"status\">\n          <ng-template\n          #cell\n          let-isEditing=\"isEditing\"\n          let-toggleRowEdit=\"toggleRowEdit\"\n          let-deleteRow=\"deleteRow\"\n          let-value=\"value\"\n          >\n          <lib-user-status-badge\n            [status]=\"value\"\n          ></lib-user-status-badge>\n          </ng-template>\n        </ng-container>\n\n      </lib-data-table>\n    </div>\n    <div card-content>\n      <verben-card-data-view\n        borderRadius=\"12px\"\n        (loadMoreClick)=\"loadMore()\"\n        #vdcv\n        dataId=\"MailAddress\"\n        border=\"5px\"\n        [cardDataList]=\"cardData\"\n        rbgColor=\"#f5f6f9\"\n        mg=\"0px\"\n        class=\"gap-1\"\n      >\n        <verben-left-card-data-view class=\"m-0 gap-2\" >\n          <verben-left-card-data\n            #vlcd\n            [parent]=\"vdcv\"\n            dataId=\"MailAddress\"\n            class=\"bg-secondary-100 rounded-xl border-primary border-[1px]\"\n            [cardDataList]=\"cardData\"\n\n          >\n            <ng-template #card let-item>\n              <div (click)=\"currentData = vdcv.onItemClick(item)\" class=\"flex\">\n                <verben-svg\n                  [width]=\"15\"\n                  [height]=\"15\"\n                  (click)=\"vlcd.showChildren(item)\"\n                  [ngClass]=\"vlcd.showToggle(item) ? 'visible' : 'invisible'\"\n                  class=\"items-center flex  cursor-pointer\"\n                  [icon]=\"item.isChildrenExpanded ? 'minus' : 'plus'\"\n                />\n                <div\n                 (click)=\"currentData = vdcv.onItemClick(item)\"\n                class=\"flex cursor-pointer w-full bg-secondary rounded-xl\"\n                >\n                  <div\n                    class=\"w-3 rounded-xl rounded-tr-none rounded-br-none\"\n                    [ngClass]=\"\n                      item.selected ? 'bg-primary' : 'bg-secondary-200'\n                    \"\n                  ></div>\n                  <div class=\"flex-1 flex items-end gap-y-2 gap-x-4 p-4\">\n                    <div class=\"flex-1 space-y-2\">\n                      <span\n                        class=\"font-semibold text-[#404040] flex-1 truncate\"\n                        >{{ item.title }}</span\n                      >\n\n                      <p class=\"flex items-center my-1\">\n                        <label for=\"phone\" class=\"text-[10px] font-light\"\n                          >Phone Number:</label\n                        >\n                        <span id=\"phone\" class=\"text-sm truncate\">{{\n                          item.data.PhoneNumber\n                        }}</span>\n                      </p>\n                    </div>\n\n                    <div class=\"grid gap-y-1\">\n                      <p class=\"grid\">\n                        <label\n                          for=\"role\"\n                          class=\"text-[10px] font-light text-[#404040]\"\n                          >Role</label\n                        >\n                        <span id=\"role\" class=\"text-sm font-medium\">{{\n                          item.data?.Role?.Name\n                        }}</span>\n                      </p>\n\n                      <lib-user-status-badge\n                        [status]=\"item.data.Status\"\n                      ></lib-user-status-badge>\n                    </div>\n                  </div>\n                </div>\n              </div>\n            </ng-template>\n          </verben-left-card-data>\n        </verben-left-card-data-view>\n\n        <verben-right-card-data-view>\n          <ng-template #parent>\n          <div class=\" bg-secondary-100 py-2 flex flex-col gap-20 px-2\">\n            <lib-user-request-form\n            [roles]=\"Roles\"\n            [tags]=\"Tags()\"\n            [currentData]=\"currentData\"\n            (switchView)=\"vdv.toggleView()\"\n            ></lib-user-request-form>\n            <div class=\"flex justify-between bottom-8 left-0 right-0 p-3\">\n              <verbena-button text=\"Delete\" bgColor=\"#999999\" textColor=\"white\"\n                border=\"1px solid #999999\" (click)=\"onDelete()\"></verbena-button>\n              <div class=\"flex gap-3\">\n                <verbena-button (click)=\"vdv.toggleView()\" text=\"Switch To Table\"\n                  styleType=\"ylw-outline\"></verbena-button>\n                <verbena-button  text=\"Save\" bgColor=\"#FFE681\" (click)=\"onSave()\" textColor=\"#404040\"\n                  border=\"1px solid #FFE681\">\n                  <!-- (click)=\"\" -->\n                </verbena-button>\n              </div>\n            </div>\n          </div>\n          </ng-template>\n        </verben-right-card-data-view>\n\n        <verben-card-data-view-footer class=\"w-full\">\n          <div\n            [ngClass]=\"{\n              'flex gap-2 items-center': true,\n              'justify-between': true,\n              'justify-end': vdcv.hasCurrentItem()\n            }\"\n          >\n            <verbena-button\n              *ngIf=\"!vdcv.hasCurrentItem()\"\n              [fontWeight]=\"'bold'\"\n              [bgColor]=\"'#8E8D87'\"\n              [borderRadius]=\"'4px'\"\n              [textColor]=\"'#fff'\"\n              [pd]=\"'9.79px 37.28px'\"\n              [text]=\"'Delete'\"\n            >\n            </verbena-button>\n            <div\n              class=\"flex {{\n                vdcv.hasCurrentItem() ? 'flex-1' : ''\n              }} justify-end items-center gap-5\"\n            >\n              <span class=\"paginator-text\"\n                >{{ cardData.length }} records loaded</span\n              >\n              <button\n                (click)=\"loadMore()\"\n                class=\"load-more view-links text-[#3479E9] underline\"\n              >\n                Load more\n              </button>\n            </div>\n          </div>\n        </verben-card-data-view-footer>\n      </verben-card-data-view>\n    </div>\n    <div column-content>\n      <verben-visible-column\n        (columnsUpdated)=\"onColumnsUpdated($event)\"\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"400px\"\n        textColor=\"black\"\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        [columns]=\"visibleColumns\"\n        [displayedColumns]=\"5\"\n      ></verben-visible-column>\n    </div>\n    <div filter-content>\n      <verben-table-filter\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"420px\"\n        textColor=\"black\"\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        tertiaryColor=\"#404040\"\n        [filterOptions]=\"filterArray\"\n        [maxFilterLength]=\"3\"\n        (filtersApplied)=\"onFilterApplied($event)\"\n    \n      ></verben-table-filter>\n    </div>\n    <div sort-content>\n      <verben-sort-table\n        (selectedOptions)=\"onSortUpdated($event)\"\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"400px\"\n        textColor=\"black\"\n\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        tertiaryColor=\"#404040\"\n        [enableDragAndDrop]=\"true\"\n        [sortOptions]=\"sortOptions\"\n      ></verben-sort-table>\n    </div>\n    <div export-content>\n      <lib-data-export  (exportDataEvent)=\"handleExport($event)\">\n      </lib-data-export>\n    </div>\n  </verben-data-view>\n    <div *ngIf=\"!vdcv.hasCurrentItem() && this.cardContextHistory.length == 0\"\n    class=\"message-log-button-container flex justify-between\">\n   \n  </div>\n\n  <div *ngIf=\"vdv.isTableView\" class=\"w-full flex gap-2 justify-between\">\n    <div class=\"message-log-button-container flex justify-between\">\n      <verbena-button\n        [fontWeight]=\"'bold'\"\n        [bgColor]=\"'#8E8D87'\"\n        [borderRadius]=\"'4px'\"\n        [textColor]=\"'#fff'\"\n        [pd]=\"'9.79px 37.28px'\"\n        [text]=\"'Delete'\"\n      >\n      </verbena-button>\n    </div>\n    <div class=\"flex justify-end items-center gap-5\">\n      <span class=\"paginator-text\">{{ cardData.length }} records loaded</span>\n      <button\n        (click)=\"loadMore()\"\n        class=\"load-more view-links text-[#3479E9] underline\"\n      >\n        Load more\n      </button>\n    </div>\n  </div>\n</div>\n\n\n"]}
475
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-management.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/user-management.component.ts","../../../../../../projects/verben-authentication-ui/src/lib/components/user-management/user-management.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, signal, ViewChild, WritableSignal } from '@angular/core';\nimport { columns } from './user-management.columns';\n\nimport { SearchPropertySign } from '../../models/SearchPropertySign';\nimport { UtilService } from '../../services/util.service';\nimport { PagedResult } from '../../models/PagedResult';\nimport { baseStyle } from './base-table-style';\nimport { HttpWebRequestService } from '../../services/http-web-request.service';\n\n\nimport {\n  CardData,\n  DataFilterType,\n  IDataFilter,\n  DropdownLoadEvent,\n  DropdownChangeEvent,\n  ColumnDefinition,\n  ConditionalOptions,\n  CardDataViewComponent,\n  DataViewComponent,\n} from 'verben-ng-ui';\nimport { UserAccessRequestStatus } from '../../models/user-access-request-status';\nimport { ObjectState } from '../../models/object-state';\nimport { EnvironmentService } from '../../services/environment.service';\nimport { UserManagementService } from './services/user-management.service';\nimport { User } from '../../models/user';\nimport { ErrorResponse } from '../../models/ErrorResponse';\nimport { UserManagementFormComponent } from './user-management-form/use-management-form.component';\nimport { Subject, debounceTime, BehaviorSubject } from 'rxjs';\nimport { ConditionOptions } from '../../models/conditions';\nimport { ActivatedRoute } from '@angular/router';\nimport { UserAccessRequestService } from '../user-request-approval/services/user-access-request.service';\nimport { Role } from '../../models/Role';\nimport { Tag } from '../../models/Tag';\n\n\nenum DateFilterTypes {\n  Before = SearchPropertySign.LT,\n  On = SearchPropertySign.EQ,\n  After = SearchPropertySign.GT,\n}\n\n\ninterface TestParentObject {\n  Id: string;\n  Name: string;\n}\n\n\n@Component({\n  selector: 'lib-user-management',\n  templateUrl: './user-management.component.html',\n  styleUrl: './user-management.component.css',\n})\nexport class UserManagementComponent {\n  @ViewChild('vdcv') cardDataView!: CardDataViewComponent;\n  @ViewChild('vdv') dataView!: DataViewComponent;\n  @ViewChild(UserManagementFormComponent) childComponent!: UserManagementFormComponent;\n  private currentSearchTerm: string = '';\n\n\n  filteredColumns: ColumnDefinition<User>[] =columns\n  skip: number = 0;\n  users:User[]=[]\n  searchTerm$ = new Subject<string>();\n  @Input() searchDebounceTime: number = 500;\n  @Input() pageSize: number = 1;\n  pageState: PagedResult<User> | null = null;\n  errorMessage: string = '';\n  appliedFilters: boolean = false;\n  isLoading: boolean = false;\n  hasMore: boolean = true;\n  limit: number = 20;\n  sortParam: string = 'name';\n  sortOrder: string = 'asc';\n Roles:Role[]=[]\n Tags: WritableSignal<Tag[]> = signal([]);\n  dataFit: PagedResult<User> = {\n    PageSize: 1,\n    Skip: 0,\n    Total: 0,\n    Result: [],\n    LastItem: [''],\n    IsLoadingResults: false\n  };\n\n  \n\n  currentFilters: IDataFilter[] = [];\n  currentSorts: IDataFilter[] = [];\n\n\n\n  role: string = '';\n\n  cardContextHistory: CardData[] = [];\n  param: string | null | undefined;\n\n  constructor(\n    private route: ActivatedRoute,\n    private userManagementService: UserManagementService,\n    private userRole: UserAccessRequestService,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private envSvc: EnvironmentService\n  ) {}\n\n  async ngOnInit(): Promise<void> {\n\n  this.getRoles()\n  this.getTags();\n    this.route.paramMap.subscribe(params => {\n      this.role = params.get('role') || '';  // Default to an empty string if no role\n      this.fetchUsers();\n    });\n    \n\n         \n  }\n\n  \n  cardData: CardData[] = [];\n\n  data: any[] = []; \n\n  \n\n\n\n\n  async fetchUsers(sortValue: string = 'CreatedAt', order: string = 'asc') {\n    this.isLoading = true;\n    this.utilService.sendBI(true);\n\n    try {\n      const res = await this.userManagementService.getRealUsers(this.role, this.skip,this.limit, this.sortParam, this.sortOrder)\n      this.utilService.sendBI(false);\n\n      if (res instanceof ErrorResponse) {\n        // Handle error response\n        console.error('Error fetching logs:', res);\n      } else {\n        const response = res as PagedResult<User>;\n        this.dataFit = response;\n        this.users = [...this.users, ...response.Result];\n        this.cardData = this.formatCardData(this.users);\n        this.skip += this.pageSize;\n        this.hasMore = this.skip < response.Total;\n      }\n    } catch (error) {\n      console.error('Error:', error);\n    } finally {\n      this.isLoading = false;\n    }\n  }\n\n\n  async getRoles() {\n    this.utilService.sendBI(true);\n  \n    try {\n      const res = await this.userRole.getRoles();\n      this.utilService.sendBI(false);\n  \n      if (res instanceof ErrorResponse) {\n        console.error('Error fetching roles:', res);\n        return undefined;\n      } \n  \n      const response = res as PagedResult<Role>;\n      this.Roles = response.Result;\n  \n    } catch (error) {\n      console.error('Error fetching roles:', error);\n      return undefined;\n    }\n  }\n\n  async getTags() {\n    this.utilService.sendBI(true);\n  \n    try {\n      const res = await this.userRole.getTags();\n      this.utilService.sendBI(false);\n  \n      if (res instanceof ErrorResponse) {\n        console.error('Error fetching roles:', res);\n        return undefined;\n      } \n      const response = res as PagedResult<Tag>;\n      this.Tags.set(response.Result);\n    } catch (error) {\n      console.error('Error fetching roles:', error);\n      return undefined;\n    }\n  }\n  \nhandleRoleId(value:string){\n  const matchedRole = this.Roles.filter((role) => role.Name === value);\n  return matchedRole[0]?.Code;\n}\n  /**\n   * Format users into CardData for the UI library\n   * @param users Array of users to format\n   * @returns Array of CardData\n   */\n  private formatCardData(users: User[]): CardData[] {\n    return users.map(user => ({\n      selected: false, // Default selection state\n      title: `${user.FirstName} ${user.LastName}`, // Display user's name as title\n      data: { ...user }, // Pass the entire user object\n      body: [\n        { title: 'Name', value: `${user.FirstName} ${user.LastName}` },\n        { title: 'E-Mail Address', value: user.MailAddress },\n        { title: 'Phone Number', value: user.PhoneNumber || 'N/A' },\n      ],\n      children: [], // Add child data if necessary\n    }));\n  }\n\n\n\n\n\n\n\n\n\n\n\n\n  \n\n\n\n  columns = columns;\n  styles = baseStyle;\n\n  selectedParent?: string;\n  basicOption?: string;\n  selectedOption: string[] = [];\n  selectedOptionTwo: string[] = [];\n  selectedOptionThree?: string;\n  missingObject: any;\n\n\n\n  // clearLogs(sortValue: string = 'CreatedAt', order: string = 'asc') {\n  //   this.User = []; // Clear the logs array\n  //   this.skip = 0; // Reset the skip value\n  //   this.hasMore = true; // Reset the flag to allow fetching more logs\n  //   this.appliedFilters = false;\n  //   this.fetchUsers();\n  // }\n\n\n \n\n  // Grid view properties\n  isGridView: boolean = true;\n  currentData!: CardData;\n  selectedColumnCount: number = 0;\n  selectedFilterTableCount: number = 0;\n  isOPen: boolean = true;\n  selectedSortCount: number = 0;\n  showFilter: boolean = false;\n  searchTerm: string = '';\n  showColumn: boolean = false;\n  showSort: boolean = false;\n  selectedAll: boolean = false;\n  visibleColumns: IDataFilter[] = columns.map((col) => ({\n    checked: false,\n    name: typeof col.header === 'string' ? col.header : col.id,\n    type: DataFilterType.Bool,\n  }));\n\n  filterArray: IDataFilter[] = [\n    { name: 'FirstName', type: DataFilterType.String, checked: false },\n    { name: 'LastName', type: DataFilterType.String, checked: false },\n    { name: 'MailAddress', type: DataFilterType.String, checked: false },\n    { name: 'Status', type: DataFilterType.String, checked: false },\n    { name: 'PhoneNumber', type: DataFilterType.String, checked: false },\n    { name: 'CreatedAt', type: DataFilterType.Date, checked: false },\n    { name: 'Role', type: DataFilterType.String, checked: false },\n  ];\n\n\n\n  sortOptions: IDataFilter[] = [\n    { name: 'Name', type: DataFilterType.String, checked: false },\n    { name: 'MailAddress', type: DataFilterType.String, checked: false },\n    { name: 'PhoneNumber', type: DataFilterType.String, checked: false },\n    { name: 'CreatedAt', type: DataFilterType.Date, checked: false },\n  ];\n\n  testParents: TestParentObject[] = [\n    { Id: '1', Name: 'Manager' },\n    { Id: '2', Name: 'Administrator' },\n    { Id: '3', Name: 'Jelom' },\n  ];\n\n  getParentLabel(context: any): string {\n    console.log({ MissingObj: this.missingObject });\n    return this.missingObject.Name;\n  }\n\n  onSave(): void {\n    if (this.childComponent.form.valid) {\n      // const userData: User = this.childComponent.form.value;\n      // console.log('Payload:', [userData]); // Log the payload to check its structure\n  \n      this.utilService.sendBI(true);\n      this.userManagementService.saveUsers([{\n        ...this.currentData?.data,\n        ...this.childComponent.form.value,\n        DataState: this.currentData?.data.DataState === ObjectState.Unchanged ? ObjectState.Changed : this.currentData?.data.DataState,\n      }]).then(\n        (result) => {\n          if (result instanceof ErrorResponse) {\n          } else {\n            this.utilService.showSuccess(\"User saved successfully\");\n          }\n        },\n        (error) => {\n          console.error('Unexpected error saving user:', error);\n        }\n      ).finally(() => {\n        this.utilService.sendBI(false);\n      });\n      console.log(this.childComponent.form.value);\n      \n    } else {\n      console.error('Form is invalid');\n    }\n  }\n\n  onDelete(): void {\n    console.log('Child form delete triggered');\n    // Perform delete logic here\n  }\n  onDropdownChange(event: DropdownChangeEvent): void {\n    // console.log({\n    //   'Test Parent Value': this.selectedParent,\n    //   ...\n    // });\n  }\n\n  onSelectionChange(selectedRows: User[]) {\n    console.log('Selection changed:', selectedRows);\n    // Handle the selection change\n  }\n\n  handleExport(exportedData: Partial<any>[]) {\n    console.log('Exported data:', exportedData);\n    this.downloadCSV(exportedData);\n  }\n\n  private downloadCSV(data: Partial<any>[]) {\n    const headers = Object.keys(data[0]);\n    const csvContent = [\n      headers.join(','),\n      ...data.map((row) => headers.map((header) => row[header]).join(',')),\n    ].join('\\n');\n\n    const blob = new Blob([csvContent], { type: 'text/csv;charset=utf-8;' });\n    const link = document.createElement('a');\n    if (link.download !== undefined) {\n      const url = URL.createObjectURL(blob);\n      link.setAttribute('href', url);\n      link.setAttribute('download', 'export.csv');\n      link.style.visibility = 'hidden';\n      document.body.appendChild(link);\n      link.click();\n      document.body.removeChild(link);\n    }\n  }\n\n\n  getCardDataByMailAddress(mailAddress: string): CardData | undefined {\n    console.log('cardData array:', this.cardData);\n    console.log(mailAddress);\n\n    return this.cardData.find(({ data }) => data?.MailAddress === mailAddress);\n  }\n\n  openDetailView(mailAddress: string) {\n    const cardItem = this.getCardDataByMailAddress(mailAddress);\n    console.log(cardItem);\n\n    if (cardItem && this.cardDataView) {\n      this.dataView.toggleView();\n      // First reset all selections\n      this.cardData.forEach((item) => {\n        item.selected = false;\n        if (item.children) {\n          item.children.forEach((child) => (child.selected = false));\n        }\n      });\n\n      // Set the selected item\n      cardItem.selected = true;\n      this.currentData = this.cardDataView.onItemClick(cardItem);\n\n      // Force change detection if needed\n      // this.changeDetectorRef.detectChanges();\n    }\n  }\n\n\n\n\n  \n\n\n\n  reset() {\n    this.skip = 0;\n    this.pageSize = 20;\n  }\n\n\n  clearData() {\n    this.currentData = {} as CardData;\n  }\n\n  \n  loadMore() {\n    if (this.hasMore) {\n      this.fetchUsers();\n    }\n  }\n\n  onColumnChange(event: boolean) {\n    this.showColumn = event;\n  }\n\n  onSortChange(event: boolean) {\n    this.showSort = event;\n    console.log(event);\n  }\n\n  onColumnsUpdated(updatedColumns: IDataFilter[]) {\n    this.onColumnChange(false);\n    this.selectedColumnCount = updatedColumns.length;\n\n    if (updatedColumns) {\n      // Filter columns to include only visible ones\n      this.filteredColumns = this.columns.filter((col) =>\n        this.visibleColumns.find(\n          (filter) => filter.name === col.header && filter.checked\n        )\n      );\n  \n      // Reorder columns based on the order in visibleColumns\n      const visibleColumnOrder = this.visibleColumns\n        .filter((filter) => filter.checked)\n        .map((filter) => filter.name);\n  \n      this.columns.sort((a, b) => {\n        const indexA = visibleColumnOrder.indexOf(a.header as string);\n        const indexB = visibleColumnOrder.indexOf(b.header as string);\n        return indexA - indexB;\n      });\n    }\n  }\n\n  async postSearch(payload: any) {\n    this.utilService.sendBI(true);\n    const res = await this.server.post(\n      `User/SearchUsers/0/10/CreatedAt/asc`,\n      payload\n    );\n\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n      this.appliedFilters = false;\n      return;\n    } else {\n      this.appliedFilters = true;\n      const response = res as PagedResult<User>;\n      this.dataFit = response;\n      this.users = response.Result;\n      this.cardData = this.formatCardData(this.users)      ;\n    }\n  }\n\n\n  \n  onFilterApplied(appliedFilter: IDataFilter[]) {\n    this.showFilter = false;\n    if (Array.isArray(appliedFilter)) {\n      this.selectedFilterTableCount = appliedFilter.length;\n      console.log(appliedFilter);\n\n      const queryParams = appliedFilter\n        .filter((filter) => filter.checked)\n        .map((filter) => ({\n          PropertyName: filter.name,\n          EntityValue: filter.name==='Role'?this.handleRoleId(filter.value):filter.value,\n          Type: filter.type,\n          Operator: 'And',\n          Sign: this.getCondition(filter.condition),\n        }));\n\n      this.postSearch(queryParams);\n    }\n  }\n\n  getCondition(value: any): ConditionOptions | undefined {\n    switch (value) {\n      case ConditionalOptions.On:\n        return ConditionOptions.On;\n      case ConditionalOptions.After:\n        return ConditionOptions.After;\n      case ConditionalOptions.Before:\n        return ConditionOptions.Before;\n      case ConditionalOptions.NotEqual:\n        return ConditionOptions.NotEqual;\n      default:\n        return undefined; // Explicitly return undefined for invalid cases\n    }\n  }\n  \n  onSortUpdated(updatedSorts: IDataFilter[]): void {\n    this.currentSorts = updatedSorts;\n    \n  }\n\n  async onSearch(event: { key: string; value: string }) {\n    this.searchTerm = event.value;\n    this.reset();\n    if (!this.searchTerm) {\n      this.clearLogs('CreatedAt', 'asc');\n      return;\n    }\n\n    this.isLoading = true;\n    this.utilService.sendBI(true);\n\n    try {\n      const res = await this.server.get(\n        `User/GetUserWithParam/${this.searchTerm}/${this.skip}/${this.pageSize}/CreatedAt/asc`\n      );\n\n      this.utilService.sendBI(false);\n\n      if (res instanceof ErrorResponse) {\n        console.error('Error during search:', res);\n        this.appliedFilters = false;\n      } else {\n        const response = res as PagedResult<User>;\n        this.dataFit = response;\n        this.users = response.Result;\n        this.cardData = this.formatCardData(this.users);\n\n      }\n    } catch (error) {\n      console.error('Search error:', error);\n      this.appliedFilters = false;\n    } finally {\n      this.isLoading = false;\n    }\n  }\n\n  clearLogs(sortValue: string = 'CreatedAt', order: string = 'asc') {\n    this.users= []; // Clear the logs array\n    this.skip = 0; // Reset the skip value\n    this.hasMore = true; // Reset the flag to allow fetching more logs\n    this.appliedFilters = false;\n    this.fetchUsers(sortValue, order);\n  }\n\n\n    \n\n  onViewChange(isGridView: boolean): void {}\n\n  onStateChange(event: { key: string; value: boolean }): void {\n    console.log(`State changed for ${event.key}:`, event.value);\n    if (event.key === 'create') {\n      console.log('peace is a boy');\n\n      \n\n      // const newUser = this.newItem()\n\n      // if ( newUser && this.cardDataView) {\n      //   this.dataView.toggleView();\n      //   // First reset all selections\n      //   this.cardData.forEach((item) => {\n      //     item.selected = false;\n      //     if (item.children) {\n      //       item.children.forEach((child) => (child.selected = false));\n      //     }\n      //   });\n\n      //   this.currentData = this.cardDataView.onItemClick(newUser);\n\n      //   // Force change detection if needed\n      //   // this.changeDetectorRef.detectChanges();\n      // }\n    }\n  }\n}\n","<div class=\"flex flex-col gap-4 message-log-container\">\n  <verben-data-view\n    #vdv\n    [viewState]=\"{\n      isSearch: true,\n      isColumn: true,\n      isFilter: true,\n      isSort: true,\n      isExport: true,\n      isSelect: true,\n     \n      isToggle:true\n    }\"\n    [buttonClass]=\"'my-custom-button-class'\"\n    [iconClass]=\"'my-icon-class'\"\n    [activeIconClass]=\"'my-active-icon-class'\"\n    [selectedColumnCount]=\"0\"\n    (onSearchChange)=\"onSearch($event)\"\n    [searchValue]=\"searchTerm\"\n  \n    [searchValue]=\"searchTerm\"\n    [selectedSortCount]=\"0\"\n    [showFilterChild]=\"showFilter\"\n    [selectedFilterTableCount]=\"0\"\n    (viewChange)=\"onViewChange($event)\"\n    (stateChange)=\"onStateChange($event)\"\n    [isTableView]=\"false\"\n  >\n    <div class=\"mt-2\" table-content>\n      <lib-data-table\n        [data]=\"users\"\n        [columns]=\"filteredColumns\"\n        [styleConfig]=\"styles\"\n        (selectionChange)=\"onSelectionChange($event)\"\n      >\n      <ng-container libColumn=\"select\">\n        <ng-template #cell let-isSelected=\"isSelected\" let-toggleRowSelection=\"toggleRowSelection\">\n          <input type=\"checkbox\" [checked]=\"isSelected\" (change)=\"toggleRowSelection()\" />\n        </ng-template>\n        <ng-template #header let-allRowsSelected=\"allRowsSelected\" let-someRowsSelected=\"someRowsSelected\"\n          let-toggleAllRows=\"toggleAllRows\">\n          <input type=\"checkbox\" [checked]=\"allRowsSelected()\" [indeterminate]=\"someRowsSelected()\"\n            (change)=\"toggleAllRows()\" />\n        </ng-template>\n      </ng-container>\n        <ng-container libColumn=\"createdAt\">\n          <ng-template #cell let-value>\n            {{ value | date }}\n          </ng-template>\n        </ng-container>\n        <ng-container libColumn=\"actions\">\n          <ng-template #cell let-value let-deleteRow >\n            <div class=\"flex gap-6\">\n              <verben-svg\n                (click)=\"openDetailView(value)\"\n                icon=\"edit\"\n                [width]=\"15\"\n                [height]=\"15\"\n                class=\"cursor-pointer\"\n              ></verben-svg>\n\n              <verben-svg\n                icon=\"delete\"\n                [width]=\"15\"\n                [height]=\"15\"\n                (click)=\"deleteRow()\"\n                class=\"cursor-pointer\"\n              ></verben-svg>\n            </div>\n          </ng-template>\n          <ng-template #header>\n            <strong>Actions</strong>\n          </ng-template>\n        </ng-container>\n        <ng-container libColumn=\"status\">\n          <ng-template\n          #cell\n          let-isEditing=\"isEditing\"\n          let-toggleRowEdit=\"toggleRowEdit\"\n          let-deleteRow=\"deleteRow\"\n          let-value=\"value\"\n          >\n          <lib-user-status-badge\n            [status]=\"value\"\n          ></lib-user-status-badge>\n          </ng-template>\n        </ng-container>\n\n      </lib-data-table>\n    </div>\n    <div card-content>\n      <verben-card-data-view\n        borderRadius=\"12px\"\n        (loadMoreClick)=\"loadMore()\"\n        #vdcv\n        dataId=\"MailAddress\"\n        border=\"5px\"\n        [cardDataList]=\"cardData\"\n        rbgColor=\"#f5f6f9\"\n        mg=\"0px\"\n        class=\"gap-1\"\n      >\n        <verben-left-card-data-view class=\"m-0 gap-2\" >\n          <verben-left-card-data\n            #vlcd\n            [parent]=\"vdcv\"\n            dataId=\"MailAddress\"\n            class=\"bg-secondary-100 rounded-xl border-primary border-[1px]\"\n            [cardDataList]=\"cardData\"\n\n          >\n            <ng-template #card let-item>\n              <div (click)=\"currentData = vdcv.onItemClick(item)\" class=\"flex\">\n                <verben-svg\n                  [width]=\"15\"\n                  [height]=\"15\"\n                  (click)=\"vlcd.showChildren(item)\"\n                  [ngClass]=\"vlcd.showToggle(item) ? 'visible' : 'invisible'\"\n                  class=\"items-center flex  cursor-pointer\"\n                  [icon]=\"item.isChildrenExpanded ? 'minus' : 'plus'\"\n                />\n                <div\n                 (click)=\"currentData = vdcv.onItemClick(item)\"\n                class=\"flex cursor-pointer w-full bg-secondary rounded-xl\"\n                >\n                  <div\n                    class=\"w-3 rounded-xl rounded-tr-none rounded-br-none\"\n                    [ngClass]=\"\n                      item.selected ? 'bg-primary' : 'bg-secondary-200'\n                    \"\n                  ></div>\n                  <div class=\"flex-1 flex items-end gap-y-2 gap-x-4 p-4\">\n                    <div class=\"flex-1 space-y-2\">\n                      <span\n                        class=\"font-semibold text-[#404040] flex-1 truncate\"\n                        >{{ item.title }}</span\n                      >\n\n                      <p class=\"flex items-center my-1\">\n                        <label for=\"phone\" class=\"text-[10px] font-light\"\n                          >Phone Number:</label\n                        >\n                        <span id=\"phone\" class=\"text-sm truncate\">{{\n                          item.data.PhoneNumber\n                        }}</span>\n                      </p>\n                    </div>\n\n                    <div class=\"grid gap-y-1\">\n                      <p class=\"grid\">\n                        <label\n                          for=\"role\"\n                          class=\"text-[10px] font-light text-[#404040]\"\n                          >Role</label\n                        >\n                        <span id=\"role\" class=\"text-sm font-medium\">{{\n                          item.data?.Role?.Name\n                        }}</span>\n                      </p>\n\n                      <lib-user-status-badge\n                        [status]=\"item.data.Status\"\n                      ></lib-user-status-badge>\n                    </div>\n                  </div>\n                </div>\n              </div>\n            </ng-template>\n          </verben-left-card-data>\n        </verben-left-card-data-view>\n\n        <verben-right-card-data-view>\n          <ng-template #parent>\n          <div class=\" bg-secondary-100 py-2 flex flex-col gap-20 px-2\">\n            <lib-user-request-form\n            [roles]=\"Roles\"\n            [tags]=\"Tags()\"\n            [currentData]=\"currentData\"\n            (switchView)=\"vdv.toggleView()\"\n            ></lib-user-request-form>\n            <div class=\"flex justify-between bottom-8 left-0 right-0 p-3\">\n              <verbena-button text=\"Delete\" bgColor=\"#999999\" textColor=\"white\"\n                border=\"1px solid #999999\" (click)=\"onDelete()\"></verbena-button>\n              <div class=\"flex gap-3\">\n                <verbena-button (click)=\"vdv.toggleView()\" text=\"Switch To Table\"\n                  styleType=\"ylw-outline\"></verbena-button>\n                <verbena-button  text=\"Save\" bgColor=\"#FFE681\" (click)=\"onSave()\" textColor=\"#404040\"\n                  border=\"1px solid #FFE681\">\n                  <!-- (click)=\"\" -->\n                </verbena-button>\n              </div>\n            </div>\n          </div>\n          </ng-template>\n        </verben-right-card-data-view>\n\n        <verben-card-data-view-footer class=\"w-full\">\n          <div\n            [ngClass]=\"{\n              'flex gap-2 items-center': true,\n              'justify-between': true,\n              'justify-end': vdcv.hasCurrentItem()\n            }\"\n          >\n            <verbena-button\n              *ngIf=\"!vdcv.hasCurrentItem()\"\n              [fontWeight]=\"'bold'\"\n              [bgColor]=\"'#8E8D87'\"\n              [borderRadius]=\"'4px'\"\n              [textColor]=\"'#fff'\"\n              [pd]=\"'9.79px 37.28px'\"\n              [text]=\"'Delete'\"\n            >\n            </verbena-button>\n            <div\n              class=\"flex {{\n                vdcv.hasCurrentItem() ? 'flex-1' : ''\n              }} justify-end items-center gap-5\"\n            >\n              <span class=\"paginator-text\"\n                >{{ cardData.length }} records loaded</span\n              >\n              <button\n                (click)=\"loadMore()\"\n                class=\"load-more view-links text-[#3479E9] underline\"\n              >\n                Load more\n              </button>\n            </div>\n          </div>\n        </verben-card-data-view-footer>\n      </verben-card-data-view>\n    </div>\n    <div column-content>\n      <verben-visible-column\n        (columnsUpdated)=\"onColumnsUpdated($event)\"\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"400px\"\n        textColor=\"black\"\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        [columns]=\"visibleColumns\"\n        [displayedColumns]=\"5\"\n      ></verben-visible-column>\n    </div>\n    <div filter-content>\n      <verben-table-filter\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"420px\"\n        textColor=\"black\"\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        tertiaryColor=\"#404040\"\n        [filterOptions]=\"filterArray\"\n        [maxFilterLength]=\"3\"\n        (filtersApplied)=\"onFilterApplied($event)\"\n    \n      ></verben-table-filter>\n    </div>\n    <div sort-content>\n      <verben-sort-table\n        (selectedOptions)=\"onSortUpdated($event)\"\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"400px\"\n        textColor=\"black\"\n\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        tertiaryColor=\"#404040\"\n        [enableDragAndDrop]=\"true\"\n        [sortOptions]=\"sortOptions\"\n      ></verben-sort-table>\n    </div>\n    <div export-content>\n      <lib-data-export  (exportDataEvent)=\"handleExport($event)\">\n      </lib-data-export>\n    </div>\n  </verben-data-view>\n    <div *ngIf=\"!vdcv.hasCurrentItem() && this.cardContextHistory.length == 0\"\n    class=\"message-log-button-container flex justify-between\">\n   \n  </div>\n\n  <div *ngIf=\"vdv.isTableView\" class=\"w-full flex gap-2 justify-between\">\n    <div class=\"message-log-button-container flex justify-between\">\n      <verbena-button\n        [fontWeight]=\"'bold'\"\n        [bgColor]=\"'#8E8D87'\"\n        [borderRadius]=\"'4px'\"\n        [textColor]=\"'#fff'\"\n        [pd]=\"'9.79px 37.28px'\"\n        [text]=\"'Delete'\"\n      >\n      </verbena-button>\n    </div>\n    <div class=\"flex justify-end items-center gap-5\">\n      <span class=\"paginator-text\">{{ cardData.length }} records loaded</span>\n      <button\n        (click)=\"loadMore()\"\n        class=\"load-more view-links text-[#3479E9] underline\"\n      >\n        Load more\n      </button>\n    </div>\n  </div>\n</div>\n\n\n"]}
@@ -69,11 +69,11 @@ export class UserRequestFormComponent {
69
69
  UserAccessRequestStatus.Pending || !this.form.valid);
70
70
  }
71
71
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserRequestFormComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
72
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UserRequestFormComponent, selector: "lib-user-request-form", inputs: { roles: "roles", currentData: "currentData" }, outputs: { switchView: "switchView", onApproval: "onApproval" }, ngImport: i0, template: "<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 name=\"MailAddress\"\n label=\"Mail Address:\"\n formControlName=\"MailAddress\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"First Name:\"\n name=\"FirstName\"\n type=\"text\"\n formControlName=\"FirstName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"Last Name:\"\n name=\"LastName\"\n type=\"text\"\n formControlName=\"LastName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"OtherName:\"\n name=\"OtherName\"\n type=\"text\"\n formControlName=\"OtherName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"Phone Number:\"\n name=\"PhoneNumber\"\n type=\"tel\"\n formControlName=\"PhoneNumber\"\n [readOnly]=\"true\"\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 <!-- buttons -->\n <div class=\"flex justify-between my-2\">\n <verbena-button\n width=\"114px\"\n height=\"39px\"\n text=\"Reject\"\n styleType=\"danger\"\n borderRadius=\"10px\"\n [disable]=\"disableProcessing()\"\n ></verbena-button>\n <verbena-button\n (click)=\"switchView.emit()\"\n text=\"Switch To Table\"\n styleType=\"ylw-outline\"\n ></verbena-button>\n <verbena-button\n (click)=\"\n onApproval.emit({\n email: form.get('MailAddress')?.value,\n role: form.get('RoleId')?.value\n })\n \"\n text=\"Approve\"\n bgColor=\"#28a745\"\n textColor=\"white\"\n border=\"1px solid #28a745\"\n borderRadius=\"10px\"\n pd=\"10px 20px\"\n width=\"114px\"\n height=\"39px\"\n [disable]=\"disableProcessing()\"\n ></verbena-button>\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: i2.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: i2.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "useIcon", "svgPosition", "iconPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "svgSize", "weight", "variant", "styleType", "svg", "svgWidth", "svgHeight", "iconColor", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }, { kind: "component", type: i2.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"] }] });
72
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UserRequestFormComponent, selector: "lib-user-request-form", inputs: { roles: "roles", currentData: "currentData" }, outputs: { switchView: "switchView", onApproval: "onApproval" }, ngImport: i0, template: "<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 name=\"MailAddress\"\n label=\"Mail Address:\"\n formControlName=\"MailAddress\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"First Name:\"\n name=\"FirstName\"\n type=\"text\"\n formControlName=\"FirstName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"Last Name:\"\n name=\"LastName\"\n type=\"text\"\n formControlName=\"LastName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"OtherName:\"\n name=\"OtherName\"\n type=\"text\"\n formControlName=\"OtherName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"Phone Number:\"\n name=\"PhoneNumber\"\n type=\"tel\"\n formControlName=\"PhoneNumber\"\n [readOnly]=\"true\"\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 <!-- buttons -->\n <div class=\"flex justify-between my-2\">\n <verbena-button\n width=\"114px\"\n height=\"39px\"\n text=\"Reject\"\n styleType=\"danger\"\n borderRadius=\"10px\"\n [disable]=\"disableProcessing()\"\n ></verbena-button>\n <verbena-button\n (click)=\"switchView.emit()\"\n text=\"Switch To Table\"\n styleType=\"ylw-outline\"\n ></verbena-button>\n <verbena-button\n (click)=\"\n onApproval.emit({\n email: form.get('MailAddress')?.value,\n role: form.get('RoleID')?.value\n })\n \"\n text=\"Approve\"\n bgColor=\"#28a745\"\n textColor=\"white\"\n border=\"1px solid #28a745\"\n borderRadius=\"10px\"\n pd=\"10px 20px\"\n width=\"114px\"\n height=\"39px\"\n [disable]=\"disableProcessing()\"\n ></verbena-button>\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: i2.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: i2.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "useIcon", "svgPosition", "iconPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "svgSize", "weight", "variant", "styleType", "svg", "svgWidth", "svgHeight", "iconColor", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }, { kind: "component", type: i2.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"] }] });
73
73
  }
74
74
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserRequestFormComponent, decorators: [{
75
75
  type: Component,
76
- args: [{ selector: 'lib-user-request-form', template: "<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 name=\"MailAddress\"\n label=\"Mail Address:\"\n formControlName=\"MailAddress\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"First Name:\"\n name=\"FirstName\"\n type=\"text\"\n formControlName=\"FirstName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"Last Name:\"\n name=\"LastName\"\n type=\"text\"\n formControlName=\"LastName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"OtherName:\"\n name=\"OtherName\"\n type=\"text\"\n formControlName=\"OtherName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"Phone Number:\"\n name=\"PhoneNumber\"\n type=\"tel\"\n formControlName=\"PhoneNumber\"\n [readOnly]=\"true\"\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 <!-- buttons -->\n <div class=\"flex justify-between my-2\">\n <verbena-button\n width=\"114px\"\n height=\"39px\"\n text=\"Reject\"\n styleType=\"danger\"\n borderRadius=\"10px\"\n [disable]=\"disableProcessing()\"\n ></verbena-button>\n <verbena-button\n (click)=\"switchView.emit()\"\n text=\"Switch To Table\"\n styleType=\"ylw-outline\"\n ></verbena-button>\n <verbena-button\n (click)=\"\n onApproval.emit({\n email: form.get('MailAddress')?.value,\n role: form.get('RoleId')?.value\n })\n \"\n text=\"Approve\"\n bgColor=\"#28a745\"\n textColor=\"white\"\n border=\"1px solid #28a745\"\n borderRadius=\"10px\"\n pd=\"10px 20px\"\n width=\"114px\"\n height=\"39px\"\n [disable]=\"disableProcessing()\"\n ></verbena-button>\n </div>\n</form>\n" }]
76
+ args: [{ selector: 'lib-user-request-form', template: "<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 name=\"MailAddress\"\n label=\"Mail Address:\"\n formControlName=\"MailAddress\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"First Name:\"\n name=\"FirstName\"\n type=\"text\"\n formControlName=\"FirstName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"Last Name:\"\n name=\"LastName\"\n type=\"text\"\n formControlName=\"LastName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"OtherName:\"\n name=\"OtherName\"\n type=\"text\"\n formControlName=\"OtherName\"\n [readOnly]=\"true\"\n />\n <verbena-input\n label=\"Phone Number:\"\n name=\"PhoneNumber\"\n type=\"tel\"\n formControlName=\"PhoneNumber\"\n [readOnly]=\"true\"\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 <!-- buttons -->\n <div class=\"flex justify-between my-2\">\n <verbena-button\n width=\"114px\"\n height=\"39px\"\n text=\"Reject\"\n styleType=\"danger\"\n borderRadius=\"10px\"\n [disable]=\"disableProcessing()\"\n ></verbena-button>\n <verbena-button\n (click)=\"switchView.emit()\"\n text=\"Switch To Table\"\n styleType=\"ylw-outline\"\n ></verbena-button>\n <verbena-button\n (click)=\"\n onApproval.emit({\n email: form.get('MailAddress')?.value,\n role: form.get('RoleID')?.value\n })\n \"\n text=\"Approve\"\n bgColor=\"#28a745\"\n textColor=\"white\"\n border=\"1px solid #28a745\"\n borderRadius=\"10px\"\n pd=\"10px 20px\"\n width=\"114px\"\n height=\"39px\"\n [disable]=\"disableProcessing()\"\n ></verbena-button>\n </div>\n</form>\n" }]
77
77
  }], ctorParameters: () => [{ type: i1.FormBuilder }], propDecorators: { roles: [{
78
78
  type: Input
79
79
  }], currentData: [{
@@ -83,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
83
83
  }], onApproval: [{
84
84
  type: Output
85
85
  }] } });
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"use-request-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/verben-authentication-ui/src/lib/components/user-request-approval/user-request-form/use-request-form.component.ts","../../../../../../../projects/verben-authentication-ui/src/lib/components/user-request-approval/user-request-form/user-request-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  signal,\n  WritableSignal,\n} from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { CardData } from 'verben-ng-ui';\nimport { Role } from '../../../models/Role';\nimport { UserAccessRequestStatus } from '../../../models/user-access-request-status';\n\ninterface UserFormData {\n  MailAddress: string;\n  Name: string;\n  PhoneNumber: string;\n}\n\n@Component({\n  selector: 'lib-user-request-form',\n  templateUrl: './user-request-form.component.html',\n  styleUrl: './user-request-form.component.css',\n})\nexport class UserRequestFormComponent {\n  @Input() roles: Role[] = [];\n  @Input()\n  get currentData(): CardData | null {\n    return this._currentData;\n  }\n  set currentData(value: CardData | null) {\n    this._currentData = value;\n    console.log(value?.data);\n    if (value?.data) {\n      this.form.patchValue({\n        MailAddress: value.data.MailAddress || '',\n        FirstName: value.data.FirstName || '',\n        LastName: value.data.LastName || '',\n        OtherName: value.data.OtherName || '',\n        PhoneNumber: value.data.PhoneNumber || '',\n        RoleID: value.data.RoleID || '',\n      });\n    } else {\n      this.form.reset();\n    }\n  }\n\n  private _currentData: CardData | null = null;\n\n  @Output() switchView = new EventEmitter<undefined>();\n  @Output() onApproval = new EventEmitter<{ email: string; role: string }>();\n\n  form: FormGroup;\n\n  // roles: WritableSignal<Role[]> = signal([]);\n\n  constructor(private fb: FormBuilder) {\n    this.form = this.fb.group({\n      MailAddress: ['', { readonly: true }],\n      FirstName: ['', { readonly: true }],\n      LastName: ['', { readonly: true }],\n      OtherName: ['', { readonly: true }],\n      PhoneNumber: ['', { readonly: true }],\n      RoleID: ['', { validators: [Validators.required] }],\n    });\n  }\n\n  ngOnInit(): void {\n    // this.userAccessRequestFacade.getRoles$().subscribe((data) => {\n    //   this.roles.set(data);\n    // });\n    // try {\n    //   this.userAccessRequestFacade.loadRoles();\n    // } catch (error) {\n    //   // Handle error\n    // }\n    console.log(this.currentData?.data);\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    }\n  }\n\n  onDelete(): void {\n    // Emit delete event\n    console.log('Delete requested');\n  }\n\n  disableProcessing(): boolean {\n    return (\n      this.currentData?.data?.RequestStatus !==\n        UserAccessRequestStatus.Pending || !this.form.valid\n    );\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    name=\"MailAddress\"\n    label=\"Mail Address:\"\n    formControlName=\"MailAddress\"\n    [readOnly]=\"true\"\n  />\n  <verbena-input\n    label=\"First Name:\"\n    name=\"FirstName\"\n    type=\"text\"\n    formControlName=\"FirstName\"\n    [readOnly]=\"true\"\n  />\n  <verbena-input\n    label=\"Last Name:\"\n    name=\"LastName\"\n    type=\"text\"\n    formControlName=\"LastName\"\n    [readOnly]=\"true\"\n  />\n  <verbena-input\n    label=\"OtherName:\"\n    name=\"OtherName\"\n    type=\"text\"\n    formControlName=\"OtherName\"\n    [readOnly]=\"true\"\n  />\n  <verbena-input\n    label=\"Phone Number:\"\n    name=\"PhoneNumber\"\n    type=\"tel\"\n    formControlName=\"PhoneNumber\"\n    [readOnly]=\"true\"\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  <!-- buttons -->\n  <div class=\"flex justify-between my-2\">\n    <verbena-button\n      width=\"114px\"\n      height=\"39px\"\n      text=\"Reject\"\n      styleType=\"danger\"\n      borderRadius=\"10px\"\n      [disable]=\"disableProcessing()\"\n    ></verbena-button>\n    <verbena-button\n      (click)=\"switchView.emit()\"\n      text=\"Switch To Table\"\n      styleType=\"ylw-outline\"\n    ></verbena-button>\n    <verbena-button\n      (click)=\"\n        onApproval.emit({\n          email: form.get('MailAddress')?.value,\n          role: form.get('RoleId')?.value\n        })\n      \"\n      text=\"Approve\"\n      bgColor=\"#28a745\"\n      textColor=\"white\"\n      border=\"1px solid #28a745\"\n      borderRadius=\"10px\"\n      pd=\"10px 20px\"\n      width=\"114px\"\n      height=\"39px\"\n      [disable]=\"disableProcessing()\"\n    ></verbena-button>\n  </div>\n</form>\n"]}
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"use-request-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/verben-authentication-ui/src/lib/components/user-request-approval/user-request-form/use-request-form.component.ts","../../../../../../../projects/verben-authentication-ui/src/lib/components/user-request-approval/user-request-form/user-request-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  signal,\n  WritableSignal,\n} from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { CardData } from 'verben-ng-ui';\nimport { Role } from '../../../models/Role';\nimport { UserAccessRequestStatus } from '../../../models/user-access-request-status';\n\ninterface UserFormData {\n  MailAddress: string;\n  Name: string;\n  PhoneNumber: string;\n}\n\n@Component({\n  selector: 'lib-user-request-form',\n  templateUrl: './user-request-form.component.html',\n  styleUrl: './user-request-form.component.css',\n})\nexport class UserRequestFormComponent {\n  @Input() roles: Role[] = [];\n  @Input()\n  get currentData(): CardData | null {\n    return this._currentData;\n  }\n  set currentData(value: CardData | null) {\n    this._currentData = value;\n    console.log(value?.data);\n    if (value?.data) {\n      this.form.patchValue({\n        MailAddress: value.data.MailAddress || '',\n        FirstName: value.data.FirstName || '',\n        LastName: value.data.LastName || '',\n        OtherName: value.data.OtherName || '',\n        PhoneNumber: value.data.PhoneNumber || '',\n        RoleID: value.data.RoleID || '',\n      });\n    } else {\n      this.form.reset();\n    }\n  }\n\n  private _currentData: CardData | null = null;\n\n  @Output() switchView = new EventEmitter<undefined>();\n  @Output() onApproval = new EventEmitter<{ email: string; role: string }>();\n\n  form: FormGroup;\n\n  // roles: WritableSignal<Role[]> = signal([]);\n\n  constructor(private fb: FormBuilder) {\n    this.form = this.fb.group({\n      MailAddress: ['', { readonly: true }],\n      FirstName: ['', { readonly: true }],\n      LastName: ['', { readonly: true }],\n      OtherName: ['', { readonly: true }],\n      PhoneNumber: ['', { readonly: true }],\n      RoleID: ['', { validators: [Validators.required] }],\n    });\n  }\n\n  ngOnInit(): void {\n    // this.userAccessRequestFacade.getRoles$().subscribe((data) => {\n    //   this.roles.set(data);\n    // });\n    // try {\n    //   this.userAccessRequestFacade.loadRoles();\n    // } catch (error) {\n    //   // Handle error\n    // }\n    console.log(this.currentData?.data);\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    }\n  }\n\n  onDelete(): void {\n    // Emit delete event\n    console.log('Delete requested');\n  }\n\n  disableProcessing(): boolean {\n    return (\n      this.currentData?.data?.RequestStatus !==\n        UserAccessRequestStatus.Pending || !this.form.valid\n    );\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    name=\"MailAddress\"\n    label=\"Mail Address:\"\n    formControlName=\"MailAddress\"\n    [readOnly]=\"true\"\n  />\n  <verbena-input\n    label=\"First Name:\"\n    name=\"FirstName\"\n    type=\"text\"\n    formControlName=\"FirstName\"\n    [readOnly]=\"true\"\n  />\n  <verbena-input\n    label=\"Last Name:\"\n    name=\"LastName\"\n    type=\"text\"\n    formControlName=\"LastName\"\n    [readOnly]=\"true\"\n  />\n  <verbena-input\n    label=\"OtherName:\"\n    name=\"OtherName\"\n    type=\"text\"\n    formControlName=\"OtherName\"\n    [readOnly]=\"true\"\n  />\n  <verbena-input\n    label=\"Phone Number:\"\n    name=\"PhoneNumber\"\n    type=\"tel\"\n    formControlName=\"PhoneNumber\"\n    [readOnly]=\"true\"\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  <!-- buttons -->\n  <div class=\"flex justify-between my-2\">\n    <verbena-button\n      width=\"114px\"\n      height=\"39px\"\n      text=\"Reject\"\n      styleType=\"danger\"\n      borderRadius=\"10px\"\n      [disable]=\"disableProcessing()\"\n    ></verbena-button>\n    <verbena-button\n      (click)=\"switchView.emit()\"\n      text=\"Switch To Table\"\n      styleType=\"ylw-outline\"\n    ></verbena-button>\n    <verbena-button\n      (click)=\"\n        onApproval.emit({\n          email: form.get('MailAddress')?.value,\n          role: form.get('RoleID')?.value\n        })\n      \"\n      text=\"Approve\"\n      bgColor=\"#28a745\"\n      textColor=\"white\"\n      border=\"1px solid #28a745\"\n      borderRadius=\"10px\"\n      pd=\"10px 20px\"\n      width=\"114px\"\n      height=\"39px\"\n      [disable]=\"disableProcessing()\"\n    ></verbena-button>\n  </div>\n</form>\n"]}