上饶市警务平台后台管理前端
zhongrj
2024-05-08 d28aa85c277bc510f9ade4d8c99623054b3fc3b2
可用资源图页面搭建接入
4 files added
1207 ■■■■■ changed files
src/api/three/resPic.js 62 ●●●●● patch | view | raw | blame | history
src/api/three/riskHidDangPic.js 62 ●●●●● patch | view | raw | blame | history
src/views/three/resPic/resPic.vue 538 ●●●●● patch | view | raw | blame | history
src/views/three/riskHidDangPic/riskHidDangPic.vue 545 ●●●●● patch | view | raw | blame | history
src/api/three/resPic.js
New file
@@ -0,0 +1,62 @@
import request from '@/router/axios';
export const getList = (current, size, params) => {
  return request({
    url: '/api/blade-resPicDetail/resPicDetail/list',
    method: 'get',
    params: {
      ...params,
      current,
      size,
    }
  })
}
export const getPage = (current, size, params) => {
  return request({
    url: '/api/blade-resPicDetail/resPicDetail/page',
    method: 'get',
    params: {
      ...params,
      current,
      size,
    }
  })
}
export const getDetail = (id) => {
  return request({
    url: '/api/blade-resPicDetail/resPicDetail/detail',
    method: 'get',
    params: {
      id
    }
  })
}
export const remove = (ids) => {
  return request({
    url: '/api/blade-resPicDetail/resPicDetail/remove',
    method: 'post',
    params: {
      ids,
    }
  })
}
export const add = (row) => {
  return request({
    url: '/api/blade-resPicDetail/resPicDetail/submit',
    method: 'post',
    data: row
  })
}
export const update = (row) => {
  return request({
    url: '/api/blade-resPicDetail/resPicDetail/submit',
    method: 'post',
    data: row
  })
}
src/api/three/riskHidDangPic.js
New file
@@ -0,0 +1,62 @@
import request from '@/router/axios';
export const getList = (current, size, params) => {
  return request({
    url: '/api/blade-riskHidDangPicDetail/riskHidDangPicDetail/list',
    method: 'get',
    params: {
      ...params,
      current,
      size,
    }
  })
}
export const getPage = (current, size, params) => {
  return request({
    url: '/api/blade-riskHidDangPicDetail/riskHidDangPicDetail/page',
    method: 'get',
    params: {
      ...params,
      current,
      size,
    }
  })
}
export const getDetail = (id) => {
  return request({
    url: '/api/blade-riskHidDangPicDetail/riskHidDangPicDetail/detail',
    method: 'get',
    params: {
      id
    }
  })
}
export const remove = (ids) => {
  return request({
    url: '/api/blade-riskHidDangPicDetail/riskHidDangPicDetail/remove',
    method: 'post',
    params: {
      ids,
    }
  })
}
export const add = (row) => {
  return request({
    url: '/api/blade-riskHidDangPicDetail/riskHidDangPicDetail/submit',
    method: 'post',
    data: row
  })
}
export const update = (row) => {
  return request({
    url: '/api/blade-riskHidDangPicDetail/riskHidDangPicDetail/submit',
    method: 'post',
    data: row
  })
}
src/views/three/resPic/resPic.vue
New file
@@ -0,0 +1,538 @@
<template>
    <basic-container>
        <avue-crud :option="option" :table-loading="loading" :data="data" :page.sync="page" :permission="permissionList"
            :before-open="beforeOpen" v-model="form" ref="crud" @row-update="rowUpdate" @row-save="rowSave"
            @row-del="rowDel" @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.security_delete"
                    @click="handleDelete">删 除
                </el-button>
                <el-button type="success" size="small" plain icon="el-icon-upload2" @click="handleImport">导入
                </el-button>
            </template>
        </avue-crud>
        <el-dialog title="提示" :visible.sync="placeBox" append-to-body destroy-on-close width="70%">
            <search-map @getLonLat="getLonLat" @getAddress="getAddress" :point-lon-lat="point"></search-map>
            <span slot="footer" class="dialog-footer">
                <el-button type="primary" @click="confirmLonLat">确 定</el-button>
            </span>
        </el-dialog>
        <el-dialog title="可用资源图明细数据导入" append-to-body :visible.sync="excelBox" width="555px">
            <avue-form :option="excelOption" v-model="excelForm" :upload-after="uploadAfter">
                <template slot="excelTemplate">
                    <el-button type="primary" @click="handleTemplate">
                        点击下载<i class="el-icon-download el-icon--right"></i>
                    </el-button>
                </template>
            </avue-form>
        </el-dialog>
    </basic-container>
