From 42e8cb4d1c9655e161df8088473d0b943d879e37 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Tue, 14 Dec 2021 11:54:58 +0800
Subject: [PATCH] 20211214

---
 src/main/java/cc/mrbird/febs/video/controller/AdminVideoController.java       |   70 ++++++++
 src/main/java/cc/mrbird/febs/video/mapper/VideoCategoryMapper.java            |   11 +
 src/main/java/cc/mrbird/febs/video/service/IVideoCategoryService.java         |   14 +
 src/main/resources/templates/febs/views/video/test                            |    0 
 src/main/resources/mapper/video/VideoCategoryMapper.xml                       |    8 +
 src/main/java/cc/mrbird/febs/video/service/impl/VideoCategoryServiceImpl.java |   60 +++++++
 src/main/java/cc/mrbird/febs/video/entity/VideoCategoryEntity.java            |    2 
 src/main/resources/templates/febs/views/video/video/category.html             |  237 +++++++++++++++++++++++++++++
 pom.xml                                                                       |    4 
 src/main/java/cc/mrbird/febs/common/entity/DeptTree.java                      |    2 
 src/main/java/cc/mrbird/febs/video/controller/ViewController.java             |   20 ++
 11 files changed, 425 insertions(+), 3 deletions(-)

diff --git a/pom.xml b/pom.xml
index 0af040f..48804c6 100644
--- a/pom.xml
+++ b/pom.xml
@@ -19,18 +19,18 @@
         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
         <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
         <mybatis.plus.version>3.3.1</mybatis.plus.version>
-        <hutool.version>5.3.1</hutool.version>
         <swagger.ui>2.9.2</swagger.ui>
         <tomcat.version>9.0.31</tomcat.version>
+        <hutool.version>5.3.1</hutool.version>
     </properties>
 
     <dependencies>
-
         <dependency>
             <groupId>cn.hutool</groupId>
             <artifactId>hutool-all</artifactId>
             <version>${hutool.version}</version>
         </dependency>
+
         <!-- Spring系列 -->
         <dependency>
             <groupId>org.springframework.boot</groupId>
diff --git a/src/main/java/cc/mrbird/febs/common/entity/DeptTree.java b/src/main/java/cc/mrbird/febs/common/entity/DeptTree.java
index eae7980..30181b3 100644
--- a/src/main/java/cc/mrbird/febs/common/entity/DeptTree.java
+++ b/src/main/java/cc/mrbird/febs/common/entity/DeptTree.java
@@ -28,7 +28,7 @@
     private boolean hasParent = false;
     private boolean hasChild = false;
 
