From 8ef3cfe94b977f5f3eadc40233eb7eaddf53c485 Mon Sep 17 00:00:00 2001
From: zhongrj <646384940@qq.com>
Date: Fri, 17 May 2024 11:42:34 +0800
Subject: [PATCH] 新增警务网格处理

---
 vue.config.js                 |    4 
 src/views/community/index.vue |   42 ++--
 src/views/grid/jwGrid.vue     |  384 ++++++++++++++++++++++++++++++++++++++++++++++++
 src/api/grid/jwGrid.js        |   49 ++++++
 4 files changed, 456 insertions(+), 23 deletions(-)

diff --git a/src/api/grid/jwGrid.js b/src/api/grid/jwGrid.js
new file mode 100644
index 0000000..2bd1e2e
--- /dev/null
+++ b/src/api/grid/jwGrid.js
@@ -0,0 +1,49 @@
+import request from '@/router/axios';
+
+export const getList = (current, size, params) => {
+  return request({
+    url: '/api/blade-policeAffairsGrid/policeAffairsGrid/page',
+    method: 'get',
+    params: {
+      ...params,
+      current,
+      size,
+    }
+  })
+}
+
+export const remove = (ids) => {
+  return request({
+    url: '/api/blade-policeAffairsGrid/policeAffairsGrid/remove',
+    method: 'post',
+    params: {
+      ids,
+    }
+  })
+}
+
+export const add = (row) => {
+  return request({
+    url: '/api/blade-policeAffairsGrid/policeAffairsGrid/saveOrUpdate',
+    method: 'post',
+    data: row
+  })
+}
+
+export const update = (row) => {
+  return request({
+    url: '/api/blade-policeAffairsGrid/policeAffairsGrid/saveOrUpdate',
+    method: 'post',
+    data: row
+  })
+}
+
+export const getDetail = (id) => {
+  return request({
+    url: '/api/blade-policeAffairsGrid/policeAffairsGrid/detail',
+    method: 'get',
+    params: {
+      id
+    }
+  })
+}
\ No newline at end of file
diff --git a/src/views/community/index.vue b/src/views/community/index.vue
index 0335d83..b5d6bf4 100644
--- a/src/views/community/index.vue
+++ b/src/views/community/index.vue
@@ -57,7 +57,7 @@
                 selection: true,
                 dialogClickModal: false,
                 column: [{
-                    width: 156,
+                    // width: 156,
                     overHidden: true,
                     label: "社区名称",
                     prop: "name",
@@ -72,7 +72,7 @@
                     },],
                 },
                 {
-                    width: 110,
+                    // width: 110,
                     overHidden: true,
                     label: "社区编号",
                     prop: "code",
@@ -87,7 +87,7 @@
                 },
 
                 {
-                    width: 110,
+                    // width: 110,
                     label: "所属街道",
                     parent: false,
                     addDisplay: false,
@@ -116,25 +116,25 @@
                     },],
                 },
 
