luobisheng
2022-11-29 89311b0d8981e10c59e9b42f1a9edc2ce42efb56
卡口管理修改
3个文件已修改
66 ■■■■■ 已修改文件
src/api/system/bayonet.js 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/operate/video/updateInterface/index.vue 62 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/systemSetting/device/bayonet/index.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/system/bayonet.js
@@ -4,7 +4,7 @@
        return http.get('/sccg/equipment_bayonet/query', params);
    },
    exportBayonetList: (params) => {
        return http.post('/sccg/equipment_bayonet/export', params);
        return http.downloadFile('/sccg/equipment_bayonet/export', params);
    },
    addBayonet: (params) => {
        return http.post('/sccg/equipment_bayonet/addition', params);
src/views/operate/video/updateInterface/index.vue
@@ -22,14 +22,18 @@
        <el-input v-model="videoData.id"></el-input>
      </el-form-item>
      <el-form-item prop="url" label="视频" min-width="8">
        <template v-if="videoList">
          <video controls v-for="video in videoList" :src="video" :key="video" width="300px" height="200px" />
        <template v-if="videoList" >
          <div class="video-cover" v-for="video in videoList" :key="video">
            <i v-if="isUpdate" @click="handleDelete(video)" class="el-icon-delete video-delete-icon"></i>
            <video controls :src="video" width="100%" height="100%"/>
          </div>
        </template>
        <el-upload
            v-if="isUpdate"
            class="avatar-uploader"
            action=""
            ref="image"
            limit="4"
            :show-file-list="false"
            :auto-upload="true"
            :http-request="videoUpload">
@@ -69,13 +73,13 @@
        belongToId: [{ required: true, trigger: 'blur', message: '请输入所属事件编号' }],
        eventSource: [{ required: true, trigger: 'blur', message: '请输入事件来源' }],
        regionName: [{ required: true, trigger: 'blur', message: '请输入社区名称' }],
        id: [{ required: true, trigger: 'blur', message: '请输入图片Id' }],
        id: [{ required: true, trigger: 'blur', message: '请输入视频Id' }],
        category: [{ required: true, trigger: 'blue', message: '请输入问题类型' }],
        url: [{ required: true, validator: validateVideoUrl }],
        type: [{ required: true, trigger: ['blur', 'change'], message: '请选择类型' }]
      },
      isDisabled: false,
      videoList: null
      videoList: []
    }
  },
@@ -121,8 +125,10 @@
      formData.append('file', file.file);
      imageManagement.importImage(formData)
          .then(res => {
            this.$refs.image.clearFiles();
            this.$set(this.videoData, 'url', FILE_ORIGINAL_URL + res.url1);
            const url = res.url1 ?? res.url2 ?? res.url3 ?? res.url4;
            const videoUrl = FILE_ORIGINAL_URL + url;
            this.videoList.push(videoUrl);
            this.$set(this.videoData, 'url', this.videoList.join(','));
            this.$message.success('上传成功');
          })
          .catch(err => {
@@ -130,6 +136,12 @@
            this.$refs.image.clearFiles();
          })
    },
    handleDelete(data) {
      this.videoList = this.videoList.filter(item => item !== data);
      this.videoData.url = this.videoList.join(',');
    },
    getResourceType(value) {
      return value ? RESOURCE_TYPE.find(item => item.value === value) : RESOURCE_TYPE;
    }
@@ -153,23 +165,29 @@
  display: flex;
  justify-content: center;
  align-items: center;
  .avatar-uploader .el-upload {
    border: 1px solid #ffffff;
    border-radius: 6px;
    cursor: pointer;
  .video-cover {
    height: 169px;
    display: flex;
  }
  .video-cover:hover {
    background-color: #ffffff;
    opacity: .6;
    .video-delete-icon {
      display: inline;
      opacity: 1;
    }
  }
  .video-delete-icon {
    position: relative;
    overflow: hidden;
  }
  .avatar-uploader .el-upload:hover {
    border-color: #409EFF;
  }
  .avatar-uploader-icon {
    font-size: 14px;
    color: #8c939d;
    width: 50px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    color: red;
    left: calc(100% - 150px);
    top: calc(100% - 95px);
    z-index: 2;
    height: 14px;
    display: none;
  }
  .submit-button {
src/views/systemSetting/device/bayonet/index.vue
@@ -178,7 +178,7 @@
        .exportBayonetList({
          bayonetName: this.context,
          current: this.current,
          size: this.size,
          size: this.size
        })
        .then((res) => {
          downloadFile(res);