2020-07-26 19:20:16 +08:00
|
|
|
|
@using AntDesign.Docs.Services
|
2020-12-18 16:00:51 +08:00
|
|
|
|
<Menu Class="aside-container menu-site" Theme="MenuTheme.Light" Mode="MenuMode.Inline" >
|
2020-05-10 15:42:02 +08:00
|
|
|
|
@menuItemTemplate((MenuItems, LanguageService, 1))
|
2020-05-18 14:46:42 +08:00
|
|
|
|
</Menu>
|
2020-03-30 14:33:39 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@inject ILanguageService LanguageService
|
2020-05-10 15:42:02 +08:00
|
|
|
|
@inject NavigationManager NavigationManager
|
|
|
|
|
@inject HttpClient HttpClient
|
2020-07-26 19:20:16 +08:00
|
|
|
|
@inject DemoService DemoService;
|
2020-03-30 14:33:39 +08:00
|
|
|
|
|
|
|
|
|
@code {
|
2020-05-10 15:42:02 +08:00
|
|
|
|
|
|
|
|
|
[Parameter]
|
2020-05-18 14:46:42 +08:00
|
|
|
|
public DemoMenuItem[] MenuItems { get; set; } = {};
|
2020-03-30 14:33:39 +08:00
|
|
|
|
|
2020-05-18 14:46:42 +08:00
|
|
|
|
static readonly RenderFragment<(DemoMenuItem[] items, ILanguageService languageService, int level)> menuItemTemplate = context =>
|
2020-03-31 00:45:14 +08:00
|
|
|
|
@<Template>
|
|
|
|
|
@foreach (var menu in context.items)
|
2020-03-30 14:33:39 +08:00
|
|
|
|
{
|
2020-03-31 00:45:14 +08:00
|
|
|
|
if (menu.Type == "menuItem")
|
|
|
|
|
{
|
2020-07-14 22:32:12 +08:00
|
|
|
|
<MenuItem RouterLink="@($"{context.languageService.CurrentCulture.Name}/{menu.Url}")" RouterMatch="@NavLinkMatch.All">
|
2020-03-31 00:45:14 +08:00
|
|
|
|
<span>@menu.Title</span>
|
2020-05-10 15:42:02 +08:00
|
|
|
|
@if (menu.SubTitle != null)
|
|
|
|
|
{
|
|
|
|
|
<span class="chinese">@menu.SubTitle</span>
|
|
|
|
|
}
|
2020-07-14 22:32:12 +08:00
|
|
|
|
</MenuItem>
|
2020-03-31 00:45:14 +08:00
|
|
|
|
}
|
|
|
|
|
else if (menu.Type == "subMenu")
|
|
|
|
|
{
|
2020-07-20 22:28:09 +08:00
|
|
|
|
<SubMenu Title="@menu.Title" IsOpen="true">
|
2020-03-31 00:45:14 +08:00
|
|
|
|
@if (menu.Children.Any())
|
|
|
|
|
{
|
2020-05-10 15:42:02 +08:00
|
|
|
|
@menuItemTemplate((menu.Children, context.languageService, context.level + 1))
|
2020-03-31 00:45:14 +08:00
|
|
|
|
}
|
2020-05-18 14:46:42 +08:00
|
|
|
|
</SubMenu>
|
2020-03-31 00:45:14 +08:00
|
|
|
|
}
|
|
|
|
|
else if (menu.Type == "itemGroup")
|
|
|
|
|
{
|
2020-07-20 22:28:09 +08:00
|
|
|
|
<MenuItemGroup Title="@menu.Title">
|
2020-03-31 00:45:14 +08:00
|
|
|
|
@if (menu.Children.Any())
|
|
|
|
|
{
|
2020-05-10 15:42:02 +08:00
|
|
|
|
@menuItemTemplate((menu.Children, context.languageService, context.level + 1))
|
2020-03-31 00:45:14 +08:00
|
|
|
|
}
|
2020-05-18 14:46:42 +08:00
|
|
|
|
</MenuItemGroup>
|
2020-03-31 00:45:14 +08:00
|
|
|
|
}
|
2020-03-30 14:33:39 +08:00
|
|
|
|
}
|
2020-03-31 00:45:14 +08:00
|
|
|
|
</Template>;
|
2020-03-30 14:33:39 +08:00
|
|
|
|
|
|
|
|
|
|
2020-05-10 15:42:02 +08:00
|
|
|
|
}
|