-    private Dept data;
+    private T data;
 
     public void initChildren(){
         this.children = new ArrayList<>();
diff --git a/src/main/java/cc/mrbird/febs/video/controller/AdminVideoController.java b/src/main/java/cc/mrbird/febs/video/controller/AdminVideoController.java
new file mode 100644
index 0000000..f45fd9d
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/video/controller/AdminVideoController.java
@@ -0,0 +1,70 @@
+package cc.mrbird.febs.video.controller;
+
+import cc.mrbird.febs.common.annotation.ControllerEndpoint;
+import cc.mrbird.febs.common.entity.DeptTree;
+import cc.mrbird.febs.common.entity.FebsResponse;
+import cc.mrbird.febs.system.entity.Dept;
+import cc.mrbird.febs.video.entity.VideoCategoryEntity;
+import cc.mrbird.febs.video.service.IVideoCategoryService;
+import com.baomidou.mybatisplus.core.toolkit.StringPool;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.shiro.authz.annotation.RequiresPermissions;
+import org.springframework.web.bind.annotation.*;
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.StrUtil;
+
+import javax.validation.constraints.NotBlank;
+import java.util.Date;
+import java.util.List;
+
+/**
+ * @author wzy
+ * @date 2021-12-13
+ **/
+@Slf4j
+@RestController
+@RequiredArgsConstructor
+@RequestMapping("video")
+public class AdminVideoController {
+
+    private final IVideoCategoryService videoCategoryService;
+
+    @GetMapping("/allCategory")
+    public List<DeptTree<VideoCategoryEntity>> allCategory() {
+        return this.videoCategoryService.findVideoCategory();
+    }
+
+    @GetMapping("/categoryTree")
+    @ControllerEndpoint(exceptionMessage = "获取视频分类失败")
+    public FebsResponse categoryTree(VideoCategoryEntity category) {
+        List<DeptTree<VideoCategoryEntity>> depts = this.videoCategoryService.categoryTree(category);
+        return new FebsResponse().success().data(depts);
+    }
+
+    @PostMapping("/addCate")
+    @RequiresPermissions("category:add")
+    @ControllerEndpoint(operation = "新增分类", exceptionMessage = "新增分类失败")
+    public FebsResponse addCate(VideoCategoryEntity category) {
+        this.videoCategoryService.save(category);
+        return new FebsResponse().success();
+    }
+
+    @PostMapping("/updateCate")
+    @RequiresPermissions("category:update")
+    @ControllerEndpoint(operation = "修改分类", exceptionMessage = "修改分类失败")
+    public FebsResponse updateCate(VideoCategoryEntity category) {
+        category.setUpdatedTime(new Date());
+        this.videoCategoryService.updateById(category);
+        return new FebsResponse().success();
+    }
+
+    @GetMapping("/delCate/{cateIds}")
+    @RequiresPermissions("category:update")
+    @ControllerEndpoint(operation = "修改分类", exceptionMessage = "修改分类失败")
+    public FebsResponse delCate(@NotBlank(message = "{required}") @PathVariable String cateIds) {
+        List<String> ids = StrUtil.split(cateIds, ',');
+        this.videoCategoryService.removeByIds(ids);
+        return new FebsResponse().success();
+    }
+}
diff --git a/src/main/java/cc/mrbird/febs/video/controller/ViewController.java b/src/main/java/cc/mrbird/febs/video/controller/ViewController.java
new file mode 100644
index 0000000..1e22ddb
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/video/controller/ViewController.java
@@ -0,0 +1,20 @@
+package cc.mrbird.febs.video.controller;
+
+import cc.mrbird.febs.common.entity.FebsConstant;
+import cc.mrbird.febs.common.utils.FebsUtil;
+import lombok.RequiredArgsConstructor;
+import org.apache.shiro.authz.annotation.RequiresPermissions;
+import org.springframework.stereotype.Controller;
+import org.springframework.web.bind.annotation.GetMapping;
+
+@Controller("videoView")
+@RequiredArgsConstructor
+public class ViewController {
+
+
+    @GetMapping(FebsConstant.VIEW_PREFIX + "video/category")
+    @RequiresPermissions("category:view")
+    public String systemMenu() {
+        return FebsUtil.view("video/video/category");
+    }
+}
diff --git a/src/main/java/cc/mrbird/febs/video/entity/VideoCategoryEntity.java b/src/main/java/cc/mrbird/febs/video/entity/VideoCategoryEntity.java
index e5cab88..43e988a 100644
--- a/src/main/java/cc/mrbird/febs/video/entity/VideoCategoryEntity.java
+++ b/src/main/java/cc/mrbird/febs/video/entity/VideoCategoryEntity.java
@@ -11,4 +11,6 @@
     private String name;
 
     private Long parentId;
+
+    private Integer seq;
 }
