Files
Picsur/frontend/src/app/routes/settings/roles/settings-roles-edit/settings-roles-edit.component.ts
2022-06-05 12:20:16 +02:00

114 lines
3.3 KiB
TypeScript

import { Component, OnInit } from '@angular/core';
import { ActivatedRoute, Router } from '@angular/router';
import { Permission } from 'picsur-shared/dist/dto/permissions.dto';
import { HasFailed } from 'picsur-shared/dist/types';
import { UIFriendlyPermissions } from 'src/app/i18n/permissions.i18n';
import { SnackBarType } from 'src/app/models/dto/snack-bar-type.dto';
import { UpdateRoleControl } from 'src/app/models/forms/update-role.control';
import { RolesService } from 'src/app/services/api/roles.service';
import { StaticInfoService } from 'src/app/services/api/static-info.service';
import { Logger } from 'src/app/services/logger/logger.service';
import { UtilService } from 'src/app/util/util-module/util.service';
enum EditMode {
edit = 'edit',
add = 'add',
}
@Component({
selector: 'app-settings-roles-edit',
templateUrl: './settings-roles-edit.component.html',
styleUrls: ['./settings-roles-edit.component.scss'],
})
export class SettingsRolesEditComponent implements OnInit {
private readonly logger = new Logger('SettingsRolesEditComponent');
private mode: EditMode = EditMode.edit;
model = new UpdateRoleControl();
allPermissions: string[] = [];
get adding() {
return this.mode === EditMode.add;
}
get editing() {
return this.mode === EditMode.edit;
}
constructor(
private route: ActivatedRoute,
private router: Router,
private utilService: UtilService,
private rolesService: RolesService,
private staticInfo: StaticInfoService,
) {}
ngOnInit() {
Promise.all([this.initRole(), this.initPermissions()]).catch(
this.logger.error,
);
}
private async initRole() {
// Check if adding or editing
const rolename = this.route.snapshot.paramMap.get('role');
if (!rolename) {
this.mode = EditMode.add;
return;
}
this.mode = EditMode.edit;
this.model.putRoleName(rolename);
// Fetch data and populate form
const role = await this.rolesService.getRole(rolename);
if (HasFailed(role)) {
this.utilService.showSnackBar('Failed to get role', SnackBarType.Error);
return;
}
this.model.putRoleName(role.name);
this.model.putPermissions(role.permissions);
}
private async initPermissions() {
// Get a list of all permissions so that we can select them
this.allPermissions = await this.staticInfo.getAllPermissions();
}
async updateRole() {
const data = this.model.getData();
if (this.adding) {
const resultRole = await this.rolesService.createRole(data);
if (HasFailed(resultRole)) {
this.utilService.showSnackBar(
'Failed to create role',
SnackBarType.Error,
);
return;
}
this.utilService.showSnackBar('Role created', SnackBarType.Success);
} else {
const resultRole = await this.rolesService.updateRole(data);
if (HasFailed(resultRole)) {
this.utilService.showSnackBar(
'Failed to update role',
SnackBarType.Error,
);
return;
}
this.utilService.showSnackBar('Role updated', SnackBarType.Success);
}
this.router.navigate(['/settings/roles']);
}
cancel() {
this.router.navigate(['/settings/roles']);
}
public UIFriendlyPermission(name: string) {
return UIFriendlyPermissions[name as Permission] ?? name;
}
}