@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
110 lines • 16.5 kB
JavaScript
import { Component, ViewChild } from '@angular/core';
import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
import { FormControl } from '@angular/forms';
import { debounceTime } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "./services/role-assignment.service";
import * as i2 from "../../user/services/user.service";
export class AbstractRoleAssignmentComponent {
_service;
_userService;
userList;
viewport;
users;
nets;
filteredProcesses = [];
userMultiSelect;
searchUserControl = new FormControl();
searchNetControl = new FormControl();
SEARCH_DEBOUNCE_TIME = 600;
subValueChanges;
subNetValueChanges;
subUsers;
constructor(_service, _userService) {
this._service = _service;
this._userService = _userService;
this.users = this._service.userList;
this.nets = this._service.processList;
this.userMultiSelect = true;
}
ngOnInit() {
this.nets.loadProcesses().subscribe(processes => {
this.filteredProcesses = processes;
});
this.subValueChanges = this.searchUserControl.valueChanges.pipe(debounceTime(this.SEARCH_DEBOUNCE_TIME)).subscribe(searchText => {
this.users.reload(searchText);
});
this.subNetValueChanges = this.searchNetControl.valueChanges.pipe(debounceTime(this.SEARCH_DEBOUNCE_TIME)).subscribe(searchText => {
this.filteredProcesses = this.nets.processes.filter(itm => itm.title.toLowerCase().includes(searchText.toLowerCase()));
});
}
ngAfterViewInit() {
this.subUsers = this.users.usersReload$.subscribe(() => {
this.userList.deselectAll();
this.userList.selectedOptions.clear();
this.autoSelectRoles();
});
}
ngOnDestroy() {
this._userService.reload();
this.subValueChanges.unsubscribe();
this.subNetValueChanges.unsubscribe();
this.subUsers.unsubscribe();
this.users = undefined;
this.nets = undefined;
this.filteredProcesses = undefined;
}
loadNextUserPage() {
if (!this.viewport) {
return;
}
this.users.nextPage(this.viewport.getRenderedRange().end, this.viewport.getDataLength());
}
autoSelectRoles() {
const all = this.userList.selectedOptions.selected.map(option => option.value.roles);
if (all.length === 0) {
this.nets.selectRoles(new Set([]));
}
const intersection = all.reduce((acc, curr) => new Set([...acc].filter(s => curr.has(s))), all[0]);
this.nets.selectRoles(intersection);
}
update(role) {
this.nets.updateSelectedRoles(role);
const selected = this.userList.selectedOptions.selected.map(option => option.value);
this.users.updateRoles(selected, this.nets.selectedRoles).subscribe(_ => {
this.autoSelectRoles();
});
}
selectAllUsers(select) {
this.userList.options.forEach(option => {
option.value.selected = select;
});
this.autoSelectRoles();
}
toggleAllRoles(net, select) {
net.roles.forEach(r => {
r.selected = select;
this.nets.updateSelectedRoles(r);
});
const selected = this.userList.selectedOptions.selected.map(option => option.value);
this.users.updateRoles(selected, this.nets.selectedRoles).subscribe(_ => {
this.autoSelectRoles();
});
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractRoleAssignmentComponent, deps: [{ token: i1.RoleAssignmentService }, { token: i2.UserService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractRoleAssignmentComponent, selector: "ncc-abstract-role", viewQueries: [{ propertyName: "userList", first: true, predicate: ["userList"], descendants: true }, { propertyName: "viewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }], ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractRoleAssignmentComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-role',
template: ''
}]
}], ctorParameters: () => [{ type: i1.RoleAssignmentService }, { type: i2.UserService }], propDecorators: { userList: [{
type: ViewChild,
args: ['userList']
}], viewport: [{
type: ViewChild,
args: [CdkVirtualScrollViewport]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-role-assignment.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/admin/role-assignment/abstract-role-assignment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, OnDestroy, OnInit, ViewChild} from '@angular/core';\nimport {MatSelectionList} from '@angular/material/list';\nimport {CdkVirtualScrollViewport} from '@angular/cdk/scrolling';\nimport {UserListItem, UserListService} from '../../user/services/user-list.service';\nimport {ProcessList, ExtendedProcessRole, ProcessVersion, ProcessListItem} from './services/ProcessList';\nimport {FormControl} from '@angular/forms';\nimport {RoleAssignmentService} from './services/role-assignment.service';\nimport {UserService} from '../../user/services/user.service';\nimport {debounceTime} from 'rxjs/operators';\nimport {Subscription} from 'rxjs';\n\n@Component({\n    selector: 'ncc-abstract-role',\n    template: ''\n})\nexport abstract class AbstractRoleAssignmentComponent implements OnInit, AfterViewInit, OnDestroy {\n\n    @ViewChild('userList') public userList: MatSelectionList;\n    @ViewChild(CdkVirtualScrollViewport) public viewport: CdkVirtualScrollViewport;\n\n    public users: UserListService;\n    public nets: ProcessList;\n    public filteredProcesses: Array<ProcessListItem> = [];\n    public userMultiSelect: boolean;\n    public searchUserControl = new FormControl();\n    public searchNetControl = new FormControl();\n    protected SEARCH_DEBOUNCE_TIME = 600;\n    protected subValueChanges: Subscription;\n    protected subNetValueChanges: Subscription;\n    protected subUsers: Subscription;\n\n    constructor(protected _service: RoleAssignmentService, protected _userService: UserService) {\n        this.users = this._service.userList;\n        this.nets = this._service.processList;\n        this.userMultiSelect = true;\n    }\n\n    ngOnInit(): void {\n        this.nets.loadProcesses().subscribe(processes => {\n            this.filteredProcesses = processes;\n        });\n        this.subValueChanges = this.searchUserControl.valueChanges.pipe(debounceTime(this.SEARCH_DEBOUNCE_TIME)).subscribe(searchText => {\n            this.users.reload(searchText);\n        });\n        this.subNetValueChanges = this.searchNetControl.valueChanges.pipe(debounceTime(this.SEARCH_DEBOUNCE_TIME)).subscribe(searchText => {\n            this.filteredProcesses = this.nets.processes.filter(itm => itm.title.toLowerCase().includes(searchText.toLowerCase()));\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.subUsers = this.users.usersReload$.subscribe(() => {\n            this.userList.deselectAll();\n            this.userList.selectedOptions.clear();\n            this.autoSelectRoles();\n        });\n    }\n\n    ngOnDestroy(): void {\n        this._userService.reload();\n        this.subValueChanges.unsubscribe();\n        this.subNetValueChanges.unsubscribe();\n        this.subUsers.unsubscribe();\n        this.users = undefined;\n        this.nets = undefined;\n        this.filteredProcesses = undefined;\n    }\n\n    public loadNextUserPage(): void {\n        if (!this.viewport) {\n            return;\n        }\n        this.users.nextPage(this.viewport.getRenderedRange().end, this.viewport.getDataLength());\n    }\n\n    public autoSelectRoles(): void {\n        const all = this.userList.selectedOptions.selected.map(option => (option.value as UserListItem).roles);\n        if (all.length === 0) {\n            this.nets.selectRoles(new Set<string>([]));\n        }\n        const intersection = all.reduce((acc, curr) => new Set([...acc].filter(s => curr.has(s))), all[0]);\n        this.nets.selectRoles(intersection);\n    }\n\n    public update(role: ExtendedProcessRole): void {\n        this.nets.updateSelectedRoles(role);\n        const selected = this.userList.selectedOptions.selected.map(option => (option.value as UserListItem));\n        this.users.updateRoles(selected, this.nets.selectedRoles).subscribe(_ => {\n            this.autoSelectRoles();\n        });\n    }\n\n    public selectAllUsers(select: boolean): void {\n        this.userList.options.forEach(option => {\n            (option.value as UserListItem).selected = select;\n        });\n        this.autoSelectRoles();\n    }\n\n    public toggleAllRoles(net: ProcessVersion, select: boolean): void {\n        net.roles.forEach(r => {\n            r.selected = select;\n            this.nets.updateSelectedRoles(r);\n        });\n        const selected = this.userList.selectedOptions.selected.map(option => (option.value as UserListItem));\n        this.users.updateRoles(selected, this.nets.selectedRoles).subscribe(_ => {\n            this.autoSelectRoles();\n        });\n    }\n}\n"]}