liaoxujun@qq.com
2024-02-18 b73ffe97fc885b652b20328c1c3d079a9124fb89
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
// WTM默认页面 Wtm buidin page
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Threading.Tasks;
using WalkingTec.Mvvm.Core;
using WalkingTec.Mvvm.Mvc.Admin.ViewModels.DataPrivilegeVMs;
using WalkingTec.Mvvm.Mvc.Admin.ViewModels.FrameworkMenuVMs;
 
namespace WalkingTec.Mvvm.Mvc.Admin.ViewModels.FrameworkGroupVMs
{
    public class FrameworkGroupMDVM : BaseVM
    {
 
        [Display(Name = "_Admin.GroupCode")]
        public string GroupCode { get; set; }
        public List<GroupDp> DpLists { get; set; }
 
        public FrameworkGroupMDVM()
        {
        }
 
        protected override void InitVM()
        {
            DpLists = new List<GroupDp>();
            foreach (var item in Wtm.DataPrivilegeSettings)
            {
                DpListVM list = new DpListVM();
                list.Searcher = new DpSearcher();
                list.Searcher.TableName = item.ModelName;
                DpLists.Add(new GroupDp { DpName = item.PrivillegeName, List = list, SelectedIds = new List<string>() });
            }
            var alldp = DC.Set<DataPrivilege>().Where(x => x.GroupCode == GroupCode).ToList();
            foreach (var item in DpLists)
            {
                var select = alldp.Where(x => x.TableName == item.List.Searcher.TableName).Select(x => x.RelateId).ToList();
                if(select.Count == 0)
                {
                    item.IsAll = null;
                }
                else if (select.Contains(null))
                {
                    item.IsAll = true;
                }
                else
                {
                    item.IsAll = false;
                    item.SelectedIds = select;
                }
            }
        }
 
        public bool DoChange()
        {
            List<Guid> oldIDs =  DC.Set<DataPrivilege>().Where(x => x.GroupCode == GroupCode).Select(x => x.ID).ToList();
            
            foreach (var oldid in oldIDs)
            {
                DataPrivilege dp = new DataPrivilege { ID = oldid };
                DC.Set<DataPrivilege>().Attach(dp);
                DC.DeleteEntity(dp);
            }
            foreach (var item in DpLists)
            {
                if(item.IsAll == true)
                {
                    DataPrivilege dp = new DataPrivilege();
                    dp.RelateId = null;
                    dp.GroupCode = GroupCode;
                    dp.TableName = item.List.Searcher.TableName;
                    dp.TenantCode = LoginUserInfo.CurrentTenant;
                    DC.Set<DataPrivilege>().Add(dp);
                }
                if (item.IsAll == false && item.SelectedIds != null)
                {
                    foreach (var id in item.SelectedIds)
                    {
                        DataPrivilege dp = new DataPrivilege();
                        dp.RelateId = id;
                        dp.GroupCode = GroupCode;
                        dp.TableName = item.List.Searcher.TableName;
                        dp.TenantCode = LoginUserInfo.CurrentTenant;
                        DC.Set<DataPrivilege>().Add(dp);
                    }
 
                }
            }
            DC.SaveChanges();
            Wtm.RemoveUserCacheByGroup(GroupCode).Wait();
            return true;
        }
 
    }
 
    public class GroupDp
    {
        public DpListVM List { get; set; }
        public string DpName { get; set; }
 
        public List<string> SelectedIds { get; set; }
 
        public bool? IsAll { get; set; }
    }
}