feat: Client 增加登出弹框功能
This commit is contained in:
parent
580055c688
commit
76a6628865
|
@ -152,4 +152,22 @@ class DictService : BaseDatabase, IDict
|
||||||
public bool SaveWebFooter(string footer) => SaveDict(new Dict { Category = "网站设置", Name = "网站页脚", Code = footer });
|
public bool SaveWebFooter(string footer) => SaveDict(new Dict { Category = "网站设置", Name = "网站页脚", Code = footer });
|
||||||
|
|
||||||
public bool SaveCookieExpiresPeriod(int expiresPeriod) => SaveDict(new Dict { Category = "网站设置", Name = "Cookie保留时长", Code = expiresPeriod.ToString() });
|
public bool SaveCookieExpiresPeriod(int expiresPeriod) => SaveDict(new Dict { Category = "网站设置", Name = "Cookie保留时长", Code = expiresPeriod.ToString() });
|
||||||
|
|
||||||
|
public string? GetProfileUrl(string appId) => GetUrlByName(appId, "个人中心地址");
|
||||||
|
|
||||||
|
public string? GetSettingsUrl(string appId) => GetUrlByName(appId, "系统设置地址");
|
||||||
|
|
||||||
|
public string? GetNotificationUrl(string appId) => GetUrlByName(appId, "系统通知地址");
|
||||||
|
|
||||||
|
private string? GetUrlByName(string appId, string dictName)
|
||||||
|
{
|
||||||
|
string? url = null;
|
||||||
|
var dicts = GetAll();
|
||||||
|
var appName = dicts.FirstOrDefault(d => d.Category == "应用程序" && d.Code == appId && d.Define == EnumDictDefine.System)?.Name;
|
||||||
|
if (!string.IsNullOrEmpty(appName))
|
||||||
|
{
|
||||||
|
url = dicts.FirstOrDefault(d => d.Category == appName && d.Name == dictName && d.Define == EnumDictDefine.Customer)?.Code;
|
||||||
|
}
|
||||||
|
return url;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -111,5 +111,11 @@ namespace BootstrapAdmin.Web.Core
|
||||||
/// <param name="expiresPeriod"></param>
|
/// <param name="expiresPeriod"></param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
bool SaveCookieExpiresPeriod(int expiresPeriod);
|
bool SaveCookieExpiresPeriod(int expiresPeriod);
|
||||||
|
|
||||||
|
string? GetProfileUrl(string appId);
|
||||||
|
|
||||||
|
string? GetSettingsUrl(string appId);
|
||||||
|
|
||||||
|
string? GetNotificationUrl(string appId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,8 +8,14 @@
|
||||||
<Header>
|
<Header>
|
||||||
<span class="ml-3 flex-sm-fill d-none d-sm-block">Bootstrap of Blazor</span>
|
<span class="ml-3 flex-sm-fill d-none d-sm-block">Bootstrap of Blazor</span>
|
||||||
<Widget></Widget>
|
<Widget></Widget>
|
||||||
<img src="_content/BootstrapClient.Web.Shared/images/Argo.png" class="layout-avatar-right" />
|
<Logout ImageUrl="_content/BootstrapClient.Web.Shared/images/Argo.png" DisplayName="@DisplayName" UserName="@UserName">
|
||||||
<span class="mx-3 d-none d-sm-block">@DisplayName</span>
|
<LinkTemplate>
|
||||||
|
<a href="@ProfileUrl"><i class="fa fa-suitcase"></i>个人中心</a>
|
||||||
|
<a href="@SettingsUrl"><i class="fa fa-cog"></i>设置</a>
|
||||||
|
<a href="@NotificationUrl"><i class="fa fa-bell"></i>通知<span id="logoutNoti" class="badge badge-pill badge-success"></span></a>
|
||||||
|
<a href="#" @onclick="OnLogout"><i class="fa fa-key"></i>注销</a>
|
||||||
|
</LinkTemplate>
|
||||||
|
</Logout>
|
||||||
<div class="layout-drawer" @onclick="@(e => IsOpen = !IsOpen)"><i class="fa fa-gears"></i></div>
|
<div class="layout-drawer" @onclick="@(e => IsOpen = !IsOpen)"><i class="fa fa-gears"></i></div>
|
||||||
</Header>
|
</Header>
|
||||||
<Side>
|
<Side>
|
||||||
|
|
|
@ -5,6 +5,7 @@ using BootstrapClient.Web.Shared.Extensions;
|
||||||
using Microsoft.AspNetCore;
|
using Microsoft.AspNetCore;
|
||||||
using Microsoft.AspNetCore.Components;
|
using Microsoft.AspNetCore.Components;
|
||||||
using Microsoft.AspNetCore.Components.Authorization;
|
using Microsoft.AspNetCore.Components.Authorization;
|
||||||
|
using Microsoft.Extensions.Configuration;
|
||||||
using Microsoft.Extensions.Options;
|
using Microsoft.Extensions.Options;
|
||||||
|
|
||||||
namespace BootstrapClient.Web.Shared.Shared
|
namespace BootstrapClient.Web.Shared.Shared
|
||||||
|
@ -30,6 +31,12 @@ namespace BootstrapClient.Web.Shared.Shared
|
||||||
|
|
||||||
private IEnumerable<MenuItem>? MenuItems { get; set; }
|
private IEnumerable<MenuItem>? MenuItems { get; set; }
|
||||||
|
|
||||||
|
private string? ProfileUrl { get; set; }
|
||||||
|
|
||||||
|
private string? SettingsUrl { get; set; }
|
||||||
|
|
||||||
|
private string? NotificationUrl { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 获得 当前用户登录显示名称
|
/// 获得 当前用户登录显示名称
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -74,6 +81,31 @@ namespace BootstrapClient.Web.Shared.Shared
|
||||||
[NotNull]
|
[NotNull]
|
||||||
private NavigationManager? NavigationManager { get; set; }
|
private NavigationManager? NavigationManager { get; set; }
|
||||||
|
|
||||||
|
[Inject]
|
||||||
|
[NotNull]
|
||||||
|
private IConfiguration? Configuration { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// OnInitialized 方法
|
||||||
|
/// </summary>
|
||||||
|
protected override void OnInitialized()
|
||||||
|
{
|
||||||
|
base.OnInitialized();
|
||||||
|
|
||||||
|
// TODO: 后期重构 AppId 到统一的地方
|
||||||
|
var appId = Configuration.GetValue("AppId", "Blazor");
|
||||||
|
ProfileUrl = CombinePath(DictsService.GetProfileUrl(appId));
|
||||||
|
SettingsUrl = CombinePath(DictsService.GetSettingsUrl(appId));
|
||||||
|
NotificationUrl = CombinePath(DictsService.GetNotificationUrl(appId));
|
||||||
|
}
|
||||||
|
|
||||||
|
private string CombinePath(string? url)
|
||||||
|
{
|
||||||
|
url ??= "";
|
||||||
|
var hostUrl = AuthorizationOption.Value.AuthHost.TrimEnd('/');
|
||||||
|
return string.Join('/', hostUrl, url.TrimStart('/'));
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// OnInitialized 方法
|
/// OnInitialized 方法
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -96,6 +128,8 @@ namespace BootstrapClient.Web.Shared.Shared
|
||||||
|
|
||||||
private Task<bool> OnAuthorizing(string url) => SecurityService.AuhorizingNavigation(UserName, url);
|
private Task<bool> OnAuthorizing(string url) => SecurityService.AuhorizingNavigation(UserName, url);
|
||||||
|
|
||||||
private string GetAuthorUrl() => $"{AuthorizationOption.Value.AuthHost}/Account/Login?ReturnUrl={NavigationManager.Uri}";
|
private string GetAuthorUrl() => CombinePath($"/Account/Login?ReturnUrl={NavigationManager.Uri}");
|
||||||
|
|
||||||
|
private void OnLogout() => NavigationManager.NavigateTo(CombinePath("/Account/Logout"), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
namespace BootstrapClient.Web.Shared.Utils;
|
||||||
|
|
||||||
|
class AppContext
|
||||||
|
{
|
||||||
|
[NotNull]
|
||||||
|
public string? AppId { get; set; }
|
||||||
|
}
|
Loading…
Reference in New Issue