0
I need, for the current system I develop, a way to hide or display components according to profiles, for example:
Profile: Master
View View, Create, Edit, and Remove Registrations button
Profile: Internal Controls
Display only the View Entries button
For this case, what I thought was the following: Create a checker component, which asks for the profile and the required permission to view its content, as shown in the code below:
import { Component, OnInit, Input } from '@angular/core';
import { RuleCheckService } from 'src/app/core/services/rule-check/rule-check.service';
@Component({
    selector: 'app-rule-check',
    template: `
    <ng-template [ngIf]="canShowContent">
        <ng-content></ng-content>
    </ng-template>
    `,
    styleUrls: []
})
export class RuleCheckComponent implements OnInit {
    @Input()
    public ruleGroup: string; // Grupo de regras ao qual o perfil deve se encaixar
    @Input()
    public permissionCheck: any; // Permissão necessária para exibição do conteúdo, podendo ser string ou array de string
    public canShowContent = false; // Verifica se deve ou não exibir o conteúdo do componente, de acordo com as regras verificadas
    constructor(
        private ruleCheckService: RuleCheckService // Serviço que puxa o usuário logado, obtendo suas permissões
    ) { }
    ngOnInit(): void {
        this.checkPermission();
    }
    checkPermission() { // Método que fará a verificação e alterará para visível ou não
        if ( this.ruleGroup === null || this.permissionCheck === null ) {
            this.canShowContent = false;
            return;
        }
        const $check = this.ruleCheckService.check( this.ruleGroup, this.permissionCheck )
        $check.subscribe( permission => {
            this.canShowContent = permission;
        });
    }
}
Have some more practical and/or intelligent way to use this situation?