flowMeter.vue 4.93 KB
Newer Older
耿迪迪's avatar
耿迪迪 committed
1 2
<template>
  <el-dialog
3
    :title="title"
耿迪迪's avatar
耿迪迪 committed
4 5 6
    :visible.sync="dialogVisible"
    width="80%"
    :before-close="handleClose">
耿迪迪's avatar
耿迪迪 committed
7 8
    <el-form ref="form" :model="form" :rules="rules" label-width="135px">
      <el-form-item label="所属管道" prop="pipeCode">
9 10 11 12 13 14 15 16
        <el-select v-model="form.pipeCode" placeholder="请选择所属管道">
          <el-option
            v-for="item in pipeList"
            :key="item.pipeCode"
            :label="item.pipeName"
            :value="item.pipeCode">
          </el-option>
        </el-select>
耿迪迪's avatar
耿迪迪 committed
17
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
18 19
      <el-form-item label="设备名称" prop="deviceName">
        <el-input v-model="form.deviceName" placeholder="请输入设备名称" />
耿迪迪's avatar
耿迪迪 committed
20
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
21 22
      <el-form-item label="所在地址" prop="deviceAddr">
        <el-input v-model="form.deviceAddr" placeholder="请输入所在地址" />
耿迪迪's avatar
耿迪迪 committed
23
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
24 25
      <el-form-item label="设备型号" prop="deviceModel">
        <el-input v-model="form.deviceModel" placeholder="请输入设备型号" />
26
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
27 28
      <el-form-item label="经度" prop="longitude">
        <el-input v-model="form.longitude" placeholder="请输入经度" />
耿迪迪's avatar
耿迪迪 committed
29
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
30 31
      <el-form-item label="纬度" prop="latitude">
        <el-input v-model="form.latitude" placeholder="请输入纬度" />
耿迪迪's avatar
耿迪迪 committed
32
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
33 34
      <el-form-item label="物联网编号" prop="iotNo">
        <el-input v-model="form.iotNo" placeholder="请输入物联网编号" />
耿迪迪's avatar
耿迪迪 committed
35
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
36
      <el-form-item label="设备图片上传" prop="iconUrl">
耿迪迪's avatar
耿迪迪 committed
37 38 39 40 41 42
        <MyFileUpload
          listType="picture-card"
          @resFun="getFileInfo"
          @remove="listRemove"
          :fileArr="fileArr"
        />
43
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
44 45
      <el-form-item label="联系人" prop="linkman">
        <el-input v-model="form.linkman" placeholder="请输入联系人" />
耿迪迪's avatar
耿迪迪 committed
46
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
47 48 49 50 51 52 53 54 55 56
      <el-form-item label="电话" prop="phone">
        <el-input v-model="form.phone" placeholder="请输入电话" />
      </el-form-item>
      <el-form-item label="安装时间" prop="installationTime">
        <el-date-picker clearable size="small"
                        v-model="form.installationTime"
                        type="datetime"
                        value-format="yyyy-MM-dd HH:mm:ss"
                        placeholder="选择安装时间">
        </el-date-picker>
耿迪迪's avatar
耿迪迪 committed
57
      </el-form-item>
耿迪迪's avatar
耿迪迪 committed
58 59
      <el-form-item label="备注" prop="remarks">
        <el-input v-model="form.remarks" placeholder="请输入备注" />
耿迪迪's avatar
耿迪迪 committed
60 61 62 63
      </el-form-item>
    </el-form>
    <span slot="footer" class="dialog-footer">
      <el-button @click="dialogVisible = false">取 消</el-button>
耿迪迪's avatar
耿迪迪 committed
64
      <el-button type="primary" @click="submitForm">确 定</el-button>
耿迪迪's avatar
耿迪迪 committed
65 66 67 68 69
    </span>
  </el-dialog>
</template>

<script>
耿迪迪's avatar
耿迪迪 committed
70 71

  import { getAllDeviceInfo ,addDeviceInfo, updateDeviceInfo } from "@/api/device/deviceInfo";
72
  import { pipeAllInfoList } from "@/api/device/pipe";
耿迪迪's avatar
耿迪迪 committed
73
  import MyFileUpload from "@/components/MyFileUpload";
耿迪迪's avatar
耿迪迪 committed
74 75
  import { DEVICE_TYPE } from "utils/gaodeMap.js";

耿迪迪's avatar
耿迪迪 committed
76 77
  export default {
    props: {
78
      title: { type: String }
耿迪迪's avatar
耿迪迪 committed
79 80 81
    },
    data () {
      return {
耿迪迪's avatar
耿迪迪 committed
82
        form : {
83
          deviceType : "3"
耿迪迪's avatar
耿迪迪 committed
84 85 86 87 88 89 90 91
        },
        dialogVisible : false,
        fileList: [],
        // 表单校验
        rules: {
        },
        map : null,
        obj : null,
耿迪迪's avatar
耿迪迪 committed
92
        gaoMap : null,
93 94
        fileArr: [],
        pipeList: []
耿迪迪's avatar
耿迪迪 committed
95 96
      }
    },
耿迪迪's avatar
耿迪迪 committed
97
    components: {
耿迪迪's avatar
耿迪迪 committed
98
      MyFileUpload,
耿迪迪's avatar
耿迪迪 committed
99
    },
耿迪迪's avatar
耿迪迪 committed
100 101 102 103 104 105 106
    methods: {
      show () {
        this.dialogVisible = true;
      },
      hide () {
        this.remove()
      },
耿迪迪's avatar
耿迪迪 committed
107 108 109 110 111 112 113 114
      getFileInfo(res){
        this.form.iconUrl = res.url;
      },
      submitForm() {
        this.$refs["form"].validate(valid => {
          if (valid) {
            if (this.form.deviceId != null) {
              updateDeviceInfo(this.form).then(response => {
耿迪迪's avatar
耿迪迪 committed
115
                this.dialogVisible = false;
116 117
                this.map.remove(this.obj);
                this.gaoMap.addMarker(this.gaoMap.deviceType,this.form);
耿迪迪's avatar
耿迪迪 committed
118 119 120 121 122 123 124 125 126
                this.msgSuccess("修改成功");
              });
            } else {
              addDeviceInfo(this.form).then(response => {
                if(response.code == 200){
                  this.remove();
                  this.map.remove(this.obj);
                  this.form.deviceId = response.data;
                  this.gaoMap.addMarker(this.gaoMap.deviceType,this.form);
127
                  this.gaoMap.placeSearch.clear();
耿迪迪's avatar
耿迪迪 committed
128
                  this.gaoMap.closeAddMarker();
耿迪迪's avatar
耿迪迪 committed
129 130 131 132 133 134 135 136 137
                  this.msgSuccess("新增成功");
                }else{
                  this.msgSuccess("新增失败");
                }
              });
            }
          }
        });
      },
耿迪迪's avatar
耿迪迪 committed
138
      handleClose(done) {
耿迪迪's avatar
耿迪迪 committed
139
        done();
耿迪迪's avatar
耿迪迪 committed
140 141 142 143
      },
      listRemove(e) {
        this.form.url = "";
        this.fileArr = [];
耿迪迪's avatar
耿迪迪 committed
144
      }
145 146 147 148 149
    },
    mounted(){
      pipeAllInfoList({}).then(response => {
        this.pipeList = response.data;
      });
耿迪迪's avatar
耿迪迪 committed
150 151 152 153 154
    }
  }
</script>