保安监管系统-验收版本
zhengpz
2021-12-02 d3ed55cf51ced9a280a453a8b63b51b88d9184ba
Merge branch 'master' of http://s16s652780.51mypc.cn:49896/r/zhba_regulatory_ys
2 files modified
1 files added
538 ■■■■■ changed files
src/api/desk/notice.js 8 ●●●● patch | view | raw | blame | history
src/views/desk/notice.vue 55 ●●●●● patch | view | raw | blame | history
src/views/desk/notice懒加载.vue 475 ●●●●● patch | view | raw | blame | history
src/api/desk/notice.js
@@ -16,10 +16,10 @@
    return request({
        url: '/api/blade-system/dept/lazy-tree-user',
        method: 'get',
        params: {
            ...params,
            type: 4,
        }
        // params: {
        //     ...params,
        //     type: 4,
        // }
    })
}
src/views/desk/notice.vue
@@ -62,8 +62,6 @@
export default {
  data() {
    let deptid = this.$store.state.user.userInfo.dept_id,
      dicUrl = `/api/blade-system/dept/lazy-tree-user?parentId=`;
    return {
      form: {},
      query: {},
@@ -146,43 +144,12 @@
            span: 24,
            type: "tree",
            // lazy: true,
            dicUrl: dicUrl,
            // dicUrl: "/api/blade-system/dept/lazy-tree-user?type={{key}}",
            hide: true,
            leafOnly: true,
            props: {
              label: "title",
              value: "id",
            },
            lazy: true,
            treeLoad: (node, resolve) => {
              let stop_level = 1;
              let level = node.level;
              let data = node.data || {};
              let deptid = data.id;
              let list = [];
              let callback = () => {
                resolve(
                  (list || []).map((ele) => {
                    return Object.assign(ele, {
                      leaf: level >= stop_level,
                    });
                  })
                );
              };
              if (level == 0) {
                axios.get(`${dicUrl}`).then((res) => {
                  list = res.data.data;
                  callback();
                });
              } else if (level == 1) {
                axios.get(`${dicUrl}${deptid}`).then((res) => {
                  list = res.data.data;
                  callback();
                });
              } else {
                list = [];
                callback();
              }
            },
            multiple: true,
            // dataType: "number",
@@ -293,6 +260,19 @@
      return ids.join(",");
    },
  },
  mounted() {
    // this.getDeptInfo(this.userInfo.dept_id);
    getPeopleList({ deptId: this.userInfo.dept_id }).then((res) => {
      const columnReceivedIds = this.findObject(
        this.option.column,
        "receivedIds"
      );
      // console.log(columnReceivedIds, res.data.data, 6456);
      columnReceivedIds.dicData = res.data.data;
    });
  },
  methods: {
    //跳转到附近列表页面
    handleUploadPage(row) {
@@ -305,7 +285,7 @@
      });
    },
    rowSave(row, done, loading) {
      row.category = 2;
      // row.category = 2;
      row.deptId = this.deptId;
      row["type"] = 1;
      var rece = "";
@@ -316,6 +296,9 @@
        }
      }
      row.receivedIds = rece;
      // console.log(row);
      // done();
      // return;
      add(row).then(
        () => {
          this.onLoad(this.page);
@@ -332,7 +315,7 @@
      );
    },
    rowUpdate(row, index, done, loading) {
      row.category = 2;
      // row.category = 2;
      row.deptId = this.deptId;
      update(row).then(
        () => {
src/views/desk/notice懒加载.vue
New file
@@ -0,0 +1,475 @@
<template>
  <basic-container class="notice">
    <avue-crud
      :option="option"
      :table-loading="loading"
      :data="data"
      :page.sync="page"
      ref="crud"
      @row-del="rowDel"
      v-model="form"
      :permission="permissionList"
      @row-update="rowUpdate"
      @row-save="rowSave"
      :before-open="beforeOpen"
      @filter="filterChange"
      @search-change="searchChange"
      @search-reset="searchReset"
      @selection-change="selectionChange"
      @current-change="currentChange"
      @size-change="sizeChange"
      @refresh-change="refreshChange"
      @on-load="onLoad"
    >
      <template slot="menuLeft">
        <el-button
          type="danger"
          size="small"
          icon="el-icon-delete"
          plain
          v-if="permission.notice_delete"
          @click="handleDelete"
          >删 除
        </el-button>
        <!-- v-if="permission.notice_delete" -->
      </template>
      <template slot-scope="{ row }" slot="category">
        <el-tag>{{ row.categoryName }}</el-tag>
      </template>
      <template slot-scope="{ type, size, row }" slot="menu">
        <el-button
          :size="size"
          :type="type"
          @click="handleUploadPage(row)"
          v-if="permission.notice_upload"
          >附件上传
        </el-button>
      </template>
    </avue-crud>
  </basic-container>
</template>
<script>
import {
  getListPage,
  remove,
  update,
  add,
  getNotice,
  getPeopleList,
} from "@/api/desk/notice";
import { mapGetters } from "vuex";
export default {
  data() {
    let deptid = this.$store.state.user.userInfo.dept_id,
      dicUrl = `/api/blade-system/dept/lazy-tree-user?parentId=`;
    return {
      form: {},
      query: {},
      loading: true,
      deptCategory: "",
      deptId: "",
      userId: "",
      permissionAdd: "",
      permissionDelete: "",
      permissionView: "",
      permissionEdit: "",
      page: {
        pageSize: 10,
        currentPage: 1,
        total: 0,
      },
      selectionList: [],
      option: {
        height: "auto",
        calcHeight: 30,
        dialogWidth: 950,
        tip: false,
        searchShow: true,
        searchShowBtn: false,
        searchMenuSpan: 6,
        border: false,
        index: true,
        // stripe: true,
        viewBtn: true,
        selection: true,
        excelBtn: false,
        menuWidth: 380,
        dialogClickModal: false,
        addBtnText: "发布",
        addTitle: "发布",
        saveBtnText: "发布",
        column: [
          {
            label: "通知标题",
            prop: "title",
            span: 24,
            searchSpan: 4,
            row: true,
            search: true,
            rules: [
              {
                required: true,
                message: "请输入通知标题",
                trigger: "blur",
              },
            ],
          },
          {
            label: "通知类型",
            type: "select",
            dicUrl: "/api/blade-system/dict/dictionary?code=notice",
            props: {
              label: "dictValue",
              value: "dictKey",
            },
            dataType: "number",
            slot: true,
            // addDisplay: false,
            // editDisplay: false,
            defaultValue: "1",
            prop: "category",
            search: true,
            searchSpan: 4,
            rules: [
              {
                required: true,
                message: "请输入通知类型",
                trigger: "blur",
              },
            ],
          },
          {
            label: "接收人",
            prop: "receivedIds",
            span: 24,
            type: "tree",
            // lazy: true,
            dicUrl: dicUrl,
            hide: true,
            leafOnly: true,
            props: {
              label: "title",
              value: "id",
            },
            lazy: true,
            treeLoad: (node, resolve) => {
              let stop_level = 1;
              let level = node.level;
              let data = node.data || {};
              let deptid = data.id;
              let list = [];
              let callback = () => {
                resolve(
                  (list || []).map((ele) => {
                    return Object.assign(ele, {
                      leaf: level >= stop_level,
                    });
                  })
                );
              };
              if (level == 0) {
                axios.get(`${dicUrl}`).then((res) => {
                  list = res.data.data;
                  callback();
                });
              } else if (level == 1) {
                axios.get(`${dicUrl}${deptid}`).then((res) => {
                  list = res.data.data;
                  callback();
                });
              } else {
                list = [];
                callback();
              }
            },
            multiple: true,
            // dataType: "number",
            rules: [
              {
                required: true,
                message: "请选择接收人",
                trigger: "blur",
              },
            ],
          },
          {
            label: "接收人",
            prop: "receivedName",
            addDisplay: false,
            editDisplay: false,
            viewDisplay: false,
          },
          {
            label: "发布单位",
            prop: "deptId",
            type: "tree",
            dicUrl: "/api/blade-system/dept/lazy-tree",
            props: {
              label: "title",
              value: "id",
            },
            addDisplay: false,
            editDisplay: false,
            rules: [
              {
                required: true,
                message: "所属组织机构",
                trigger: "click",
              },
            ],
          },
          {
            label: "通知时间",
            prop: "releaseTimeRange",
            type: "datetime",
            format: "yyyy-MM-dd",
            valueFormat: "yyyy-MM-dd",
            searchRange: true,
            hide: true,
            addDisplay: false,
            editDisplay: false,
            viewDisplay: false,
            search: true,
            searchSpan: 6,
            rules: [
              {
                required: true,
                message: "请输入通知时间",
                trigger: "blur",
              },
            ],
          },
          {
            label: "通知日期",
            prop: "releaseTime",
            type: "date",
            format: "yyyy-MM-dd hh:mm:ss",
            valueFormat: "yyyy-MM-dd hh:mm:ss",
            rules: [
              {
                required: true,
                message: "请输入通知日期",
                trigger: "click",
              },
            ],
          },
          {
            label: "通知内容",
            prop: "content",
            component: "AvueUeditor",
            // options: {
            //     action: "/api/blade-resource/oss/endpoint/put-file",
            //     props: {
            //         res: "data",
            //         url: "link",
            //     },
            // },
            hide: false,
            minRows: 6,
            span: 24,
          },
        ],
      },
      data: [],
    };
  },
  computed: {
    ...mapGetters(["permission", "userInfo"]),
    permissionList() {
      return {
        addBtn: this.vaildData(this.permission.notice_add, false),
        viewBtn: this.vaildData(this.permission.notice_view, false),
        delBtn: this.vaildData(this.permission.notice_delete, false),
        editBtn: this.vaildData(this.permission.notice_edit, false),
      };
    },
    ids() {
      let ids = [];
      this.selectionList.forEach((ele) => {
        ids.push(ele.id);
      });
      return ids.join(",");
    },
  },
  methods: {
    //跳转到附近列表页面
    handleUploadPage(row) {
      this.$router.push({
        path: `/resource/uploadNotice`,
        query: {
          deptId: row.deptId,
          noticeId: row.id,
        },
      });
    },
    rowSave(row, done, loading) {
      row.category = 2;
      row.deptId = this.deptId;
      row["type"] = 1;
      var rece = "";
      for (let k in row.receivedIds) {
        rece += row.receivedIds[k];
        if (k != row.receivedIds.length - 1) {
          rece += ",";
        }
      }
      row.receivedIds = rece;
      // console.log(row)
      // return
      add(row).then(
        () => {
          this.onLoad(this.page);
          this.$message({
            type: "success",
            message: "操作成功!",
          });
          done();
        },
        (error) => {
          window.console.log(error);
          loading();
        }
      );
    },
    rowUpdate(row, index, done, loading) {
      row.category = 2;
      row.deptId = this.deptId;
      console.log(row);
      return;
      update(row).then(
        () => {
          this.onLoad(this.page);
          this.$message({
            type: "success",
            message: "操作成功!",
          });
          done();
        },
        (error) => {
          window.console.log(error);
          loading();
        }
      );
    },
    rowDel(row) {
      this.$confirm("确定将选择数据删除?", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          return remove(row.id);
        })
        .then(() => {
          this.onLoad(this.page);
          this.$message({
            type: "success",
            message: "操作成功!",
          });
        });
    },
    searchReset() {
      this.query = {};
      this.onLoad(this.page);
    },
    searchChange(params, done) {
      this.query = params;
      this.page.currentPage = 1;
      this.onLoad(this.page, params);
      done();
    },
    selectionChange(list) {
      this.selectionList = list;
    },
    selectionClear() {
      this.selectionList = [];
      this.$refs.crud.toggleSelection();
    },
    handleDelete() {
      if (this.selectionList.length === 0) {
        this.$message.warning("请选择至少一条数据");
        return;
      }
      this.$confirm("确定将选择数据删除?", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          return remove(this.ids);
        })
        .then(() => {
          this.onLoad(this.page);
          this.$message({
            type: "success",
            message: "操作成功!",
          });
          this.$refs.crud.toggleSelection();
        });
    },
    beforeOpen(done, type) {
      if (["edit", "view"].includes(type)) {
        getNotice(this.form.id).then((res) => {
          this.form = res.data.data;
        });
      }
      if (type == "edit") {
        let ceec = this.form.receivedIds.split(",");
        this.form.receivedIds = ceec;
        // console.log(type, ceec);
      }
      done();
    },
    currentChange(currentPage) {
      this.page.currentPage = currentPage;
    },
    sizeChange(pageSize) {
      this.page.pageSize = pageSize;
    },
    refreshChange() {
      this.onLoad(this.page, this.query);
    },
    onLoad(page, params = {}) {
      this.deptId = JSON.parse(
        window.localStorage.getItem("saber-userInfo")
      ).content.dept_id;
      this.userId = JSON.parse(
        window.localStorage.getItem("saber-userInfo")
      ).content.user_id;
      if (this.deptId != 1123598813738675201) {
        params["deptId"] = this.deptId;
      }
      params["type"] = 1;
      const { releaseTimeRange } = this.query;
      let values = {
        ...params,
      };
      if (releaseTimeRange) {
        values = {
          ...params,
          startTime: releaseTimeRange[0],
          endTime: releaseTimeRange[1],
          ...this.query,
        };
        values.releaseTimeRange = null;
      }
      this.loading = true;
      getListPage(page.currentPage, page.pageSize, values).then((res) => {
        const data = res.data.data;
        this.page.total = data.total;
        this.data = data.records;
        this.loading = false;
        this.selectionClear();
      });
    },
  },
};
</script>
<style>
</style>