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
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: yubaolee
|
||||||
Description: Create a list of properties from a database table
|
Description: Create a list of properties from a database table
|
||||||
--%>
|
--%>
|
||||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="应用层" %>
|
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="应用层" %>
|
@ -1,6 +1,6 @@
|
|||||||
<%--
|
<%--
|
||||||
Name: Database Table Properties
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: yubaolee
|
||||||
Description: Create a list of properties from a database table
|
Description: Create a list of properties from a database table
|
||||||
--%>
|
--%>
|
||||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="控制器" %>
|
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="控制器" %>
|
@ -1,6 +1,6 @@
|
|||||||
<%--
|
<%--
|
||||||
Name: Database Table Properties
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: yubaolee
|
||||||
Description: Create a list of properties from a database table
|
Description: Create a list of properties from a database table
|
||||||
--%>
|
--%>
|
||||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="创建包含组织机构的接口" %>
|
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="False" Description="创建包含组织机构的接口" %>
|
@ -1,6 +1,6 @@
|
|||||||
<%--
|
<%--
|
||||||
Name: Database Table Properties
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: yubaolee
|
||||||
Description: Create a list of properties from a database table
|
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." %>
|
<%@ 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
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: yubaolee
|
||||||
Description: Create a list of properties from a database table
|
Description: 没有树状导航的datagrid
|
||||||
--%>
|
--%>
|
||||||
<%@ CodeTemplate Language="C#" Encoding="utf-8" TargetLanguage="C#" Debug="True" Description="Create a list of properties from database table." %>
|
<%@ 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." %>
|
<%@ 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");}
|
@{ Html.RenderAction("MenuHeader", "Home");}
|
||||||
<div class="bjui-pageContent tableContent">
|
<div class="bjui-pageContent tableContent">
|
||||||
<div class="clearfix">
|
<div class="clearfix">
|
||||||
<div style="float: left; width: 220px; overflow: auto;" class="table table-bordered">
|
<div id="@_treeDetail" style="margin-left: 225px;">
|
||||||
<ul id="@_treeId" class="ztree"></ul>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="@_treeDetail" style="margin-left: 225px;">
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
var selectedId = 0;
|
|
||||||
$(document).ready(function () {
|
$(document).ready(function () {
|
||||||
initZtree();
|
|
||||||
loadDataGrid();
|
loadDataGrid();
|
||||||
});
|
});
|
||||||
//加载数据到datagrid
|
//加载数据到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%>() {
|
function del<%=ModuleName%>() {
|
||||||
var selected = getSelected('#@_gridId',2);
|
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>
|
|
@ -14,17 +14,20 @@ namespace OpenAuth.App
|
|||||||
private IUserRepository _repository;
|
private IUserRepository _repository;
|
||||||
private IModuleRepository _moduleRepository;
|
private IModuleRepository _moduleRepository;
|
||||||
private IRelevanceRepository _relevanceRepository;
|
private IRelevanceRepository _relevanceRepository;
|
||||||
private IRepository<ModuleElement> _moduleElementRepository;
|
private IRepository<ModuleElement> _moduleElementRepository;
|
||||||
|
private IResourceRepository _resourceRepository;
|
||||||
|
|
||||||
public LoginApp(IUserRepository repository,
|
public LoginApp(IUserRepository repository,
|
||||||
IModuleRepository moduleRepository,
|
IModuleRepository moduleRepository,
|
||||||
IRelevanceRepository relevanceRepository,
|
IRelevanceRepository relevanceRepository,
|
||||||
IRepository<ModuleElement> moduleElementRepository )
|
IRepository<ModuleElement> moduleElementRepository,
|
||||||
|
IResourceRepository resourceRepository)
|
||||||
{
|
{
|
||||||
_repository = repository;
|
_repository = repository;
|
||||||
_moduleRepository = moduleRepository;
|
_moduleRepository = moduleRepository;
|
||||||
_relevanceRepository = relevanceRepository;
|
_relevanceRepository = relevanceRepository;
|
||||||
_moduleElementRepository = moduleElementRepository;
|
_moduleElementRepository = moduleElementRepository;
|
||||||
|
_resourceRepository = resourceRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
public LoginUserVM Login(string userName, string password)
|
public LoginUserVM Login(string userName, string password)
|
||||||
@ -64,8 +67,15 @@ namespace OpenAuth.App
|
|||||||
{
|
{
|
||||||
module.Elements = _moduleElementRepository.Find(u => u.ModuleId == module.Id && elementIds.Contains( u.Id)).ToList();
|
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>
|
/// <summary>
|
||||||
@ -86,6 +96,8 @@ namespace OpenAuth.App
|
|||||||
{
|
{
|
||||||
module.Elements = _moduleElementRepository.Find(u => u.ModuleId == module.Id).ToList();
|
module.Elements = _moduleElementRepository.Find(u => u.ModuleId == module.Id).ToList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
loginUser.Resources = _resourceRepository.Find(null).ToList();
|
||||||
return loginUser;
|
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>();
|
var rolevms = new List<RoleVM>();
|
||||||
foreach (var role in roleIds)
|
foreach (var role in roleIds)
|
||||||
{
|
{
|
||||||
|
@ -27,6 +27,14 @@ namespace OpenAuth.App.ViewModel
|
|||||||
/// 用户可以访问到的模块(包括所属角色与自己的所有模块)
|
/// 用户可以访问到的模块(包括所属角色与自己的所有模块)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public List<ModuleView> Modules { get; set; }
|
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 为用户设置角色界面
|
#region 为用户设置角色界面
|
||||||
public ActionResult LookUpMulti(int userId)
|
|
||||||
|
public ActionResult LookupMulti(int userId)
|
||||||
{
|
{
|
||||||
ViewBag.UserId = 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)
|
public string AccessRoles(int userId, string ids)
|
||||||
@ -83,6 +89,7 @@ namespace OpenAuth.Mvc.Controllers
|
|||||||
_app.AccessRole(userId, roleids);
|
_app.AccessRole(userId, roleids);
|
||||||
return JsonHelper.Instance.Serialize(BjuiResponse);
|
return JsonHelper.Instance.Serialize(BjuiResponse);
|
||||||
}
|
}
|
||||||
#endregion
|
|
||||||
|
#endregion 为用户设置角色界面
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -574,6 +574,7 @@
|
|||||||
<Content Include="Views\Home\Index.cshtml" />
|
<Content Include="Views\Home\Index.cshtml" />
|
||||||
<Content Include="Views\ResourceManager\Add.cshtml" />
|
<Content Include="Views\ResourceManager\Add.cshtml" />
|
||||||
<Content Include="Views\ResourceManager\Index.cshtml" />
|
<Content Include="Views\ResourceManager\Index.cshtml" />
|
||||||
|
<Content Include="Views\RoleManager\LookupMulti.cshtml" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Folder Include="App_Data\" />
|
<Folder Include="App_Data\" />
|
||||||
@ -640,7 +641,6 @@
|
|||||||
<Content Include="Views\UserManager\Add.cshtml" />
|
<Content Include="Views\UserManager\Add.cshtml" />
|
||||||
<Content Include="Views\RoleManager\Add.cshtml" />
|
<Content Include="Views\RoleManager\Add.cshtml" />
|
||||||
<Content Include="Views\RoleManager\Index.cshtml" />
|
<Content Include="Views\RoleManager\Index.cshtml" />
|
||||||
<Content Include="Views\RoleManager\LookupMulti.cshtml" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">10.0</VisualStudioVersion>
|
<VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">10.0</VisualStudioVersion>
|
||||||
|
@ -1,77 +1,126 @@
|
|||||||
@model List<OpenAuth.App.ViewModel.RoleVM>
|
@{
|
||||||
@{
|
string _prefix = "assignRoleForUser";
|
||||||
ViewBag.Title = "title";
|
var _treeId = _prefix + "Tree";
|
||||||
Layout = null;
|
var _gridId = _prefix + "Grid";
|
||||||
|
var _treeDetail = _prefix + "Detail";
|
||||||
}
|
}
|
||||||
@*<div class="bjui-pageHeader">
|
<div class="bjui-pageHeader">
|
||||||
<div class="bjui-searchBar">
|
<div class="bjui-searchBar">
|
||||||
<label>名称:</label><input type="text" value="" name="code" size="10" />
|
<input style="display: none" id="userId" value="@ViewBag.UserId" />
|
||||||
<button type="submit" class="btn-default" data-icon="search">查询</button>
|
<div class="pull-right">
|
||||||
<a class="btn btn-orange" href="javascript:;" data-toggle="reloadsearch" data-clear-query="true" data-icon="undo">清空查询</a>
|
<div class="alert alert-info search-inline">
|
||||||
<div class="pull-right">
|
<i class="fa fa-info-circle"></i> 点击行为单选,点击复选框可多选统一授权
|
||||||
<input type="checkbox" name="lookupType" value="1" data-toggle="icheck" data-label="追加" checked>
|
</div>
|
||||||
<button type="button" class="btn-blue" data-toggle="lookupback" data-lookupid="ids" data-warn="请至少选择一项职业" data-icon="check-square-o">选择选中</button>
|
<button type="button" class="btn-green" data-num="1" data-icon="plus" onclick="assign()">
|
||||||
</div>
|
授权选中项目
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</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>
|
<div class="bjui-pageContent tableContent">
|
||||||
<li><button type="button" class="btn-close" data-icon="close">关闭</button></li>
|
<div class="clearfix">
|
||||||
<li>
|
<div style="float: left; width: 220px; overflow: auto;" class="table table-bordered">
|
||||||
<button type="button" class="btn-blue"
|
<ul id="@_treeId" class="ztree"></ul>
|
||||||
data-url="RoleManager/AccessRoles?userid={#userId}&ids={#bjui-selected}"
|
</div>
|
||||||
data-toggle="doajax" data-icon="check-square-o">
|
|
||||||
设置权限
|
<div id="@_treeDetail" style="margin-left: 225px;">
|
||||||
</button>
|
</div>
|
||||||
</li>
|
</div>
|
||||||
</ul>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
var moduleIds;
|
var selectedId = 0;
|
||||||
$(document).ready(function () {
|
$(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() {
|
$('#@_gridId').datagrid({
|
||||||
$.post('UserManager/AccessModule', { userId: $('#userId').val(), moduleIds: moduleIds },
|
showToolbar: false,
|
||||||
function (json) {
|
filterThead: false,
|
||||||
var rel = $.parseJSON(json);
|
columns: [
|
||||||
if (rel.statusCode == "200") {
|
{
|
||||||
$(this).alertmsg('ok', rel.message);
|
name: 'Id',
|
||||||
} else {
|
label: '角色ID',
|
||||||
$(this).alertmsg('error', rel.message);
|
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>
|
</script>
|
@ -182,6 +182,8 @@
|
|||||||
id: 'accessUserRole',
|
id: 'accessUserRole',
|
||||||
url: '/RoleManager/LookupMulti',
|
url: '/RoleManager/LookupMulti',
|
||||||
title: '为用户分配角色',
|
title: '为用户分配角色',
|
||||||
|
width: 600,
|
||||||
|
height: 380,
|
||||||
data: {
|
data: {
|
||||||
userId: selected
|
userId: selected
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,8 @@ namespace OpenAuth.UnitTest
|
|||||||
var login = new LoginApp(new UserRepository(),
|
var login = new LoginApp(new UserRepository(),
|
||||||
new ModuleRepository(),
|
new ModuleRepository(),
|
||||||
new RelevanceRepository(),
|
new RelevanceRepository(),
|
||||||
new BaseRepository<ModuleElement>()
|
new BaseRepository<ModuleElement>(),
|
||||||
|
new ResourceRepository()
|
||||||
);
|
);
|
||||||
var user = login.Login("admin", "admin");
|
var user = login.Login("admin", "admin");
|
||||||
foreach (var module in user.Modules)
|
foreach (var module in user.Modules)
|
||||||
|
Loading…
Reference in New Issue
Block a user