UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

106 lines 16.7 kB
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-ldap-group.service"; export class AbstractLdapGroupRoleAssignmentComponent { _service; ldapGroupList; viewport; ldapGroup; nets; filteredProcesses = []; ldapGroupMultiSelect; searchLdapGroupControl = new FormControl(); searchNetControl = new FormControl(); SEARCH_DEBOUNCE_TIME = 600; subValueChanges; subNetValueChanges; subLdapGroup; constructor(_service) { this._service = _service; this.ldapGroup = this._service.ldapGroupList; this.nets = this._service.processList; this.ldapGroupMultiSelect = true; } ngOnInit() { this.nets.loadProcesses().subscribe(processes => { this.filteredProcesses = processes; }); this.subValueChanges = this.searchLdapGroupControl.valueChanges.pipe(debounceTime(this.SEARCH_DEBOUNCE_TIME)).subscribe(searchText => { this.ldapGroup.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.subLdapGroup = this.ldapGroup.ldapGroupsReload$.subscribe(() => { this.ldapGroupList.deselectAll(); this.ldapGroupList.selectedOptions.clear(); this.autoSelectRoles(); }); } ngOnDestroy() { this.subValueChanges.unsubscribe(); this.subLdapGroup.unsubscribe(); this.ldapGroup = undefined; this.subNetValueChanges.unsubscribe(); this.nets = undefined; this.filteredProcesses = undefined; } loadNextLdapGroupPage() { if (!this.viewport) { return; } this.ldapGroup.nextPage(this.viewport.getRenderedRange().end, this.viewport.getDataLength()); } autoSelectRoles() { const all = this.ldapGroupList.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.ldapGroupList.selectedOptions.selected.map(option => option.value); this.ldapGroup.updateRoles(selected, this.nets.selectedRoles).subscribe(_ => { this.autoSelectRoles(); }); } selectAllLdapGroup(select) { this.ldapGroupList.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.ldapGroupList.selectedOptions.selected.map(option => option.value); this.ldapGroup.updateRoles(selected, this.nets.selectedRoles).subscribe(_ => { this.autoSelectRoles(); }); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractLdapGroupRoleAssignmentComponent, deps: [{ token: i1.RoleAssignmentLdapGroupService }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractLdapGroupRoleAssignmentComponent, selector: "ncc-abstract-ldap-group-role-assignment", viewQueries: [{ propertyName: "ldapGroupList", first: true, predicate: ["ldapGroupList"], 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: AbstractLdapGroupRoleAssignmentComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-abstract-ldap-group-role-assignment', template: '' }] }], ctorParameters: () => [{ type: i1.RoleAssignmentLdapGroupService }], propDecorators: { ldapGroupList: [{ type: ViewChild, args: ['ldapGroupList'] }], viewport: [{ type: ViewChild, args: [CdkVirtualScrollViewport] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-ldap-group-role-assignment.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/admin/role-assignment-ldap-group/abstract-ldap-group-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 {\n    ProcessList,\n    ExtendedProcessRole,\n    ProcessVersion,\n    ProcessListItem\n} from '../role-assignment/services/ProcessList';\nimport {FormControl} from '@angular/forms';\nimport {debounceTime} from 'rxjs/operators';\nimport {Subscription} from 'rxjs';\nimport {RoleAssignmentLdapGroupService} from './services/role-assignment-ldap-group.service';\nimport {LdapGroupListItem, LdapGroupListService} from '../../groups/services/ldap-group-list.service';\n\n@Component({\n    selector: 'ncc-abstract-ldap-group-role-assignment',\n    template: ''\n})\nexport abstract class AbstractLdapGroupRoleAssignmentComponent implements OnInit, AfterViewInit, OnDestroy {\n\n    @ViewChild('ldapGroupList') public ldapGroupList: MatSelectionList;\n    @ViewChild(CdkVirtualScrollViewport) public viewport: CdkVirtualScrollViewport;\n\n    public ldapGroup: LdapGroupListService;\n    public nets: ProcessList;\n    public filteredProcesses: Array<ProcessListItem> = [];\n    public ldapGroupMultiSelect: boolean;\n    public searchLdapGroupControl = new FormControl();\n    public searchNetControl = new FormControl();\n    protected SEARCH_DEBOUNCE_TIME = 600;\n    protected subValueChanges: Subscription;\n    protected subNetValueChanges: Subscription;\n    protected subLdapGroup: Subscription;\n\n    constructor(protected _service: RoleAssignmentLdapGroupService) {\n        this.ldapGroup = this._service.ldapGroupList;\n        this.nets = this._service.processList;\n        this.ldapGroupMultiSelect = true;\n    }\n\n    ngOnInit(): void {\n        this.nets.loadProcesses().subscribe(processes => {\n            this.filteredProcesses = processes;\n        });\n        this.subValueChanges = this.searchLdapGroupControl.valueChanges.pipe(\n            debounceTime(this.SEARCH_DEBOUNCE_TIME)\n        ).subscribe(searchText => {\n            this.ldapGroup.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.subLdapGroup = this.ldapGroup.ldapGroupsReload$.subscribe(() => {\n            this.ldapGroupList.deselectAll();\n            this.ldapGroupList.selectedOptions.clear();\n            this.autoSelectRoles();\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.subValueChanges.unsubscribe();\n        this.subLdapGroup.unsubscribe();\n        this.ldapGroup = undefined;\n        this.subNetValueChanges.unsubscribe();\n        this.nets = undefined;\n        this.filteredProcesses = undefined;\n    }\n\n    public loadNextLdapGroupPage(): void {\n        if (!this.viewport) {\n            return;\n        }\n        this.ldapGroup.nextPage(this.viewport.getRenderedRange().end, this.viewport.getDataLength());\n    }\n\n    public autoSelectRoles(): void {\n        const all = this.ldapGroupList.selectedOptions.selected.map(option => (option.value as LdapGroupListItem).roles);\n        if (all.length === 0) {\n            this.nets.selectRoles(new Set<string>([]));\n        }\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.ldapGroupList.selectedOptions.selected.map(option => (option.value as LdapGroupListItem));\n        this.ldapGroup.updateRoles(selected, this.nets.selectedRoles).subscribe(_ => {\n            this.autoSelectRoles();\n        });\n    }\n\n    public selectAllLdapGroup(select: boolean): void {\n        this.ldapGroupList.options.forEach(option => {\n            (option.value as LdapGroupListItem).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.ldapGroupList.selectedOptions.selected.map(option => (option.value as LdapGroupListItem));\n        this.ldapGroup.updateRoles(selected, this.nets.selectedRoles).subscribe(_ => {\n            this.autoSelectRoles();\n        });\n    }\n}\n"]}