+                // {
+                //     width: 110,
+                //     label: "社区民警",
+                //     prop: "resPoliceUserId",
+                //     type: "tree",
+                //     multiple: true,
+                //     dicUrl: "/api/blade-system/user/getUserListByParam?roleName=民警",
+                //     props: {
+                //         label: "name",
+                //         value: "id"
+                //     },
+                //     rules: [{
+                //         required: true,
+                //         message: "请选择社区民警",
+                //         trigger: "blur",
+                //     },],
+                // },
                 {
-                    width: 110,
-                    label: "社区民警",
-                    prop: "resPoliceUserId",
-                    type: "tree",
-                    multiple: true,
-                    dicUrl: "/api/blade-system/user/getUserListByParam?roleName=民警",
-                    props: {
-                        label: "name",
-                        value: "id"
-                    },
-                    rules: [{
-                        required: true,
-                        message: "请选择社区民警",
-                        trigger: "blur",
-                    },],
-                },
-                {
-                    width: 110,
+                    // width: 110,
                     label: "社区图片",
                     prop: "picUrl",
                     type: "upload",
diff --git a/src/views/grid/jwGrid.vue b/src/views/grid/jwGrid.vue
new file mode 100644
index 0000000..7a2507c
--- /dev/null
+++ b/src/views/grid/jwGrid.vue
@@ -0,0 +1,384 @@
+<template>
+  <basic-container>
+    <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"
+      @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 size="small" icon="el-icon-delete" plain v-if="permission.grid_delete" @click="handleDelete">删 除
+        </el-button>
+      </template>
+      <template slot-scope="{row, size}" slot="principalPhone">
+        <el-button :size="size" type="text" @click="showStringDispose(row, 'principalPhoneflag')"
+          v-text="textDispose(row, 'principalPhoneflag', 'principalPhone')">
+        </el-button>
+      </template>
+    </avue-crud>
+  </basic-container>
+</template>
+
+<script>
+import {
+  getList,
+  remove,
+  update,
+  add,
+  getDetail
+} from "@/api/grid/jwGrid"
+import {
+  mapGetters
+} from "vuex"
+// import website from '@/config/website'
+export default {
+  data() {
+    //手机号格式校验
+    let validatorPhone = function (rule, value, callback) {
+      if (value) {
+        if (!/^1[3456789]\d{9}$/.test(value)) {
+          callback(new Error('手机号格式有误!'))
+        } else {
+          callback()
+        }
+      }
+      callback()
+    }
+
+    return {
+      form: {},
+      query: {},
+      loading: true,
+      page: {
+        pageSize: 10,
+        currentPage: 1,
+        total: 0,
+      },
+      datetime: "",
+      selectionList: [],
+      option: {
+        labelWidth: 96,
+        searchLabelWidth: 96,
+        searchShow: true,
+        searchMenuSpan: 3,
+        menuWidth: 210,
+        labelWidth: 150,
+        height: "auto",
+        calcHeight: 54,
+        dialogWidth: 950,
+        tip: false,
+        border: true,
+        //stripe:true,
+        index: true,
+        viewBtn: true,
+        selection: true,
+        dialogClickModal: false,
+        column: [
+          {
+          overHidden: true,
+          label: "所属派出所",
+          prop: "pcsCode",
+          searchSpan: 4,
+          type:"tree",
+          // search: true,
+          row: true,
+          hide:true,
+          dicUrl: "/api/blade-policeStation/policeStation/tree",
+          props: {
+            label: "name",
+            value: "id",
+          },
+          defaultExpandAll: true,
+          rules: [{
+            required: true,
+            message: "请选择所属派出所",
+            trigger: "blur",
+          },],
+        }, 
+        {
+          overHidden: true,
+          label: "所属派出所",
+          prop: "pcsName",
+          addDisplay: false,
+          editDisplay: false,
+          viewDisplay: false,
+          searchSpan: 4,
+          search: true,
+          row: true,
+          rules: [{
+            required: true,
+            message: "请输入网格名称",
+            trigger: "blur",
+          },],
+        }, 
+        {
+          overHidden: true,
+          label: "所属社区",
+          addDisplay: false,
+          editDisplay: false,
+          viewDisplay: false,
+          prop: "communityName",
+          search: true,
+          searchSpan: 4,
+          searchLabelWidth: 76,
+          rules: [{
+            required: true,
+            message: "请选择所属社区",
+            trigger: "blur",
+          }],
+        },
+        {
+          hide: true,
+          parent: false,
+          label: "所属社区",
+          prop: "communityCode",
+          search: false,
+          type: "tree",
+          dicUrl: "/api/blade-system/region/treeToCommunity",
+          row: true,
+          defaultExpandedKeys: ["361102"],
+          props: {
+            label: "name",
+            value: "id",
+          },
+          rules: [{
+            required: true,
+            message: "请选择所属社区",
+            trigger: "blur",
+          },],
+        },
+        {
+          overHidden: true,
+          label: "警务网格编号",
+          prop: "jwGridCode",
+          searchLabelWidth: 110,
+          searchSpan: 5,
+          search: true,
+          // width:120,
+          rules: [{
+            required: true,
+            message: "请输入网格编号",
+            trigger: "blur",
+          },],
+        },
+        {
+          label: "责任民警",
+          prop: "policeUserId",
+          type: "tree",
+          multiple: true,
+          dicUrl: "/api/blade-system/user/getUserListByParam?roleName=民警",
+          props: {
+            label: "name",
+            value: "id"
+          },
+          rules: [{
+            required: true,
+            message: "请选择责任民警",
+            trigger: "blur",
+          },],
+        },
+        // {
+        //   label: "责任民警联系电话",
+        //   prop: "principalPhone",
+        //   span: 12,
+        //   searchSpan: 4,
+        //   rules: [{
+        //     required: true,
+        //     message: "请输入联系电话",
+        //     trigger: "blur",
+        //   },
+        //   {
+        //     validator: validatorPhone,
+        //     trigger: 'blur'
+        //   }
+        //   ],
+        //   slot: true
+        // },
+        {
+          label: "区域",
+          prop: "geom",
+          type: "textarea",
+          hide: true,
+          span: 24,
+          display: false,
+          rules: [{
+            required: true,
+            message: "请输入区域",
+            trigger: "blur",
+          },],
+        }
+        ],
+      },
+      data: [],
+    }
+  },
+  watch: {},
+  computed: {
+    ...mapGetters(["permission", "userInfo"]),
+    permissionList() {
+      return {
+        addBtn: this.vaildData(this.permission.grid_add, true),
+        viewBtn: this.vaildData(this.permission.grid_view, true),
+        delBtn: this.vaildData(this.permission.grid_delete, true),
+        editBtn: this.vaildData(this.permission.grid_edit, true),
+      }
+    },
+    ids() {
+      let ids = []
+      this.selectionList.forEach((ele) => {
+        ids.push(ele.id)
+      })
+      return ids.join(",")
+    },
+
+    textDispose() {
+      return (row, flag, type) => {
+        if (row[flag] || row[type] == null) {
+          return row[type]
+        } else {
+          if (type == 'principalIdCard') {
+            return row[type].replace(/^(.{6})(?:\d+)(.{4})$/, "$1******$2")
+          } else {
+            return row[type].replace(/^(.{3})(?:\d+)(.{4})$/, "$1****$2")
+          }
+        }
+      }
+    }
+  },
+  methods: {
+    showStringDispose(row, type) {
+      row[type] = !row[type]
+    },
+
+    rowSave(row, done, loading) {
+      add(row).then(
+        () => {
+          this.onLoad(this.page)
+          this.$message({
+            type: "success",
+            message: "操作成功!",
+          })
+          done()
+        },
+        (error) => {
+          window.console.log(error)
+          loading()
+        }
+      )
+    },
+    rowUpdate(row, index, done, loading) {
+      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)) {
+      //   getGrid(this.form.id).then((res) => {
+      //     this.form = res.data.data
+      //   })
+      // }
+      // con
+      done()
+    },
+    currentChange(currentPage) {
+      this.page.currentPage = currentPage
+    },
+    sizeChange(pageSize) {
+      this.page.pageSize = pageSize
+    },
+    refreshChange() {
+      this.onLoad(this.page, this.query)
+    },
+    onLoad(page, params = {}) {
+      this.loading = true
+
+      getList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then((res) => {
+        const data = {
+          ...res.data.data,
+          records: res.data.data.records.map(item => {
+            return {
+              ...item,
+              'principalPhoneflag': false
+            }
+          })
+        }
+        this.page.total = data.total
+        this.data = data.records
+        this.loading = false
+        this.selectionClear()
+      })
+    }
+  }
+}
+</script>
+
+<style>
+.avue-upload__icon {
+  line-height: 6;
+}
+</style>
\ No newline at end of file
diff --git a/vue.config.js b/vue.config.js
index a47489b..c823fab 100644
--- a/vue.config.js
+++ b/vue.config.js
@@ -54,8 +54,8 @@
       },
       "/api": {
         //本地服务接口地址
-        // target: "http://192.168.31.188:9528",
-        target: "https://srgdjczzxtpt.com:2080/api",
+        target: "http://192.168.1.50:9528",
+        // target: "https://srgdjczzxtpt.com:2080/api",
         // target: "https://kt39592615.goho.co",
         // target: "http://z4042833u6.wicp.vip",
         // target: "http://localhost:9528",

--
Gitblit v1.9.3