From 7c20fd15b7fbc2bd5756b39d5ab655cc849ffcc3 Mon Sep 17 00:00:00 2001
From: zhanghua <314079846@qq.com>
Date: 星期三, 16 七月 2025 22:39:23 +0800
Subject: [PATCH] 添加时间筛选

---
 src/views/operate/video/updateInterface/index.vue |   88 ++++++++++++++++++++++----------------------
 1 files changed, 44 insertions(+), 44 deletions(-)

diff --git a/src/views/operate/video/updateInterface/index.vue b/src/views/operate/video/updateInterface/index.vue
index 4d1d80c..8318d34 100644
--- a/src/views/operate/video/updateInterface/index.vue
+++ b/src/views/operate/video/updateInterface/index.vue
@@ -1,35 +1,19 @@
 <template>
   <div class="updateUser">
     <el-form label-position="right" label-width="150px" :model="videoData" :rules="rules" :disabled="isDisabled" ref="user">
-      <el-form-item prop="belongToId" label="鎵�灞炰簨浠剁紪鍙�">
-        <el-input v-model="videoData.belongToId"></el-input>
-      </el-form-item>
-      <el-form-item prop="eventSource" label="浜嬩欢鏉ユ簮">
-        <el-input v-model="videoData.eventSource"></el-input>
-      </el-form-item>
-      <el-form-item prop="category" label="闂绫诲埆">
-        <el-input v-model="videoData.category"></el-input>
-      </el-form-item>
-      <el-form-item prop="type" label="绫诲瀷">
-        <el-select v-model="videoData.type">
-          <el-option v-for="item in getResourceType()" :key="item.value" :label="item.label" :value="item.value" />
-        </el-select>
-      </el-form-item>
-      <el-form-item prop="regionName" label="绀惧尯鍚嶇О">
-        <el-input v-model="videoData.regionName"></el-input>
-      </el-form-item>
-      <el-form-item prop="id" label="瑙嗛Id">
-        <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">
@@ -43,7 +27,7 @@
 <script>
 import { deepClone, RESOURCE_TYPE } from "@/utils/helper";
 import videoManagement from "@/api/operate/videoManagement";
-import { FILE_ORIGINAL_URL } from "@/utils";
+import { FILE_ORIGINAL_PATH} from "@/utils";
 import imageManagement from "@/api/operate/imageManagement";
 
 export default {
@@ -69,13 +53,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: '璇疯緭鍏ュ浘鐗嘔d' }],
+        id: [{ required: true, trigger: 'blur', message: '璇疯緭鍏ヨ棰慖d' }],
         category: [{ required: true, trigger: 'blue', message: '璇疯緭鍏ラ棶棰樼被鍨�' }],
         url: [{ required: true, validator: validateVideoUrl }],
         type: [{ required: true, trigger: ['blur', 'change'], message: '璇烽�夋嫨绫诲瀷' }]
       },
       isDisabled: false,
-      videoList: null
+      videoList: []
     }
   },
 
@@ -96,6 +80,7 @@
           delete params.eventSource;
           delete params.id;
           params.belongToId = +params.belongToId;
+          params.type="03"
           if (this.isUpdate && !this.dialogData) {
             videoManagement.addVideoResource(params)
                 .then(() => {
@@ -121,8 +106,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_PATH + url;
+            this.videoList.push(videoUrl);
+            this.$set(this.videoData, 'url', this.videoList.join(','));
             this.$message.success('涓婁紶鎴愬姛');
           })
           .catch(err => {
@@ -130,6 +117,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;
     }
@@ -149,27 +142,34 @@
 <style lang="scss" scoped>
 .updateUser {
   border-radius: 1px;
-  background-color: #09152f;
+  // background-color: #09152f;
   display: flex;
   justify-content: center;
   align-items: center;
-  .avatar-uploader .el-upload {
-    border: 1px solid #ffffff;
-    border-radius: 6px;
-    cursor: pointer;
-    position: relative;
-    overflow: hidden;
+
+  .video-cover {
+    height: 169px;
+    display: flex;
   }
-  .avatar-uploader .el-upload:hover {
-    border-color: #409EFF;
+
+  .video-cover:hover {
+    background-color: #ffffff;
+    opacity: .6;
+    .video-delete-icon {
+      display: block;
+      opacity: 1;
+    }
   }
-  .avatar-uploader-icon {
-    font-size: 14px;
-    color: #8c939d;
-    width: 50px;
-    height: 50px;
-    line-height: 50px;
-    text-align: center;
+
+  .video-delete-icon {
+    position: absolute;
+    color: red;
+    left: calc(100% - 160px);
+    top: calc(100% - 150px);
+    z-index: 2;
+    height: 14px;
+    font-size: 24px;
+    display: none;
   }
 
   .submit-button {
@@ -182,7 +182,7 @@
 }
 
 .updateUser::v-deep .el-input__inner {
-  background-color: #09152f;
+  // background-color: #09152f;
   border: 1px solid #17324c;
 }
 

--
Gitblit v1.8.0