mirror of
https://gitee.com/dotnetchina/OpenAuth.Net.git
synced 2025-07-15 23:13:40 +08:00
修改用户分配角色操作界面
This commit is contained in:
parent
40188e36a5
commit
f853bd13b7
140
CodeSmith/Add.cshtml.cst
Normal file
140
CodeSmith/Add.cshtml.cst
Normal file
@ -0,0 +1,140 @@
|
||||
<%--
|
||||
Name: 添加界面
|
||||
Author: yubaolee
|
||||
Description: 任务对象界面
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" TargetLanguage="C#" Debug="False" Encoding="utf-8" Description="添加模块" %>
|
||||
<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="Context"
|
||||
Description="连接的数据库" %>
|
||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
||||
<%@ Property Name="CascadeId" Type="String" Category="" Default="ParentId" Description="级联字段" %>
|
||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||
<%@ Assembly Name="SchemaExplorer" %>
|
||||
<%@ Import Namespace="SchemaExplorer" %>
|
||||
<script runat="template">
|
||||
public String GetModelName() {
|
||||
if (NeedViewModel)
|
||||
return ModuleName + "View";
|
||||
else
|
||||
return ModuleName;
|
||||
}
|
||||
</script>
|
||||
<%if(NeedViewModel){ %>
|
||||
@model OpenAuth.App.ViewModel.<%=GetModelName()%>
|
||||
<%} else{ %>
|
||||
@model OpenAuth.Domain.<%=GetModelName()%>
|
||||
<%} %>
|
||||
@{
|
||||
ViewBag.Title = "<%=GetModelName()%>编辑界面";
|
||||
Layout = null;
|
||||
}
|
||||
<div class="bjui-pageContent">
|
||||
<form action="/<%=ModuleName%>Manager/Add" class="pageForm" data-toggle="validate">
|
||||
<table class="table table-condensed table-hover">
|
||||
<tbody>
|
||||
<% foreach (ColumnSchema column in this.SourceTable.Columns) {
|
||||
if(column.Name == "CascadeId") continue; //cascadeId字段需要程序控制
|
||||
%>
|
||||
<tr>
|
||||
<td>
|
||||
<%if(column.IsPrimaryKeyMember){ %>
|
||||
@Html.HiddenFor(m =>m.<%=column.Name%>)
|
||||
<% } else if(column.Name == CascadeId) {%>
|
||||
@Html.HiddenFor(m =>m.<%=CascadeId %>)
|
||||
@if (Model.Id == 0) //添加
|
||||
{
|
||||
//这个只用于显示使用,并不会进行提交处理,真正提交的是cascadeId
|
||||
<label for="CascadeName" class="control-label x120">父节点流水号:</label>
|
||||
<input type="text" name="CascadeName" id="CascadeName"
|
||||
data-toggle="selectztree" size="20" data-tree="#j_select_tree1" value="">
|
||||
<ul id="j_select_tree1" class="ztree hide" data-toggle="ztree"></ul>
|
||||
<script type="text/javascript">
|
||||
$(document).ready(function () {
|
||||
Init();
|
||||
});
|
||||
function Init() {
|
||||
var setting = {
|
||||
view: {
|
||||
selectedMulti: false
|
||||
},
|
||||
check: {
|
||||
enable: true,
|
||||
chkStyle: "radio",
|
||||
radioType: "all"
|
||||
},
|
||||
data: {
|
||||
key: {
|
||||
name: 'Name',
|
||||
title: 'Name'
|
||||
},
|
||||
simpleData: {
|
||||
enable: true,
|
||||
idKey: 'Id',
|
||||
pIdKey: 'ParentId',
|
||||
rootPId: 'null'
|
||||
}
|
||||
},
|
||||
callback: {
|
||||
onClick: zTreeOnClick,
|
||||
onCheck: zTreeCheck
|
||||
}
|
||||
};
|
||||
$.getJSON('CategoryManager/LoadForTree', function (json) {
|
||||
var zTreeObj = $.fn.zTree.init($('#j_select_tree1'), setting, json);
|
||||
zTreeObj.expandAll(true);
|
||||
});
|
||||
}
|
||||
function zTreeCheck(e, treeId, treeNode) {
|
||||
var zTree = $.fn.zTree.getZTreeObj(treeId),
|
||||
nodes = zTree.getCheckedNodes(true);
|
||||
var ids = '', names = '';
|
||||
for (var i = 0; i < nodes.length; i++) {
|
||||
ids += ',' + nodes[i].Id;
|
||||
names += ',' + nodes[i].Name;
|
||||
}
|
||||
if (ids.length > 0) { //去掉第一个逗号
|
||||
ids = ids.substr(1);
|
||||
names = names.substr(1);
|
||||
}
|
||||
var $from = $('#' + treeId).data('fromObj');
|
||||
if ($from && $from.length) $from.val(names);
|
||||
$('#<%=CascadeId%>').val(ids);
|
||||
}
|
||||
function zTreeOnClick(event, treeId, treeNode) {
|
||||
var zTree = $.fn.zTree.getZTreeObj(treeId);
|
||||
zTree.checkNode(treeNode, !treeNode.checked, true, true);
|
||||
event.preventDefault();
|
||||
}
|
||||
</script>
|
||||
}
|
||||
else //编辑
|
||||
{
|
||||
<label for="CascadeId" class="control-label x120">节点语义ID:</label>
|
||||
<input type="text" name="CascadeId" id="CascadeId" value="@Model.CascadeId"
|
||||
data-rule="required" size="20">
|
||||
}
|
||||
<% } else if(CSharpAlias[column.SystemType.FullName] == "bool") {%>
|
||||
<label for="<%=column.Name%>" class="control-label x120"><%=column.Description%>:</label>
|
||||
<select name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
||||
<option value="0" @if (Model.<%=column.Name%>) { <text> selected="selected" </text> }>否</option>
|
||||
<option value="1" @if (!Model.<%=column.Name%>) { <text> selected="selected" </text> }>是</option>
|
||||
</select>
|
||||
<%} else{%>
|
||||
<label for="<%=column.Name%>" class="control-label x120"><%=column.Description%>:</label>
|
||||
<input type="text" name="<%=column.Name%>" id="<%=column.Name%>" value="@Model.<%=column.Name%>"
|
||||
data-rule="required" size="20">
|
||||
<%} %>
|
||||
</td>
|
||||
</tr>
|
||||
<% } %>
|
||||
</tbody>
|
||||
</table>
|
||||
</form>
|
||||
</div>
|
||||
<div class="bjui-pageFooter">
|
||||
<ul>
|
||||
<li><button type="button" class="btn-close">关闭</button></li>
|
||||
<li><button type="submit" class="btn-green">保存</button></li>
|
||||
</ul>
|
||||
</div>
|
@ -1,6 +1,6 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Author: yubaolee
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="应用层" %>
|
@ -1,6 +1,6 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Author: yubaolee
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="控制器" %>
|
@ -1,6 +1,6 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Author: yubaolee
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="创建包含组织机构的接口" %>
|
@ -1,6 +1,6 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Author: yubaolee
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="True" Description="Create a list of properties from database table." %>
|
@ -1,7 +1,7 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Description: Create a list of properties from a database table
|
||||
Author: yubaolee
|
||||
Description: 没有树状导航的datagrid
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="True" Description="Create a list of properties from database table." %>
|
||||
<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="Context" Description="Table that the object is based on." %>
|
||||
@ -20,20 +20,12 @@ Description: Create a list of properties from a database table
|
||||
@{ Html.RenderAction("MenuHeader", "Home");}
|
||||
<div class="bjui-pageContent tableContent">
|
||||
<div class="clearfix">
|
||||
<div style="float: left; width: 220px; overflow: auto;" class="table table-bordered">
|
||||
<ul id="@_treeId" class="ztree"></ul>
|
||||
</div>
|
||||
|
||||
<div id="@_treeDetail" style="margin-left: 225px;">
|
||||
</div>
|
||||
<div id="@_treeDetail" style="margin-left: 225px;">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<script type="text/javascript">
|
||||
var selectedId = 0;
|
||||
$(document).ready(function () {
|
||||
initZtree();
|
||||
loadDataGrid();
|
||||
});
|
||||
//加载数据到datagrid
|
||||
@ -82,34 +74,6 @@ Description: Create a list of properties from a database table
|
||||
});
|
||||
}
|
||||
|
||||
function zTreeOnClick(event, treeId, treeNode) {
|
||||
selectedId = treeNode.Id;
|
||||
loadDataGrid();
|
||||
}
|
||||
|
||||
function initZtree() {
|
||||
var setting = {
|
||||
view: {selectedMulti: false},
|
||||
data: {
|
||||
key: {
|
||||
name: 'Name',
|
||||
title: 'Name'
|
||||
},
|
||||
simpleData: {
|
||||
enable: true,
|
||||
idKey: 'Id',
|
||||
pIdKey: 'ParentId',
|
||||
rootPId: 'null'
|
||||
}
|
||||
},
|
||||
callback: {onClick: zTreeOnClick}
|
||||
};
|
||||
$.getJSON('<%=ModuleName%>Manager/LoadForTree', function (json) {
|
||||
var zTreeObj = $.fn.zTree.init($('#@_treeId'), setting, json);
|
||||
zTreeObj.expandAll(true);
|
||||
});
|
||||
}
|
||||
|
||||
//删除
|
||||
function del<%=ModuleName%>() {
|
||||
var selected = getSelected('#@_gridId',2);
|
49
CodeSmith/Repository.cst
Normal file
49
CodeSmith/Repository.cst
Normal file
@ -0,0 +1,49 @@
|
||||
<%--
|
||||
Name: 数据访问
|
||||
Author: yubaolee
|
||||
Description:
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="数据访问" %>
|
||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||
<%@ Assembly Name="SchemaExplorer" %>
|
||||
<%@ Import Namespace="SchemaExplorer" %>
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using OpenAuth.Domain;
|
||||
using OpenAuth.Domain.Interface;
|
||||
|
||||
namespace OpenAuth.Repository
|
||||
{
|
||||
public class <%=ModuleName%>Repository :BaseRepository<<%=ModuleName%>>, I<%=ModuleName%>Repository
|
||||
{
|
||||
|
||||
public IEnumerable<<%=ModuleName%>> Load<%=ModuleName%>s(int pageindex, int pagesize)
|
||||
{
|
||||
return Context.Categories.OrderBy(u => u.Id).Skip((pageindex - 1) * pagesize).Take(pagesize);
|
||||
}
|
||||
|
||||
public IEnumerable<<%=ModuleName%>> LoadInOrgs(params int[] orgId)
|
||||
{
|
||||
var result = from <%=ModuleName.ToLower()%> in Context.<%=ModuleName%>s where orgId.Contains(<%=ModuleName.ToLower()%>.Id)
|
||||
select <%=ModuleName.ToLower()%>;
|
||||
return result;
|
||||
|
||||
}
|
||||
|
||||
public int Get<%=ModuleName%>CntInOrgs(params int[] orgIds)
|
||||
{
|
||||
return LoadInOrgs(orgIds).Count();
|
||||
}
|
||||
|
||||
public IEnumerable<<%=ModuleName%>> LoadInOrgs(int pageindex, int pagesize, params int[] orgIds)
|
||||
{
|
||||
return LoadInOrgs(orgIds).OrderBy(u =>u.Id).Skip((pageindex -1)*pagesize).Take(pagesize);
|
||||
}
|
||||
|
||||
public void Delete(int id)
|
||||
{
|
||||
Delete(u =>u.Id == id);
|
||||
}
|
||||
}
|
||||
}
|
@ -1,145 +0,0 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" TargetLanguage="C#" Debug="False" Encoding="utf-8" Description="添加模块" %>
|
||||
<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="Context"
|
||||
Description="连接的数据库" %>
|
||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
||||
<%@ Property Name="CascadeId" Type="String" Category="" Default="ParentId" Description="级联字段" %>
|
||||
<%@ Property Name="CascadeName" Type="String" Category="" Default="ParentName" Description="级联显示的文字" %>
|
||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||
<%@ Assembly Name="SchemaExplorer" %>
|
||||
<%@ Import Namespace="SchemaExplorer" %>
|
||||
<script runat="template">
|
||||
public String GetModelName()
|
||||
{
|
||||
if(NeedViewModel)
|
||||
return ModuleName +"View";
|
||||
else
|
||||
return ModuleName;
|
||||
}
|
||||
</script>
|
||||
<%if(NeedViewModel){ %>
|
||||
@model OpenAuth.App.ViewModel.<%=GetModelName()%>
|
||||
<%} else{ %>
|
||||
@model OpenAuth.Domain.<%=GetModelName()%>
|
||||
<%} %>
|
||||
@{
|
||||
ViewBag.Title = "<%=GetModelName()%>编辑界面";
|
||||
Layout = null;
|
||||
}
|
||||
|
||||
<div class="bjui-pageContent">
|
||||
<form action="/<%=ModuleName%>Manager/Add" class="pageForm" data-toggle="validate">
|
||||
<table class="table table-condensed table-hover">
|
||||
<tbody>
|
||||
<% foreach (ColumnSchema column in this.SourceTable.Columns) {
|
||||
if(column.Name == CascadeName) continue;
|
||||
%>
|
||||
<tr>
|
||||
<td>
|
||||
<%if(column.IsPrimaryKeyMember){ %>
|
||||
@Html.HiddenFor(m =>m.Id)
|
||||
<% } else if(column.Name == CascadeId) {%>
|
||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||
<input id="<%=column.Name%>" name="<%=column.Name%>" value="" style="display: none"/>
|
||||
<input type="text" name="<%=CascadeName%>" id="<%=CascadeName%>"
|
||||
data-toggle="selectztree" size="20" data-tree="#j_select_tree1" value="@Model.<%=CascadeName%>">
|
||||
<ul id="j_select_tree1" class="ztree hide" data-toggle="ztree"></ul>
|
||||
|
||||
<% } else if(CSharpAlias[column.SystemType.FullName] == "bool") {%>
|
||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||
|
||||
<select name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
||||
<option value="0" @if (Model.<%=column.Name%>) { <text> selected="selected" </text> }>否</option>
|
||||
<option value="1" @if (!Model.<%=column.Name%>) { <text> selected="selected" </text> }>是</option>
|
||||
</select>
|
||||
<%} else if(CSharpAlias[column.SystemType.FullName] == "int") {%>
|
||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||
<select name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
||||
<option value="0" @if (Model.<%=column.Name%> == 0) { <text> selected="selected" </text> }>默认</option>
|
||||
<option value="1" @if (Model.<%=column.Name%> == 1) { <text> selected="selected" </text> }>状态1</option>
|
||||
</select>
|
||||
<%} else{%>
|
||||
<label for="<%=column.Name%>" class="control-label x90"><%=column.Description%>:</label>
|
||||
<input type="text" name="<%=column.Name%>" id="<%=column.Name%>" value="@Model.<%=column.Name%>"
|
||||
data-rule="required" size="20">
|
||||
<%} %>
|
||||
</td>
|
||||
</tr>
|
||||
<% } %>
|
||||
</tbody>
|
||||
</table>
|
||||
</form>
|
||||
</div>
|
||||
<div class="bjui-pageFooter">
|
||||
<ul>
|
||||
<li><button type="button" class="btn-close">关闭</button></li>
|
||||
<li><button type="submit" class="btn-green">保存</button></li>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
<script type="text/javascript">
|
||||
$(document).ready(function () {
|
||||
Init();
|
||||
});
|
||||
function Init() {
|
||||
var setting = {
|
||||
view: {
|
||||
selectedMulti: false
|
||||
},
|
||||
check: {
|
||||
enable: true,
|
||||
chkStyle: "checkbox",
|
||||
chkboxType: { "Y": "", "N": "" } //去掉勾选时级联
|
||||
},
|
||||
data: {
|
||||
key: {
|
||||
name: 'Name',
|
||||
title: 'Name'
|
||||
},
|
||||
simpleData: {
|
||||
enable: true,
|
||||
idKey: 'Id',
|
||||
pIdKey: 'ParentId',
|
||||
rootPId: 'null'
|
||||
}
|
||||
},
|
||||
callback: {
|
||||
onClick: zTreeOnClick,
|
||||
onCheck: zTreeCheck
|
||||
}
|
||||
};
|
||||
$.getJSON('OrgManager/LoadOrg', function (json) {
|
||||
var zTreeObj = $.fn.zTree.init($('#j_select_tree1'), setting, json);
|
||||
zTreeObj.expandAll(true);
|
||||
});
|
||||
}
|
||||
|
||||
function zTreeCheck(e, treeId, treeNode) {
|
||||
var zTree = $.fn.zTree.getZTreeObj(treeId),
|
||||
nodes = zTree.getCheckedNodes(true);
|
||||
var ids = '', names = '';
|
||||
for (var i = 0; i < nodes.length; i++) {
|
||||
ids += ',' + nodes[i].Id;
|
||||
names += ',' + nodes[i].Name;
|
||||
}
|
||||
if (ids.length > 0) { //去掉第一个逗号
|
||||
ids = ids.substr(1);
|
||||
names = names.substr(1);
|
||||
}
|
||||
|
||||
var $from = $('#' + treeId).data('fromObj');
|
||||
if ($from && $from.length) $from.val(names);
|
||||
|
||||
$('#<%=CascadeId%>').val(ids);
|
||||
}
|
||||
function zTreeOnClick(event, treeId, treeNode) {
|
||||
var zTree = $.fn.zTree.getZTreeObj(treeId);
|
||||
zTree.checkNode(treeNode, !treeNode.checked, true, true);
|
||||
event.preventDefault();
|
||||
}
|
||||
</script>
|
@ -1,138 +0,0 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="应用层" %>
|
||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||
<%@ Assembly Name="SchemaExplorer" %>
|
||||
<%@ Import Namespace="SchemaExplorer" %>
|
||||
<script runat="template">
|
||||
public String GetModelName()
|
||||
{
|
||||
if(NeedViewModel)
|
||||
return ModuleName +"View";
|
||||
else
|
||||
return ModuleName;
|
||||
}
|
||||
</script>
|
||||
|
||||
<%if(NeedViewModel){ %>
|
||||
using OpenAuth.App.ViewModel;
|
||||
<%} %>
|
||||
using OpenAuth.Domain;
|
||||
using OpenAuth.Domain.Interface;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
namespace OpenAuth.App
|
||||
{
|
||||
public class <%=ModuleName%>ManagerApp
|
||||
{
|
||||
private I<%=ModuleName%>Repository _repository;
|
||||
private IOrgRepository _orgRepository;
|
||||
|
||||
public <%=ModuleName%>ManagerApp(I<%=ModuleName%>Repository repository,
|
||||
IOrgRepository orgRepository)
|
||||
{
|
||||
_repository = repository;
|
||||
_orgRepository = orgRepository;
|
||||
}
|
||||
|
||||
public int Get<%=GetModelName()%>CntInOrg(int orgId)
|
||||
{
|
||||
if (orgId == 0)
|
||||
{
|
||||
return _repository.Find(null).Count();
|
||||
}
|
||||
else
|
||||
{
|
||||
return _repository.Get<%=GetModelName()%>CntInOrgs(GetSubOrgIds(orgId));
|
||||
}
|
||||
}
|
||||
|
||||
public List<<%=GetModelName()%>> LoadAll()
|
||||
{
|
||||
return _repository.Find(null).ToList();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 加载一个节点下面的一个或全部<%=GetModelName()%>s
|
||||
/// </summary>
|
||||
public dynamic Load(int orgId, int pageindex, int pagesize)
|
||||
{
|
||||
IEnumerable<<%=ModuleName%>> <%=ModuleName%>s;
|
||||
int total = 0;
|
||||
if (orgId == 0)
|
||||
{
|
||||
<%=ModuleName%>s = _repository.Load<%=ModuleName%>s(pageindex, pagesize);
|
||||
total = _repository.GetCount();
|
||||
}
|
||||
else
|
||||
{
|
||||
<%=ModuleName%>s = _repository.LoadInOrgs(pageindex, pagesize,GetSubOrgIds(orgId));
|
||||
total = _repository.Get<%=ModuleName%>CntInOrgs(orgId);
|
||||
}
|
||||
<%if(NeedViewModel){ %>
|
||||
var <%=ModuleName%>views = new List<<%=ModuleName%>View>();
|
||||
foreach (var <%=ModuleName%> in <%=ModuleName%>s)
|
||||
{
|
||||
<%=ModuleName%>View uv = <%=ModuleName%>;
|
||||
uv.Organizations = string.Join(",", _orgRepository.LoadBy<%=ModuleName%>(<%=ModuleName%>.Id).Select(u => u.Name).ToList());
|
||||
<%=ModuleName%>views.Add(uv);
|
||||
}
|
||||
<%} %>
|
||||
|
||||
return new
|
||||
{
|
||||
total = total,
|
||||
list = <%=GetModelName()%>s,
|
||||
pageCurrent = pageindex
|
||||
};
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 获取当前节点的所有下级节点
|
||||
/// </summary>
|
||||
private int[] GetSubOrgIds(int orgId)
|
||||
{
|
||||
var org = _orgRepository.FindSingle(u => u.Id == orgId);
|
||||
var orgs = _orgRepository.Find(u => u.CascadeId.Contains(org.CascadeId)).Select(u => u.Id).ToArray();
|
||||
return orgs;
|
||||
}
|
||||
|
||||
public <%=GetModelName()%> Find(int id)
|
||||
{
|
||||
var <%=ModuleName.ToLower()%> = _repository.FindSingle(u => u.Id == id);
|
||||
if (<%=ModuleName.ToLower()%> == null) return new <%=GetModelName()%>();
|
||||
|
||||
return <%=ModuleName.ToLower() %>;
|
||||
}
|
||||
|
||||
public void Delete(int id)
|
||||
{
|
||||
_repository.Delete(id);
|
||||
}
|
||||
|
||||
public void AddOrUpdate(<%=GetModelName()%> model)
|
||||
{
|
||||
<%=ModuleName%> <%=ModuleName.ToLower()%> = new <%=ModuleName%>();
|
||||
model.CopyTo(<%=ModuleName.ToLower()%>);
|
||||
|
||||
if (<%=ModuleName.ToLower()%>.Id == 0)
|
||||
{
|
||||
_repository.Add(<%=ModuleName.ToLower()%>);
|
||||
}
|
||||
else
|
||||
{
|
||||
_repository.Update(<%=ModuleName.ToLower()%>);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
@ -1,110 +0,0 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="控制器" %>
|
||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||
<%@ Assembly Name="SchemaExplorer" %>
|
||||
<%@ Import Namespace="SchemaExplorer" %>
|
||||
<script runat="template">
|
||||
public String GetModelName()
|
||||
{
|
||||
if(NeedViewModel)
|
||||
return ModuleName +"View";
|
||||
else
|
||||
return ModuleName;
|
||||
}
|
||||
</script>
|
||||
|
||||
using System;
|
||||
using System.Web.Mvc;
|
||||
using Infrastructure;
|
||||
using OpenAuth.App;
|
||||
<%if(NeedViewModel){ %>
|
||||
using OpenAuth.App.ViewModel;
|
||||
<%} %>
|
||||
using OpenAuth.Domain;
|
||||
|
||||
namespace OpenAuth.Mvc.Controllers
|
||||
{
|
||||
public class <%=ModuleName%>ManagerController : BaseController
|
||||
{
|
||||
private <%=ModuleName%>ManagerApp _app;
|
||||
|
||||
public <%=ModuleName%>ManagerController()
|
||||
{
|
||||
_app = AutofacExt.GetFromFac<<%=ModuleName%>ManagerApp>();
|
||||
}
|
||||
|
||||
//
|
||||
// GET: /UserManager/
|
||||
public ActionResult Index()
|
||||
{
|
||||
return View();
|
||||
}
|
||||
|
||||
public ActionResult Add(int id = 0)
|
||||
{
|
||||
return View(_app.Find(id));
|
||||
}
|
||||
|
||||
//添加或修改<%=ModuleName %>
|
||||
[HttpPost]
|
||||
public string Add(<%=GetModelName()%> model)
|
||||
{
|
||||
try
|
||||
{
|
||||
_app.AddOrUpdate(model);
|
||||
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
BjuiResponse.statusCode = "300";
|
||||
BjuiResponse.message = ex.Message;
|
||||
}
|
||||
return JsonHelper.Instance.Serialize(BjuiResponse);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 加载节点下面的所有<%=ModuleName %>s
|
||||
/// </summary>
|
||||
public string Load(int parentidId, int pageCurrent = 1, int pageSize = 30)
|
||||
{
|
||||
return JsonHelper.Instance.Serialize(_app.Load(parentidId, pageCurrent, pageSize));
|
||||
}
|
||||
|
||||
public string LoadForTree()
|
||||
{
|
||||
var models = _app.LoadAll();
|
||||
//添加根节点
|
||||
models.Add(new <%=ModuleName %>
|
||||
{
|
||||
Id = 0,
|
||||
ParentId = -1,
|
||||
Name = "根结点",
|
||||
CascadeId = "0"
|
||||
});
|
||||
return JsonHelper.Instance.Serialize(models);
|
||||
}
|
||||
|
||||
public string Delete(int Id)
|
||||
{
|
||||
try
|
||||
{
|
||||
_app.Delete(Id);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
BjuiResponse.statusCode = "300";
|
||||
BjuiResponse.message = e.Message;
|
||||
}
|
||||
|
||||
return JsonHelper.Instance.Serialize(BjuiResponse);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
@ -1,28 +0,0 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="创建包含组织机构的接口" %>
|
||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||
<%@ Assembly Name="SchemaExplorer" %>
|
||||
<%@ Import Namespace="SchemaExplorer" %>
|
||||
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
namespace OpenAuth.Domain.Interface
|
||||
{
|
||||
public interface I<%=ModuleName%>Repository :IRepository<<%=ModuleName%>>
|
||||
{
|
||||
IEnumerable<<%=ModuleName%>> Load<%=ModuleName%>s(int pageindex, int pagesize);
|
||||
|
||||
IEnumerable<<%=ModuleName%>> LoadInOrgs(params int[] orgId);
|
||||
int Get<%=ModuleName%>CntInOrgs(params int[] orgIds);
|
||||
IEnumerable<<%=ModuleName%>> LoadInOrgs(int pageindex, int pagesize, params int[] orgIds);
|
||||
|
||||
void Delete(int id);
|
||||
|
||||
}
|
||||
}
|
@ -1,145 +0,0 @@
|
||||
<%--
|
||||
Name: Database Table Properties
|
||||
Author: Paul Welter
|
||||
Description: Create a list of properties from a database table
|
||||
--%>
|
||||
<%@ CodeTemplate Language="C#" TargetLanguage="C#" Debug="False" Encoding="utf-8" Description="添加模块" %>
|
||||
<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="Context"
|
||||
Description="连接的数据库" %>
|
||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
||||
<%@ Property Name="CascadeId" Type="String" Category="" Default="ParentId" Description="级联字段" %>
|
||||
<%@ Property Name="CascadeName" Type="String" Category="" Default="ParentName" Description="级联显示的文字" %>
|
||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||
<%@ Assembly Name="SchemaExplorer" %>
|
||||
<%@ Import Namespace="SchemaExplorer" %>
|
||||
<script runat="template">
|
||||
public String GetModelName()
|
||||
{
|
||||
if(NeedViewModel)
|
||||
return ModuleName +"View";
|
||||
else
|
||||
return ModuleName;
|
||||
}
|
||||
</script>
|
||||
<%if(NeedViewModel){ %>
|
||||
@model OpenAuth.App.ViewModel.<%=GetModelName()%>
|
||||
<%} else{ %>
|
||||
@model OpenAuth.Domain.<%=GetModelName()%>
|
||||
<%} %>
|
||||
@{
|
||||
ViewBag.Title = "<%=GetModelName()%>编辑界面";
|
||||
Layout = null;
|
||||
}
|
||||
|
||||
<div class="bjui-pageContent">
|
||||
<form action="/<%=ModuleName%>Manager/Add" class="pageForm" data-toggle="validate">
|
||||
<table class="table table-condensed table-hover">
|
||||
<tbody>
|
||||
<% foreach (ColumnSchema column in this.SourceTable.Columns) {
|
||||
if(column.Name == CascadeName) continue;
|
||||
%>
|
||||
<tr>
|
||||
<td>
|
||||
<%if(column.IsPrimaryKeyMember){ %>
|
||||
@Html.HiddenFor(m =>m.Id)
|
||||
<% } else if(column.Name == CascadeId) {%>
|
||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||
<input id="<%=column.Name%>" name="<%=column.Name%>" value="" style="display: none"/>
|
||||
<input type="text" name="<%=CascadeName%>" id="<%=CascadeName%>"
|
||||
data-toggle="selectztree" size="20" data-tree="#j_select_tree1" value="@Model.<%=CascadeName%>">
|
||||
<ul id="j_select_tree1" class="ztree hide" data-toggle="ztree"></ul>
|
||||
|
||||
<% } else if(CSharpAlias[column.SystemType.FullName] == "bool") {%>
|
||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||
|
||||
<select name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
||||
<option value="0" @if (Model.<%=column.Name%>) { <text> selected="selected" </text> }>否</option>
|
||||
<option value="1" @if (!Model.<%=column.Name%>) { <text> selected="selected" </text> }>是</option>
|
||||
</select>
|
||||
<%} else if(CSharpAlias[column.SystemType.FullName] == "int") {%>
|
||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||
<select name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
||||
<option value="0" @if (Model.<%=column.Name%> == 0) { <text> selected="selected" </text> }>默认</option>
|
||||
<option value="1" @if (Model.<%=column.Name%> == 1) { <text> selected="selected" </text> }>状态1</option>
|
||||
</select>
|
||||
<%} else{%>
|
||||
<label for="<%=column.Name%>" class="control-label x90"><%=column.Description%>:</label>
|
||||
<input type="text" name="<%=column.Name%>" id="<%=column.Name%>" value="@Model.<%=column.Name%>"
|
||||
data-rule="required" size="20">
|
||||
<%} %>
|
||||
</td>
|
||||
</tr>
|
||||
<% } %>
|
||||
</tbody>
|
||||
</table>
|
||||
</form>
|
||||
</div>
|
||||
<div class="bjui-pageFooter">
|
||||
<ul>
|
||||
<li><button type="button" class="btn-close">关闭</button></li>
|
||||
<li><button type="submit" class="btn-green">保存</button></li>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
<script type="text/javascript">
|
||||
$(document).ready(function () {
|
||||
Init();
|
||||
});
|
||||
function Init() {
|
||||
var setting = {
|
||||
view: {
|
||||
selectedMulti: false
|
||||
},
|
||||
check: {
|
||||
enable: true,
|
||||
chkStyle: "checkbox",
|
||||
chkboxType: { "Y": "", "N": "" } //去掉勾选时级联
|
||||
},
|
||||
data: {
|
||||
key: {
|
||||
name: 'Name',
|
||||
title: 'Name'
|
||||
},
|
||||
simpleData: {
|
||||
enable: true,
|
||||
idKey: 'Id',
|
||||
pIdKey: 'ParentId',
|
||||
rootPId: 'null'
|
||||
}
|
||||
},
|
||||
callback: {
|
||||
onClick: zTreeOnClick,
|
||||
onCheck: zTreeCheck
|
||||
}
|
||||
};
|
||||
$.getJSON('OrgManager/LoadOrg', function (json) {
|
||||
var zTreeObj = $.fn.zTree.init($('#j_select_tree1'), setting, json);
|
||||
zTreeObj.expandAll(true);
|
||||
});
|
||||
}
|
||||
|
||||
function zTreeCheck(e, treeId, treeNode) {
|
||||
var zTree = $.fn.zTree.getZTreeObj(treeId),
|
||||
nodes = zTree.getCheckedNodes(true);
|
||||
var ids = '', names = '';
|
||||
for (var i = 0; i < nodes.length; i++) {
|
||||
ids += ',' + nodes[i].Id;
|
||||
names += ',' + nodes[i].Name;
|
||||
}
|
||||
if (ids.length > 0) { //去掉第一个逗号
|
||||
ids = ids.substr(1);
|
||||
names = names.substr(1);
|
||||
}
|
||||
|
||||
var $from = $('#' + treeId).data('fromObj');
|
||||
if ($from && $from.length) $from.val(names);
|
||||
|
||||
$('#<%=CascadeId%>').val(ids);
|
||||
}
|
||||
function zTreeOnClick(event, treeId, treeNode) {
|
||||
var zTree = $.fn.zTree.getZTreeObj(treeId);
|
||||
zTree.checkNode(treeNode, !treeNode.checked, true, true);
|
||||
event.preventDefault();
|
||||
}
|
||||
</script>
|
@ -15,16 +15,19 @@ namespace OpenAuth.App
|
||||
private IModuleRepository _moduleRepository;
|
||||
private IRelevanceRepository _relevanceRepository;
|
||||
private IRepository<ModuleElement> _moduleElementRepository;
|
||||
private IResourceRepository _resourceRepository;
|
||||
|
||||
public LoginApp(IUserRepository repository,
|
||||
IModuleRepository moduleRepository,
|
||||
IRelevanceRepository relevanceRepository,
|
||||
IRepository<ModuleElement> moduleElementRepository )
|
||||
IRepository<ModuleElement> moduleElementRepository,
|
||||
IResourceRepository resourceRepository)
|
||||
{
|
||||
_repository = repository;
|
||||
_moduleRepository = moduleRepository;
|
||||
_relevanceRepository = relevanceRepository;
|
||||
_moduleElementRepository = moduleElementRepository;
|
||||
_resourceRepository = resourceRepository;
|
||||
}
|
||||
|
||||
public LoginUserVM Login(string userName, string password)
|
||||
@ -65,7 +68,14 @@ namespace OpenAuth.App
|
||||
module.Elements = _moduleElementRepository.Find(u => u.ModuleId == module.Id && elementIds.Contains( u.Id)).ToList();
|
||||
}
|
||||
|
||||
return loginVM;
|
||||
//用户角色与自己分配到的资源ID
|
||||
var resourceIds = _relevanceRepository.Find(
|
||||
u =>
|
||||
(u.FirstId == user.Id && u.Key == "UserResource") ||
|
||||
(u.Key == "RoleResource" && userRoleIds.Contains(u.FirstId))).Select(u => u.SecondId).ToList();
|
||||
loginVM.Resources = _resourceRepository.Find(u => resourceIds.Contains(u.Id)).ToList();
|
||||
|
||||
return loginVM;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@ -86,6 +96,8 @@ namespace OpenAuth.App
|
||||
{
|
||||
module.Elements = _moduleElementRepository.Find(u => u.ModuleId == module.Id).ToList();
|
||||
}
|
||||
|
||||
loginUser.Resources = _resourceRepository.Find(null).ToList();
|
||||
return loginUser;
|
||||
}
|
||||
}
|
||||
|
@ -96,9 +96,9 @@ namespace OpenAuth.App
|
||||
}
|
||||
}
|
||||
|
||||
public List<RoleVM> LoadWithUser(int userId)
|
||||
public List<RoleVM> LoadForOrgAndUser(int orgId, int userId)
|
||||
{
|
||||
var roleIds = _repository.Find(null).ToList();
|
||||
var roleIds = _repository.Find(u =>u.OrgId == orgId).ToList();
|
||||
var rolevms = new List<RoleVM>();
|
||||
foreach (var role in roleIds)
|
||||
{
|
||||
|
@ -27,6 +27,14 @@ namespace OpenAuth.App.ViewModel
|
||||
/// 用户可以访问到的模块(包括所属角色与自己的所有模块)
|
||||
/// </summary>
|
||||
public List<ModuleView> Modules { get; set; }
|
||||
|
||||
//用户可以访问的资源
|
||||
public List<Resource> Resources { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// 用户所属机构
|
||||
/// </summary>
|
||||
public List<Org> Orgs { get; set; }
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -71,10 +71,16 @@ namespace OpenAuth.Mvc.Controllers
|
||||
}
|
||||
|
||||
#region 为用户设置角色界面
|
||||
public ActionResult LookUpMulti(int userId)
|
||||
|
||||
public ActionResult LookupMulti(int userId)
|
||||
{
|
||||
ViewBag.UserId = userId;
|
||||
return View(_app.LoadWithUser(userId));
|
||||
return View();
|
||||
}
|
||||
|
||||
public string LoadForOrgAndUser(int orgId, int userId)
|
||||
{
|
||||
return JsonHelper.Instance.Serialize(_app.LoadForOrgAndUser(orgId, userId));
|
||||
}
|
||||
|
||||
public string AccessRoles(int userId, string ids)
|
||||
@ -83,6 +89,7 @@ namespace OpenAuth.Mvc.Controllers
|
||||
_app.AccessRole(userId, roleids);
|
||||
return JsonHelper.Instance.Serialize(BjuiResponse);
|
||||
}
|
||||
#endregion
|
||||
|
||||
#endregion 为用户设置角色界面
|
||||
}
|
||||
}
|
@ -574,6 +574,7 @@
|
||||
<Content Include="Views\Home\Index.cshtml" />
|
||||
<Content Include="Views\ResourceManager\Add.cshtml" />
|
||||
<Content Include="Views\ResourceManager\Index.cshtml" />
|
||||
<Content Include="Views\RoleManager\LookupMulti.cshtml" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Folder Include="App_Data\" />
|
||||
@ -640,7 +641,6 @@
|
||||
<Content Include="Views\UserManager\Add.cshtml" />
|
||||
<Content Include="Views\RoleManager\Add.cshtml" />
|
||||
<Content Include="Views\RoleManager\Index.cshtml" />
|
||||
<Content Include="Views\RoleManager\LookupMulti.cshtml" />
|
||||
</ItemGroup>
|
||||
<PropertyGroup>
|
||||
<VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">10.0</VisualStudioVersion>
|
||||
|
@ -1,77 +1,126 @@
|
||||
@model List<OpenAuth.App.ViewModel.RoleVM>
|
||||
@{
|
||||
ViewBag.Title = "title";
|
||||
Layout = null;
|
||||
@{
|
||||
string _prefix = "assignRoleForUser";
|
||||
var _treeId = _prefix + "Tree";
|
||||
var _gridId = _prefix + "Grid";
|
||||
var _treeDetail = _prefix + "Detail";
|
||||
}
|
||||
@*<div class="bjui-pageHeader">
|
||||
<div class="bjui-searchBar">
|
||||
<label>名称:</label><input type="text" value="" name="code" size="10" />
|
||||
<button type="submit" class="btn-default" data-icon="search">查询</button>
|
||||
<a class="btn btn-orange" href="javascript:;" data-toggle="reloadsearch" data-clear-query="true" data-icon="undo">清空查询</a>
|
||||
<div class="pull-right">
|
||||
<input type="checkbox" name="lookupType" value="1" data-toggle="icheck" data-label="追加" checked>
|
||||
<button type="button" class="btn-blue" data-toggle="lookupback" data-lookupid="ids" data-warn="请至少选择一项职业" data-icon="check-square-o">选择选中</button>
|
||||
</div>
|
||||
<div class="bjui-pageHeader">
|
||||
<div class="bjui-searchBar">
|
||||
<input style="display: none" id="userId" value="@ViewBag.UserId" />
|
||||
<div class="pull-right">
|
||||
<div class="alert alert-info search-inline">
|
||||
<i class="fa fa-info-circle"></i> 点击行为单选,点击复选框可多选统一授权
|
||||
</div>
|
||||
<button type="button" class="btn-green" data-num="1" data-icon="plus" onclick="assign()">
|
||||
授权选中项目
|
||||
</button>
|
||||
</div>
|
||||
</div>*@
|
||||
|
||||
<div class="bjui-pageContent">
|
||||
<input style="display: none" id="userId" value="@ViewBag.UserId" />
|
||||
<table data-selected-multi="true" class="table table-bordered" data-toggle="tablefixed" data-width="100%">
|
||||
<thead>
|
||||
<tr>
|
||||
<th data-order-field="id">ID</th>
|
||||
<th data-order-field="name">名称</th>
|
||||
<th data-order-field="note">所属部门</th>
|
||||
<th class="orderby asc" data-order-field="date">部门级联ID</th>
|
||||
<th >是否已经分配</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
@foreach (var role in Model)
|
||||
{
|
||||
<tr data-id="@role.Id">
|
||||
<td>@role.Id</td>
|
||||
<td>@role.Name</td>
|
||||
<td>@role.OrgName</td>
|
||||
<td>@role.OrgCascadeId</td>
|
||||
<td><input type="checkbox" disabled data-toggle="icheck"
|
||||
@if (role.IsBelongUser) { <text> checked </text> }></td>
|
||||
</tr>
|
||||
}
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
<div class="bjui-pageFooter">
|
||||
<ul>
|
||||
<li><button type="button" class="btn-close" data-icon="close">关闭</button></li>
|
||||
<li>
|
||||
<button type="button" class="btn-blue"
|
||||
data-url="RoleManager/AccessRoles?userid={#userId}&ids={#bjui-selected}"
|
||||
data-toggle="doajax" data-icon="check-square-o">
|
||||
设置权限
|
||||
</button>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<div class="bjui-pageContent tableContent">
|
||||
<div class="clearfix">
|
||||
<div style="float: left; width: 220px; overflow: auto;" class="table table-bordered">
|
||||
<ul id="@_treeId" class="ztree"></ul>
|
||||
</div>
|
||||
|
||||
<div id="@_treeDetail" style="margin-left: 225px;">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script type="text/javascript">
|
||||
var moduleIds;
|
||||
var selectedId = 0;
|
||||
$(document).ready(function () {
|
||||
|
||||
initZtree();
|
||||
loadDataGrid();
|
||||
});
|
||||
//加载数据到datagrid
|
||||
function loadDataGrid() {
|
||||
//b-jui的datagrid需要重新处理HTML
|
||||
$('#@_treeDetail').empty()
|
||||
.append('<table id="@_gridId" class="table table-bordered table-hover table-striped table-top"></table>');
|
||||
|
||||
function save() {
|
||||
$.post('UserManager/AccessModule', { userId: $('#userId').val(), moduleIds: moduleIds },
|
||||
function (json) {
|
||||
var rel = $.parseJSON(json);
|
||||
if (rel.statusCode == "200") {
|
||||
$(this).alertmsg('ok', rel.message);
|
||||
} else {
|
||||
$(this).alertmsg('error', rel.message);
|
||||
$('#@_gridId').datagrid({
|
||||
showToolbar: false,
|
||||
filterThead: false,
|
||||
columns: [
|
||||
{
|
||||
name: 'Id',
|
||||
label: '角色ID',
|
||||
hide: true
|
||||
},
|
||||
{
|
||||
name: 'Name',
|
||||
label: '角色名称',
|
||||
width: 100
|
||||
},
|
||||
|
||||
{
|
||||
name: 'IsBelongUser',
|
||||
label: '是否已经授权',
|
||||
type: 'select',
|
||||
align: 'center',
|
||||
items: [{ 'false': '未授权', 'true': '已授权' }],
|
||||
width: 100
|
||||
}
|
||||
],
|
||||
dataUrl: 'RoleManager/LoadForOrgAndUser?orgId=' + selectedId + '&userId=' + $('#userId').val(),
|
||||
fullGrid: true,
|
||||
showLinenumber: true,
|
||||
showCheckboxcol: true,
|
||||
paging: true,
|
||||
filterMult: false,
|
||||
showTfoot: true
|
||||
});
|
||||
}
|
||||
|
||||
function zTreeOnClick(event, treeId, treeNode) {
|
||||
selectedId = treeNode.Id;
|
||||
loadDataGrid();
|
||||
}
|
||||
|
||||
function initZtree() {
|
||||
var setting = {
|
||||
view: { selectedMulti: false },
|
||||
data: {
|
||||
key: {
|
||||
name: 'Name',
|
||||
title: 'Name'
|
||||
},
|
||||
simpleData: {
|
||||
enable: true,
|
||||
idKey: 'Id',
|
||||
pIdKey: 'ParentId',
|
||||
rootPId: 'null'
|
||||
}
|
||||
},
|
||||
callback: { onClick: zTreeOnClick }
|
||||
};
|
||||
$.getJSON('OrgManager/LoadOrg', function (json) {
|
||||
var zTreeObj = $.fn.zTree.init($('#@_treeId'), setting, json);
|
||||
zTreeObj.expandAll(true);
|
||||
});
|
||||
}
|
||||
|
||||
//授权选中的
|
||||
function assign() {
|
||||
var selected = getSelectedMany('#@_gridId', 2);
|
||||
if (selected == null) return;
|
||||
|
||||
$.post('RoleManager/AccessRoles', {
|
||||
userId: $('#userId').val(),
|
||||
ids: selected
|
||||
},
|
||||
function (json) {
|
||||
// var rel = $.parseJSON(json);
|
||||
refreshGrid();
|
||||
});
|
||||
}
|
||||
|
||||
//@@ sourceURL=lookupMulti.js
|
||||
function refreshGrid() {
|
||||
$('#@_gridId').datagrid('refresh');
|
||||
// loadDataGrid();
|
||||
}
|
||||
//@@ sourceURL=RoleLookup.js
|
||||
</script>
|
@ -182,6 +182,8 @@
|
||||
id: 'accessUserRole',
|
||||
url: '/RoleManager/LookupMulti',
|
||||
title: '为用户分配角色',
|
||||
width: 600,
|
||||
height: 380,
|
||||
data: {
|
||||
userId: selected
|
||||
}
|
||||
|
@ -22,7 +22,8 @@ namespace OpenAuth.UnitTest
|
||||
var login = new LoginApp(new UserRepository(),
|
||||
new ModuleRepository(),
|
||||
new RelevanceRepository(),
|
||||
new BaseRepository<ModuleElement>()
|
||||
new BaseRepository<ModuleElement>(),
|
||||
new ResourceRepository()
|
||||
);
|
||||
var user = login.Login("admin", "admin");
|
||||
foreach (var module in user.Modules)
|
||||
|
Loading…
Reference in New Issue
Block a user