dept category
This commit is contained in:
parent
097965d7a0
commit
20f8f204b2
|
|
@ -0,0 +1,48 @@
|
||||||
|
package com.ghy.web.controller.goods;
|
||||||
|
|
||||||
|
import com.ghy.common.core.controller.BaseController;
|
||||||
|
import com.ghy.common.core.domain.Ztree;
|
||||||
|
import com.ghy.goods.service.GoodsCategoryService;
|
||||||
|
import org.apache.shiro.authz.annotation.RequiresPermissions;
|
||||||
|
import org.springframework.stereotype.Controller;
|
||||||
|
import org.springframework.ui.ModelMap;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.ResponseBody;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Controller
|
||||||
|
@RequestMapping("goods/deptcategory")
|
||||||
|
public class GoodsDeptCategoryController extends BaseController {
|
||||||
|
|
||||||
|
private static final String PREFIX = "goods/deptcategory";
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
GoodsCategoryService goodsCategoryService;
|
||||||
|
// @Resource
|
||||||
|
// GoodsDeptCategoryService goodsDeptCategoryService;
|
||||||
|
|
||||||
|
@RequiresPermissions("goods:deptcategory:view")
|
||||||
|
@GetMapping()
|
||||||
|
public String goodsCategory() {
|
||||||
|
return PREFIX + "/deptcategory";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@RequiresPermissions("goods:deptcategory:add")
|
||||||
|
@GetMapping("/add")
|
||||||
|
public String edit(ModelMap mmap) {
|
||||||
|
return PREFIX + "/add";
|
||||||
|
}
|
||||||
|
|
||||||
|
@GetMapping("/tree")
|
||||||
|
@ResponseBody
|
||||||
|
public List<Ztree> goodsDeptCategoryTree() {
|
||||||
|
// Long parentId = ShiroUtils.getSysUser().getParentId();
|
||||||
|
// List<Ztree> ztrees = goodsDeptCategoryService.tree(parentId);
|
||||||
|
return goodsCategoryService.selectCategoryTree(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,64 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="zh" xmlns:th="http://www.thymeleaf.org" >
|
||||||
|
<head>
|
||||||
|
<th:block th:include="include :: header('修改角色')" />
|
||||||
|
<th:block th:include="include :: ztree-css" />
|
||||||
|
</head>
|
||||||
|
<body class="white-bg">
|
||||||
|
<div class="wrapper wrapper-content animated fadeInRight ibox-content">
|
||||||
|
<form class="form-horizontal m" id="form-role-edit">
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="col-sm-3 control-label">菜单权限:</label>
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<label class="check-box">
|
||||||
|
<input type="checkbox" value="1">展开/折叠</label>
|
||||||
|
<label class="check-box">
|
||||||
|
<input type="checkbox" value="2">全选/全不选</label>
|
||||||
|
<label class="check-box">
|
||||||
|
<input type="checkbox" value="3" checked>父子联动</label>
|
||||||
|
<div id="menuTrees" class="ztree ztree-border"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<th:block th:include="include :: footer" />
|
||||||
|
<th:block th:include="include :: ztree-js" />
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(function() {
|
||||||
|
var url = ctx + "goods/deptcategory/tree";
|
||||||
|
var options = {
|
||||||
|
id: "menuTrees",
|
||||||
|
url: url,
|
||||||
|
check: { enable: true },
|
||||||
|
expandLevel: 0
|
||||||
|
};
|
||||||
|
$.tree.init(options);
|
||||||
|
});
|
||||||
|
|
||||||
|
function edit() {
|
||||||
|
var menuIds = $.tree.getCheckedNodes();
|
||||||
|
$.ajax({
|
||||||
|
cache : true,
|
||||||
|
type : "POST",
|
||||||
|
url : ctx + "system/role/edit",
|
||||||
|
data : {
|
||||||
|
"menuIds": menuIds
|
||||||
|
},
|
||||||
|
async : false,
|
||||||
|
error : function(request) {
|
||||||
|
$.modal.alertError("系统错误");
|
||||||
|
},
|
||||||
|
success : function(data) {
|
||||||
|
$.operate.successCallback(data);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function submitHandler() {
|
||||||
|
if ($.validate.form()) {
|
||||||
|
add();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
@ -0,0 +1,113 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
|
||||||
|
<head>
|
||||||
|
<th:block th:include="include :: header('类目列表')"/>
|
||||||
|
</head>
|
||||||
|
<body class="gray-bg">
|
||||||
|
<div class="container-div">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-12 search-collapse">
|
||||||
|
<form id="dept-form">
|
||||||
|
<div class="select-list">
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
类目名称:<input type="text" name="goodsCategoryName"/>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
类目状态:<select name="status" th:with="type=${@dict.getType('sys_normal_disable')}">
|
||||||
|
<option value="">所有</option>
|
||||||
|
<option th:each="dict : ${type}" th:text="${dict.dictLabel}"
|
||||||
|
th:value="${dict.dictValue}"></option>
|
||||||
|
</select>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a class="btn btn-primary btn-rounded btn-sm" onclick="$.treeTable.search()"><i
|
||||||
|
class="fa fa-search"></i> 搜索</a>
|
||||||
|
<a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i
|
||||||
|
class="fa fa-refresh"></i> 重置</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="btn-group-sm" id="toolbar" role="group">
|
||||||
|
<a class="btn btn-primary" onclick="$.operate.edit(1)" shiro:hasPermission="goods:category:edit">
|
||||||
|
<i class="fa fa-edit"></i> 修改
|
||||||
|
</a>
|
||||||
|
<a class="btn btn-info" id="expandAllBtn">
|
||||||
|
<i class="fa fa-exchange"></i> 展开/折叠
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-12 select-table table-striped">
|
||||||
|
<table id="bootstrap-tree-table"></table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<th:block th:include="include :: footer"/>
|
||||||
|
<script th:inline="javascript">
|
||||||
|
var addFlag = [[${@permission.hasPermi('goods:category:add')}]];
|
||||||
|
var editFlag = [[${@permission.hasPermi('goods:category:edit')}]];
|
||||||
|
var removeFlag = [[${@permission.hasPermi('goods:category:remove')}]];
|
||||||
|
var datas = [[${@dict.getType('sys_normal_disable')}]];
|
||||||
|
var prefix = ctx + "goods/category"
|
||||||
|
|
||||||
|
$(function() {
|
||||||
|
var options = {
|
||||||
|
code: "goodsCategoryId",
|
||||||
|
parentCode: "parentCategoryId",
|
||||||
|
uniqueId: "goodsCategoryId",
|
||||||
|
url: prefix + "/list",
|
||||||
|
createUrl: prefix + "/add/{id}",
|
||||||
|
updateUrl: prefix + "/edit/{id}",
|
||||||
|
removeUrl: prefix + "/remove/{id}",
|
||||||
|
modalName: "类目",
|
||||||
|
columns: [{
|
||||||
|
field: 'selectItem',
|
||||||
|
radio: true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'goodsCategoryName',
|
||||||
|
title: '类目名称',
|
||||||
|
align: "left"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'categorySort',
|
||||||
|
title: '排序',
|
||||||
|
align: "left"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'status',
|
||||||
|
title: '状态',
|
||||||
|
align: "left",
|
||||||
|
formatter: function(value, item, index) {
|
||||||
|
return $.table.selectDictLabel(datas, item.status);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'createTime',
|
||||||
|
title: '创建时间',
|
||||||
|
align: "left"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '操作',
|
||||||
|
align: 'left',
|
||||||
|
formatter: function(value, row, index) {
|
||||||
|
if (row.parentId != 0) {
|
||||||
|
var actions = [];
|
||||||
|
actions.push('<a class="btn btn-success btn-xs ' + editFlag + '" href="javascript:void(0)" onclick="$.operate.edit(\'' + row.goodsCategoryId + '\')"><i class="fa fa-edit"></i>编辑</a> ');
|
||||||
|
actions.push('<a class="btn btn-info btn-xs ' + addFlag + '" href="javascript:void(0)" onclick="$.operate.add(\'' + row.goodsCategoryId + '\')"><i class="fa fa-plus"></i>新增</a> ');
|
||||||
|
actions.push('<a class="btn btn-danger btn-xs ' + removeFlag + '" href="javascript:void(0)" onclick="$.operate.remove(\'' + row.goodsCategoryId + '\')"><i class="fa fa-trash"></i>删除</a>');
|
||||||
|
return actions.join('');
|
||||||
|
} else {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
};
|
||||||
|
$.treeTable.init(options);
|
||||||
|
});
|
||||||
|
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
@ -21,7 +21,7 @@ public class DeptGoodsCategory extends BaseEntity {
|
||||||
private Long goodsCategoryId;
|
private Long goodsCategoryId;
|
||||||
|
|
||||||
@Excel(name = "排序", cellType = Excel.ColumnType.STRING)
|
@Excel(name = "排序", cellType = Excel.ColumnType.STRING)
|
||||||
private String categorySort;
|
private Integer categorySort;
|
||||||
|
|
||||||
@Excel(name = "一级分销扣点比例", cellType = Excel.ColumnType.STRING)
|
@Excel(name = "一级分销扣点比例", cellType = Excel.ColumnType.STRING)
|
||||||
private String oneRate;
|
private String oneRate;
|
||||||
|
|
|
||||||
|
|
@ -1,11 +1,47 @@
|
||||||
package com.ghy.goods.mapper;
|
package com.ghy.goods.mapper;
|
||||||
|
|
||||||
|
import com.ghy.goods.domain.DeptGoodsCategory;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 分公司使用类目mapper
|
* 分公司使用类目mapper
|
||||||
|
*
|
||||||
* @author clunt
|
* @author clunt
|
||||||
*/
|
*/
|
||||||
public interface DeptGoodsCategoryMapper {
|
public interface DeptGoodsCategoryMapper {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param category 商品属性
|
||||||
|
* @return 成功条数
|
||||||
|
*/
|
||||||
|
int insertDeptGoodsCategory(DeptGoodsCategory category);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param category 商品属性
|
||||||
|
* @return 成功条数
|
||||||
|
*/
|
||||||
|
int updateDeptGoodsCategory(DeptGoodsCategory category);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param category 商品入参
|
||||||
|
* @return 商品集合
|
||||||
|
*/
|
||||||
|
List<DeptGoodsCategory> selectDeptGoodsCategoryList(DeptGoodsCategory category);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param goodsCategoryId 商品id
|
||||||
|
* @return 商品
|
||||||
|
*/
|
||||||
|
DeptGoodsCategory selectById(Long goodsCategoryId);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 批量删除商品信息
|
||||||
|
*
|
||||||
|
* @param goodsCategoryId 需要删除的数据ID
|
||||||
|
* @return 结果
|
||||||
|
*/
|
||||||
|
int deleteDeptGoodsCategoryByIds(Long[] goodsCategoryId);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,11 @@
|
||||||
|
package com.ghy.goods.service;
|
||||||
|
|
||||||
|
import com.ghy.common.core.domain.Ztree;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public interface GoodsDeptCategoryService {
|
||||||
|
|
||||||
|
|
||||||
|
List<Ztree> tree(Long parentId);
|
||||||
|
}
|
||||||
|
|
@ -3,19 +3,83 @@
|
||||||
<mapper namespace="com.ghy.goods.mapper.DeptGoodsCategoryMapper">
|
<mapper namespace="com.ghy.goods.mapper.DeptGoodsCategoryMapper">
|
||||||
|
|
||||||
<resultMap id="DeptGoodsCategoryResult" type="com.ghy.goods.domain.DeptGoodsCategory">
|
<resultMap id="DeptGoodsCategoryResult" type="com.ghy.goods.domain.DeptGoodsCategory">
|
||||||
|
<result property="deptGoodsCategoryId" column="dept_goods_category_id"/>
|
||||||
|
<result property="deptId" column="dept_id"/>
|
||||||
|
<result property="goodsCategoryId" column="goods_category_id"/>
|
||||||
|
<result property="categorySort" column="category_sort"/>
|
||||||
|
<result property="oneRate" column="one_rate"/>
|
||||||
|
<result property="twoRate" column="two_rate"/>
|
||||||
|
<result property="threeRate" column="three_rate"/>
|
||||||
|
|
||||||
<result property="createBy" column="create_by" />
|
<result property="createBy" column="create_by"/>
|
||||||
<result property="createTime" column="create_time" />
|
<result property="createTime" column="create_time"/>
|
||||||
<result property="updateBy" column="update_by" />
|
<result property="updateBy" column="update_by"/>
|
||||||
<result property="updateTime" column="update_time" />
|
<result property="updateTime" column="update_time"/>
|
||||||
<result property="remark" column="remark" />
|
<result property="remark" column="remark"/>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
|
|
||||||
<sql id="selectDeptGoodsCategory">
|
<sql id="selectDeptGoodsCategory">
|
||||||
SELECT create_by, create_time, remark
|
SELECT dept_goods_category_id, dept_id, dept_goods_category_id, category_sort,
|
||||||
|
one_rate, two_rate, three_rate, create_by, create_time, remark
|
||||||
FROM dept_goods_category
|
FROM dept_goods_category
|
||||||
</sql>
|
</sql>
|
||||||
|
|
||||||
|
<update id="updateDeptGoodsCategory" parameterType="com.ghy.goods.domain.DeptGoodsCategory">
|
||||||
|
UPDATE dept_goods_category
|
||||||
|
<set>
|
||||||
|
<if test="deptId != null and goodsCategoryCode != ''">dept_id = #{deptId},</if>
|
||||||
|
<if test="goodsCategoryId != null">goods_category_id = #{goodsCategoryId},</if>
|
||||||
|
<if test="categorySort != null">category_sort = #{categorySort},</if>
|
||||||
|
<if test="oneRate != null and oneRate != ''">one_rate = #{oneRate},</if>
|
||||||
|
<if test="twoRate != null and twoRate != ''">two_rate = #{twoRate},</if>
|
||||||
|
<if test="threeRate != null and threeRate != ''">three_rate = #{threeRate},</if>
|
||||||
|
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
|
||||||
|
update_time = sysdate()
|
||||||
|
</set>
|
||||||
|
WHERE dept_goods_category_id = #{goodsCategoryId}
|
||||||
|
</update>
|
||||||
|
|
||||||
|
<delete id="deleteDeptGoodsCategoryByIds" parameterType="Long">
|
||||||
|
DELETE FROM dept_goods_category WHERE dept_goods_category_id IN
|
||||||
|
<foreach collection="array" item="goodsCategoryId" open="(" separator="," close=")">
|
||||||
|
#{goodsCategoryId}
|
||||||
|
</foreach>
|
||||||
|
</delete>
|
||||||
|
|
||||||
|
<insert id="insertDeptGoodsCategory" parameterType="com.ghy.goods.domain.DeptGoodsCategory" useGeneratedKeys="true"
|
||||||
|
keyProperty="goodsCategoryId">
|
||||||
|
insert into dept_goods_category(
|
||||||
|
<if test="deptId != null and goodsCategoryCode != ''">dept_id,</if>
|
||||||
|
<if test="goodsCategoryId != null">goods_category_id,</if>
|
||||||
|
<if test="categorySort != null">category_sort,</if>
|
||||||
|
<if test="oneRate != null and oneRate != ''">one_rate,</if>
|
||||||
|
<if test="twoRate != null and twoRate != ''">two_rate,</if>
|
||||||
|
<if test="threeRate != null and threeRate != ''">three_rate,</if>
|
||||||
|
<if test="createBy != null and createBy != ''">create_by,</if>
|
||||||
|
create_time
|
||||||
|
)values(
|
||||||
|
<if test="deptId != null and goodsCategoryCode != ''">#{deptId},</if>
|
||||||
|
<if test="goodsCategoryId != null">#{goodsCategoryId},</if>
|
||||||
|
<if test="categorySort != null">#{categorySort},</if>
|
||||||
|
<if test="oneRate != null and oneRate != ''">#{oneRate},</if>
|
||||||
|
<if test="twoRate != null and twoRate != ''">#{twoRate},</if>
|
||||||
|
<if test="threeRate != null and threeRate != ''">#{threeRate},</if>
|
||||||
|
<if test="createBy != null and createBy != ''">#{createBy},</if>
|
||||||
|
sysdate()
|
||||||
|
)
|
||||||
|
</insert>
|
||||||
|
|
||||||
|
<select id="selectDeptGoodsCategoryList" parameterType="com.ghy.goods.domain.DeptGoodsCategory" resultMap="DeptGoodsCategoryResult">
|
||||||
|
<include refid="selectDeptGoodsCategory" />
|
||||||
|
<where>
|
||||||
|
<if test="deptId != null">
|
||||||
|
AND dept_id = #{deptId}
|
||||||
|
</if>
|
||||||
|
</where>
|
||||||
|
</select>
|
||||||
|
|
||||||
|
<select id="selectById" parameterType="long" resultMap="DeptGoodsCategoryResult">
|
||||||
|
<include refid="selectDeptGoodsCategory"/>
|
||||||
|
WHERE dept_goods_category_id = #{deptGoodsCategoryId}
|
||||||
|
</select>
|
||||||
</mapper>
|
</mapper>
|
||||||
Loading…
Reference in New Issue