mirror of
https://gitee.com/dotnetchina/OpenAuth.Net.git
synced 2025-07-16 16:50:54 +08:00
添加Category
This commit is contained in:
parent
999046f887
commit
f79e5c08fa
@ -1,148 +1,145 @@
|
|||||||
<%--
|
<%--
|
||||||
Name: Database Table Properties
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: Paul Welter
|
||||||
Description: Create a list of properties from a database table
|
Description: Create a list of properties from a database table
|
||||||
--%>
|
--%>
|
||||||
<%@ CodeTemplate Language="C#" TargetLanguage="C#" Debug="False" Encoding="utf-8" Description="添加模块" %>
|
<%@ CodeTemplate Language="C#" TargetLanguage="C#" Debug="False" Encoding="utf-8" Description="添加模块" %>
|
||||||
<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="Context"
|
<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="Context"
|
||||||
Description="连接的数据库" %>
|
Description="连接的数据库" %>
|
||||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||||
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
||||||
<%@ Property Name="CascadeId" Type="String" Category="" Default="ParentId" Description="级联字段" %>
|
<%@ Property Name="CascadeId" Type="String" Category="" Default="ParentId" Description="级联字段" %>
|
||||||
<%@ Property Name="CascadeName" Type="String" Category="" Default="ParentName" Description="级联显示的文字" %>
|
<%@ Property Name="CascadeName" Type="String" Category="" Default="ParentName" Description="级联显示的文字" %>
|
||||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||||
<%@ Assembly Name="SchemaExplorer" %>
|
<%@ Assembly Name="SchemaExplorer" %>
|
||||||
<%@ Import Namespace="SchemaExplorer" %>
|
<%@ Import Namespace="SchemaExplorer" %>
|
||||||
<script runat="template">
|
<script runat="template">
|
||||||
public String GetModelName()
|
public String GetModelName()
|
||||||
{
|
{
|
||||||
if(NeedViewModel)
|
if(NeedViewModel)
|
||||||
return ModuleName +"View";
|
return ModuleName +"View";
|
||||||
else
|
else
|
||||||
return ModuleName;
|
return ModuleName;
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
<%if(NeedViewModel){ %>
|
<%if(NeedViewModel){ %>
|
||||||
@model OpenAuth.App.ViewModel.<%=GetModelName()%>
|
@model OpenAuth.App.ViewModel.<%=GetModelName()%>
|
||||||
<%} else{ %>
|
<%} else{ %>
|
||||||
@model OpenAuth.Domain.<%=GetModelName()%>
|
@model OpenAuth.Domain.<%=GetModelName()%>
|
||||||
<%} %>
|
<%} %>
|
||||||
@{
|
@{
|
||||||
ViewBag.Title = "<%=GetModelName()%>编辑界面";
|
ViewBag.Title = "<%=GetModelName()%>编辑界面";
|
||||||
Layout = null;
|
Layout = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
<div class="bjui-pageContent">
|
<div class="bjui-pageContent">
|
||||||
<form action="/<%=ModuleName%>Manager/Add" class="pageForm" data-toggle="validate">
|
<form action="/<%=ModuleName%>Manager/Add" class="pageForm" data-toggle="validate">
|
||||||
<table class="table table-condensed table-hover">
|
<table class="table table-condensed table-hover">
|
||||||
<tbody>
|
<tbody>
|
||||||
<tr>
|
<% foreach (ColumnSchema column in this.SourceTable.Columns) {
|
||||||
<td align="center"><h3>* 添加</h3></td>
|
if(column.Name == CascadeName) continue;
|
||||||
</tr>
|
%>
|
||||||
<% foreach (ColumnSchema column in this.SourceTable.Columns) {
|
<tr>
|
||||||
if(column.Name == CascadeName) continue;
|
<td>
|
||||||
%>
|
<%if(column.IsPrimaryKeyMember){ %>
|
||||||
<tr>
|
@Html.HiddenFor(m =>m.Id)
|
||||||
<td>
|
<% } else if(column.Name == CascadeId) {%>
|
||||||
<%if(column.IsPrimaryKeyMember){ %>
|
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||||
@Html.HiddenFor(m =>m.Id)
|
<input id="<%=column.Name%>" name="<%=column.Name%>" value="" style="display: none"/>
|
||||||
<% } else if(column.Name == CascadeId) {%>
|
<input type="text" name="<%=CascadeName%>" id="<%=CascadeName%>"
|
||||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
data-toggle="selectztree" size="20" data-tree="#j_select_tree1" value="@Model.<%=CascadeName%>">
|
||||||
<input id="<%=column.Name%>" name="<%=column.Name%>" value="" style="display: none"/>
|
<ul id="j_select_tree1" class="ztree hide" data-toggle="ztree"></ul>
|
||||||
<input type="text" name="<%=CascadeName%>" id="<%=CascadeName%>"
|
|
||||||
data-toggle="selectztree" size="20" data-tree="#j_select_tree1" value="@Model.<%=CascadeName%>">
|
<% } else if(CSharpAlias[column.SystemType.FullName] == "bool") {%>
|
||||||
<ul id="j_select_tree1" class="ztree hide" data-toggle="ztree"></ul>
|
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||||
|
|
||||||
<% } else if(CSharpAlias[column.SystemType.FullName] == "bool") {%>
|
<select name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
||||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
<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 name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
</select>
|
||||||
<option value="0" @if (Model.<%=column.Name%>) { <text> selected="selected" </text> }>否</option>
|
<%} else if(CSharpAlias[column.SystemType.FullName] == "int") {%>
|
||||||
<option value="1" @if (!Model.<%=column.Name%>) { <text> selected="selected" </text> }>是</option>
|
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
||||||
</select>
|
<select name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
||||||
<%} else if(CSharpAlias[column.SystemType.FullName] == "int") {%>
|
<option value="0" @if (Model.<%=column.Name%> == 0) { <text> selected="selected" </text> }>默认</option>
|
||||||
<label for="<%=column.Name%>" class="control-label x85"><%=column.Description%>:</label>
|
<option value="1" @if (Model.<%=column.Name%> == 1) { <text> selected="selected" </text> }>状态1</option>
|
||||||
<select name="<%=column.Name%>" id="<%=column.Name%>" data-toggle="selectpicker" data-rule="required">
|
</select>
|
||||||
<option value="0" @if (Model.<%=column.Name%> == 0) { <text> selected="selected" </text> }>默认</option>
|
<%} else{%>
|
||||||
<option value="1" @if (Model.<%=column.Name%> == 1) { <text> selected="selected" </text> }>状态1</option>
|
<label for="<%=column.Name%>" class="control-label x90"><%=column.Description%>:</label>
|
||||||
</select>
|
<input type="text" name="<%=column.Name%>" id="<%=column.Name%>" value="@Model.<%=column.Name%>"
|
||||||
<%} else{%>
|
data-rule="required" size="20">
|
||||||
<label for="<%=column.Name%>" class="control-label x90"><%=column.Description%>:</label>
|
<%} %>
|
||||||
<input type="text" name="<%=column.Name%>" id="<%=column.Name%>" value="@Model.<%=column.Name%>"
|
</td>
|
||||||
data-rule="required" size="20">
|
</tr>
|
||||||
<%} %>
|
<% } %>
|
||||||
</td>
|
</tbody>
|
||||||
</tr>
|
</table>
|
||||||
<% } %>
|
</form>
|
||||||
</tbody>
|
</div>
|
||||||
</table>
|
<div class="bjui-pageFooter">
|
||||||
</form>
|
<ul>
|
||||||
</div>
|
<li><button type="button" class="btn-close">关闭</button></li>
|
||||||
<div class="bjui-pageFooter">
|
<li><button type="submit" class="btn-green">保存</button></li>
|
||||||
<ul>
|
</ul>
|
||||||
<li><button type="button" class="btn-close">关闭</button></li>
|
</div>
|
||||||
<li><button type="submit" class="btn-green">保存</button></li>
|
|
||||||
</ul>
|
<script type="text/javascript">
|
||||||
</div>
|
$(document).ready(function () {
|
||||||
|
Init();
|
||||||
<script type="text/javascript">
|
});
|
||||||
$(document).ready(function () {
|
function Init() {
|
||||||
Init();
|
var setting = {
|
||||||
});
|
view: {
|
||||||
function Init() {
|
selectedMulti: false
|
||||||
var setting = {
|
},
|
||||||
view: {
|
check: {
|
||||||
selectedMulti: false
|
enable: true,
|
||||||
},
|
chkStyle: "checkbox",
|
||||||
check: {
|
chkboxType: { "Y": "", "N": "" } //去掉勾选时级联
|
||||||
enable: true,
|
},
|
||||||
chkStyle: "checkbox",
|
data: {
|
||||||
chkboxType: { "Y": "", "N": "" } //去掉勾选时级联
|
key: {
|
||||||
},
|
name: 'Name',
|
||||||
data: {
|
title: 'Name'
|
||||||
key: {
|
},
|
||||||
name: 'Name',
|
simpleData: {
|
||||||
title: 'Name'
|
enable: true,
|
||||||
},
|
idKey: 'Id',
|
||||||
simpleData: {
|
pIdKey: 'ParentId',
|
||||||
enable: true,
|
rootPId: 'null'
|
||||||
idKey: 'Id',
|
}
|
||||||
pIdKey: 'ParentId',
|
},
|
||||||
rootPId: 'null'
|
callback: {
|
||||||
}
|
onClick: zTreeOnClick,
|
||||||
},
|
onCheck: zTreeCheck
|
||||||
callback: {
|
}
|
||||||
onClick: zTreeOnClick,
|
};
|
||||||
onCheck: zTreeCheck
|
$.getJSON('OrgManager/LoadOrg', function (json) {
|
||||||
}
|
var zTreeObj = $.fn.zTree.init($('#j_select_tree1'), setting, json);
|
||||||
};
|
zTreeObj.expandAll(true);
|
||||||
$.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);
|
||||||
function zTreeCheck(e, treeId, treeNode) {
|
var ids = '', names = '';
|
||||||
var zTree = $.fn.zTree.getZTreeObj(treeId),
|
for (var i = 0; i < nodes.length; i++) {
|
||||||
nodes = zTree.getCheckedNodes(true);
|
ids += ',' + nodes[i].Id;
|
||||||
var ids = '', names = '';
|
names += ',' + nodes[i].Name;
|
||||||
for (var i = 0; i < nodes.length; i++) {
|
}
|
||||||
ids += ',' + nodes[i].Id;
|
if (ids.length > 0) { //去掉第一个逗号
|
||||||
names += ',' + nodes[i].Name;
|
ids = ids.substr(1);
|
||||||
}
|
names = names.substr(1);
|
||||||
if (ids.length > 0) { //去掉第一个逗号
|
}
|
||||||
ids = ids.substr(1);
|
|
||||||
names = names.substr(1);
|
var $from = $('#' + treeId).data('fromObj');
|
||||||
}
|
if ($from && $from.length) $from.val(names);
|
||||||
|
|
||||||
var $from = $('#' + treeId).data('fromObj');
|
$('#<%=CascadeId%>').val(ids);
|
||||||
if ($from && $from.length) $from.val(names);
|
}
|
||||||
|
function zTreeOnClick(event, treeId, treeNode) {
|
||||||
$('#<%=CascadeId%>').val(ids);
|
var zTree = $.fn.zTree.getZTreeObj(treeId);
|
||||||
}
|
zTree.checkNode(treeNode, !treeNode.checked, true, true);
|
||||||
function zTreeOnClick(event, treeId, treeNode) {
|
event.preventDefault();
|
||||||
var zTree = $.fn.zTree.getZTreeObj(treeId);
|
}
|
||||||
zTree.checkNode(treeNode, !treeNode.checked, true, true);
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
</script>
|
</script>
|
@ -1,131 +1,131 @@
|
|||||||
<%--
|
<%--
|
||||||
Name: Database Table Properties
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: Paul Welter
|
||||||
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="应用层" %>
|
||||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||||
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
||||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||||
<%@ Assembly Name="SchemaExplorer" %>
|
<%@ Assembly Name="SchemaExplorer" %>
|
||||||
<%@ Import Namespace="SchemaExplorer" %>
|
<%@ Import Namespace="SchemaExplorer" %>
|
||||||
<script runat="template">
|
<script runat="template">
|
||||||
public String GetModelName()
|
public String GetModelName()
|
||||||
{
|
{
|
||||||
if(NeedViewModel)
|
if(NeedViewModel)
|
||||||
return ModuleName +"View";
|
return ModuleName +"View";
|
||||||
else
|
else
|
||||||
return ModuleName;
|
return ModuleName;
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<%if(NeedViewModel){ %>
|
<%if(NeedViewModel){ %>
|
||||||
using OpenAuth.App.ViewModel;
|
using OpenAuth.App.ViewModel;
|
||||||
<%} %>
|
<%} %>
|
||||||
using OpenAuth.Domain;
|
using OpenAuth.Domain;
|
||||||
using OpenAuth.Domain.Interface;
|
using OpenAuth.Domain.Interface;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
|
||||||
namespace OpenAuth.App
|
namespace OpenAuth.App
|
||||||
{
|
{
|
||||||
public class <%=ModuleName%>ManagerApp
|
public class <%=ModuleName%>ManagerApp
|
||||||
{
|
{
|
||||||
private I<%=ModuleName%>Repository _repository;
|
private I<%=ModuleName%>Repository _repository;
|
||||||
private IOrgRepository _orgRepository;
|
private IOrgRepository _orgRepository;
|
||||||
|
|
||||||
public <%=ModuleName%>ManagerApp(I<%=ModuleName%>Repository repository,
|
public <%=ModuleName%>ManagerApp(I<%=ModuleName%>Repository repository,
|
||||||
IOrgRepository orgRepository)
|
IOrgRepository orgRepository)
|
||||||
{
|
{
|
||||||
_repository = repository;
|
_repository = repository;
|
||||||
_orgRepository = orgRepository;
|
_orgRepository = orgRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int Get<%=GetModelName()%>CntInOrg(int orgId)
|
public int Get<%=GetModelName()%>CntInOrg(int orgId)
|
||||||
{
|
{
|
||||||
if (orgId == 0)
|
if (orgId == 0)
|
||||||
{
|
{
|
||||||
return _repository.Find(null).Count();
|
return _repository.Find(null).Count();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return _repository.Get<%=GetModelName()%>CntInOrgs(GetSubOrgIds(orgId));
|
return _repository.Get<%=GetModelName()%>CntInOrgs(GetSubOrgIds(orgId));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 加载一个部门及子部门全部<%=GetModelName()%>s
|
/// 加载一个部门及子部门全部<%=GetModelName()%>s
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public dynamic Load(int orgId, int pageindex, int pagesize)
|
public dynamic Load(int orgId, int pageindex, int pagesize)
|
||||||
{
|
{
|
||||||
IEnumerable<<%=ModuleName%>> <%=ModuleName%>s;
|
IEnumerable<<%=ModuleName%>> <%=ModuleName%>s;
|
||||||
int total = 0;
|
int total = 0;
|
||||||
if (orgId == 0)
|
if (orgId == 0)
|
||||||
{
|
{
|
||||||
<%=ModuleName%>s = _repository.Load<%=ModuleName%>s(pageindex, pagesize);
|
<%=ModuleName%>s = _repository.Load<%=ModuleName%>s(pageindex, pagesize);
|
||||||
total = _repository.GetCount();
|
total = _repository.GetCount();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
<%=ModuleName%>s = _repository.LoadInOrgs(pageindex, pagesize,GetSubOrgIds(orgId));
|
<%=ModuleName%>s = _repository.LoadInOrgs(pageindex, pagesize,GetSubOrgIds(orgId));
|
||||||
total = _repository.Get<%=ModuleName%>CntInOrgs(orgId);
|
total = _repository.Get<%=ModuleName%>CntInOrgs(orgId);
|
||||||
}
|
}
|
||||||
<%if(NeedViewModel){ %>
|
<%if(NeedViewModel){ %>
|
||||||
var <%=ModuleName%>views = new List<<%=ModuleName%>View>();
|
var <%=ModuleName%>views = new List<<%=ModuleName%>View>();
|
||||||
foreach (var <%=ModuleName%> in <%=ModuleName%>s)
|
foreach (var <%=ModuleName%> in <%=ModuleName%>s)
|
||||||
{
|
{
|
||||||
<%=ModuleName%>View uv = <%=ModuleName%>;
|
<%=ModuleName%>View uv = <%=ModuleName%>;
|
||||||
uv.Organizations = string.Join(",", _orgRepository.LoadBy<%=ModuleName%>(<%=ModuleName%>.Id).Select(u => u.Name).ToList());
|
uv.Organizations = string.Join(",", _orgRepository.LoadBy<%=ModuleName%>(<%=ModuleName%>.Id).Select(u => u.Name).ToList());
|
||||||
<%=ModuleName%>views.Add(uv);
|
<%=ModuleName%>views.Add(uv);
|
||||||
}
|
}
|
||||||
<%} %>
|
<%} %>
|
||||||
|
|
||||||
return new
|
return new
|
||||||
{
|
{
|
||||||
total = total,
|
total = total,
|
||||||
list = <%=GetModelName()%>s,
|
list = <%=GetModelName()%>s,
|
||||||
pageCurrent = pageindex
|
pageCurrent = pageindex
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 获取当前组织的所有下级组织
|
/// 获取当前组织的所有下级组织
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private int[] GetSubOrgIds(int orgId)
|
private int[] GetSubOrgIds(int orgId)
|
||||||
{
|
{
|
||||||
var org = _orgRepository.FindSingle(u => u.Id == orgId);
|
var org = _orgRepository.FindSingle(u => u.Id == orgId);
|
||||||
var orgs = _orgRepository.Find(u => u.CascadeId.Contains(org.CascadeId)).Select(u => u.Id).ToArray();
|
var orgs = _orgRepository.Find(u => u.CascadeId.Contains(org.CascadeId)).Select(u => u.Id).ToArray();
|
||||||
return orgs;
|
return orgs;
|
||||||
}
|
}
|
||||||
|
|
||||||
public <%=GetModelName()%> Find(int id)
|
public <%=GetModelName()%> Find(int id)
|
||||||
{
|
{
|
||||||
var <%=ModuleName.ToLower()%> = _repository.FindSingle(u => u.Id == id);
|
var <%=ModuleName.ToLower()%> = _repository.FindSingle(u => u.Id == id);
|
||||||
if (<%=ModuleName.ToLower()%> == null) return new <%=GetModelName()%>();
|
if (<%=ModuleName.ToLower()%> == null) return new <%=GetModelName()%>();
|
||||||
|
|
||||||
return <%=ModuleName.ToLower() %>;
|
return <%=ModuleName.ToLower() %>;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Delete(int id)
|
public void Delete(int id)
|
||||||
{
|
{
|
||||||
_repository.Delete(id);
|
_repository.Delete(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void AddOrUpdate(<%=GetModelName()%> model)
|
public void AddOrUpdate(<%=GetModelName()%> model)
|
||||||
{
|
{
|
||||||
<%=ModuleName%> <%=ModuleName.ToLower()%> = model;
|
<%=ModuleName%> <%=ModuleName.ToLower()%> = model;
|
||||||
if (<%=ModuleName.ToLower()%>.Id == 0)
|
if (<%=ModuleName.ToLower()%>.Id == 0)
|
||||||
{
|
{
|
||||||
_repository.Add(<%=ModuleName.ToLower()%>);
|
_repository.Add(<%=ModuleName.ToLower()%>);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_repository.Update(<%=ModuleName.ToLower()%>);
|
_repository.Update(<%=ModuleName.ToLower()%>);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,102 +1,95 @@
|
|||||||
<%--
|
<%--
|
||||||
Name: Database Table Properties
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: Paul Welter
|
||||||
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="控制器" %>
|
||||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||||
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
<%@ Property Name="NeedViewModel" Type="Boolean" Category="Context" Default="False" Description="是否需要ViewModel" %>
|
||||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||||
<%@ Assembly Name="SchemaExplorer" %>
|
<%@ Assembly Name="SchemaExplorer" %>
|
||||||
<%@ Import Namespace="SchemaExplorer" %>
|
<%@ Import Namespace="SchemaExplorer" %>
|
||||||
<script runat="template">
|
<script runat="template">
|
||||||
public String GetModelName()
|
public String GetModelName()
|
||||||
{
|
{
|
||||||
if(NeedViewModel)
|
if(NeedViewModel)
|
||||||
return ModuleName +"View";
|
return ModuleName +"View";
|
||||||
else
|
else
|
||||||
return ModuleName;
|
return ModuleName;
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Web.Mvc;
|
using System.Web.Mvc;
|
||||||
using Infrastructure;
|
using Infrastructure;
|
||||||
using OpenAuth.App;
|
using OpenAuth.App;
|
||||||
<%if(NeedViewModel){ %>
|
<%if(NeedViewModel){ %>
|
||||||
using OpenAuth.App.ViewModel;
|
using OpenAuth.App.ViewModel;
|
||||||
<%} %>
|
<%} %>
|
||||||
|
|
||||||
namespace OpenAuth.Mvc.Controllers
|
namespace OpenAuth.Mvc.Controllers
|
||||||
{
|
{
|
||||||
public class <%=ModuleName%>ManagerController : BaseController
|
public class <%=ModuleName%>ManagerController : BaseController
|
||||||
{
|
{
|
||||||
private <%=ModuleName%>ManagerApp _app;
|
private <%=ModuleName%>ManagerApp _app;
|
||||||
|
|
||||||
public <%=ModuleName%>ManagerController()
|
public <%=ModuleName%>ManagerController()
|
||||||
{
|
{
|
||||||
_app = (<%=ModuleName%>ManagerApp)DependencyResolver.Current.GetService(typeof(<%=ModuleName%>ManagerApp));
|
_app = (<%=ModuleName%>ManagerApp)DependencyResolver.Current.GetService(typeof(<%=ModuleName%>ManagerApp));
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// GET: /<%=ModuleName%>Manager/
|
// GET: /UserManager/
|
||||||
public ActionResult Index()
|
public ActionResult Index()
|
||||||
{
|
{
|
||||||
return View();
|
return View();
|
||||||
}
|
}
|
||||||
|
|
||||||
public ActionResult Add(int id = 0)
|
public ActionResult Add(int id = 0)
|
||||||
{
|
{
|
||||||
return View(_app.Find(id));
|
return View(_app.Find(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
//添加或修改组织
|
//添加或修改<%=ModuleName %>
|
||||||
[HttpPost]
|
[HttpPost]
|
||||||
public string Add(<%=GetModelName()%> model)
|
public string Add(<%=GetModelName()%> model)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_app.AddOrUpdate(model);
|
_app.AddOrUpdate(model);
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
BjuiResponse.statusCode = "300";
|
BjuiResponse.statusCode = "300";
|
||||||
BjuiResponse.message = ex.Message;
|
BjuiResponse.message = ex.Message;
|
||||||
}
|
}
|
||||||
return JsonHelper.Instance.Serialize(BjuiResponse);
|
return JsonHelper.Instance.Serialize(BjuiResponse);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 加载组织下面的所有用户
|
/// 加载组织下面的所有用户
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public string Load(int orgId, int pageCurrent = 1, int pageSize = 30)
|
public string Load(int orgId, int pageCurrent = 1, int pageSize = 30)
|
||||||
{
|
{
|
||||||
return JsonHelper.Instance.Serialize(_app.Load(orgId, pageCurrent, pageSize));
|
return JsonHelper.Instance.Serialize(_app.Load(orgId, pageCurrent, pageSize));
|
||||||
}
|
}
|
||||||
|
|
||||||
//获取组织下面用户个数
|
public string Delete(int Id)
|
||||||
public int GetCount(int orgId)
|
{
|
||||||
{
|
try
|
||||||
return _app.Get<%=GetModelName()%>CntInOrg(orgId);
|
{
|
||||||
}
|
_app.Delete(Id);
|
||||||
|
}
|
||||||
public string Delete(string Id)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
try
|
BjuiResponse.statusCode = "300";
|
||||||
{
|
BjuiResponse.message = e.Message;
|
||||||
foreach (var obj in Id.Split(','))
|
}
|
||||||
{
|
|
||||||
_app.Delete(int.Parse(obj));
|
return JsonHelper.Instance.Serialize(BjuiResponse);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
}
|
||||||
BjuiResponse.statusCode = "300";
|
|
||||||
BjuiResponse.message = e.Message;
|
|
||||||
}
|
|
||||||
|
|
||||||
return JsonHelper.Instance.Serialize(BjuiResponse);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -1,28 +1,28 @@
|
|||||||
<%--
|
<%--
|
||||||
Name: Database Table Properties
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: Paul Welter
|
||||||
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="创建包含组织机构的接口" %>
|
||||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||||
<%@ Assembly Name="SchemaExplorer" %>
|
<%@ Assembly Name="SchemaExplorer" %>
|
||||||
<%@ Import Namespace="SchemaExplorer" %>
|
<%@ Import Namespace="SchemaExplorer" %>
|
||||||
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
|
||||||
namespace OpenAuth.Domain.Interface
|
namespace OpenAuth.Domain.Interface
|
||||||
{
|
{
|
||||||
public interface I<%=ModuleName%>Repository :IRepository<<%=ModuleName%>>
|
public interface I<%=ModuleName%>Repository :IRepository<<%=ModuleName%>>
|
||||||
{
|
{
|
||||||
IEnumerable<<%=ModuleName%>> Load<%=ModuleName%>s(int pageindex, int pagesize);
|
IEnumerable<<%=ModuleName%>> Load<%=ModuleName%>s(int pageindex, int pagesize);
|
||||||
|
|
||||||
IEnumerable<<%=ModuleName%>> LoadInOrgs(params int[] orgId);
|
IEnumerable<<%=ModuleName%>> LoadInOrgs(params int[] orgId);
|
||||||
int Get<%=ModuleName%>CntInOrgs(params int[] orgIds);
|
int Get<%=ModuleName%>CntInOrgs(params int[] orgIds);
|
||||||
IEnumerable<<%=ModuleName%>> LoadInOrgs(int pageindex, int pagesize, params int[] orgIds);
|
IEnumerable<<%=ModuleName%>> LoadInOrgs(int pageindex, int pagesize, params int[] orgIds);
|
||||||
|
|
||||||
void Delete(int id);
|
void Delete(int id);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,170 +1,148 @@
|
|||||||
<%--
|
<%--
|
||||||
Name: Database Table Properties
|
Name: Database Table Properties
|
||||||
Author: Paul Welter
|
Author: Paul Welter
|
||||||
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." %>
|
||||||
<%@ 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." %>
|
||||||
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
<%@ Property Name="ModuleName" Type="String" Category="Context" Description="模块名称" %>
|
||||||
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
<%@ Map Name="CSharpAlias" Src="System-CSharpAlias" Description="System to C# Type Map" %>
|
||||||
<%@ Assembly Name="SchemaExplorer" %>
|
<%@ Assembly Name="SchemaExplorer" %>
|
||||||
<%@ Import Namespace="SchemaExplorer" %>
|
<%@ Import Namespace="SchemaExplorer" %>
|
||||||
|
|
||||||
@{
|
@{
|
||||||
string _prefix = "<%=ModuleName%>";
|
string _prefix = "<%=ModuleName%>";
|
||||||
var _treeId = _prefix + "Tree";
|
var _treeId = _prefix + "Tree";
|
||||||
var _gridId = _prefix + "Grid";
|
var _gridId = _prefix + "Grid";
|
||||||
var _treeDetail = _prefix + "Detail";
|
var _treeDetail = _prefix + "Detail";
|
||||||
}
|
}
|
||||||
<div class="bjui-pageContent">
|
|
||||||
<div class="clearfix">
|
@{ Html.RenderAction("MenuHeader", "Home");}
|
||||||
<div style="float: left; width: 220px; overflow: auto;" class="table table-bordered">
|
<div class="bjui-pageContent tableContent">
|
||||||
<ul id="@_treeId" class="ztree"></ul>
|
<div class="clearfix">
|
||||||
</div>
|
<div style="float: left; width: 220px; overflow: auto;" class="table table-bordered">
|
||||||
|
<ul id="@_treeId" class="ztree"></ul>
|
||||||
<div id="@_treeDetail" style="margin-left: 225px;">
|
</div>
|
||||||
</div>
|
|
||||||
</div>
|
<div id="@_treeDetail" style="margin-left: 225px;">
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<script type="text/javascript">
|
|
||||||
var gridid = '#@_gridId';
|
|
||||||
var selectedId = 0;
|
<script type="text/javascript">
|
||||||
$(document).ready(function () {
|
var selectedId = 0;
|
||||||
initZtree();
|
$(document).ready(function () {
|
||||||
loadDataGrid();
|
initZtree();
|
||||||
});
|
loadDataGrid();
|
||||||
//加载数据到datagrid
|
});
|
||||||
function loadDataGrid() {
|
//加载数据到datagrid
|
||||||
//b-jui的datagrid需要重新处理HTML
|
function loadDataGrid() {
|
||||||
$('#@_treeDetail').empty()
|
//b-jui的datagrid需要重新处理HTML
|
||||||
.append('<table id="@_gridId" class="table table-bordered"></table>');
|
$('#@_treeDetail').empty()
|
||||||
|
.append('<table id="@_gridId" class="table table-bordered table-hover table-striped table-top"></table>');
|
||||||
$(gridid).datagrid({
|
|
||||||
gridTitle: '列表',
|
$('#@_gridId').datagrid({
|
||||||
showToolbar: true,
|
showToolbar: false,
|
||||||
filterThead: false,
|
filterThead: false,
|
||||||
toolbarItem: 'refresh, |, del',
|
columns: [
|
||||||
toolbarCustom: '<a href="/<%=ModuleName%>Manager/Add" class="btn btn-green" data-icon ="plus" ' +
|
<% foreach (ColumnSchema column in this.SourceTable.Columns) { %>
|
||||||
'data-toggle="dialog" data-id="dialog-mask" data-mask="true" data-on-close="refreshGrid">添加</a>' +
|
{
|
||||||
'<button class=" btn-green" onclick="edit<%=ModuleName%>()" data-icon="pencil" type="button">编辑</button>',
|
name: '<%=column.Name%>',
|
||||||
columns: [
|
label: '<%=column.Description%>',
|
||||||
<% foreach (ColumnSchema column in this.SourceTable.Columns) { %>
|
width: 100
|
||||||
{
|
<%if(column.IsPrimaryKeyMember){ %>
|
||||||
name: '<%=column.Name%>',
|
, hide: true
|
||||||
label: '<%=column.Description%>',
|
<%} %>
|
||||||
width: 100
|
<%else if(CSharpAlias[column.SystemType.FullName] == "System.DateTime") {%>
|
||||||
<%if(column.IsPrimaryKeyMember){ %>
|
, type: 'date',
|
||||||
, hide: true
|
pattern: 'yyyy-MM-dd HH:mm:ss'
|
||||||
<%} %>
|
<%} %>
|
||||||
<%else if(CSharpAlias[column.SystemType.FullName] == "System.DateTime") {%>
|
<%else if(CSharpAlias[column.SystemType.FullName] == "bool") {%>
|
||||||
, type: 'date',
|
,type: 'select',
|
||||||
pattern: 'yyyy-MM-dd HH:mm:ss'
|
align: 'center',
|
||||||
<%} %>
|
items: [{ '0': '否' }, { '1': '是' }],
|
||||||
<%else if(CSharpAlias[column.SystemType.FullName] == "bool") {%>
|
<%} %>
|
||||||
,type: 'select',
|
<%else if(CSharpAlias[column.SystemType.FullName] == "int") {%>
|
||||||
align: 'center',
|
,type: 'select',
|
||||||
items: [{ '0': '否' }, { '1': '是' }],
|
align: 'center',
|
||||||
<%} %>
|
items: [{ '0': '默认' }, { '1': '状态1' }],
|
||||||
<%else if(CSharpAlias[column.SystemType.FullName] == "int") {%>
|
<%} %>
|
||||||
,type: 'select',
|
},
|
||||||
align: 'center',
|
<% } %>
|
||||||
items: [{ '0': '默认' }, { '1': '状态1' }],
|
],
|
||||||
<%} %>
|
dataUrl: '<%=ModuleName%>Manager/Load?orgId=' + selectedId,
|
||||||
},
|
fullGrid: true,
|
||||||
<% } %>
|
showLinenumber: true,
|
||||||
],
|
showCheckboxcol: true,
|
||||||
dataUrl: '<%=ModuleName%>Manager/Load?orgId=' + selectedId,
|
paging: true,
|
||||||
delUrl: '<%=ModuleName%>/Delete',
|
filterMult: false,
|
||||||
delPK: "Id",
|
showTfoot: true,
|
||||||
fullGrid: true,
|
height: '700'
|
||||||
showLinenumber: true,
|
});
|
||||||
showCheckboxcol: true,
|
}
|
||||||
paging: true,
|
|
||||||
filterMult: false,
|
function zTreeOnClick(event, treeId, treeNode) {
|
||||||
showTfoot: true,
|
selectedId = treeNode.Id;
|
||||||
height: '700',
|
loadDataGrid();
|
||||||
delCallback: function (delResult) {
|
}
|
||||||
if (delResult.statusCode == "200")
|
|
||||||
loadDataGrid();
|
function initZtree() {
|
||||||
else {
|
var setting = {
|
||||||
$(this).alertmsg('warn', delResult.message);
|
view: {selectedMulti: false},
|
||||||
}
|
data: {
|
||||||
}
|
key: {
|
||||||
});
|
name: 'Name',
|
||||||
}
|
title: 'Name'
|
||||||
|
},
|
||||||
function zTreeOnClick(event, treeId, treeNode) {
|
simpleData: {
|
||||||
selectedId = treeNode.Id;
|
enable: true,
|
||||||
loadDataGrid();
|
idKey: 'Id',
|
||||||
}
|
pIdKey: 'ParentId',
|
||||||
|
rootPId: 'null'
|
||||||
function initZtree() {
|
}
|
||||||
var setting = {
|
},
|
||||||
view: {selectedMulti: false},
|
callback: {onClick: zTreeOnClick}
|
||||||
data: {
|
};
|
||||||
key: {
|
$.getJSON('<%=ModuleName%>Manager/LoadModuleWithRoot', function (json) {
|
||||||
name: 'Name',
|
var zTreeObj = $.fn.zTree.init($('#@_treeId'), setting, json);
|
||||||
title: 'Name'
|
zTreeObj.expandAll(true);
|
||||||
},
|
});
|
||||||
simpleData: {
|
}
|
||||||
enable: true,
|
|
||||||
idKey: 'Id',
|
//删除
|
||||||
pIdKey: 'ParentId',
|
function del<%=ModuleName%>() {
|
||||||
rootPId: 'null'
|
var selected = getSelected('#@_gridId',2);
|
||||||
}
|
if (selected == null) return;
|
||||||
},
|
|
||||||
callback: {onClick: zTreeOnClick}
|
$.get('<%=ModuleName%>Manager/Delete?Id=' + selected, function (data) {
|
||||||
};
|
if (data.statusCode == "200")
|
||||||
$.getJSON('OrgManager/LoadOrg', function (json) {
|
loadDataGrid();
|
||||||
var zTreeObj = $.fn.zTree.init($('#@_treeId'), setting, json);
|
else {
|
||||||
zTreeObj.expandAll(true);
|
$(this).alertmsg('warn', data.message);
|
||||||
});
|
}
|
||||||
}
|
});
|
||||||
|
}
|
||||||
//获取勾选的值
|
|
||||||
//column:为从0开始的列标识
|
//自定义的编辑按钮
|
||||||
function getSelected(column) {
|
function edit<%=ModuleName%>() {
|
||||||
var selected = $(gridid).data('selectedTrs');
|
var selected = getSelected('#@_gridId',2);
|
||||||
if (selected == null || selected.length == 0) {
|
if (selected == null) return;
|
||||||
$(this).alertmsg('warn', '至少选择一个对象', {
|
|
||||||
displayMode: 'slide',
|
$(this).dialog({
|
||||||
title: '重要提示'
|
id: 'editDialog',
|
||||||
});
|
url: '/<%=ModuleName%>Manager/Add?id=' + selected,
|
||||||
return null;
|
title: '编辑',
|
||||||
}
|
onClose:function() {
|
||||||
|
refreshModuleGrid();
|
||||||
//todo:下面这段只能chrome有效
|
}
|
||||||
var records = new Array();
|
});
|
||||||
selected.each(function () {
|
|
||||||
records[records.length] = this.children[column].innerText;
|
}
|
||||||
});
|
|
||||||
|
function refresh<%=ModuleName%>Grid() {
|
||||||
return records[0];
|
$('#@_gridId').datagrid('refresh');
|
||||||
}
|
// loadDataGrid();
|
||||||
|
}
|
||||||
|
//@@ sourceURL=<%=ModuleName%>ManagerIndex.js
|
||||||
|
</script>
|
||||||
//自定义的编辑按钮
|
|
||||||
function edit<%=ModuleName%>() {
|
|
||||||
var selected = getSelected(2);
|
|
||||||
if (selected == null) return;
|
|
||||||
|
|
||||||
$(this).dialog({
|
|
||||||
id: 'editDialog',
|
|
||||||
url: '/<%=ModuleName%>Manager/Add?id=' + selected,
|
|
||||||
title: '编辑',
|
|
||||||
onClose:function() {
|
|
||||||
refreshGrid();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function refreshGrid() {
|
|
||||||
$('#@_gridId').datagrid('refresh');
|
|
||||||
// loadDataGrid();
|
|
||||||
}
|
|
||||||
//@@ sourceURL=<%=ModuleName%>ManagerIndex.js
|
|
||||||
</script>
|
|
||||||
|
99
OpenAuth.App/CategoryManagerApp.cs
Normal file
99
OpenAuth.App/CategoryManagerApp.cs
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
|
||||||
|
using OpenAuth.Domain;
|
||||||
|
using OpenAuth.Domain.Interface;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
|
namespace OpenAuth.App
|
||||||
|
{
|
||||||
|
public class CategoryManagerApp
|
||||||
|
{
|
||||||
|
private ICategoryRepository _repository;
|
||||||
|
private IOrgRepository _orgRepository;
|
||||||
|
|
||||||
|
public CategoryManagerApp(ICategoryRepository repository,
|
||||||
|
IOrgRepository orgRepository)
|
||||||
|
{
|
||||||
|
_repository = repository;
|
||||||
|
_orgRepository = orgRepository;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int GetCategoryCntInOrg(int orgId)
|
||||||
|
{
|
||||||
|
if (orgId == 0)
|
||||||
|
{
|
||||||
|
return _repository.Find(null).Count();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return _repository.GetCategoryCntInOrgs(GetSubOrgIds(orgId));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 加载一个部门及子部门全部Categorys
|
||||||
|
/// </summary>
|
||||||
|
public dynamic Load(int orgId, int pageindex, int pagesize)
|
||||||
|
{
|
||||||
|
IEnumerable<Category> Categorys;
|
||||||
|
int total = 0;
|
||||||
|
if (orgId == 0)
|
||||||
|
{
|
||||||
|
Categorys = _repository.LoadCategorys(pageindex, pagesize);
|
||||||
|
total = _repository.GetCount();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Categorys = _repository.LoadInOrgs(pageindex, pagesize,GetSubOrgIds(orgId));
|
||||||
|
total = _repository.GetCategoryCntInOrgs(orgId);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new
|
||||||
|
{
|
||||||
|
total = total,
|
||||||
|
list = Categorys,
|
||||||
|
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 Category Find(int id)
|
||||||
|
{
|
||||||
|
var category = _repository.FindSingle(u => u.Id == id);
|
||||||
|
if (category == null) return new Category();
|
||||||
|
|
||||||
|
return category;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Delete(int id)
|
||||||
|
{
|
||||||
|
_repository.Delete(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void AddOrUpdate(Category model)
|
||||||
|
{
|
||||||
|
Category category = model;
|
||||||
|
if (category.Id == 0)
|
||||||
|
{
|
||||||
|
_repository.Add(category);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_repository.Update(category);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -43,6 +43,7 @@
|
|||||||
<Reference Include="System.Xml" />
|
<Reference Include="System.Xml" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<Compile Include="CategoryManagerApp.cs" />
|
||||||
<Compile Include="LoginApp.cs" />
|
<Compile Include="LoginApp.cs" />
|
||||||
<Compile Include="ModuleElementManagerApp.cs" />
|
<Compile Include="ModuleElementManagerApp.cs" />
|
||||||
<Compile Include="ModuleManagerApp.cs" />
|
<Compile Include="ModuleManagerApp.cs" />
|
||||||
|
17
OpenAuth.Domain/Interface/ICategoryRepository.cs
Normal file
17
OpenAuth.Domain/Interface/ICategoryRepository.cs
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
|
namespace OpenAuth.Domain.Interface
|
||||||
|
{
|
||||||
|
public interface ICategoryRepository :IRepository<Category>
|
||||||
|
{
|
||||||
|
IEnumerable<Category> LoadCategorys(int pageindex, int pagesize);
|
||||||
|
|
||||||
|
IEnumerable<Category> LoadInOrgs(params int[] orgId);
|
||||||
|
int GetCategoryCntInOrgs(params int[] orgIds);
|
||||||
|
IEnumerable<Category> LoadInOrgs(int pageindex, int pagesize, params int[] orgIds);
|
||||||
|
|
||||||
|
void Delete(int id);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -46,6 +46,7 @@
|
|||||||
<Compile Include="Core\User.cs" />
|
<Compile Include="Core\User.cs" />
|
||||||
<Compile Include="DicDetail.cs" />
|
<Compile Include="DicDetail.cs" />
|
||||||
<Compile Include="DicIndex.cs" />
|
<Compile Include="DicIndex.cs" />
|
||||||
|
<Compile Include="Interface\ICategoryRepository.cs" />
|
||||||
<Compile Include="Interface\IModuleRepository.cs" />
|
<Compile Include="Interface\IModuleRepository.cs" />
|
||||||
<Compile Include="Interface\IOrgRepository.cs" />
|
<Compile Include="Interface\IOrgRepository.cs" />
|
||||||
<Compile Include="Interface\IRepository.cs" />
|
<Compile Include="Interface\IRepository.cs" />
|
||||||
|
73
OpenAuth.Mvc/Controllers/CategoryManagerController.cs
Normal file
73
OpenAuth.Mvc/Controllers/CategoryManagerController.cs
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Web.Mvc;
|
||||||
|
using Infrastructure;
|
||||||
|
using OpenAuth.App;
|
||||||
|
using OpenAuth.Domain;
|
||||||
|
|
||||||
|
namespace OpenAuth.Mvc.Controllers
|
||||||
|
{
|
||||||
|
public class CategoryManagerController : BaseController
|
||||||
|
{
|
||||||
|
private CategoryManagerApp _app;
|
||||||
|
|
||||||
|
public CategoryManagerController()
|
||||||
|
{
|
||||||
|
_app = (CategoryManagerApp)DependencyResolver.Current.GetService(typeof(CategoryManagerApp));
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// GET: /UserManager/
|
||||||
|
public ActionResult Index()
|
||||||
|
{
|
||||||
|
return View();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ActionResult Add(int id = 0)
|
||||||
|
{
|
||||||
|
return View(_app.Find(id));
|
||||||
|
}
|
||||||
|
|
||||||
|
//添加或修改Category
|
||||||
|
[HttpPost]
|
||||||
|
public string Add(Category model)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_app.AddOrUpdate(model);
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
BjuiResponse.statusCode = "300";
|
||||||
|
BjuiResponse.message = ex.Message;
|
||||||
|
}
|
||||||
|
return JsonHelper.Instance.Serialize(BjuiResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 加载组织下面的所有用户
|
||||||
|
/// </summary>
|
||||||
|
public string Load(int orgId, int pageCurrent = 1, int pageSize = 30)
|
||||||
|
{
|
||||||
|
return JsonHelper.Instance.Serialize(_app.Load(orgId, pageCurrent, pageSize));
|
||||||
|
}
|
||||||
|
|
||||||
|
public string Delete(int Id)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_app.Delete(Id);
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
BjuiResponse.statusCode = "300";
|
||||||
|
BjuiResponse.message = e.Message;
|
||||||
|
}
|
||||||
|
|
||||||
|
return JsonHelper.Instance.Serialize(BjuiResponse);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -20,6 +20,7 @@
|
|||||||
<IISExpressAnonymousAuthentication>enabled</IISExpressAnonymousAuthentication>
|
<IISExpressAnonymousAuthentication>enabled</IISExpressAnonymousAuthentication>
|
||||||
<IISExpressWindowsAuthentication>disabled</IISExpressWindowsAuthentication>
|
<IISExpressWindowsAuthentication>disabled</IISExpressWindowsAuthentication>
|
||||||
<IISExpressUseClassicPipelineMode />
|
<IISExpressUseClassicPipelineMode />
|
||||||
|
<UseGlobalApplicationHostFile />
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
||||||
<DebugSymbols>true</DebugSymbols>
|
<DebugSymbols>true</DebugSymbols>
|
||||||
@ -125,6 +126,7 @@
|
|||||||
<Compile Include="App_Start\RouteConfig.cs" />
|
<Compile Include="App_Start\RouteConfig.cs" />
|
||||||
<Compile Include="AutofacExt.cs" />
|
<Compile Include="AutofacExt.cs" />
|
||||||
<Compile Include="Controllers\BaseController.cs" />
|
<Compile Include="Controllers\BaseController.cs" />
|
||||||
|
<Compile Include="Controllers\CategoryManagerController.cs" />
|
||||||
<Compile Include="Controllers\ErrorController.cs" />
|
<Compile Include="Controllers\ErrorController.cs" />
|
||||||
<Compile Include="Controllers\HomeController.cs" />
|
<Compile Include="Controllers\HomeController.cs" />
|
||||||
<Compile Include="Controllers\LoginController.cs" />
|
<Compile Include="Controllers\LoginController.cs" />
|
||||||
@ -554,6 +556,8 @@
|
|||||||
<Content Include="BJUI\themes\purple\zTreeStandard.png" />
|
<Content Include="BJUI\themes\purple\zTreeStandard.png" />
|
||||||
<Content Include="favicon.ico" />
|
<Content Include="favicon.ico" />
|
||||||
<Content Include="Global.asax" />
|
<Content Include="Global.asax" />
|
||||||
|
<Content Include="Views\CategoryManager\Add.cshtml" />
|
||||||
|
<Content Include="Views\CategoryManager\Index.cshtml" />
|
||||||
<None Include="Views\Error\NoAccess.cshtml" />
|
<None Include="Views\Error\NoAccess.cshtml" />
|
||||||
<None Include="Views\Home\git.cshtml" />
|
<None Include="Views\Home\git.cshtml" />
|
||||||
<Content Include="Web.config" />
|
<Content Include="Web.config" />
|
||||||
|
143
OpenAuth.Mvc/Views/CategoryManager/Add.cshtml
Normal file
143
OpenAuth.Mvc/Views/CategoryManager/Add.cshtml
Normal file
@ -0,0 +1,143 @@
|
|||||||
|
@model OpenAuth.Domain.Category
|
||||||
|
@{
|
||||||
|
ViewBag.Title = "Category编辑界面";
|
||||||
|
Layout = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
<div class="bjui-pageContent">
|
||||||
|
<form action="/CategoryManager/Add" class="pageForm" data-toggle="validate">
|
||||||
|
<table class="table table-condensed table-hover">
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
@Html.HiddenFor(m =>m.Id)
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<label for="CascadeId" class="control-label x90">节点语义ID:</label>
|
||||||
|
<input type="text" name="CascadeId" id="CascadeId" value="@Model.CascadeId"
|
||||||
|
data-rule="required" size="20">
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<label for="Name" class="control-label x90">名称:</label>
|
||||||
|
<input type="text" name="Name" id="Name" value="@Model.Name"
|
||||||
|
data-rule="required" size="20">
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<label for="ParentId" class="control-label x85">父节点流水号:</label>
|
||||||
|
<input id="ParentId" name="ParentId" value="" style="display: none"/>
|
||||||
|
<input type="text" name="ParentName" id="ParentName"
|
||||||
|
data-toggle="selectztree" size="20" data-tree="#j_select_tree1" value="@Model.ParentName">
|
||||||
|
<ul id="j_select_tree1" class="ztree hide" data-toggle="ztree"></ul>
|
||||||
|
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<label for="Status" class="control-label x85">当前状态:</label>
|
||||||
|
<select name="Status" id="Status" data-toggle="selectpicker" data-rule="required">
|
||||||
|
<option value="0" @if (Model.Status == 0) { <text> selected="selected" </text> }>默认</option>
|
||||||
|
<option value="1" @if (Model.Status == 1) { <text> selected="selected" </text> }>状态1</option>
|
||||||
|
</select>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<label for="SortNo" class="control-label x85">排序号:</label>
|
||||||
|
<select name="SortNo" id="SortNo" data-toggle="selectpicker" data-rule="required">
|
||||||
|
<option value="0" @if (Model.SortNo == 0) { <text> selected="selected" </text> }>默认</option>
|
||||||
|
<option value="1" @if (Model.SortNo == 1) { <text> selected="selected" </text> }>状态1</option>
|
||||||
|
</select>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<label for="RootKey" class="control-label x90">资源分类标识:</label>
|
||||||
|
<input type="text" name="RootKey" id="RootKey" value="@Model.RootKey"
|
||||||
|
data-rule="required" size="20">
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<label for="RootName" class="control-label x90">资源分类:</label>
|
||||||
|
<input type="text" name="RootName" id="RootName" value="@Model.RootName"
|
||||||
|
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);
|
||||||
|
|
||||||
|
$('#ParentId').val(ids);
|
||||||
|
}
|
||||||
|
function zTreeOnClick(event, treeId, treeNode) {
|
||||||
|
var zTree = $.fn.zTree.getZTreeObj(treeId);
|
||||||
|
zTree.checkNode(treeNode, !treeNode.checked, true, true);
|
||||||
|
event.preventDefault();
|
||||||
|
}
|
||||||
|
</script>
|
162
OpenAuth.Mvc/Views/CategoryManager/Index.cshtml
Normal file
162
OpenAuth.Mvc/Views/CategoryManager/Index.cshtml
Normal file
@ -0,0 +1,162 @@
|
|||||||
|
@{
|
||||||
|
string _prefix = "Category";
|
||||||
|
var _treeId = _prefix + "Tree";
|
||||||
|
var _gridId = _prefix + "Grid";
|
||||||
|
var _treeDetail = _prefix + "Detail";
|
||||||
|
}
|
||||||
|
|
||||||
|
@{ 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>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<script type="text/javascript">
|
||||||
|
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>');
|
||||||
|
|
||||||
|
$('#@_gridId').datagrid({
|
||||||
|
showToolbar: false,
|
||||||
|
filterThead: false,
|
||||||
|
columns: [
|
||||||
|
{
|
||||||
|
name: 'Id',
|
||||||
|
label: '资源表ID',
|
||||||
|
width: 100
|
||||||
|
, hide: true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'CascadeId',
|
||||||
|
label: '节点语义ID',
|
||||||
|
width: 100
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Name',
|
||||||
|
label: '名称',
|
||||||
|
width: 100
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'ParentId',
|
||||||
|
label: '父节点流水号',
|
||||||
|
width: 100
|
||||||
|
,type: 'select',
|
||||||
|
align: 'center',
|
||||||
|
items: [{ '0': '默认' }, { '1': '状态1' }],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Status',
|
||||||
|
label: '当前状态',
|
||||||
|
width: 100
|
||||||
|
,type: 'select',
|
||||||
|
align: 'center',
|
||||||
|
items: [{ '0': '默认' }, { '1': '状态1' }],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'SortNo',
|
||||||
|
label: '排序号',
|
||||||
|
width: 100
|
||||||
|
,type: 'select',
|
||||||
|
align: 'center',
|
||||||
|
items: [{ '0': '默认' }, { '1': '状态1' }],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'RootKey',
|
||||||
|
label: '根节点',
|
||||||
|
width: 100
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'RootName',
|
||||||
|
label: '根节点名称',
|
||||||
|
width: 100
|
||||||
|
},
|
||||||
|
],
|
||||||
|
dataUrl: 'CategoryManager/Load?orgId=' + selectedId,
|
||||||
|
fullGrid: true,
|
||||||
|
showLinenumber: true,
|
||||||
|
showCheckboxcol: true,
|
||||||
|
paging: true,
|
||||||
|
filterMult: false,
|
||||||
|
showTfoot: true,
|
||||||
|
height: '700'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
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('CategoryManager/LoadModuleWithRoot', function (json) {
|
||||||
|
var zTreeObj = $.fn.zTree.init($('#@_treeId'), setting, json);
|
||||||
|
zTreeObj.expandAll(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
//删除
|
||||||
|
function delCategory() {
|
||||||
|
var selected = getSelected('#@_gridId',2);
|
||||||
|
if (selected == null) return;
|
||||||
|
|
||||||
|
$.get('CategoryManager/Delete?Id=' + selected, function (data) {
|
||||||
|
if (data.statusCode == "200")
|
||||||
|
loadDataGrid();
|
||||||
|
else {
|
||||||
|
$(this).alertmsg('warn', data.message);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
//自定义的编辑按钮
|
||||||
|
function editCategory() {
|
||||||
|
var selected = getSelected('#@_gridId',2);
|
||||||
|
if (selected == null) return;
|
||||||
|
|
||||||
|
$(this).dialog({
|
||||||
|
id: 'editDialog',
|
||||||
|
url: '/CategoryManager/Add?id=' + selected,
|
||||||
|
title: '编辑',
|
||||||
|
onClose:function() {
|
||||||
|
refreshModuleGrid();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function refreshCategoryGrid() {
|
||||||
|
$('#@_gridId').datagrid('refresh');
|
||||||
|
// loadDataGrid();
|
||||||
|
}
|
||||||
|
//@@ sourceURL=CategoryManagerIndex.js
|
||||||
|
</script>
|
39
OpenAuth.Repository/CategoryRepository.cs
Normal file
39
OpenAuth.Repository/CategoryRepository.cs
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using OpenAuth.Domain;
|
||||||
|
using OpenAuth.Domain.Interface;
|
||||||
|
|
||||||
|
namespace OpenAuth.Repository
|
||||||
|
{
|
||||||
|
public class CategoryRepository :BaseRepository<Category>, ICategoryRepository
|
||||||
|
{
|
||||||
|
|
||||||
|
public IEnumerable<Category> LoadCategorys(int pageindex, int pagesize)
|
||||||
|
{
|
||||||
|
return Context.Categories.OrderBy(u => u.Id).Skip((pageindex - 1) * pagesize).Take(pagesize);
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<Category> LoadInOrgs(params int[] orgId)
|
||||||
|
{
|
||||||
|
var result = from category in Context.Categories where orgId.Contains(category.Id)
|
||||||
|
select category;
|
||||||
|
return result;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public int GetCategoryCntInOrgs(params int[] orgIds)
|
||||||
|
{
|
||||||
|
return LoadInOrgs(orgIds).Count();
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<Category> 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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -72,6 +72,7 @@
|
|||||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||||
<Compile Include="ModuleRepository.cs" />
|
<Compile Include="ModuleRepository.cs" />
|
||||||
<Compile Include="RoleRepository.cs" />
|
<Compile Include="RoleRepository.cs" />
|
||||||
|
<Compile Include="CategoryRepository.cs" />
|
||||||
<Compile Include="UserRepository.cs" />
|
<Compile Include="UserRepository.cs" />
|
||||||
<Compile Include="RelevanceRepository.cs" />
|
<Compile Include="RelevanceRepository.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
Loading…
Reference in New Issue
Block a user