2025-06-24 20:48:38 +08:00
|
|
|
using System.Windows.Controls;
|
2025-06-26 22:40:20 +08:00
|
|
|
using CommunityToolkit.Mvvm.Messaging;
|
|
|
|
|
using iNKORE.UI.WPF.Modern.Common.IconKeys;
|
2025-06-24 20:48:38 +08:00
|
|
|
using PMSWPF.Data.Entities;
|
2025-06-26 22:40:20 +08:00
|
|
|
using PMSWPF.Enums;
|
2025-06-25 22:33:57 +08:00
|
|
|
using PMSWPF.Extensions;
|
2025-06-26 22:40:20 +08:00
|
|
|
using PMSWPF.Helper;
|
|
|
|
|
using PMSWPF.Message;
|
2025-06-25 22:33:57 +08:00
|
|
|
using PMSWPF.Models;
|
2025-06-24 20:48:38 +08:00
|
|
|
using SqlSugar;
|
|
|
|
|
|
|
|
|
|
namespace PMSWPF.Data.Repositories;
|
|
|
|
|
|
2025-06-26 19:36:27 +08:00
|
|
|
public class MenuRepository
|
2025-06-24 20:48:38 +08:00
|
|
|
{
|
|
|
|
|
private readonly SqlSugarClient _db;
|
|
|
|
|
|
2025-06-26 19:36:27 +08:00
|
|
|
public MenuRepository()
|
2025-06-24 20:48:38 +08:00
|
|
|
{
|
2025-06-26 19:36:27 +08:00
|
|
|
_db = DbContext.GetInstance();
|
2025-06-24 20:48:38 +08:00
|
|
|
}
|
|
|
|
|
|
2025-06-25 22:33:57 +08:00
|
|
|
public async Task<List<MenuBean>> GetMenu()
|
2025-06-24 20:48:38 +08:00
|
|
|
{
|
2025-06-25 22:33:57 +08:00
|
|
|
// //无主键用法新:5.1.4.110
|
|
|
|
|
// db.Queryable<Tree>().ToTree(it=>it.Child,it=>it.ParentId,0,it=>it.Id)//+4重载
|
2025-06-26 19:36:27 +08:00
|
|
|
List<MenuBean> menus = new();
|
|
|
|
|
var dbMenuList = await _db.Queryable<DbMenu>().ToTreeAsync(dm => dm.Items, dm => dm.ParentId, 0);
|
2025-06-25 22:33:57 +08:00
|
|
|
foreach (var item in dbMenuList)
|
|
|
|
|
{
|
|
|
|
|
menus.Add(item.CopyTo<MenuBean>());
|
|
|
|
|
}
|
2025-06-26 19:36:27 +08:00
|
|
|
|
2025-06-25 22:33:57 +08:00
|
|
|
return menus;
|
2025-06-24 20:48:38 +08:00
|
|
|
}
|
2025-06-26 19:36:27 +08:00
|
|
|
|
2025-06-25 22:33:57 +08:00
|
|
|
public async Task<int> AddMenu(MenuBean menu)
|
2025-06-24 20:48:38 +08:00
|
|
|
{
|
2025-06-25 22:33:57 +08:00
|
|
|
return await _db.Insertable<DbMenu>(menu.CopyTo<DbMenu>()).ExecuteCommandAsync();
|
2025-06-24 20:48:38 +08:00
|
|
|
}
|
2025-06-26 19:36:27 +08:00
|
|
|
|
2025-06-26 22:40:20 +08:00
|
|
|
|
|
|
|
|
public async Task<bool> AddDeviceMenu(MenuBean menu)
|
2025-06-26 19:36:27 +08:00
|
|
|
{
|
2025-06-26 22:40:20 +08:00
|
|
|
bool result = false;
|
|
|
|
|
var deviceMainMenu = await _db.Queryable<DbMenu>().FirstAsync(m => m.Name == "设备");
|
|
|
|
|
if (deviceMainMenu == null)
|
|
|
|
|
throw new InvalidOperationException("没有找到设备菜单!!");
|
|
|
|
|
|
|
|
|
|
menu.ParentId=deviceMainMenu.Id;
|
|
|
|
|
var addDeviceMenuRes = await _db.Insertable<DbMenu>(menu.CopyTo<DbMenu>())
|
|
|
|
|
.ExecuteCommandAsync();
|
|
|
|
|
if (addDeviceMenuRes == 0)
|
|
|
|
|
throw new InvalidOperationException($"{menu.Name},设备菜单添加失败!!");
|
|
|
|
|
|
|
|
|
|
var addDM = await _db.Queryable<DbMenu>().OrderBy(m => m.Id, OrderByType.Desc)
|
|
|
|
|
.FirstAsync(m => m.Name == menu.Name);
|
|
|
|
|
if (addDM == null)
|
|
|
|
|
throw new InvalidOperationException($"添加默认变量表菜单时,没有找到名字为:{menu.Name}的菜单项!");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var defVarTable=new MenuBean()
|
|
|
|
|
{
|
|
|
|
|
Name = "默认变量表",
|
|
|
|
|
Icon = SegoeFluentIcons.Tablet.Glyph,
|
2025-06-28 19:32:51 +08:00
|
|
|
Type = MenuType.VariableTableMenu,
|
2025-06-26 22:40:20 +08:00
|
|
|
ParentId = addDM.Id,
|
|
|
|
|
};
|
|
|
|
|
var addVarTable=new MenuBean()
|
|
|
|
|
{
|
|
|
|
|
Name = "添加变量表",
|
|
|
|
|
Icon = SegoeFluentIcons.Add.Glyph,
|
2025-06-28 19:32:51 +08:00
|
|
|
Type = MenuType.AddVariableTableMenu,
|
2025-06-26 22:40:20 +08:00
|
|
|
ParentId = addDM.Id,
|
|
|
|
|
};
|
|
|
|
|
var defTableRes = await _db.Insertable<DbMenu>(defVarTable).ExecuteCommandAsync();
|
|
|
|
|
var addTableRes = await _db.Insertable<DbMenu>(addVarTable).ExecuteCommandAsync();
|
|
|
|
|
if ((addTableRes+defTableRes) != 2)
|
|
|
|
|
{
|
|
|
|
|
// 如果出错删除原来添加的设备菜单
|
|
|
|
|
await _db.Deleteable<DbMenu>().Where(m=>m.Id==addDM.Id).ExecuteCommandAsync();
|
|
|
|
|
throw new InvalidOperationException("添加默认变量表时发生了错误!!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
2025-06-26 19:36:27 +08:00
|
|
|
}
|
2025-06-26 22:40:20 +08:00
|
|
|
}
|