</template>
<script>
import { getPage, getDetail, add, update, remove } from "@/api/three/resPic"
import { getUserInfos } from "@/api/system/user"
// import AvueMap from 'avue-plugin-map';
import { mapGetters } from "vuex"
import securityManage from "@/views/securityManage/securityManage"
import securityManageCar from "@/views/securityManageCar/securityManageCar"
import MapBox from "@/components/map/mapBox"
import SearchMap from "@/components/map/searchMap"
import DcMap from "@/components/map/dcMap"
import { exportBlob } from "@/api/common";
import { getToken } from "@/util/auth";
import { downloadXls } from "@/util/util";
export default {
    components: {
        DcMap,
        SearchMap,
        MapBox,
        securityManage,
        securityManageCar
    },
    data() {
        return {
            securityId: "",
            carBox: false,
            personBox: false,
            placeBox: false,
            point: "",
            chosePoint: {},
            form: {},
            query: {},
            loading: true,
            page: {
                pageSize: 10,
                currentPage: 1,
                total: 0
            },
            excelBox: false,
            excelOption: {
                submitBtn: false,
                emptyBtn: false,
                column: [
                    {
                        label: '模板上传',
                        prop: 'excelFile',
                        type: 'upload',
                        drag: true,
                        loadText: '模板上传中,请稍等',
                        span: 24,
                        propsHttp: {
                            res: 'data'
                        },
                        tip: '请上传 .xls,.xlsx 标准格式文件',
                        action: "/api/blade-resPicDetail/resPicDetail/import-ResPicDetail"
                    },
                    // {
                    //     label: "数据覆盖",
                    //     prop: "isCovered",
                    //     type: "switch",
                    //     align: "center",
                    //     width: 80,
                    //     dicData: [
                    //         {
                    //             label: "否",
                    //             value: 0
                    //         },
                    //         {
                    //             label: "是",
                    //             value: 1
                    //         }
                    //     ],
                    //     value: 0,
                    //     slot: true,
                    //     rules: [
                    //         {
                    //             required: true,
                    //             message: "请选择是否覆盖",
                    //             trigger: "blur"
                    //         }
                    //     ]
                    // },
                    {
                        label: '模板下载',
                        prop: 'excelTemplate',
                        formslot: true,
                        span: 24,
                    }
                ]
            },
            selectionList: [],
            option: {
                height: 'auto',
                calcHeight: 30,
                labelWidth: "180",
                dialogWidth: 1050,
                tip: false,
                searchShow: true,
                searchMenuSpan: 6,
                border: true,
                index: true,
                viewBtn: true,
                selection: true,
                excelBtn: true,
                dialogClickModal: false,
                menuWidth: 260,
                column: [
                    {
                        label: "重点部位分类",
                        prop: "type",
                        search: true,
                        searchSpan: 4,
                        // type: "select",
                        // dicUrl: "/api/blade-system/dict-biz/dictionary?code=securityType",
                        // props: {
                        //     label: "dictValue",
                        //     value: "dictKey"
                        // },
                        rules: [{
                            required: true,
                            message: "请输入分类名称",
                            trigger: "blur"
                        }],
                        // width: 90,
                    },
                    {
                        label: "场所名称",
                        prop: "placeName",
                        search: true,
                        searchSpan: 4,
                        rules: [{
                            required: true,
                            message: "请输入resPicDetail",
                            trigger: "blur"
                        }],
                        overHidden: true,
                    },
                    {
                        type: 'select',
                        label: "位置",
                        prop: "address",
                        span: 24,
                        click: () => {
                            this.placeBox = !this.placeBox
                        },
                        overHidden: true,
                        rules: [{
                            required: true,
                            message: "请选择活动地点",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "经度",
                        prop: "lng",
                        span: 12,
                        hide: true,
                        disabled: true,
                        rules: [{
                            required: true,
                            message: "请输入纬度",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "纬度",
                        prop: "lat",
                        span: 12,
                        hide: true,
                        disabled: true,
                        rules: [{
                            required: true,
                            message: "请输入纬度",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "快反时间",
                        prop: "fastTime",
                        width: 100,
                        rules: [{
                            required: true,
                            message: "请输入快反时间",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "探头编号",
                        prop: "probeNo",
                        width: 80,
                        rules: [{
                            required: true,
                            message: "请输入快反时间",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "单位保安对接人",
                        prop: "unitSecName",
                        width: 80,
                        placeholder: '请输入单位保安对接人姓名',
                        rules: [{
                            required: true,
                            message: "请输入单位保安对接人姓名",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "单位保安对接人联系方式",
                        prop: "unitSecPhone",
                        labelWidth: 180,
                        width: 100,
                        rules: [{
                            required: true,
                            message: "请输入单位保安对接人联系方式",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "民警姓名",
                        prop: "policeman",
                        width: 80,
                        placeholder: '请输入民警姓名',
                        rules: [{
                            required: true,
                            message: "请输入民警姓名",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "民警联系方式",
                        prop: "policemanPhone",
                        width: 100,
                        rules: [{
                            required: true,
                            message: "请输入民警联系方式",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "所属派出所",
                        prop: "pcsName",
                        type: "tree",
                        dicUrl: "api/blade-system/dept/getPoliceStationTree",
                        props: {
                            label: 'name',
                            value: 'name',
                            children: 'children'
                        },
                        parent: false,
                        search: true,
                        searchSpan: 4,
                        searchLabelWidth: 100,
                        defaultExpandAll: "true",
                        width: 110,
                        rules: [{
                            required: true,
                            message: "请选择所属辖区",
                            trigger: "blur"
                        }]
                    },
                    {
                        label: "创建时间",
                        prop: "createTime",
                        addDisplay: false,
                        editDisplay: false,
                        rules: [{
                            required: true,
                            message: "请输入创建时间",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "更新时间",
                        prop: "updateTime",
                        addDisplay: false,
                        editDisplay: false,
                        hide: true,
                        rules: [{
                            required: true,
                            message: "请输入创建时间",
                            trigger: "blur"
                        }],
                    },
                ]
            },
            data: []
        }
    },
    computed: {
        ...mapGetters(["userInfo", "permission"]),
        permissionList() {
            return {
                addBtn: this.vaildData(this.permission.security_add, false),
                viewBtn: this.vaildData(this.permission.security_view, true),
                delBtn: this.vaildData(this.permission.security_delete, false),
                editBtn: this.vaildData(this.permission.security_edit, false)
            }
        },
        ids() {
            let ids = []
            this.selectionList.forEach(ele => {
                ids.push(ele.id)
            })
            return ids.join(",")
        }
    },
    created() {
        const tokenLength = window.location.href.indexOf('=')
        if (tokenLength > 0) {
            //取“=”之后的token
            this.getUserInfo()
        }
    },
    methods: {
        //下面为导入操作
        handleImport() {
            this.excelBox = true;
        },
        uploadAfter(res, done, loading, column) {
            window.console.log(column);
            this.excelBox = false;
            this.refreshChange();
            done();
        },
        handleTemplate() {
            exportBlob(`/api/blade-resPicDetail/resPicDetail/export-template?${this.website.tokenHeader}=${getToken()}`).then(res => {
                downloadXls(res.data, "可用资源图明细数据模板.xlsx");
            })
        },
        getUserInfo() {
            getUserInfos().then(res => {
                const data = res.data
                this.$store.commit('SET_TOKEN', data.access_token)
                this.$store.commit('SET_REFRESH_TOKEN', data.refresh_token)
                this.$store.commit('SET_TENANT_ID', data.tenant_id)
                this.$store.commit('SET_USER_INFO', data)
                this.$store.commit('DEL_ALL_TAG')
                this.$store.commit('CLEAR_LOCK')
            })
        },
        rowSave(row, done, loading) {
            add(row).then(() => {
                this.onLoad(this.page)
                this.$message({
                    type: "success",
                    message: "操作成功!"
                })
                done()
            }, error => {
                loading()
                window.console.log(error)
            })
        },
        rowUpdate(row, index, done, loading) {
            update(row).then(() => {
                this.onLoad(this.page)
                this.$message({
                    type: "success",
                    message: "操作成功!"
                })
                done()
            }, error => {
                loading()
                console.log(error)
            })
        },
        rowDel(row) {
            this.$confirm("确定将选择数据删除?", {
                confirmButtonText: "确定",
                cancelButtonText: "取消",
                type: "warning"
            })
                .then(() => {
                    return remove(row.id)
                })
                .then(() => {
                    this.onLoad(this.page)
                    this.$message({
                        type: "success",
                        message: "操作成功!"
                    })
                })
        },
        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)) {
                getDetail(this.form.id).then(res => {
                    var data = res.data.data
                    this.form = data
                    this.form['datetimerange'] = [data.startTime, data.endTime]
                    this.form['longitude'] = data.position.split(" ")[0]
                    this.form['latitude'] = data.position.split(" ")[1]
                    this.point = "POINT(" + this.form.longitude + " " + this.form.latitude + ")"
                    this.$refs.dcMap.showPolygon(this.form.activityArea)
                })
            }
            done()
        },
        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()
        },
        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
            if (this.userInfo.role_name != "admin" && this.userInfo.role_name != "administrator") {
                params["jurisdiction"] = this.userInfo.dept_id
            }
            getPage(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
                const data = res.data.data
                this.page.total = data.total
                this.data = data.records
                this.loading = false
                this.selectionClear()
            })
        },
        //活动人员区域点击按钮事件
        handlePersonList(row) {
            this.personBox = true
            this.securityId = row.id
        },
        //活动车辆区域点击按钮事件
        handleCarList(row) {
            this.carBox = true
            this.securityId = row.id
        },
        //地图传回的polygon坐标
        toData(data) {
            console.log('data', data)
            this.form.activityArea = data
        },
        getLonLat(data) {
            this.chosePoint.longitude = data[0]
            this.chosePoint.latitude = data[1]
        },
        getAddress(data) {
            this.chosePoint.address = data
        },
        confirmLonLat() {
            if (this.chosePoint.longitude) {
                this.form.longitude = this.chosePoint.longitude
                this.form.latitude = this.chosePoint.latitude
                this.form.place = this.chosePoint.address
                this.point = "POINT(" + this.form.longitude + " " + this.form.latitude + ")"
                this.placeBox = false
            } else {
                this.$alert('该点没有位置信息,请重新选点!', '提示', {
                    confirmButtonText: '确定',
                })
            }
        }
    }
}
</script>
<style></style>
src/views/three/riskHidDangPic/riskHidDangPic.vue
New file
@@ -0,0 +1,545 @@
<template>
    <basic-container>
        <avue-crud :option="option" :table-loading="loading" :data="data" :page.sync="page" :permission="permissionList"
            :before-open="beforeOpen" v-model="form" ref="crud" @row-update="rowUpdate" @row-save="rowSave"
            @row-del="rowDel" @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.security_delete"
                    @click="handleDelete">删 除
                </el-button>
            </template>
            <template slot-scope="{type,size,row,index}" slot="menu">
                <el-button icon="el-icon-coordinate" :size="size" :type="type" @click="handlePersonList(row)">活动人员
                </el-button>
                <el-button icon="el-icon-data-line" :size="size" :type="type" @click="handleCarList(row)">活动车辆
                </el-button>
            </template>
            <!-- <template slot="activityAreaForm"> -->
            <!-- <dc-map ref="dcMap" @toData="toData" :range="form.activityArea"></dc-map> -->
            <!-- </template> -->
        </avue-crud>
        <el-drawer title="活动人员区域" :visible.sync="personBox" :append-to-body="true" size="50%" :destroy-on-close="true">
            <securityManage ref="securityManage" :securityId="securityId" />
        </el-drawer>
        <el-drawer title="活动车辆区域" :visible.sync="carBox" :append-to-body="true" size="50%" :destroy-on-close="true">
            <securityManageCar ref="car" :securityId="securityId" />
        </el-drawer>
        <el-dialog title="提示" :visible.sync="placeBox" append-to-body destroy-on-close width="70%">
            <search-map @getLonLat="getLonLat" @getAddress="getAddress" :point-lon-lat="point"></search-map>
            <span slot="footer" class="dialog-footer">
                <el-button type="primary" @click="confirmLonLat">确 定</el-button>
            </span>
        </el-dialog>
    </basic-container>
</template>
<script>
import { getPage, getDetail, add, update, remove } from "@/api/security/security"
import { getUserInfos } from "@/api/system/user"
// import AvueMap from 'avue-plugin-map';
import { mapGetters } from "vuex"
import securityManage from "@/views/securityManage/securityManage"
import securityManageCar from "@/views/securityManageCar/securityManageCar"
import MapBox from "@/components/map/mapBox"
import SearchMap from "@/components/map/searchMap"
import DcMap from "@/components/map/dcMap"
export default {
    components: {
        DcMap,
        SearchMap,
        MapBox,
        securityManage,
        securityManageCar
    },
    data () {
        return {
            securityId: "",
            carBox: false,
            personBox: false,
            placeBox: false,
            point: "",
            chosePoint: {},
            form: {},
            query: {},
            loading: true,
            page: {
                pageSize: 10,
                currentPage: 1,
                total: 0
            },
            selectionList: [],
            option: {
                height: 'auto',
                calcHeight: 30,
                labelWidth: "100",
                dialogWidth: 950,
                tip: false,
                searchShow: true,
                searchMenuSpan: 6,
                border: true,
                index: true,
                viewBtn: true,
                selection: true,
                excelBtn: true,
                dialogClickModal: false,
                menuWidth: 370,
                column: [
                    {
                        label: "活动名称",
                        prop: "name",
                        search: true,
                        searchSpan: 4,
                        rules: [{
                            required: true,
                            message: "请输入活动名称",
                            trigger: "blur"
                        }],
                        overHidden: true,
                    },
                    {
                        label: "负责单位",
                        prop: "company",
                        hide: true,
                    },
                    {
                        label: "负责人",
                        prop: "person",
                        width: 80,
                        placeholder: '请输入民警姓名',
                        rules: [{
                            required: true,
                            message: "请输入民警姓名",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "联系方式",
                        prop: "contact",
                        width: 100,
                        rules: [{
                            required: true,
                            message: "请输入联系方式",
                            trigger: "blur"
                        }],
                    },
                    {
                        type: 'select',
                        label: "活动地点",
                        prop: "place",
                        span: 24,
                        click: () => {
                            this.placeBox = !this.placeBox
                        },
                        overHidden: true,
                        rules: [{
                            required: true,
                            message: "请选择活动地点",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "经度",
                        prop: "longitude",
                        span: 12,
                        hide: true,
                        disabled: true,
                        rules: [{
                            required: true,
                            message: "请输入纬度",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "纬度",
                        prop: "latitude",
                        span: 12,
                        hide: true,
                        disabled: true,
                        rules: [{
                            required: true,
                            message: "请输入纬度",
                            trigger: "blur"
                        }],
                    },
                    // {
                    //     label: "活动区域",
                    //     prop: "activityArea",
                    //     type: "input",
                    //     hide: true,
                    //     span: 24,
                    //     display: true,
                    //     addDisplay: true,
                    //     rules: [{
                    //         required: true,
                    //         message: "请绘制活动区域",
                    //         trigger: "blur"
                    //     }],
                    // },
                    {
                        label: "所属辖区",
                        prop: "deptId",
                        type: "tree",
                        dicUrl: "api/blade-system/dept/getPoliceStationTree",
                        props: {
                            label: 'name',
                            value: 'id',
                            children: 'children'
                        },
                        search: true,
                        searchSpan: 4,
                        defaultExpandAll: "true",
                        width: 110,
                        rules: [{
                            required: true,
                            message: "请选择所属辖区",
                            trigger: "blur"
                        }]
                    },
                    {
                        label: "标绘类型",
                        prop: "plotType",
                        type: "select",
                        dicData: [
                            {
                                label: "二维",
                                value: 1
                            },
                            {
                                label: "三维",
                                value: 3
                            }
                        ],
                        search: true,
                        searchSpan: 4,
                        rules: [{
                            required: true,
                            message: "请选择标绘类型",
                            trigger: "blur"
                        }]
                    },
                    // {
                    //   label: "地址",
                    //   prop: "avueMap",
                    //   type: "map",
                    // },
                    {
                        span: 24,
                        label: "时间范围",
                        prop: "datetimerange",
                        type: "datetimerange",
                        defaultTime: ['00:00', '00:00'],
                        format: "yyyy-MM-dd HH:mm",
                        valueFormat: "yyyy-MM-dd HH:mm",
                        startPlaceholder: '开始时间',
                        endPlaceholder: '结束时间',
                        rules: [{
                            required: true,
                            message: "请选择时间范围",
                            trigger: "blur"
                        }],
                        width: 120,
                    },
                    // {
                    //     label: "开始时间",
                    //     prop: "startTime",
                    //     type: "datetime",
                    //     defaultTime: '00:00:00',
                    //     format: "yyyy-MM-dd HH:mm",
                    //     valueFormat: "yyyy-MM-dd HH:mm:ss",
                    //     rules: [{
                    //         required: true,
                    //         message: "请输入开始时间",
                    //         trigger: "blur"
                    //     }],
                    //     width: 120,
                    // },
                    // {
                    //     label: "结束时间",
                    //     prop: "endTime",
                    //     type: "datetime",
                    //     defaultTime: '23:59:59',
                    //     format: "yyyy-MM-dd HH:mm",
                    //     valueFormat: "yyyy-MM-dd HH:mm",
                    //     disabledDate (time) {
                    //         return time.getTime() < Date.now()
                    //     },
                    //     rules: [{
                    //         required: true,
                    //         message: "请输入结束时间",
                    //         trigger: "blur"
                    //     }],
                    //     width: 120,
                    // },
                    // {
                    //   label: "",
                    //   prop: "map",
                    //   labelWidth: 10,
                    //   searchSpan: 0,
                    //   // maxlength: 5,
                    //   hide: true,
                    //   span: 3,
                    //   // display:false,
                    //   component: "AvueMap",
                    // },
                    {
                        label: "活动类型",
                        prop: "type",
                        type: "select",
                        dicUrl: "/api/blade-system/dict-biz/dictionary?code=securityType",
                        props: {
                            label: "dictValue",
                            value: "dictKey"
                        },
                        rules: [{
                            required: true,
                            message: "请选择活动类型",
                            trigger: "blur"
                        }],
                        width: 90,
                    },
                    {
                        label: "人数",
                        prop: "number",
                        width: 60,
                        rules: [{
                            required: true,
                            message: "请输入人数",
                            trigger: "blur"
                        }],
                    },
                    {
                        label: "活动内容",
                        prop: "content",
                        type: "textarea",
                        span: 24,
                        hide: true,
                    },
                ]
            },
            data: []
        }
    },
    // watch: {
    //   //latitude   longitude   formattedAddress
    //   "form.avueMap":{
    //     handler (newObj) {
    //       if (newObj.length>0) {
    //         this.form.place = newObj[2]
    //         this.form.position = newObj[0]+","+newObj[1]
    //       }
    //     }
    //   }
    // },
    computed: {
        ...mapGetters(["userInfo", "permission"]),
        permissionList () {
            return {
                addBtn: this.vaildData(this.permission.security_add, false),
                viewBtn: this.vaildData(this.permission.security_view, false),
                delBtn: this.vaildData(this.permission.security_delete, false),
                editBtn: this.vaildData(this.permission.security_edit, false)
            }
        },
        ids () {
            let ids = []
            this.selectionList.forEach(ele => {
                ids.push(ele.id)
            })
            return ids.join(",")
        }
    },
    created () {
        const tokenLength = window.location.href.indexOf('=')
        if (tokenLength > 0) {
            //取“=”之后的token
            this.getUserInfo()
        }
    },
    methods: {
        getUserInfo () {
            getUserInfos().then(res => {
                const data = res.data
                this.$store.commit('SET_TOKEN', data.access_token)
                this.$store.commit('SET_REFRESH_TOKEN', data.refresh_token)
                this.$store.commit('SET_TENANT_ID', data.tenant_id)
                this.$store.commit('SET_USER_INFO', data)
                this.$store.commit('DEL_ALL_TAG')
                this.$store.commit('CLEAR_LOCK')
            })
        },
        rowSave (row, done, loading) {
            row.startTime = row.datetimerange[0]
            row.endTime = row.datetimerange[1]
            row.position = row.longitude + " " + row.latitude
            add(row).then(() => {
                this.onLoad(this.page)
                this.$message({
                    type: "success",
                    message: "操作成功!"
                })
                done()
            }, error => {
                loading()
                window.console.log(error)
            })
        },
        rowUpdate (row, index, done, loading) {
            row.startTime = row.datetimerange[0]
            row.endTime = row.datetimerange[1]
            row.position = row.longitude + " " + row.latitude
            update(row).then(() => {
                this.onLoad(this.page)
                this.$message({
                    type: "success",
                    message: "操作成功!"
                })
                done()
            }, error => {
                loading()
                console.log(error)
            })
        },
        rowDel (row) {
            this.$confirm("确定将选择数据删除?", {
                confirmButtonText: "确定",
                cancelButtonText: "取消",
                type: "warning"
            })
                .then(() => {
                    return remove(row.id)
                })
                .then(() => {
                    this.onLoad(this.page)
                    this.$message({
                        type: "success",
                        message: "操作成功!"
                    })
                })
        },
        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)) {
                getDetail(this.form.id).then(res => {
                    var data = res.data.data
                    this.form = data
                    this.form['datetimerange'] = [data.startTime, data.endTime]
                    this.form['longitude'] = data.position.split(" ")[0]
                    this.form['latitude'] = data.position.split(" ")[1]
                    this.point = "POINT(" + this.form.longitude + " " + this.form.latitude + ")"
                    this.$refs.dcMap.showPolygon(this.form.activityArea)
                })
            }
            done()
        },
        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()
        },
        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
            if (this.userInfo.role_name != "admin" && this.userInfo.role_name != "administrator") {
                params["jurisdiction"] = this.userInfo.dept_id
            }
            getPage(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
                const data = res.data.data
                this.page.total = data.total
                this.data = data.records
                this.loading = false
                this.selectionClear()
            })
        },
        //活动人员区域点击按钮事件
        handlePersonList (row) {
            this.personBox = true
            this.securityId = row.id
        },
        //活动车辆区域点击按钮事件
        handleCarList (row) {
            this.carBox = true
            this.securityId = row.id
        },
        //地图传回的polygon坐标
        toData (data) {
            console.log('data', data)
            this.form.activityArea = data
        },
        getLonLat (data) {
            this.chosePoint.longitude = data[0]
            this.chosePoint.latitude = data[1]
        },
        getAddress (data) {
            this.chosePoint.address = data
        },
        confirmLonLat () {
            if (this.chosePoint.longitude) {
                this.form.longitude = this.chosePoint.longitude
                this.form.latitude = this.chosePoint.latitude
                this.form.place = this.chosePoint.address
                this.point = "POINT(" + this.form.longitude + " " + this.form.latitude + ")"
                this.placeBox = false
            } else {
                this.$alert('该点没有位置信息,请重新选点!', '提示', {
                    confirmButtonText: '确定',
                })
            }
        }
    }
}
</script>
<style></style>