vcomply-workflow-engine 6.0.96 → 6.0.98
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/lib/more-option/more-option.component.mjs +2 -13
- package/esm2022/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.mjs +5 -2
- package/esm2022/lib/workflow-program/workflow-program.component.mjs +8 -3
- package/fesm2022/vcomply-workflow-engine.mjs +12 -15
- package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
- package/lib/workflow-risk/workflow-risk.component.d.ts +1 -1
- package/package.json +1 -1
package/esm2022/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.mjs
CHANGED
|
@@ -135,7 +135,7 @@ export class UserGroupListComponent {
|
|
|
135
135
|
const isChecked = evt?.target?.checked === true;
|
|
136
136
|
const sourceUsers = this.fromResponsibility ? this.disableUsers() : this.usersList;
|
|
137
137
|
if (isChecked) {
|
|
138
|
-
this.selectedUsers = sourceUsers
|
|
138
|
+
this.selectedUsers = sourceUsers;
|
|
139
139
|
this.selectedUserIds = this.selectedUsers.map((user) => user?.member_id);
|
|
140
140
|
}
|
|
141
141
|
else {
|
|
@@ -330,6 +330,9 @@ export class UserGroupListComponent {
|
|
|
330
330
|
this.reviewerIds?.includes(user?.member_id) ||
|
|
331
331
|
this.assigneeIds?.includes(user?.member_id)));
|
|
332
332
|
break;
|
|
333
|
+
case 'collaborator':
|
|
334
|
+
this.nonDisabledUsers = this.usersList.filter((user) => !(this.disabledIds?.includes(user?.member_id)));
|
|
335
|
+
break;
|
|
333
336
|
default:
|
|
334
337
|
}
|
|
335
338
|
return this.nonDisabledUsers;
|
|
@@ -429,4 +432,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
429
432
|
type: Input,
|
|
430
433
|
args: ['selectedGroups']
|
|
431
434
|
}] } });
|
|
432
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-group-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { SearchPipe } from '../pipes/search.pipe';\nimport { ASSETS } from '../../../constants/assets.constants';\n\n@Component({\n  selector: 'user-group-list',\n  templateUrl: './user-group-list.component.html',\n  styleUrls: ['./user-group-list.component.less'],\n})\nexport class UserGroupListComponent implements OnInit {\n  ASSETS = ASSETS;\n  @Output() save = new EventEmitter();\n  @Output() cancel = new EventEmitter();\n  @Input() groupEnabled!: false;\n  @Input() panelTitle = 'Select User(s)';\n  @Input() singleSelect = false;\n  @Input() selectedReviewer = false;\n  @Input() featureflag = false;\n  @Input() reviewerWorkflowType: string = 'SEQUENTIAL';\n  @Output() reviewerWorkflowTypeChange = new EventEmitter();\n  @Input() mode: string = 'CREATE';\n  @Input() fieldType = '';\n  searchKey = '';\n  isPagination: any;\n  approvalWorkflowType: 'ANYONE' | 'ROUNDROBIN' | 'SEQUENTIAL' = 'SEQUENTIAL';\n  usersList: any = [];\n  groupsList: any = [];\n  @Input() fromResponsibility: any;\n  @Input() assignorId: any[] = [];\n  @Input() assigneeIds: any[] = [];\n  @Input() reviewerIds: any[] = [];\n  @Input() overseerIds: any[] = [];\n  @Input() FromProgram = false;\n  @Input() userListInfo!: any;\n  @Input() groupListInfo!: any;\n  @Input() fromApprovalWorkflow: boolean = false;\n  @Input() set approvalType(value: 'ANYONE' | 'ROUNDROBIN' | 'SEQUENTIAL') {\n    this.approvalWorkflowType = value;\n  }\n  @Input() showFutureUsersSwitch: boolean = false;\n  @Input() futureUsersWillSelect: boolean = false;\n  @Input() isAllDisabled: boolean = false;\n  @Input() isGroupTabShow: boolean = true;\n\n  @Output() fetchUserData = new EventEmitter();\n\n  @Input() disabledIds: any = [];\n  @Input() nonRemovableUserIds: any = [];\n  @Input() allUserSelectedDisabled = false;\n  selectedUsers: any = [];\n  selectedUserIds: any = [];\n  allUsersIds: any = [];\n  allUserSelected = false;\n\n  @Input() nonRemovableGroupIds: any = [];\n  selectedGroups: any = [];\n  selectedGroupIds: any = [];\n  allGroupsIds: any = [];\n  allGroupSelected = false;\n  allGroupSelectedDisabled = false;\n  searchPipe = new SearchPipe();\n\n  userCurrentPage = 1;\n  groupCurrentPage = 1;\n  @Input() loading: boolean = false;\n  nonDisabledUsers: any[] = [];\n  @Input('userlist') set setUserList(value: any) {\n    if (value && value?.length) {\n      this.usersList = [...value];\n      this.allUsersIds = this.usersList.map((ele: any) => ele?.member_id);\n      this.allUserSelectedStatus();\n      this.setUserListInit();\n    }\n  }\n\n  @Input('selectedUsers') set setSelectedUser(value: any) {\n    if (value?.length) {\n      this.selectedUsers = this.uniqueByProp(\n        [...this.selectedUsers, ...value],\n        'member_id'\n      );\n      this.selectedUserIds = this.selectedUsers.map(\n        (ele: any) => ele?.member_id\n      );\n      this.allUserSelectedStatus();\n      this.setUserListInit();\n    }\n  }\n\n  defaultSelectedUsers: any = [];\n  defaultSelectedUserIds: any = [];\n  @Input('defaultSelectedUsers') set setDefaultSelectedUsers(value: any) {\n    this.defaultSelectedUsers = this.uniqueByProp(\n      [...this.defaultSelectedUsers, ...value],\n      'member_id'\n    );\n    this.defaultSelectedUserIds = this.defaultSelectedUsers.map(\n      (ele: any) => ele?.member_id\n    );\n  }\n  @Input() userType: string = 'assignees';\n  showConfirmation = false;\n\n  setUserListInit() {\n    if (this.userCurrentPage === 1) {\n      const selected = this.selectedUsers;\n      const otherUser = this.usersList.filter(\n        (ele: any) => !this.selectedUserIds.includes(ele?.member_id)\n      );\n      this.usersList = this.uniqueByProp(\n        [...selected?.sort(), ...otherUser?.sort()],\n        'member_id'\n      );\n    }\n  }\n  allUserSelectedStatus() {\n    this.allUserSelected =\n      this.allUsersIds.sort().toString() ===\n      this.selectedUserIds.sort()?.toString();\n    this.allUserSelectedDisabled =\n      this.allUsersIds.sort().toString() ===\n      this.selectedUserIds.sort()?.toString() &&\n      this.allUsersIds.sort().toString() ===\n      this.nonRemovableUserIds.sort()?.toString();\n  }\n\n  @Input('groupList') set setGroupList(value: any) {\n    if (value && value?.length) {\n      this.groupsList = [...value];\n      this.allGroupsIds = this.groupsList.map((ele: any) => ele?.group_id);\n      this.allGroupSelectedStatus();\n      this.setGroupListInit();\n    }\n  }\n\n  @Input('selectedGroups') set setSelectedGroup(value: any) {\n    this.selectedGroups = this.uniqueByProp(\n      [...this.selectedGroups, ...value],\n      'group_id'\n    );\n    this.selectedGroupIds = this.selectedGroups.map(\n      (ele: any) => ele?.group_id\n    );\n    this.allGroupSelectedStatus();\n    this.setGroupListInit();\n  }\n\n  setGroupListInit() {\n    if (this.userCurrentPage === 1) {\n      const selected = this.selectedGroups;\n      const otherGroup = this.groupsList.filter(\n        (ele: any) => !this.selectedGroupIds.includes(ele?.group_id)\n      );\n      this.groupsList = this.uniqueByProp(\n        [...selected?.sort(), ...otherGroup?.sort()],\n        'group_id'\n      );\n    }\n  }\n  allGroupSelectedStatus() {\n    this.allGroupSelected =\n      this.allGroupsIds?.sort()?.toString() ===\n      this.selectedGroupIds?.sort()?.toString();\n    this.allGroupSelectedDisabled =\n      this.allGroupsIds.sort().toString() ===\n      this.selectedGroupIds.sort()?.toString() &&\n      this.allGroupsIds.sort().toString() ===\n      this.nonRemovableGroupIds.sort()?.toString();\n  }\n\n  userPageChange(page: any) {\n    this.userCurrentPage = page;\n    this.fetchUserData.emit({ page, searchKey: this.searchKey });\n  }\n\n  /**\n   * #### Description\n   * Selects item or deselect a itme\n   * @param evt\n   * @param payload\n   */\n  selectItem(evt: any, payload: any) {\n    evt?.target?.checked === true\n      ? this.manipulateSelectedUser('ADD', payload)\n      : this.manipulateSelectedUser('DELETE', payload);\n  }\n\n  selectItemRadio(evt: any, payload: any) {\n    if (evt?.target?.checked) {\n      this.selectedUsers = [];\n      this.manipulateSelectedUser('ADD', payload);\n    }\n  }\n\n  /**\n   * #### Description\n   *\n   * Manipulates selected items in role list\n   * @param action :'ADD' | 'DELETE'\n   * @param payload\n   */\n  manipulateSelectedUser(action: 'ADD' | 'DELETE', payload: any) {\n    if (action === 'ADD') {\n      this.selectedUsers = this.uniqueByProp(\n        [...this.selectedUsers, ...[payload]],\n        'member_id'\n      );\n      this.selectedUserIds = this.selectedUsers.map(\n        (ele: any) => ele?.member_id\n      );\n    } else if (action === 'DELETE') {\n      let index = this.selectedUsers.findIndex(\n        (ele: any) => ele?.member_id === payload?.member_id\n      );\n      if (index > -1) {\n        this.selectedUsers = this.selectedUsers.filter(\n          (ele: any) => ele?.member_id !== payload?.member_id\n        );\n        this.selectedUserIds = this.selectedUserIds.filter(\n          (ele: any) => ele !== payload?.member_id\n        );\n      }\n    }\n    this.allUserSelectedStatus();\n  }\n  selectAllUser(evt: any) {\n    const isChecked = evt?.target?.checked === true;\n    const sourceUsers = this.fromResponsibility ? this.disableUsers() : this.usersList;\n    \n    if (isChecked) {\n      this.selectedUsers = sourceUsers.filter((user: any) => !this.disabledIds.includes(user?.member_id));\n      this.selectedUserIds = this.selectedUsers.map((user: { member_id: string | number }) => user?.member_id);\n    } else {\n      this.selectedUsers = this.usersList.filter((user: { member_id: string | number }) => \n        this.nonRemovableUserIds.includes(user?.member_id)\n      );\n      this.selectedUserIds = this.selectedUsers.map((user: { member_id: string | number }) => user?.member_id);\n    }\n    \n    this.allUserSelectedStatus();\n  }\n\n  /**\n   * #### Description\n   * Selects item or deselect a itme\n   * @param evt\n   * @param payload\n   */\n  selectGroup(evt: any, payload: any) {\n    evt?.target?.checked === true\n      ? this.manipulateSelectedGroup('ADD', payload)\n      : this.manipulateSelectedGroup('DELETE', payload);\n  }\n\n  /**\n   * #### Description\n   *\n   * Manipulates selected items in role list\n   * @param action :'ADD' | 'DELETE'\n   * @param payload\n   */\n  manipulateSelectedGroup(action: 'ADD' | 'DELETE', payload: any) {\n    if (action === 'ADD') {\n      this.selectedGroups = this.uniqueByProp(\n        [...this.selectedGroups, ...[payload]],\n        'group_id'\n      );\n      this.selectedGroupIds = this.selectedGroups.map(\n        (ele: any) => ele?.group_id\n      );\n    } else if (action === 'DELETE') {\n      let index = this.selectedGroups.findIndex(\n        (ele: any) => ele?.group_id === payload?.group_id\n      );\n      if (index > -1) {\n        this.selectedGroups = this.selectedGroups.filter(\n          (ele: any) => ele?.group_id !== payload?.group_id\n        );\n        this.selectedGroupIds = this.selectedGroupIds.filter(\n          (ele: any) => ele !== payload?.group_id\n        );\n      }\n    }\n    this.allGroupSelectedStatus();\n  }\n  selectAllGroup(evt: any) {\n    const groupData = this.searchPipe.transform(\n      this.groupsList,\n      this.searchKey,\n      'group_name'\n    );\n    if (evt?.target?.checked === true) {\n      this.selectedGroups = groupData;\n      this.selectedGroupIds = groupData.map((ele: any) => ele?.group_id);\n    } else {\n      this.selectedGroups = this.groupsList.filter((ele: any) =>\n        this.nonRemovableGroupIds.includes(ele?.group_id)\n      );\n      this.selectedGroupIds = this.selectedGroups.map(\n        (ele: any) => ele?.group_id\n      );\n    }\n    this.allGroupSelectedStatus();\n  }\n\n  animation = true;\n  constructor() { }\n\n  ngOnInit(): void {\n    let disabledIds = [...this.disabledIds, ...this.nonRemovableUserIds];\n    this.disabledIds = [...new Set(disabledIds)];\n    this.paginationVisible();\n    this.animation = true;\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n  }\n  currentTab = 'USER';\n  switchTab(tab: string) {\n    this.currentTab = tab;\n    this.searchKey = '';\n  }\n\n  saveList() {\n    if (\n      this.defaultSelectedUserIds &&\n      this.defaultSelectedUserIds?.length &&\n      this.selectedUserIds &&\n      this.selectedUserIds?.length\n    ) {\n      this.defaultSelectedUserIds?.forEach((id: number): any => {\n        if (!this.selectedUserIds?.includes(id)) {\n          this.showConfirmation = true;\n        }\n      });\n    } else {\n      this.showConfirmation = false;\n    }\n    if (!this.showConfirmation)\n      this.save.emit({\n        users: this.selectedUsers,\n        groups: this.selectedGroups,\n        futureUsersWillSelect: this.futureUsersWillSelect,\n      });\n  }\n\n  confirmAction(evt: 'YES' | 'NO') {\n    if (evt === 'YES') {\n      this.save.emit({\n        users: this.selectedUsers,\n        groups: this.selectedGroups,\n        futureUsersWillSelect: this.futureUsersWillSelect,\n      });\n    } else if (evt === 'NO') {\n      this.showConfirmation = false;\n    }\n  }\n\n  closeList() {\n    this.cancel.emit();\n  }\n\n  //\n\n  /**\n   * #### Description\n   *\n   * Returns the unique array of object based on unique key\n   * @param array\n   * @param key\n   * @returns\n   */\n  uniqueByProp(array: any, key: string) {\n    return Array.from(\n      array\n        .reduce(\n          (acc: any, item: any) => (\n            item && item[key] && acc.set(item[key], item), acc\n          ),\n          new Map()\n        )\n        .values()\n    );\n  }\n\n  paginationVisible() {\n    if (this.userListInfo?.total_pages > 1) {\n      this.isPagination = true;\n    } else {\n      this.isPagination = false;\n    }\n  }\n  workflowTypeChanged(event: string) {\n    this.reviewerWorkflowType = event;\n    this.reviewerWorkflowTypeChange.emit(event);\n  }\n\n  disableUsers() {\n    switch (this.fromResponsibility) {\n      case 'Assignee':\n        this.nonDisabledUsers = this.usersList.filter(\n          (user: any) =>\n            !(\n              this.reviewerIds?.includes(user?.member_id) ||\n              this.overseerIds?.includes(user?.member_id)\n            )\n        );\n        break;\n      case 'Reviewer':\n        this.nonDisabledUsers = this.usersList.filter(\n          (user: any) =>\n            !(\n              this.overseerIds?.includes(user?.member_id) ||\n              this.assigneeIds?.includes(user?.member_id)\n            )\n        );\n        break;\n      case 'Overseer':\n        this.nonDisabledUsers = this.usersList.filter(\n          (user: any) =>\n            !(\n              this.assignorId?.includes(user?.member_id) ||\n              this.reviewerIds?.includes(user?.member_id) ||\n              this.assigneeIds?.includes(user?.member_id)\n            )\n        );\n        break;\n      default:\n    }\n    return this.nonDisabledUsers;\n  }\n\n  setAllUsersSelected(event: any) {\n    this.futureUsersWillSelect = event;\n    if (event) {\n      this.selectedUsers = [];\n      this.selectedGroups = [];\n      this.selectedUserIds = [];\n      this.selectedGroupIds = [];\n    }\n  }\n}\n","<div class=\"user-group-list\" [class.animate]=\"animation\">\n  <div class=\"user-group-list-head\">\n    <h3 class=\"user-group-list-title\">{{ panelTitle }}</h3>\n  </div>\n  <div class=\"user-group-list-body\">\n    <div class=\"user-group-list-body-inner\">\n      <app-loader-inline *ngIf=\"loading\"></app-loader-inline>\n      <div\n        class=\"user-group-list-tab vx-d-flex vx-align-center vx-justify-between vx-mb-2\"\n        *ngIf=\"groupEnabled\"\n      >\n        <div class=\"vx-d-flex vx-align-center\">\n          <button\n            (click)=\"switchTab('USER')\"\n            class=\"tab-btn vx-fs-11 vx-fw-600 vx-paragraph-txt vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\n            [class.active]=\"currentTab === 'USER'\"\n          >\n            USERS\n            <span\n              class=\"vx-pl-1 vx-pr-1 vx-d-flex vx-align-center vx-justify-center vx-ml-2 vx-lh-4\"\n              >{{\n                searchKey?.length && currentTab === \"USER\"\n                  ? (usersList | filter : searchKey)?.length\n                  : usersList?.length || userListInfo?.total_items\n              }}</span\n            >\n          </button>\n          <button\n            *ngIf=\"isGroupTabShow\"\n            (click)=\"switchTab('GROUP')\"\n            class=\"tab-btn vx-fs-11 vx-fw-600 vx-paragraph-txt vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\n            [class.active]=\"currentTab === 'GROUP'\"\n          >\n            {{ featureflag ? \"USER GROUPS\" : \"GROUPS\" }}\n            <span\n              class=\"vx-pl-1 vx-pr-1 vx-d-flex vx-align-center vx-justify-center vx-ml-2 vx-lh-4\"\n              >{{\n                searchKey?.length && currentTab === \"GROUP\"\n                  ? (groupsList | search : searchKey : \"group_name\")?.length\n                  : groupsList?.length || groupListInfo?.total_items\n              }}</span\n            >\n          </button>\n        </div>\n\n        <div\n          class=\"future-user vx-d-flex vx-align-center\"\n          *ngIf=\"showFutureUsersSwitch\"\n        >\n          <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase\">\n            Visible to All Current & Future Users\n          </div>\n          <i\n            class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1 vx-mr-1\"\n            [appTooltip]=\"\n              'If selected, this policy will be visible to all users that are currently active in your VComply account and users that might be added in the future.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n          <app-cs-switch\n            [ngValue]=\"futureUsersWillSelect\"\n            (ngValueChange)=\"setAllUsersSelected($event)\"\n          >\n          </app-cs-switch>\n        </div>\n      </div>\n\n      <div class=\"search-block vx-mb-2\">\n        <i class=\"icons\">&#xe90b;</i>\n        <input\n          *ngIf=\"!featureflag\"\n          [(ngModel)]=\"searchKey\"\n          type=\"text\"\n          placeholder=\"{{\n            currentTab === 'USER' ? 'Search User' : 'Search Group'\n          }}\"\n        />\n        <input\n          *ngIf=\"featureflag\"\n          [(ngModel)]=\"searchKey\"\n          type=\"text\"\n          placeholder=\"{{\n            currentTab === 'USER' ? 'Search User' : 'Search User Group'\n          }}\"\n        />\n      </div>\n\n      <ng-container *ngIf=\"currentTab === 'USER' && !loading\">\n        <ng-container *ngIf=\"usersList | filter : searchKey as users\">\n          <vui-pagination\n            *ngIf=\"\n              userListInfo?.total_pages > 1 &&\n              usersList?.length !== userListInfo?.total_items\n            \"\n            [currentPage]=\"userCurrentPage\"\n            [totalPage]=\"userListInfo?.total_pages\"\n            (pageChanged)=\"userPageChange($event)\"\n          ></vui-pagination>\n          <div\n            class=\"user-group-list-mid\"\n            [class.with-pagination]=\"isPagination\"\n          >\n            <ng-container *ngIf=\"users?.length > 0; else nouser\">\n              <div class=\"user-list-select vx-mb-2\">\n                <vui-checkbox\n                  *ngIf=\"!singleSelect\"\n                  #user\n                  [checked]=\"allUserSelected || futureUsersWillSelect\"\n                  [disabled]=\"\n                    allUserSelectedDisabled ||\n                    futureUsersWillSelect ||\n                    isAllDisabled\n                  \"\n                  (change)=\"selectAllUser($event)\"\n                >\n                  <div\n                    class=\"user-name vx-fs-12 vx-fw-600 vx-label-txt vx-tt-none\"\n                  >\n                    {{ !user?.checked ? \"Select All\" : \"Deselect All\" }}\n                  </div>\n                </vui-checkbox>\n              </div>\n              <div class=\"user-list-item\">\n                <ul class=\"vx-m-0 vx-p-0 vx-d-flex\">\n                  <ng-container *ngFor=\"let user of users\">\n                    <li\n                      class=\"vx-mb-3\"\n                      *ngIf=\"!singleSelect\"\n                      [appTooltip]=\"\n                        user\n                          | tooltipMessage\n                            : fromResponsibility\n                            : reviewerIds\n                            : overseerIds\n                            : assignorId\n                            : assigneeIds\n                            : 'member_id'\n                            : disabledIds?.includes(user?.member_id)\n                            : FromProgram\n                      \"\n                      placement=\"bottom-left\"\n                      delay=\"0\"\n                      type=\"black\"\n                      [tooltipMandatory]=\"true\"\n                    >\n                      <vui-checkbox\n                        (change)=\"selectItem($event, user)\"\n                        [disabled]=\"\n                          disabledIds?.includes(user?.member_id) ||\n                          futureUsersWillSelect ||\n                          isAllDisabled\n                        \"\n                        [checked]=\"\n                          selectedUserIds?.includes(user?.member_id) ||\n                          futureUsersWillSelect\n                        \"\n                        ><div class=\"user-name\">\n                          {{ user?.member_name }}\n                        </div></vui-checkbox\n                      >\n                    </li>\n                    <li class=\"vx-mb-3\" *ngIf=\"singleSelect\">\n                      <app-cs-radio\n                        [name]=\"'radio-selector'\"\n                        (checkedEvent)=\"selectItemRadio($event, user)\"\n                        [name]=\"'rx-category'\"\n                        [checked]=\"selectedUserIds?.includes(user?.member_id)\"\n                        [appTooltip]=\"user?.member_email\"\n                        placement=\"bottom-left\"\n                        delay=\"0\"\n                        [tooltipMandatory]=\"true\"\n                      >\n                        {{ user?.member_name }}\n                      </app-cs-radio>\n                    </li>\n                  </ng-container>\n                </ul>\n              </div>\n            </ng-container>\n            <ng-template #nouser>\n              <app-no-data\n                *ngIf=\"!loading\"\n                [noDataImage]=\"ASSETS.search_data\"\n                [noDataText]=\"\n                  searchKey?.length > 0 ? 'No match found.' : 'No Users found.'\n                \"\n              ></app-no-data>\n            </ng-template>\n          </div>\n        </ng-container>\n      </ng-container>\n\n      <ng-container *ngIf=\"currentTab === 'GROUP'\">\n        <ng-container\n          *ngIf=\"groupsList | search : searchKey : 'group_name' as groups\"\n        >\n          <div\n            class=\"user-group-list-mid\"\n            [class.with-pagination]=\"isPagination\"\n          >\n            <ng-container *ngIf=\"groups?.length > 0; else nogroup\">\n              <div class=\"user-list-select vx-mb-2\">\n                <vui-checkbox\n                  #group\n                  [checked]=\"allGroupSelected\"\n                  [disabled]=\"allGroupSelectedDisabled\"\n                  (change)=\"selectAllGroup($event)\"\n                >\n                  <div\n                    class=\"user-name vx-fs-12 vx-fw-600 vx-label-txt vx-tt-none\"\n                  >\n                    {{ !group?.checked ? \"Select All\" : \"Deselect All\" }}\n                  </div>\n                </vui-checkbox>\n              </div>\n              <div class=\"user-list-item\">\n                <ul class=\"vx-m-0 vx-p-0 vx-d-flex\">\n                  <li class=\"vx-mb-3\" *ngFor=\"let group of groups\">\n                    <vui-checkbox\n                      (change)=\"selectGroup($event, group)\"\n                      [disabled]=\"\n                        nonRemovableGroupIds?.includes(group?.group_id)\n                      \"\n                      [checked]=\"selectedGroupIds?.includes(group?.group_id)\"\n                    >\n                      <div\n                        class=\"user-name vx-d-flex vx-align-center vx-w-100\"\n                        [appTooltip]=\"group?.group_name\"\n                        placement=\"bottom-left\"\n                        delay=\"0\"\n                        [tooltipMandatory]=\"true\"\n                      >\n                        <div class=\"group-name\">{{ group?.group_name }}</div>\n                        <span\n                          class=\"counter vx-fs-9 vx-fw-600 vx-pl-1 vx-pr-1 vx-lh-3 vx-tt-uppercase\"\n                          >{{ group?.member_count }}\n                          {{ group?.member_count > 1 ? \"USERS\" : \"USER\" }}</span\n                        >\n                      </div>\n                    </vui-checkbox>\n                  </li>\n                </ul>\n              </div>\n            </ng-container>\n            <ng-template #nogroup>\n              <app-no-data\n                *ngIf=\"!loading\"\n                [noDataImage]=\"ASSETS.search_data\"\n                [noDataText]=\"\n                  searchKey?.length > 0\n                    ? 'No match found.'\n                    : 'No data to display.'\n                \"\n              ></app-no-data>\n            </ng-template>\n          </div>\n        </ng-container>\n      </ng-container>\n    </div>\n\n    <div class=\"user-group-list-footer\">\n      <vui-floating-bar\n        *ngIf=\"\n          (!singleSelect || (!singleSelect && selectedReviewer)) && !loading\n        \"\n        (closeEvent)=\"saveList()\"\n        (closeList)=\"closeList()\"\n        (workflowTypeChanged)=\"workflowTypeChanged($event)\"\n        [selectedWorkflow]=\"reviewerWorkflowType\"\n        [showWorkflow]=\"selectedReviewer\"\n        [groupSelected]=\"selectedGroups\"\n        [mode]=\"mode\"\n        [nextDisabled]=\"fromApprovalWorkflow && selectedUsers?.length === 0\"\n      >\n        <ng-container *ngIf=\"!groupEnabled\">\n          <div\n            class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2 vx-mr-2\"\n            *ngFor=\"let element of selectedUsers?.slice(0, 1); let i = index\"\n          >\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              *ngIf=\"!nonRemovableUserIds?.includes(element?.member_id)\"\n              (click)=\"selectItem({ target: { checked: false } }, element)\"\n              >&#xe9ae;</i\n            >\n            <div\n              *ngIf=\"\n                fromApprovalWorkflow &&\n                approvalWorkflowType.toLowerCase() === 'sequential'\n              \"\n              class=\"workflowLavel vx-fs-11 vx-fw-500 vx-pl-1 vx-pr-1 vx-lh-4 vx-mr-1 vx-text-center\"\n            >\n              {{ 1 == selectedUsers?.length ? \"Final\" : 1 }}\n            </div>\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"element?.member_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ element?.member_name }}</span\n            >\n            <button\n              *ngIf=\"selectedUsers?.length > 1\"\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n              appPopover\n              (click)=\"groupDisable.popover()\"\n              placement=\"left\"\n            >\n              +{{ selectedUsers?.slice(1)?.length }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip\" *ngFor=\"let element of selectedUsers?.slice(0,1);let i = index\"><i *ngIf=\"!nonRemovableUserIds?.includes(element?.member_id)\" (click)=\"selectItem({target:{checked:false}},element)\" class=\"icons\">&#xe90d;</i> <span>{{element?.member_name}}</span></div>\n              <div class=\"counter\" *ngIf=\"selectedUsers?.length>1\" appPopover (click)=\"groupDisable.popover()\"\n              placement=\"left\">+{{selectedUsers?.slice(1)?.length}}</div> -->\n        </ng-container>\n        <div\n          class=\"user-group-chip\"\n          *ngIf=\"selectedUsers?.length && groupEnabled\"\n        >\n          <i\n            class=\"icons cross\"\n            *ngIf=\"!nonRemovableUserIds?.includes(selectedUsers[0]?.member_id)\"\n            (click)=\"\n              selectItem({ target: { checked: false } }, selectedUsers[0])\n            \"\n            >&#xe9ae;</i\n          >\n          <div class=\"user-group-name\">{{ selectedUsers[0]?.member_name }}</div>\n          <ng-container *ngIf=\"groupEnabled\">\n            <div\n              class=\"counter\"\n              *ngIf=\"selectedUsers?.length > 1\"\n              appPopover\n              (click)=\"userCount.popover()\"\n              placement=\"left\"\n            >\n              +{{ selectedUsers?.length - 1 }}\n            </div>\n          </ng-container>\n        </div>\n        <div class=\"name userGroup-name\">\n          <!-- {{selectedGroups && selectedGroups?.length > 0 ?' & ':''}} -->\n          <span class=\"userGroup-text\" *ngIf=\"selectedUsers?.length === 1\"\n            >User {{ selectedGroups?.length > 0 ? \" & \" : \" selected\" }}</span\n          >\n          <span class=\"userGroup-text\" *ngIf=\"selectedUsers?.length > 1\"\n            >Users {{ selectedGroups?.length > 0 ? \" & \" : \"selected\" }}</span\n          >\n        </div>\n\n        <div class=\"user-group-chip\" *ngIf=\"selectedGroups?.length\">\n          <i\n            class=\"icons cross\"\n            *ngIf=\"!nonRemovableGroupIds?.includes(selectedGroups[0]?.group_id)\"\n            (click)=\"\n              selectGroup({ target: { checked: false } }, selectedGroups[0])\n            \"\n            >&#xe9ae;</i\n          >\n          <div class=\"user-group-name\">{{ selectedGroups[0]?.group_name }}</div>\n          <div\n            class=\"counter group\"\n            *ngIf=\"selectedGroups?.length > 1\"\n            appPopover\n            (click)=\"groupCount.popover()\"\n            placement=\"left\"\n          >\n            +{{ selectedGroups?.length - 1 }}\n          </div>\n        </div>\n        <div class=\"name userGroup-name\">\n          <span *ngIf=\"selectedGroups?.length === 1\">{{\n            featureflag ? \"User Group selected\" : \"Group selected\"\n          }}</span>\n          <span *ngIf=\"selectedGroups?.length > 1\">{{\n            featureflag ? \"User Groups selected\" : \"Groups selected\"\n          }}</span>\n        </div>\n\n        <app-popover #userCount [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"let element of selectedUsers | slice : 1; let i = index\"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      *ngIf=\"!nonRemovableUserIds?.includes(element?.member_id)\"\n                      (click)=\"\n                        selectItem({ target: { checked: false } }, element)\n                      \"\n                      >&#xe90d;</i\n                    >\n                    {{ element?.member_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n\n        <app-popover #groupDisable [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li *ngFor=\"let element of selectedUsers.slice(1); let i = index\">\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      *ngIf=\"!nonRemovableUserIds?.includes(element?.member_id)\"\n                      (click)=\"\n                        selectItem({ target: { checked: false } }, element)\n                      \"\n                      >&#xe90d;</i\n                    >\n                    <span\n                      *ngIf=\"\n                        fromApprovalWorkflow &&\n                        approvalWorkflowType.toLowerCase() === 'sequential'\n                      \"\n                      class=\"workflowLavel vx-fs-11 vx-fw-500 vx-pl-1 vx-pr-1 vx-lh-4 vx-mr-1 vx-text-center\"\n                      >{{\n                        i + 1 === selectedUsers?.length - 1 ? \"Final\" : i + 2\n                      }}</span\n                    >\n                    {{ element?.member_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n\n        <app-popover #groupCount [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let element of selectedGroups | slice : 1;\n                  let i = index\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      *ngIf=\"!nonRemovableGroupIds?.includes(element?.group_id)\"\n                      (click)=\"\n                        selectGroup({ target: { checked: false } }, element)\n                      \"\n                      >&#xe90d;</i\n                    >\n                    {{ element?.group_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n      </vui-floating-bar>\n      <vui-floating-bar\n        *ngIf=\"singleSelect && !loading\"\n        (closeEvent)=\"saveList()\"\n        (closeList)=\"closeList()\"\n        [nextDisabled]=\"fromApprovalWorkflow && selectedUsers?.length === 0\"\n      >\n        <div class=\"chip\" *ngIf=\"selectedUsers?.length\">\n          <ng-container>\n            <i\n              class=\"icons\"\n              (click)=\"\n                selectItem({ target: { checked: false } }, selectedUsers[0])\n              \"\n              >&#xe90d;</i\n            >\n            <span class=\"value\"> {{ selectedUsers[0]?.member_name }}</span>\n          </ng-container>\n        </div>\n      </vui-floating-bar>\n    </div>\n  </div>\n\n  <div class=\"user-group-list-confirmation\" *ngIf=\"showConfirmation\">\n    <div class=\"confirmation-top\">\n      <div class=\"icon-block\"><i class=\"icons\">&#xe930;</i></div>\n      <div class=\"text\">\n        This action will reset the default {{ userType }} selected for the\n        Program.\n      </div>\n    </div>\n    <div class=\"confirmation-bottom\">\n      <div class=\"message\">Are you sure you would like to proceed?</div>\n      <div class=\"button-group\">\n        <button class=\"no-btn\" (click)=\"confirmAction('NO')\">NO</button>\n        <button class=\"yes-btn\" (click)=\"confirmAction('YES')\">YES</button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
435
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-group-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/workflow-program/create-program-ui/user-group-list/user-group-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { SearchPipe } from '../pipes/search.pipe';\nimport { ASSETS } from '../../../constants/assets.constants';\n\n@Component({\n  selector: 'user-group-list',\n  templateUrl: './user-group-list.component.html',\n  styleUrls: ['./user-group-list.component.less'],\n})\nexport class UserGroupListComponent implements OnInit {\n  ASSETS = ASSETS;\n  @Output() save = new EventEmitter();\n  @Output() cancel = new EventEmitter();\n  @Input() groupEnabled!: false;\n  @Input() panelTitle = 'Select User(s)';\n  @Input() singleSelect = false;\n  @Input() selectedReviewer = false;\n  @Input() featureflag = false;\n  @Input() reviewerWorkflowType: string = 'SEQUENTIAL';\n  @Output() reviewerWorkflowTypeChange = new EventEmitter();\n  @Input() mode: string = 'CREATE';\n  @Input() fieldType = '';\n  searchKey = '';\n  isPagination: any;\n  approvalWorkflowType: 'ANYONE' | 'ROUNDROBIN' | 'SEQUENTIAL' = 'SEQUENTIAL';\n  usersList: any = [];\n  groupsList: any = [];\n  @Input() fromResponsibility: any;\n  @Input() assignorId: any[] = [];\n  @Input() assigneeIds: any[] = [];\n  @Input() reviewerIds: any[] = [];\n  @Input() overseerIds: any[] = [];\n  @Input() FromProgram = false;\n  @Input() userListInfo!: any;\n  @Input() groupListInfo!: any;\n  @Input() fromApprovalWorkflow: boolean = false;\n  @Input() set approvalType(value: 'ANYONE' | 'ROUNDROBIN' | 'SEQUENTIAL') {\n    this.approvalWorkflowType = value;\n  }\n  @Input() showFutureUsersSwitch: boolean = false;\n  @Input() futureUsersWillSelect: boolean = false;\n  @Input() isAllDisabled: boolean = false;\n  @Input() isGroupTabShow: boolean = true;\n\n  @Output() fetchUserData = new EventEmitter();\n\n  @Input() disabledIds: any = [];\n  @Input() nonRemovableUserIds: any = [];\n  @Input() allUserSelectedDisabled = false;\n  selectedUsers: any = [];\n  selectedUserIds: any = [];\n  allUsersIds: any = [];\n  allUserSelected = false;\n\n  @Input() nonRemovableGroupIds: any = [];\n  selectedGroups: any = [];\n  selectedGroupIds: any = [];\n  allGroupsIds: any = [];\n  allGroupSelected = false;\n  allGroupSelectedDisabled = false;\n  searchPipe = new SearchPipe();\n\n  userCurrentPage = 1;\n  groupCurrentPage = 1;\n  @Input() loading: boolean = false;\n  nonDisabledUsers: any[] = [];\n  @Input('userlist') set setUserList(value: any) {\n    if (value && value?.length) {\n      this.usersList = [...value];\n      this.allUsersIds = this.usersList.map((ele: any) => ele?.member_id);\n      this.allUserSelectedStatus();\n      this.setUserListInit();\n    }\n  }\n\n  @Input('selectedUsers') set setSelectedUser(value: any) {\n    if (value?.length) {\n      this.selectedUsers = this.uniqueByProp(\n        [...this.selectedUsers, ...value],\n        'member_id'\n      );\n      this.selectedUserIds = this.selectedUsers.map(\n        (ele: any) => ele?.member_id\n      );\n      this.allUserSelectedStatus();\n      this.setUserListInit();\n    }\n  }\n\n  defaultSelectedUsers: any = [];\n  defaultSelectedUserIds: any = [];\n  @Input('defaultSelectedUsers') set setDefaultSelectedUsers(value: any) {\n    this.defaultSelectedUsers = this.uniqueByProp(\n      [...this.defaultSelectedUsers, ...value],\n      'member_id'\n    );\n    this.defaultSelectedUserIds = this.defaultSelectedUsers.map(\n      (ele: any) => ele?.member_id\n    );\n  }\n  @Input() userType: string = 'assignees';\n  showConfirmation = false;\n\n  setUserListInit() {\n    if (this.userCurrentPage === 1) {\n      const selected = this.selectedUsers;\n      const otherUser = this.usersList.filter(\n        (ele: any) => !this.selectedUserIds.includes(ele?.member_id)\n      );\n      this.usersList = this.uniqueByProp(\n        [...selected?.sort(), ...otherUser?.sort()],\n        'member_id'\n      );\n    }\n  }\n  allUserSelectedStatus() {\n    this.allUserSelected =\n      this.allUsersIds.sort().toString() ===\n      this.selectedUserIds.sort()?.toString();\n    this.allUserSelectedDisabled =\n      this.allUsersIds.sort().toString() ===\n      this.selectedUserIds.sort()?.toString() &&\n      this.allUsersIds.sort().toString() ===\n      this.nonRemovableUserIds.sort()?.toString();\n  }\n\n  @Input('groupList') set setGroupList(value: any) {\n    if (value && value?.length) {\n      this.groupsList = [...value];\n      this.allGroupsIds = this.groupsList.map((ele: any) => ele?.group_id);\n      this.allGroupSelectedStatus();\n      this.setGroupListInit();\n    }\n  }\n\n  @Input('selectedGroups') set setSelectedGroup(value: any) {\n    this.selectedGroups = this.uniqueByProp(\n      [...this.selectedGroups, ...value],\n      'group_id'\n    );\n    this.selectedGroupIds = this.selectedGroups.map(\n      (ele: any) => ele?.group_id\n    );\n    this.allGroupSelectedStatus();\n    this.setGroupListInit();\n  }\n\n  setGroupListInit() {\n    if (this.userCurrentPage === 1) {\n      const selected = this.selectedGroups;\n      const otherGroup = this.groupsList.filter(\n        (ele: any) => !this.selectedGroupIds.includes(ele?.group_id)\n      );\n      this.groupsList = this.uniqueByProp(\n        [...selected?.sort(), ...otherGroup?.sort()],\n        'group_id'\n      );\n    }\n  }\n  allGroupSelectedStatus() {\n    this.allGroupSelected =\n      this.allGroupsIds?.sort()?.toString() ===\n      this.selectedGroupIds?.sort()?.toString();\n    this.allGroupSelectedDisabled =\n      this.allGroupsIds.sort().toString() ===\n      this.selectedGroupIds.sort()?.toString() &&\n      this.allGroupsIds.sort().toString() ===\n      this.nonRemovableGroupIds.sort()?.toString();\n  }\n\n  userPageChange(page: any) {\n    this.userCurrentPage = page;\n    this.fetchUserData.emit({ page, searchKey: this.searchKey });\n  }\n\n  /**\n   * #### Description\n   * Selects item or deselect a itme\n   * @param evt\n   * @param payload\n   */\n  selectItem(evt: any, payload: any) {\n    evt?.target?.checked === true\n      ? this.manipulateSelectedUser('ADD', payload)\n      : this.manipulateSelectedUser('DELETE', payload);\n  }\n\n  selectItemRadio(evt: any, payload: any) {\n    if (evt?.target?.checked) {\n      this.selectedUsers = [];\n      this.manipulateSelectedUser('ADD', payload);\n    }\n  }\n\n  /**\n   * #### Description\n   *\n   * Manipulates selected items in role list\n   * @param action :'ADD' | 'DELETE'\n   * @param payload\n   */\n  manipulateSelectedUser(action: 'ADD' | 'DELETE', payload: any) {\n    if (action === 'ADD') {\n      this.selectedUsers = this.uniqueByProp(\n        [...this.selectedUsers, ...[payload]],\n        'member_id'\n      );\n      this.selectedUserIds = this.selectedUsers.map(\n        (ele: any) => ele?.member_id\n      );\n    } else if (action === 'DELETE') {\n      let index = this.selectedUsers.findIndex(\n        (ele: any) => ele?.member_id === payload?.member_id\n      );\n      if (index > -1) {\n        this.selectedUsers = this.selectedUsers.filter(\n          (ele: any) => ele?.member_id !== payload?.member_id\n        );\n        this.selectedUserIds = this.selectedUserIds.filter(\n          (ele: any) => ele !== payload?.member_id\n        );\n      }\n    }\n    this.allUserSelectedStatus();\n  }\n  selectAllUser(evt: any) {\n    const isChecked = evt?.target?.checked === true;\n    const sourceUsers = this.fromResponsibility ? this.disableUsers() : this.usersList;\n    \n    if (isChecked) {\n      this.selectedUsers = sourceUsers;\n      this.selectedUserIds = this.selectedUsers.map((user: { member_id: string | number }) => user?.member_id);\n    } else {\n      this.selectedUsers = this.usersList.filter((user: { member_id: string | number }) => \n        this.nonRemovableUserIds.includes(user?.member_id)\n      );\n      this.selectedUserIds = this.selectedUsers.map((user: { member_id: string | number }) => user?.member_id);\n    }\n    \n    this.allUserSelectedStatus();\n  }\n\n  /**\n   * #### Description\n   * Selects item or deselect a itme\n   * @param evt\n   * @param payload\n   */\n  selectGroup(evt: any, payload: any) {\n    evt?.target?.checked === true\n      ? this.manipulateSelectedGroup('ADD', payload)\n      : this.manipulateSelectedGroup('DELETE', payload);\n  }\n\n  /**\n   * #### Description\n   *\n   * Manipulates selected items in role list\n   * @param action :'ADD' | 'DELETE'\n   * @param payload\n   */\n  manipulateSelectedGroup(action: 'ADD' | 'DELETE', payload: any) {\n    if (action === 'ADD') {\n      this.selectedGroups = this.uniqueByProp(\n        [...this.selectedGroups, ...[payload]],\n        'group_id'\n      );\n      this.selectedGroupIds = this.selectedGroups.map(\n        (ele: any) => ele?.group_id\n      );\n    } else if (action === 'DELETE') {\n      let index = this.selectedGroups.findIndex(\n        (ele: any) => ele?.group_id === payload?.group_id\n      );\n      if (index > -1) {\n        this.selectedGroups = this.selectedGroups.filter(\n          (ele: any) => ele?.group_id !== payload?.group_id\n        );\n        this.selectedGroupIds = this.selectedGroupIds.filter(\n          (ele: any) => ele !== payload?.group_id\n        );\n      }\n    }\n    this.allGroupSelectedStatus();\n  }\n  selectAllGroup(evt: any) {\n    const groupData = this.searchPipe.transform(\n      this.groupsList,\n      this.searchKey,\n      'group_name'\n    );\n    if (evt?.target?.checked === true) {\n      this.selectedGroups = groupData;\n      this.selectedGroupIds = groupData.map((ele: any) => ele?.group_id);\n    } else {\n      this.selectedGroups = this.groupsList.filter((ele: any) =>\n        this.nonRemovableGroupIds.includes(ele?.group_id)\n      );\n      this.selectedGroupIds = this.selectedGroups.map(\n        (ele: any) => ele?.group_id\n      );\n    }\n    this.allGroupSelectedStatus();\n  }\n\n  animation = true;\n  constructor() { }\n\n  ngOnInit(): void {\n    let disabledIds = [...this.disabledIds, ...this.nonRemovableUserIds];\n    this.disabledIds = [...new Set(disabledIds)];\n    this.paginationVisible();\n    this.animation = true;\n    setTimeout(() => {\n      this.animation = false;\n    }, 300);\n  }\n  currentTab = 'USER';\n  switchTab(tab: string) {\n    this.currentTab = tab;\n    this.searchKey = '';\n  }\n\n  saveList() {\n    if (\n      this.defaultSelectedUserIds &&\n      this.defaultSelectedUserIds?.length &&\n      this.selectedUserIds &&\n      this.selectedUserIds?.length\n    ) {\n      this.defaultSelectedUserIds?.forEach((id: number): any => {\n        if (!this.selectedUserIds?.includes(id)) {\n          this.showConfirmation = true;\n        }\n      });\n    } else {\n      this.showConfirmation = false;\n    }\n    if (!this.showConfirmation)\n      this.save.emit({\n        users: this.selectedUsers,\n        groups: this.selectedGroups,\n        futureUsersWillSelect: this.futureUsersWillSelect,\n      });\n  }\n\n  confirmAction(evt: 'YES' | 'NO') {\n    if (evt === 'YES') {\n      this.save.emit({\n        users: this.selectedUsers,\n        groups: this.selectedGroups,\n        futureUsersWillSelect: this.futureUsersWillSelect,\n      });\n    } else if (evt === 'NO') {\n      this.showConfirmation = false;\n    }\n  }\n\n  closeList() {\n    this.cancel.emit();\n  }\n\n  //\n\n  /**\n   * #### Description\n   *\n   * Returns the unique array of object based on unique key\n   * @param array\n   * @param key\n   * @returns\n   */\n  uniqueByProp(array: any, key: string) {\n    return Array.from(\n      array\n        .reduce(\n          (acc: any, item: any) => (\n            item && item[key] && acc.set(item[key], item), acc\n          ),\n          new Map()\n        )\n        .values()\n    );\n  }\n\n  paginationVisible() {\n    if (this.userListInfo?.total_pages > 1) {\n      this.isPagination = true;\n    } else {\n      this.isPagination = false;\n    }\n  }\n  workflowTypeChanged(event: string) {\n    this.reviewerWorkflowType = event;\n    this.reviewerWorkflowTypeChange.emit(event);\n  }\n\n  disableUsers() {\n    switch (this.fromResponsibility) {\n      case 'Assignee':\n        this.nonDisabledUsers = this.usersList.filter(\n          (user: any) =>\n            !(\n              this.reviewerIds?.includes(user?.member_id) ||\n              this.overseerIds?.includes(user?.member_id)\n            )\n        );\n        break;\n      case 'Reviewer':\n        this.nonDisabledUsers = this.usersList.filter(\n          (user: any) =>\n            !(\n              this.overseerIds?.includes(user?.member_id) ||\n              this.assigneeIds?.includes(user?.member_id)\n            )\n        );\n        break;\n      case 'Overseer':\n        this.nonDisabledUsers = this.usersList.filter(\n          (user: any) =>\n            !(\n              this.assignorId?.includes(user?.member_id) ||\n              this.reviewerIds?.includes(user?.member_id) ||\n              this.assigneeIds?.includes(user?.member_id)\n            )\n        );\n        break;\n        case 'collaborator':\n          this.nonDisabledUsers = this.usersList.filter(\n            (user: any) =>\n              !(\n                this.disabledIds?.includes(user?.member_id)\n              )\n          );\n        break;\n      default:\n    }\n    return this.nonDisabledUsers;\n  }\n\n  setAllUsersSelected(event: any) {\n    this.futureUsersWillSelect = event;\n    if (event) {\n      this.selectedUsers = [];\n      this.selectedGroups = [];\n      this.selectedUserIds = [];\n      this.selectedGroupIds = [];\n    }\n  }\n}\n","<div class=\"user-group-list\" [class.animate]=\"animation\">\n  <div class=\"user-group-list-head\">\n    <h3 class=\"user-group-list-title\">{{ panelTitle }}</h3>\n  </div>\n  <div class=\"user-group-list-body\">\n    <div class=\"user-group-list-body-inner\">\n      <app-loader-inline *ngIf=\"loading\"></app-loader-inline>\n      <div\n        class=\"user-group-list-tab vx-d-flex vx-align-center vx-justify-between vx-mb-2\"\n        *ngIf=\"groupEnabled\"\n      >\n        <div class=\"vx-d-flex vx-align-center\">\n          <button\n            (click)=\"switchTab('USER')\"\n            class=\"tab-btn vx-fs-11 vx-fw-600 vx-paragraph-txt vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\n            [class.active]=\"currentTab === 'USER'\"\n          >\n            USERS\n            <span\n              class=\"vx-pl-1 vx-pr-1 vx-d-flex vx-align-center vx-justify-center vx-ml-2 vx-lh-4\"\n              >{{\n                searchKey?.length && currentTab === \"USER\"\n                  ? (usersList | filter : searchKey)?.length\n                  : usersList?.length || userListInfo?.total_items\n              }}</span\n            >\n          </button>\n          <button\n            *ngIf=\"isGroupTabShow\"\n            (click)=\"switchTab('GROUP')\"\n            class=\"tab-btn vx-fs-11 vx-fw-600 vx-paragraph-txt vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\n            [class.active]=\"currentTab === 'GROUP'\"\n          >\n            {{ featureflag ? \"USER GROUPS\" : \"GROUPS\" }}\n            <span\n              class=\"vx-pl-1 vx-pr-1 vx-d-flex vx-align-center vx-justify-center vx-ml-2 vx-lh-4\"\n              >{{\n                searchKey?.length && currentTab === \"GROUP\"\n                  ? (groupsList | search : searchKey : \"group_name\")?.length\n                  : groupsList?.length || groupListInfo?.total_items\n              }}</span\n            >\n          </button>\n        </div>\n\n        <div\n          class=\"future-user vx-d-flex vx-align-center\"\n          *ngIf=\"showFutureUsersSwitch\"\n        >\n          <div class=\"vx-fs-11 vx-fw-500 vx-label-txt vx-tt-uppercase\">\n            Visible to All Current & Future Users\n          </div>\n          <i\n            class=\"icons info vx-fs-12 vx-txt-blue vx-ml-1 vx-mr-1\"\n            [appTooltip]=\"\n              'If selected, this policy will be visible to all users that are currently active in your VComply account and users that might be added in the future.'\n            \"\n            placement=\"bottom-right\"\n            delay=\"0\"\n            type=\"white\"\n            [tooltipMandatory]=\"true\"\n            >&#xe91f;</i\n          >\n          <app-cs-switch\n            [ngValue]=\"futureUsersWillSelect\"\n            (ngValueChange)=\"setAllUsersSelected($event)\"\n          >\n          </app-cs-switch>\n        </div>\n      </div>\n\n      <div class=\"search-block vx-mb-2\">\n        <i class=\"icons\">&#xe90b;</i>\n        <input\n          *ngIf=\"!featureflag\"\n          [(ngModel)]=\"searchKey\"\n          type=\"text\"\n          placeholder=\"{{\n            currentTab === 'USER' ? 'Search User' : 'Search Group'\n          }}\"\n        />\n        <input\n          *ngIf=\"featureflag\"\n          [(ngModel)]=\"searchKey\"\n          type=\"text\"\n          placeholder=\"{{\n            currentTab === 'USER' ? 'Search User' : 'Search User Group'\n          }}\"\n        />\n      </div>\n\n      <ng-container *ngIf=\"currentTab === 'USER' && !loading\">\n        <ng-container *ngIf=\"usersList | filter : searchKey as users\">\n          <vui-pagination\n            *ngIf=\"\n              userListInfo?.total_pages > 1 &&\n              usersList?.length !== userListInfo?.total_items\n            \"\n            [currentPage]=\"userCurrentPage\"\n            [totalPage]=\"userListInfo?.total_pages\"\n            (pageChanged)=\"userPageChange($event)\"\n          ></vui-pagination>\n          <div\n            class=\"user-group-list-mid\"\n            [class.with-pagination]=\"isPagination\"\n          >\n            <ng-container *ngIf=\"users?.length > 0; else nouser\">\n              <div class=\"user-list-select vx-mb-2\">\n                <vui-checkbox\n                  *ngIf=\"!singleSelect\"\n                  #user\n                  [checked]=\"allUserSelected || futureUsersWillSelect\"\n                  [disabled]=\"\n                    allUserSelectedDisabled ||\n                    futureUsersWillSelect ||\n                    isAllDisabled\n                  \"\n                  (change)=\"selectAllUser($event)\"\n                >\n                  <div\n                    class=\"user-name vx-fs-12 vx-fw-600 vx-label-txt vx-tt-none\"\n                  >\n                    {{ !user?.checked ? \"Select All\" : \"Deselect All\" }}\n                  </div>\n                </vui-checkbox>\n              </div>\n              <div class=\"user-list-item\">\n                <ul class=\"vx-m-0 vx-p-0 vx-d-flex\">\n                  <ng-container *ngFor=\"let user of users\">\n                    <li\n                      class=\"vx-mb-3\"\n                      *ngIf=\"!singleSelect\"\n                      [appTooltip]=\"\n                        user\n                          | tooltipMessage\n                            : fromResponsibility\n                            : reviewerIds\n                            : overseerIds\n                            : assignorId\n                            : assigneeIds\n                            : 'member_id'\n                            : disabledIds?.includes(user?.member_id)\n                            : FromProgram\n                      \"\n                      placement=\"bottom-left\"\n                      delay=\"0\"\n                      type=\"black\"\n                      [tooltipMandatory]=\"true\"\n                    >\n                      <vui-checkbox\n                        (change)=\"selectItem($event, user)\"\n                        [disabled]=\"\n                          disabledIds?.includes(user?.member_id) ||\n                          futureUsersWillSelect ||\n                          isAllDisabled\n                        \"\n                        [checked]=\"\n                          selectedUserIds?.includes(user?.member_id) ||\n                          futureUsersWillSelect\n                        \"\n                        ><div class=\"user-name\">\n                          {{ user?.member_name }}\n                        </div></vui-checkbox\n                      >\n                    </li>\n                    <li class=\"vx-mb-3\" *ngIf=\"singleSelect\">\n                      <app-cs-radio\n                        [name]=\"'radio-selector'\"\n                        (checkedEvent)=\"selectItemRadio($event, user)\"\n                        [name]=\"'rx-category'\"\n                        [checked]=\"selectedUserIds?.includes(user?.member_id)\"\n                        [appTooltip]=\"user?.member_email\"\n                        placement=\"bottom-left\"\n                        delay=\"0\"\n                        [tooltipMandatory]=\"true\"\n                      >\n                        {{ user?.member_name }}\n                      </app-cs-radio>\n                    </li>\n                  </ng-container>\n                </ul>\n              </div>\n            </ng-container>\n            <ng-template #nouser>\n              <app-no-data\n                *ngIf=\"!loading\"\n                [noDataImage]=\"ASSETS.search_data\"\n                [noDataText]=\"\n                  searchKey?.length > 0 ? 'No match found.' : 'No Users found.'\n                \"\n              ></app-no-data>\n            </ng-template>\n          </div>\n        </ng-container>\n      </ng-container>\n\n      <ng-container *ngIf=\"currentTab === 'GROUP'\">\n        <ng-container\n          *ngIf=\"groupsList | search : searchKey : 'group_name' as groups\"\n        >\n          <div\n            class=\"user-group-list-mid\"\n            [class.with-pagination]=\"isPagination\"\n          >\n            <ng-container *ngIf=\"groups?.length > 0; else nogroup\">\n              <div class=\"user-list-select vx-mb-2\">\n                <vui-checkbox\n                  #group\n                  [checked]=\"allGroupSelected\"\n                  [disabled]=\"allGroupSelectedDisabled\"\n                  (change)=\"selectAllGroup($event)\"\n                >\n                  <div\n                    class=\"user-name vx-fs-12 vx-fw-600 vx-label-txt vx-tt-none\"\n                  >\n                    {{ !group?.checked ? \"Select All\" : \"Deselect All\" }}\n                  </div>\n                </vui-checkbox>\n              </div>\n              <div class=\"user-list-item\">\n                <ul class=\"vx-m-0 vx-p-0 vx-d-flex\">\n                  <li class=\"vx-mb-3\" *ngFor=\"let group of groups\">\n                    <vui-checkbox\n                      (change)=\"selectGroup($event, group)\"\n                      [disabled]=\"\n                        nonRemovableGroupIds?.includes(group?.group_id)\n                      \"\n                      [checked]=\"selectedGroupIds?.includes(group?.group_id)\"\n                    >\n                      <div\n                        class=\"user-name vx-d-flex vx-align-center vx-w-100\"\n                        [appTooltip]=\"group?.group_name\"\n                        placement=\"bottom-left\"\n                        delay=\"0\"\n                        [tooltipMandatory]=\"true\"\n                      >\n                        <div class=\"group-name\">{{ group?.group_name }}</div>\n                        <span\n                          class=\"counter vx-fs-9 vx-fw-600 vx-pl-1 vx-pr-1 vx-lh-3 vx-tt-uppercase\"\n                          >{{ group?.member_count }}\n                          {{ group?.member_count > 1 ? \"USERS\" : \"USER\" }}</span\n                        >\n                      </div>\n                    </vui-checkbox>\n                  </li>\n                </ul>\n              </div>\n            </ng-container>\n            <ng-template #nogroup>\n              <app-no-data\n                *ngIf=\"!loading\"\n                [noDataImage]=\"ASSETS.search_data\"\n                [noDataText]=\"\n                  searchKey?.length > 0\n                    ? 'No match found.'\n                    : 'No data to display.'\n                \"\n              ></app-no-data>\n            </ng-template>\n          </div>\n        </ng-container>\n      </ng-container>\n    </div>\n\n    <div class=\"user-group-list-footer\">\n      <vui-floating-bar\n        *ngIf=\"\n          (!singleSelect || (!singleSelect && selectedReviewer)) && !loading\n        \"\n        (closeEvent)=\"saveList()\"\n        (closeList)=\"closeList()\"\n        (workflowTypeChanged)=\"workflowTypeChanged($event)\"\n        [selectedWorkflow]=\"reviewerWorkflowType\"\n        [showWorkflow]=\"selectedReviewer\"\n        [groupSelected]=\"selectedGroups\"\n        [mode]=\"mode\"\n        [nextDisabled]=\"fromApprovalWorkflow && selectedUsers?.length === 0\"\n      >\n        <ng-container *ngIf=\"!groupEnabled\">\n          <div\n            class=\"chipContainer vx-d-flex vx-align-center vx-pl-2 vx-pr-2 vx-mr-2\"\n            *ngFor=\"let element of selectedUsers?.slice(0, 1); let i = index\"\n          >\n            <i\n              class=\"icons cross vx-fs-10 vx-paragraph-txt vx-mr-1\"\n              *ngIf=\"!nonRemovableUserIds?.includes(element?.member_id)\"\n              (click)=\"selectItem({ target: { checked: false } }, element)\"\n              >&#xe9ae;</i\n            >\n            <div\n              *ngIf=\"\n                fromApprovalWorkflow &&\n                approvalWorkflowType.toLowerCase() === 'sequential'\n              \"\n              class=\"workflowLavel vx-fs-11 vx-fw-500 vx-pl-1 vx-pr-1 vx-lh-4 vx-mr-1 vx-text-center\"\n            >\n              {{ 1 == selectedUsers?.length ? \"Final\" : 1 }}\n            </div>\n            <span\n              class=\"chipName vx-fs-11 vx-label-txt\"\n              [appTooltip]=\"element?.member_name\"\n              placement=\"bottom-left\"\n              delay=\"0\"\n              type=\"black\"\n              [tooltipMandatory]=\"false\"\n              >{{ element?.member_name }}</span\n            >\n            <button\n              *ngIf=\"selectedUsers?.length > 1\"\n              class=\"countBtn vx-fs-9 vx-fw-500 vx-txt-white vx-d-flex vx-align-center vx-justify-center vx-lh-4 greenBg\"\n              appPopover\n              (click)=\"groupDisable.popover()\"\n              placement=\"left\"\n            >\n              +{{ selectedUsers?.slice(1)?.length }}\n            </button>\n          </div>\n\n          <!-- <div class=\"chip\" *ngFor=\"let element of selectedUsers?.slice(0,1);let i = index\"><i *ngIf=\"!nonRemovableUserIds?.includes(element?.member_id)\" (click)=\"selectItem({target:{checked:false}},element)\" class=\"icons\">&#xe90d;</i> <span>{{element?.member_name}}</span></div>\n              <div class=\"counter\" *ngIf=\"selectedUsers?.length>1\" appPopover (click)=\"groupDisable.popover()\"\n              placement=\"left\">+{{selectedUsers?.slice(1)?.length}}</div> -->\n        </ng-container>\n        <div\n          class=\"user-group-chip\"\n          *ngIf=\"selectedUsers?.length && groupEnabled\"\n        >\n          <i\n            class=\"icons cross\"\n            *ngIf=\"!nonRemovableUserIds?.includes(selectedUsers[0]?.member_id)\"\n            (click)=\"\n              selectItem({ target: { checked: false } }, selectedUsers[0])\n            \"\n            >&#xe9ae;</i\n          >\n          <div class=\"user-group-name\">{{ selectedUsers[0]?.member_name }}</div>\n          <ng-container *ngIf=\"groupEnabled\">\n            <div\n              class=\"counter\"\n              *ngIf=\"selectedUsers?.length > 1\"\n              appPopover\n              (click)=\"userCount.popover()\"\n              placement=\"left\"\n            >\n              +{{ selectedUsers?.length - 1 }}\n            </div>\n          </ng-container>\n        </div>\n        <div class=\"name userGroup-name\">\n          <!-- {{selectedGroups && selectedGroups?.length > 0 ?' & ':''}} -->\n          <span class=\"userGroup-text\" *ngIf=\"selectedUsers?.length === 1\"\n            >User {{ selectedGroups?.length > 0 ? \" & \" : \" selected\" }}</span\n          >\n          <span class=\"userGroup-text\" *ngIf=\"selectedUsers?.length > 1\"\n            >Users {{ selectedGroups?.length > 0 ? \" & \" : \"selected\" }}</span\n          >\n        </div>\n\n        <div class=\"user-group-chip\" *ngIf=\"selectedGroups?.length\">\n          <i\n            class=\"icons cross\"\n            *ngIf=\"!nonRemovableGroupIds?.includes(selectedGroups[0]?.group_id)\"\n            (click)=\"\n              selectGroup({ target: { checked: false } }, selectedGroups[0])\n            \"\n            >&#xe9ae;</i\n          >\n          <div class=\"user-group-name\">{{ selectedGroups[0]?.group_name }}</div>\n          <div\n            class=\"counter group\"\n            *ngIf=\"selectedGroups?.length > 1\"\n            appPopover\n            (click)=\"groupCount.popover()\"\n            placement=\"left\"\n          >\n            +{{ selectedGroups?.length - 1 }}\n          </div>\n        </div>\n        <div class=\"name userGroup-name\">\n          <span *ngIf=\"selectedGroups?.length === 1\">{{\n            featureflag ? \"User Group selected\" : \"Group selected\"\n          }}</span>\n          <span *ngIf=\"selectedGroups?.length > 1\">{{\n            featureflag ? \"User Groups selected\" : \"Groups selected\"\n          }}</span>\n        </div>\n\n        <app-popover #userCount [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"let element of selectedUsers | slice : 1; let i = index\"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      *ngIf=\"!nonRemovableUserIds?.includes(element?.member_id)\"\n                      (click)=\"\n                        selectItem({ target: { checked: false } }, element)\n                      \"\n                      >&#xe90d;</i\n                    >\n                    {{ element?.member_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n\n        <app-popover #groupDisable [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li *ngFor=\"let element of selectedUsers.slice(1); let i = index\">\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      *ngIf=\"!nonRemovableUserIds?.includes(element?.member_id)\"\n                      (click)=\"\n                        selectItem({ target: { checked: false } }, element)\n                      \"\n                      >&#xe90d;</i\n                    >\n                    <span\n                      *ngIf=\"\n                        fromApprovalWorkflow &&\n                        approvalWorkflowType.toLowerCase() === 'sequential'\n                      \"\n                      class=\"workflowLavel vx-fs-11 vx-fw-500 vx-pl-1 vx-pr-1 vx-lh-4 vx-mr-1 vx-text-center\"\n                      >{{\n                        i + 1 === selectedUsers?.length - 1 ? \"Final\" : i + 2\n                      }}</span\n                    >\n                    {{ element?.member_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n\n        <app-popover #groupCount [dontCloseonClick]=\"true\">\n          <div class=\"wf-action-list\">\n            <ul class=\"action-item\">\n              <li\n                *ngFor=\"\n                  let element of selectedGroups | slice : 1;\n                  let i = index\n                \"\n              >\n                <div class=\"avatar-card\">\n                  <span class=\"value\">\n                    <i\n                      class=\"icons\"\n                      *ngIf=\"!nonRemovableGroupIds?.includes(element?.group_id)\"\n                      (click)=\"\n                        selectGroup({ target: { checked: false } }, element)\n                      \"\n                      >&#xe90d;</i\n                    >\n                    {{ element?.group_name }}\n                  </span>\n                </div>\n              </li>\n            </ul>\n          </div>\n        </app-popover>\n      </vui-floating-bar>\n      <vui-floating-bar\n        *ngIf=\"singleSelect && !loading\"\n        (closeEvent)=\"saveList()\"\n        (closeList)=\"closeList()\"\n        [nextDisabled]=\"fromApprovalWorkflow && selectedUsers?.length === 0\"\n      >\n        <div class=\"chip\" *ngIf=\"selectedUsers?.length\">\n          <ng-container>\n            <i\n              class=\"icons\"\n              (click)=\"\n                selectItem({ target: { checked: false } }, selectedUsers[0])\n              \"\n              >&#xe90d;</i\n            >\n            <span class=\"value\"> {{ selectedUsers[0]?.member_name }}</span>\n          </ng-container>\n        </div>\n      </vui-floating-bar>\n    </div>\n  </div>\n\n  <div class=\"user-group-list-confirmation\" *ngIf=\"showConfirmation\">\n    <div class=\"confirmation-top\">\n      <div class=\"icon-block\"><i class=\"icons\">&#xe930;</i></div>\n      <div class=\"text\">\n        This action will reset the default {{ userType }} selected for the\n        Program.\n      </div>\n    </div>\n    <div class=\"confirmation-bottom\">\n      <div class=\"message\">Are you sure you would like to proceed?</div>\n      <div class=\"button-group\">\n        <button class=\"no-btn\" (click)=\"confirmAction('NO')\">NO</button>\n        <button class=\"yes-btn\" (click)=\"confirmAction('YES')\">YES</button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|