diff --git a/src/main/java/cc/mrbird/febs/video/mapper/VideoCategoryMapper.java b/src/main/java/cc/mrbird/febs/video/mapper/VideoCategoryMapper.java
new file mode 100644
index 0000000..9f01189
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/video/mapper/VideoCategoryMapper.java
@@ -0,0 +1,11 @@
+package cc.mrbird.febs.video.mapper;
+
+import cc.mrbird.febs.video.entity.VideoCategoryEntity;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+import java.util.List;
+
+public interface VideoCategoryMapper extends BaseMapper<VideoCategoryEntity> {
+
+    List<VideoCategoryEntity> selectAllCategory();
+}
diff --git a/src/main/java/cc/mrbird/febs/video/service/IVideoCategoryService.java b/src/main/java/cc/mrbird/febs/video/service/IVideoCategoryService.java
new file mode 100644
index 0000000..01097b8
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/video/service/IVideoCategoryService.java
@@ -0,0 +1,14 @@
+package cc.mrbird.febs.video.service;
+
+import cc.mrbird.febs.common.entity.DeptTree;
+import cc.mrbird.febs.video.entity.VideoCategoryEntity;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+import java.util.List;
+
+public interface IVideoCategoryService extends IService<VideoCategoryEntity> {
+
+    List<DeptTree<VideoCategoryEntity>> findVideoCategory();
+
+    List<DeptTree<VideoCategoryEntity>> categoryTree(VideoCategoryEntity category);
+}
diff --git a/src/main/java/cc/mrbird/febs/video/service/impl/VideoCategoryServiceImpl.java b/src/main/java/cc/mrbird/febs/video/service/impl/VideoCategoryServiceImpl.java
new file mode 100644
index 0000000..995452c
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/video/service/impl/VideoCategoryServiceImpl.java
@@ -0,0 +1,60 @@
+package cc.mrbird.febs.video.service.impl;
+
+import cc.mrbird.febs.common.entity.DeptTree;
+import cc.mrbird.febs.common.utils.TreeUtil;
+import cc.mrbird.febs.system.entity.Dept;
+import cc.mrbird.febs.video.entity.VideoCategoryEntity;
+import cc.mrbird.febs.video.mapper.VideoCategoryMapper;
+import cc.mrbird.febs.video.service.IVideoCategoryService;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.stereotype.Service;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * @author wzy
+ * @date 2021-12-14
+ **/
+@Slf4j
+@Service
+@RequiredArgsConstructor
+public class VideoCategoryServiceImpl extends ServiceImpl<VideoCategoryMapper, VideoCategoryEntity> implements IVideoCategoryService {
+    @Override
+    public List<DeptTree<VideoCategoryEntity>> findVideoCategory() {
+        List<VideoCategoryEntity> list = this.baseMapper.selectList(null);
+        return convertTree(list);
+    }
+
+    @Override
+    public List<DeptTree<VideoCategoryEntity>> categoryTree(VideoCategoryEntity category) {
+        QueryWrapper<VideoCategoryEntity> queryWrapper = new QueryWrapper<>();
+
+        if (StringUtils.isNotBlank(category.getName())) {
+            queryWrapper.lambda().eq(VideoCategoryEntity::getName, category.getName());
+        }
+        queryWrapper.lambda().orderByAsc(VideoCategoryEntity::getSeq);
+
+        List<VideoCategoryEntity> list = this.baseMapper.selectList(null);
+        List<DeptTree<VideoCategoryEntity>> trees = convertTree(list);
+
+        return TreeUtil.buildDeptTree(trees);
+    }
+
+    private List<DeptTree<VideoCategoryEntity>> convertTree(List<VideoCategoryEntity> list) {
+        List<DeptTree<VideoCategoryEntity>> trees = new ArrayList<>();
+        list.forEach(category -> {
+            DeptTree<VideoCategoryEntity> tree = new DeptTree<>();
+            tree.setId(String.valueOf(category.getId()));
+            tree.setParentId(String.valueOf(category.getParentId()));
+            tree.setName(category.getName());
+            tree.setData(category);
+            trees.add(tree);
+        });
+        return trees;
+    }
+}
diff --git a/src/main/resources/mapper/video/VideoCategoryMapper.xml b/src/main/resources/mapper/video/VideoCategoryMapper.xml
new file mode 100644
index 0000000..c45d988
--- /dev/null
+++ b/src/main/resources/mapper/video/VideoCategoryMapper.xml
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="cc.mrbird.febs.video.mapper.VideoCategoryMapper">
+
+    <select id="selectAllCategory" resultType="cc.mrbird.febs.video.entity.VideoCategoryEntity">
+        select * from video_category
+    </select>
+</mapper>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/video/test b/src/main/resources/templates/febs/views/video/test
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/src/main/resources/templates/febs/views/video/test
diff --git a/src/main/resources/templates/febs/views/video/video/category.html b/src/main/resources/templates/febs/views/video/video/category.html
new file mode 100644
index 0000000..a4079df
--- /dev/null
+++ b/src/main/resources/templates/febs/views/video/video/category.html
@@ -0,0 +1,237 @@
+<div class="layui-fluid layui-anim febs-anim" id="febs-category" lay-title="视频分类管理">
+    <div class="layui-row layui-col-space8 febs-container">
+        <div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
+            <div class="layui-card">
+                <div class="layui-card-body febs-table-full">
+                    <form class="layui-form layui-table-form" lay-filter="dept-table-form" id="dept-table-form">
+                        <div class="layui-row">
+                            <div class="layui-col-md8 layui-col-sm9 layui-col-xs9">
+                                <div class="layui-form-item">
+                                    <div class="layui-inline">
+                                        <label class="layui-form-label layui-form-label-sm">名称</label>
+                                        <div class="layui-input-inline">
+                                            <input type="text" name="name" autocomplete="off" class="layui-input">
+                                        </div>
+                                    </div>
+                                </div>
+                            </div>
+                            <div class="layui-col-md4 layui-col-sm12 layui-col-xs12 table-action-area">
+                                <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain  table-action" id="query">
+                                    <i class="layui-icon">&#xe848;</i>
+                                </div>
+                                <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain  table-action" id="reset">
+                                    <i class="layui-icon">&#xe79b;</i>
+                                </div>
+                                <div class="layui-btn layui-btn-sm layui-btn-primary table-action action-more"
+                                     shiro:hasAnyPermissions="category:add,category:del">
+                                    <i class="layui-icon">&#xe875;</i>
+                                </div>
+                            </div>
+                        </div>
+                    </form>
+                    <div class="dept-tree" lay-filter="cateTree" style="margin-left: 1rem"></div>
+                </div>
+            </div>
+        </div>
+        <div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
+            <div class="layui-card">
+                <div class="layui-card-header" id="form-header">新增分类</div>
+                <div class="layui-card-body febs-table-full">
+                    <form class="layui-form layui-table-form" action="" lay-filter="cate-form">
+                        <div class="layui-form-item febs-hide">
+                            <label class="layui-form-label febs-form-item-require">ID:</label>
+                            <div class="layui-input-block">
+                                <input type="text" name="id" class="layui-input">
+                            </div>
+                        </div>
+                        <div class="layui-form-item">
+                            <label class="layui-form-label">上级ID:</label>
+                            <div class="layui-input-block">
+                                <input type="text" value="" name="parentId" readonly autocomplete="off"
+                                       class="layui-input">
+                            </div>
+                        </div>
+                        <div class="layui-form-item">
+                            <label class="layui-form-label febs-form-item-require">分类名称:</label>
+                            <div class="layui-input-block">
+                                <input type="text" name="name" autocomplete="off" class="layui-input"
+                                       minlength="2" maxlength="10" lay-verify="range">
+                            </div>
+                        </div>
+                        <div class="layui-form-item">
+                            <label class="layui-form-label">分类排序:</label>
+                            <div class="layui-input-block">
+                                <input type="text" name="seq" autocomplete="off" class="layui-input"
+                                       lay-verify="number">
+                            </div>
+                        </div>
+                        <button type="reset" class="layui-btn febs-hide" id="reset-form"></button>
+                        <button class="layui-btn febs-hide" lay-submit="" lay-filter="cate-form-submit"
+                                id="submit-form"></button>
+                    </form>
+                </div>
+                <div class="layui-card-footer">
+                    <button class="layui-btn layui-btn-normal" id="submit">保存</button>
+                </div>
+            </div>
+        </div>
+    </div>
+</div>
+<script data-th-inline="javascript" type="text/javascript">
+    layui.use(['dropdown', 'jquery', 'validate', 'febs', 'form', 'eleTree'], function () {
+        var $ = layui.jquery,
+            febs = layui.febs,
+            form = layui.form,
+            validate = layui.validate,
+            eleTree = layui.eleTree,
+            dropdown = layui.dropdown,
+            $view = $('#febs-category'),
+            $query = $view.find('#query'),
+            $reset = $view.find('#reset'),
+            $submit = $view.find('#submit'),
+            $header = $view.find('#form-header'),
+            $searchForm = $view.find('#dept-table-form'),
+            $name = $searchForm.find('input[name="name"]'),
+            _currentDeptData,
+            _cateTree;
+
+        form.verify(validate);
+        form.render();
+
+        renderCateTree();
+
+        eleTree.on("nodeClick(cateTree)", function (d) {
+            $header.text('修改分类');
+            var data = d.data.currentData.data;
+            _currentDeptData = data;
+            form.val("cate-form", {
+                "name": data.name,
+                "seq": data.seq,
+                "parentId": data.parentId,
+                "id": data.id
+            });
+        });
+
+        dropdown.render({
+            elem: $view.find('.action-more'),
+            click: function (name, elem, event) {
+                if (name === 'add') {
+                    reset();
+                    var selected = _cateTree.getChecked(false, true);
+                    if (selected.length > 1) {
+                        febs.alert.warn('只能选择一个节点作为父级!');
+                        return;
+                    }
+                    form.val("cate-form", {
+                        "parentId": selected[0] ? selected[0].id : ''
+                    });
+                }
+                if (name === 'delete') {
+                    var checked = _cateTree.getChecked(false, true);
+                    if (checked.length < 1) {
+                        febs.alert.warn('请勾选需要删除的部门');
+                        return;
+                    }
+                    var cateIds = [];
+                    layui.each(checked, function (key, item) {
+                        cateIds.push(item.id)
+                    });
+                    febs.modal.confirm('提示', '当您点击确定按钮后,这些记录将会被彻底删除,如果其包含子记录,也将一并删除!', function () {
+                        febs.get(ctx + 'video/delCate/' + cateIds.join(','), null, function () {
+                            febs.alert.success('删除成功!');
+                            reloadCateTree();
+                            reset();
+                        })
+                    });
+                }
+            },
+            options: [{
+                name: 'add',
+                title: '新增分类',
+                perms: 'category:add'
+            }, {
+                name: 'delete',
+                title: '删除分类',
+                perms: 'category:del'
+            }]
+        });
+
+        $view.on('click', '#submit', function () {
+            $view.find('#submit-form').trigger('click');
+        });
+
+        $reset.on('click', function () {
+            $name.val('');
+            reloadCateTree();
+            reset();
+        });
+
+        $query.on('click', function () {
+            reloadCateTree();
+        });
+
+        function getQueryParams() {
+            return {
+                "name": $name.val().trim()
+            }
+        }
+
+        function reset() {
+            $header.text('新增分类');
+            $view.find('#reset-form').trigger('click');
+        }
+
+        function renderCateTree() {
+            _cateTree = eleTree.render({
+                elem: '.dept-tree',
+                url: ctx + 'video/categoryTree',
+                accordion: true,
+                highlightCurrent: true,
+                showCheckbox: true,
+                checkStrictly: true,
+                renderAfterExpand: false,
+                where: {
+                    "name": $name.val().trim(),
+                    "invalidate_ie_cache": new Date()
+                },
+                request: {
+                    name: 'name',
+                    key: "id",
+                    checked: "checked",
+                    data: 'data'
+                },
+                response: {
+                    statusName: "code",
+                    statusCode: 200,
+                    dataName: "data"
+                }
+            });
+            return _cateTree;
+        }
+
+        function reloadCateTree() {
+            _cateTree = renderCateTree();
+        }
+
+        form.on('submit(cate-form-submit)', function (data) {
+            if (data.field.id && $header.text().indexOf('修改') !== -1) {
+                if (febs.nativeEqual(data.field, _currentDeptData)) {
+                    febs.alert.warn('数据未作任何修改!');
+                    return false;
+                }
+                febs.post(ctx + 'video/updateCate', data.field, function () {
+                    febs.alert.success('修改成功');
+                    reloadCateTree();
+                    reset();
+                })
+            } else {
+                febs.post(ctx + 'video/addCate', data.field, function () {
+                    febs.alert.success('新增成功');
+                    reloadCateTree();
+                    reset();
+                })
+            }
+            return false;
+        });
+    });
+</script>
\ No newline at end of file

--
Gitblit v1.9.1