@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
117 lines • 17.5 kB
JavaScript
import { FormControl, Validators } from '@angular/forms';
import { LoadingEmitter } from '../../utility/loading-emitter';
import { Component } from '@angular/core';
import { debounceTime, take } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "./services/user-invite.service";
import * as i2 from "./services/organization-list.service";
import * as i3 from "../../authentication/sign-up/services/sign-up.service";
import * as i4 from "../../snack-bar/services/snack-bar.service";
import * as i5 from "@ngx-translate/core";
export class AbstractUserInviteComponent {
_userInviteService;
_orgList;
_signUpService;
_snackBar;
_translate;
invitedEmailControl;
invitedGroups;
invitedRoles;
nets;
filteredProcesses = [];
SEARCH_DEBOUNCE_TIME = 600;
searchNetControl = new FormControl();
subNetValueChanges;
loading;
constructor(_userInviteService, _orgList, _signUpService, _snackBar, _translate) {
this._userInviteService = _userInviteService;
this._orgList = _orgList;
this._signUpService = _signUpService;
this._snackBar = _snackBar;
this._translate = _translate;
this.nets = this._userInviteService.processList;
this.loading = new LoadingEmitter();
this.invitedEmailControl = new FormControl('', [Validators.email, Validators.required]);
this.invitedGroups = [];
this.invitedRoles = [];
}
get groups() {
return this._orgList.groups;
}
ngOnInit() {
this.nets.loadProcesses().subscribe(processes => {
this.filteredProcesses = processes;
});
this._orgList.loadGroups();
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()));
});
}
ngOnDestroy() {
this.subNetValueChanges.unsubscribe();
this.nets = undefined;
this.filteredProcesses = undefined;
}
removeGroup(org) {
const itemIndex = this.invitedGroups.findIndex(g => g.id === org.id);
if (itemIndex !== -1) {
this.invitedGroups.splice(itemIndex, 1);
}
}
addGroup(org) {
const itemIndex = this.invitedGroups.findIndex(g => g.id === org.id);
if (itemIndex === -1) {
this.invitedGroups.push(org);
}
}
removeRole(role) {
const itemIndex = this.invitedRoles.findIndex(r => r.stringId === role.stringId);
if (itemIndex !== -1) {
this.invitedRoles.splice(itemIndex, 1);
}
}
addRole(role) {
const itemIndex = this.invitedRoles.findIndex(r => r.stringId === role.stringId);
if (itemIndex === -1) {
this.invitedRoles.push(role);
}
}
invite() {
if (!this.invitedEmailControl.valid) {
this._snackBar.openErrorSnackBar(this._translate.instant('admin.user-invite.emailFieldMandatory'));
return;
}
if (this.invitedGroups.length === 0) {
this._snackBar.openErrorSnackBar(this._translate.instant('admin.user-invite.oneOrMoreOrganization'));
return;
}
const invitation = {
email: this.invitedEmailControl.value,
groups: this.invitedGroups.map(org => org.id),
processRoles: this.invitedRoles.map(role => role.stringId)
};
this.loading.on();
this._signUpService.invite(invitation).pipe(take(1)).subscribe(success => {
if (success) {
this._snackBar.openSuccessSnackBar(this._translate.instant('admin.user-invite.inviteSent'));
this.invitedEmailControl.setValue('');
this.invitedGroups = [];
this.invitedRoles = [];
}
else {
this._snackBar.openErrorSnackBar(this._translate.instant('admin.user-invite.inviteFailed'));
}
this.loading.off();
});
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractUserInviteComponent, deps: [{ token: i1.UserInviteService }, { token: i2.OrganizationListService }, { token: i3.SignUpService }, { token: i4.SnackBarService }, { token: i5.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractUserInviteComponent, selector: "ncc-abstract-user-invite", ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractUserInviteComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-user-invite',
template: ''
}]
}], ctorParameters: () => [{ type: i1.UserInviteService }, { type: i2.OrganizationListService }, { type: i3.SignUpService }, { type: i4.SnackBarService }, { type: i5.TranslateService }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-user-invite.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/admin/user-invite/abstract-user-invite.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {FormControl, Validators} from '@angular/forms';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ExtendedProcessRole, ProcessList, ProcessListItem} from '../role-assignment/services/ProcessList';\nimport {GroupInterface} from '../../resources/interface/group';\nimport {LoadingEmitter} from '../../utility/loading-emitter';\nimport {UserInviteService} from './services/user-invite.service';\nimport {OrganizationListService} from './services/organization-list.service';\nimport {SignUpService} from '../../authentication/sign-up/services/sign-up.service';\nimport {SnackBarService} from '../../snack-bar/services/snack-bar.service';\nimport {UserInvitationRequest} from '../../authentication/sign-up/models/user-invitation-request';\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {debounceTime, take} from 'rxjs/operators';\nimport {Subscription} from \"rxjs\";\n\n@Component({\n    selector: 'ncc-abstract-user-invite',\n    template: ''\n})\nexport abstract class AbstractUserInviteComponent implements OnInit, OnDestroy {\n\n    public invitedEmailControl: FormControl<string>;\n    public invitedGroups: Array<GroupInterface>;\n    public invitedRoles: Array<ExtendedProcessRole>;\n    public nets: ProcessList;\n    public filteredProcesses: Array<ProcessListItem> = [];\n    protected SEARCH_DEBOUNCE_TIME = 600;\n    public searchNetControl = new FormControl();\n    protected subNetValueChanges: Subscription;\n    public loading: LoadingEmitter;\n\n    constructor(protected _userInviteService: UserInviteService,\n                protected _orgList: OrganizationListService,\n                protected _signUpService: SignUpService,\n                protected _snackBar: SnackBarService,\n                protected _translate: TranslateService) {\n        this.nets = this._userInviteService.processList;\n        this.loading = new LoadingEmitter();\n        this.invitedEmailControl = new FormControl('', [Validators.email, Validators.required]);\n        this.invitedGroups = [];\n        this.invitedRoles = [];\n    }\n\n    public get groups() {\n        return this._orgList.groups;\n    }\n\n    ngOnInit(): void {\n        this.nets.loadProcesses().subscribe(processes => {\n            this.filteredProcesses = processes;\n        });\n        this._orgList.loadGroups();\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    ngOnDestroy(): void {\n        this.subNetValueChanges.unsubscribe();\n        this.nets = undefined;\n        this.filteredProcesses = undefined;\n    }\n\n    public removeGroup(org: GroupInterface): void {\n        const itemIndex = this.invitedGroups.findIndex(g => g.id === org.id);\n        if (itemIndex !== -1) {\n            this.invitedGroups.splice(itemIndex, 1);\n        }\n    }\n\n    public addGroup(org: GroupInterface): void {\n        const itemIndex = this.invitedGroups.findIndex(g => g.id === org.id);\n        if (itemIndex === -1) {\n            this.invitedGroups.push(org);\n        }\n    }\n\n    public removeRole(role: ExtendedProcessRole): void {\n        const itemIndex = this.invitedRoles.findIndex(r => r.stringId === role.stringId);\n        if (itemIndex !== -1) {\n            this.invitedRoles.splice(itemIndex, 1);\n        }\n    }\n\n    public addRole(role: ExtendedProcessRole): void {\n        const itemIndex = this.invitedRoles.findIndex(r => r.stringId === role.stringId);\n        if (itemIndex === -1) {\n            this.invitedRoles.push(role);\n        }\n    }\n\n    public invite(): void {\n        if (!this.invitedEmailControl.valid) {\n            this._snackBar.openErrorSnackBar(this._translate.instant('admin.user-invite.emailFieldMandatory'));\n            return;\n        }\n        if (this.invitedGroups.length === 0) {\n            this._snackBar.openErrorSnackBar(this._translate.instant('admin.user-invite.oneOrMoreOrganization'));\n            return;\n        }\n\n        const invitation: UserInvitationRequest = {\n            email: this.invitedEmailControl.value,\n            groups: this.invitedGroups.map(org => org.id),\n            processRoles: this.invitedRoles.map(role => role.stringId)\n        };\n\n        this.loading.on();\n        this._signUpService.invite(invitation).pipe(take(1)).subscribe(success => {\n            if (success) {\n                this._snackBar.openSuccessSnackBar(this._translate.instant('admin.user-invite.inviteSent'));\n                this.invitedEmailControl.setValue('');\n                this.invitedGroups = [];\n                this.invitedRoles = [];\n            } else {\n                this._snackBar.openErrorSnackBar(this._translate.instant('admin.user-invite.inviteFailed'));\n            }\n            this.loading.off();\n        });\n    }\n}\n"]}