首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从angular-calendar禁用CalendarEventAction

从angular-calendar禁用CalendarEventAction
EN

Stack Overflow用户
提问于 2021-09-02 10:36:56
回答 1查看 89关注 0票数 0

我有两个动作,

代码语言:javascript
复制
  actions: CalendarEventAction[] = [

    {
      label: '<i class="material-icons mat-icon">edit</i>',
      
      onClick: ({ event }: { event: CalendarEvent }): void => {
         this.editCalendarEvent(event);
    }
    }, {
      label: '<i class="material-icons mat-icon">remove</i>',
      
      onClick: ({ event }: { event: CalendarEvent }): void => {
         this.removeCalendarEvent(event);
    }
    },
]

但我只想让具有角色的用户(例如:管理员)看到第二个图标,即remove事件。

如何向其他用户隐藏第二个图标,并向管理员显示该图标。

谢谢

EN

回答 1

Stack Overflow用户

发布于 2021-09-02 11:49:13

我还没有尝试过angular,所以我不是回答这个问题的最佳人选,所以希望有人能提出更好的解决方案。但是,就目前而言,您可以在onClick函数中添加一个条件来检查用户是否具有权限。

代码语言:javascript
复制
onClick: ({ event }: { event: CalendarEvent }): void => {
    if(user.admin) {
        this.removeCalendarEvent(event);
    } else {
        alert("--!!! You Don't Have Permission To Perform This Action !!!--");
    }
}

您还可以尝试onload向标签添加onload函数,并像以前一样检查用户是否是管理员,如果不是,则可以设置label.disabled="true"

代码语言:javascript
复制
...
label: '<i onload="checkPermission()" id="removeBtn" class="material-icons mat-icon">remove</i>',
...

checkPermission() => {
    if(!user.admin) {
       document.getElementById("removeBtn").disabled = true;
    }
}

或者干脆完全隐藏按钮

代码语言:javascript
复制
...document.getElementById("removeBtn").display = "hidden";
...

您可能希望从后端的数据库中提取用户数据(例如角色)。您可以使用node.js来实现这一点。否则,您更容易受到通过控制台获得管理员权限的人的影响。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69028641

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档