Browse Source

修改产业集群详情

zs 7 months ago
parent
commit
6172d40d86

+ 35 - 0
package-lock.json

@@ -15,6 +15,7 @@
         "@vueuse/integrations": "^10.9.0",
         "@wangeditor/editor": "^5.1.23",
         "@wangeditor/editor-for-vue": "5.1.10",
+        "animate.css": "^4.1.1",
         "ant-design-vue": "^4.0.8",
         "axios": "^1.6.7",
         "dayjs": "^1.11.10",
@@ -32,6 +33,7 @@
         "qrcode.vue": "^3.4.1",
         "relation-graph-vue3": "^2.2.1",
         "stompjs": "^2.3.3",
+        "swiper": "^11.1.12",
         "universal-cookie": "^7.1.0",
         "vue": "^3.4.15",
         "vue-i18n": "^9.9.1",
@@ -1755,6 +1757,11 @@
         "url": "https://github.com/sponsors/epoberezkin"
       }
     },
+    "node_modules/animate.css": {
+      "version": "4.1.1",
+      "resolved": "https://registry.npmmirror.com/animate.css/-/animate.css-4.1.1.tgz",
+      "integrity": "sha512-+mRmCTv6SbCmtYJCN4faJMNFVNN5EuCTTprDTAo7YzIGji2KADmakjVA3+8mVDkZ2Bf09vayB35lSQIex2+QaQ=="
+    },
     "node_modules/ansi-regex": {
       "version": "5.0.1",
       "resolved": "https://registry.npmmirror.com/ansi-regex/-/ansi-regex-5.0.1.tgz",
@@ -6656,6 +6663,24 @@
         "node": ">=10.13.0"
       }
     },
+    "node_modules/swiper": {
+      "version": "11.1.12",
+      "resolved": "https://registry.npmmirror.com/swiper/-/swiper-11.1.12.tgz",
+      "integrity": "sha512-PUkCToYAZMB4kP7z+YfPnkMHOMwMO71g8vUhz2o5INGIgIMb6Sb0XiP6cEJFsiFTd7FRDn5XCbg+KVKPDZqXLw==",
+      "funding": [
+        {
+          "type": "patreon",
+          "url": "https://www.patreon.com/swiperjs"
+        },
+        {
+          "type": "open_collective",
+          "url": "http://opencollective.com/swiper"
+        }
+      ],
+      "engines": {
+        "node": ">= 4.7.0"
+      }
+    },
     "node_modules/synckit": {
       "version": "0.8.8",
       "resolved": "https://registry.npmmirror.com/synckit/-/synckit-0.8.8.tgz",
@@ -8717,6 +8742,11 @@
         "uri-js": "^4.2.2"
       }
     },
+    "animate.css": {
+      "version": "4.1.1",
+      "resolved": "https://registry.npmmirror.com/animate.css/-/animate.css-4.1.1.tgz",
+      "integrity": "sha512-+mRmCTv6SbCmtYJCN4faJMNFVNN5EuCTTprDTAo7YzIGji2KADmakjVA3+8mVDkZ2Bf09vayB35lSQIex2+QaQ=="
+    },
     "ansi-regex": {
       "version": "5.0.1",
       "resolved": "https://registry.npmmirror.com/ansi-regex/-/ansi-regex-5.0.1.tgz",
@@ -12363,6 +12393,11 @@
         "stable": "^0.1.8"
       }
     },
+    "swiper": {
+      "version": "11.1.12",
+      "resolved": "https://registry.npmmirror.com/swiper/-/swiper-11.1.12.tgz",
+      "integrity": "sha512-PUkCToYAZMB4kP7z+YfPnkMHOMwMO71g8vUhz2o5INGIgIMb6Sb0XiP6cEJFsiFTd7FRDn5XCbg+KVKPDZqXLw=="
+    },
     "synckit": {
       "version": "0.8.8",
       "resolved": "https://registry.npmmirror.com/synckit/-/synckit-0.8.8.tgz",

+ 2 - 0
package.json

@@ -18,6 +18,7 @@
     "@vueuse/integrations": "^10.9.0",
     "@wangeditor/editor": "^5.1.23",
     "@wangeditor/editor-for-vue": "5.1.10",
+    "animate.css": "^4.1.1",
     "ant-design-vue": "^4.0.8",
     "axios": "^1.6.7",
     "dayjs": "^1.11.10",
@@ -35,6 +36,7 @@
     "qrcode.vue": "^3.4.1",
     "relation-graph-vue3": "^2.2.1",
     "stompjs": "^2.3.3",
+    "swiper": "^11.1.12",
     "universal-cookie": "^7.1.0",
     "vue": "^3.4.15",
     "vue-i18n": "^9.9.1",

BIN
public/images/icon_slh.png


BIN
public/images/icon_srh.png


BIN
public/images/industryBg.png


+ 2 - 0
src/main.js

@@ -26,6 +26,8 @@ import 'default-passive-events'
 import vue3TreeOrg from 'vue3-tree-org'
 import 'vue3-tree-org/lib/vue3-tree-org.css'
 
+import 'animate.css/animate.min.css'
+
 const app = createApp(App)
 globalComponents(app)
 setupStore(app)

+ 3 - 9
src/views/center/attestation.vue

@@ -4,15 +4,9 @@
       <el-col :span="24" class="main animate__animated animate__backInRight" v-loading="loading">
         <el-col :span="24" class="one">认证入驻 </el-col>
         <el-col :span="24" class="two">
-          <el-tabs v-model="activeName" class="tabs">
-            <el-tab-pane :name="item.code" v-for="(item, index) in roleList" :key="index">
-              <template #label>
-                <span class="custom-tabs-label">
-                  <span>{{ item.title }}</span>
-                </span>
-              </template>
-            </el-tab-pane>
-          </el-tabs>
+          <el-select v-model="activeName" placeholder="请选择认证角色类型" size="large" style="width: 240px">
+            <el-option v-for="item in roleList" :key="item.code" :label="item.name" :value="item.code" />
+          </el-select>
         </el-col>
         <el-col :span="24" class="thr">
           <expert v-if="activeName == 'Expert'"></expert>

+ 2 - 1
src/views/center/match.vue

@@ -202,7 +202,7 @@ const processStore = ProcessStore()
 // 加载中
 const loading = ref(false)
 
-const searchForm = ref({ form: '0' })
+const searchForm = ref({})
 // 列表
 const list = ref([])
 let skip = 0
@@ -245,6 +245,7 @@ const formFields = ref([
 ])
 const matchFields = ref([{ label: '赛事状态', model: 'match_status', type: 'select' }])
 const matchRules = reactive({ match_status: [{ required: true, message: '请选择赛事状态', trigger: 'blur' }] })
+const rules = reactive({ name: [{ required: true, message: '请输入赛事名称', trigger: 'blur' }], form: [{ required: true, message: '请选择类别', trigger: 'blur' }] })
 // 赛事规则
 const rulesFields = ref([
   { label: '大赛背景', model: 'rules1', custom: true },

+ 291 - 95
src/views/detail/industryDetail.vue

@@ -1,30 +1,112 @@
 <template>
-  <custom-layout class="main">
-    <el-col :span="24" class="one" v-loading="loading">
-      <div class="w_1300">
-        <div class="info_1"></div>
-        <div class="info_2">
-          <div class="info_name">{{ info.title || '暂无' }}</div>
-          <div class="info_brief">
-            <div v-html="info.brief"></div>
-          </div>
-          <div class="info_friend" v-if="info.partner && info.partner.length > 0">
-            <div class="info_title">
-              <el-image class="image" :src="left" fit="fill" />
-              <div class="title">合作伙伴</div>
-              <el-image class="image" :src="right" fit="fill" />
+  <custom-layout class="main" v-loading="loading">
+    <el-col :span="24" class="one" v-if="info.carousel && info.carousel.length > 0">
+      <el-carousel height="680px">
+        <el-carousel-item v-for="(item, index) in info.carousel" :key="index">
+          <el-image class="image" :src="getUrl(item)" fit="fill" @click="toRedirect(item)" />
+        </el-carousel-item>
+      </el-carousel>
+    </el-col>
+    <el-col :span="24" class="one">
+      <div class="title animate__animated animate__fadeInDown">
+        <div class="title_1">新闻中心</div>
+        <div class="title_2">News Center</div>
+      </div>
+      <div class="one_1 w_1300">
+        <el-collapse v-model="activeName" accordion>
+          <el-collapse-item v-for="(item, index) in info.news" :key="index" :title="item.title" :name="index">
+            <div class="list_1">
+              <div class="left textOne">{{ item.title || '暂无' }}</div>
+              <div class="right">{{ moment(item.time).format('YYYY-MM-DD') || '暂无' }}</div>
+            </div>
+            <div class="list_2">
+              <el-image class="image" :src="getFile(item.logo)" fit="fill" />
+              <div v-if="item.content" v-html="item.content"></div>
+            </div>
+          </el-collapse-item>
+        </el-collapse>
+      </div>
+    </el-col>
+    <el-col :span="24" class="one">
+      <div class="title animate__animated animate__fadeInDown">
+        <div class="title_1">企业成员</div>
+        <div class="title_2">Enterprise Members</div>
+      </div>
+      <div class="one_2 w_1300">
+        <swiper :modules="modules" :slides-per-view="3" :space-between="10" :loop="true" :autoplay="{ delay: 4000, disableOnInteraction: false }" navigation :pagination="{ clickable: true }" @swiper="onSwiper" @sliderChange="onSliderChange">
+          <template v-slot:button-prev>
+            <div class="swiper-button-prev" @click="prevBtn">
+              <el-image class="image" :src="icon_slh" fit="fill" />
             </div>
+          </template>
+          <swiper-slide v-for="(item, index) in info.companyPerson" :key="index" :virtual-index="index">
             <div class="list">
-              <div class="other_1" v-for="(tag, indexx) in info.partner" :key="indexx">
-                <el-image class="image" :src="getUrl(tag.url)" fit="fill">
-                  <template v-slot:error>
-                    <el-image class="image" :src="friend" fit="fill" />
-                  </template>
-                </el-image>
-                <div class="name">{{ tag.name }}</div>
-              </div>
+              <el-image class="image" :src="getFile(item.logo)">
+                <template v-slot:error>
+                  <el-image :src="friend" />
+                </template>
+              </el-image>
+              <div class="name">{{ item.name || '暂无名称' }}</div>
+              <div class="other_1">部门:{{ item.department }}</div>
+              <div class="other_1">职位:{{ item.position }}</div>
+              <div class="brief" v-if="item.content" v-html="item.content"></div>
+            </div>
+          </swiper-slide>
+          <template v-slot:button-next>
+            <div class="swiper-button-next" @click="nextBtn">
+              <el-image class="image" :src="icon_srh" fit="fill" />
             </div>
-          </div>
+          </template>
+        </swiper>
+      </div>
+    </el-col>
+    <el-col :span="24" class="one">
+      <div class="one_3">
+        <el-carousel height="900px">
+          <el-carousel-item>
+            <div class="title animate__animated animate__fadeInDown">
+              <div class="title_1">简介</div>
+              <div class="title_2">Brief Introduction</div>
+            </div>
+            <div class="thr w_1300" v-if="info.brief" v-html="info.brief"></div>
+          </el-carousel-item>
+          <el-carousel-item>
+            <div class="title animate__animated animate__fadeInDown">
+              <div class="title_1">发展进程</div>
+              <div class="title_2">Development Process</div>
+            </div>
+            <div class="thr w_1300" v-if="info.process" v-html="info.process"></div>
+          </el-carousel-item>
+          <el-carousel-item>
+            <div class="title animate__animated animate__fadeInDown">
+              <div class="title_1">合作情况</div>
+              <div class="title_2">Cooperation Situation</div>
+            </div>
+            <div class="thr w_1300" v-if="info.situation" v-html="info.situation"></div>
+          </el-carousel-item>
+          <el-carousel-item>
+            <div class="title animate__animated animate__fadeInDown">
+              <div class="title_1">重大活动</div>
+              <div class="title_2">Major Events</div>
+            </div>
+            <div class="thr w_1300" v-if="info.activity" v-html="info.activity"></div>
+          </el-carousel-item>
+        </el-carousel>
+      </div>
+    </el-col>
+    <el-col :span="24" class="one">
+      <div class="title animate__animated animate__fadeInDown">
+        <div class="title_1">合作伙伴</div>
+        <div class="title_2">Cooperative Partner</div>
+      </div>
+      <div class="one_4 w_1300">
+        <div class="list" v-for="(item, index) in info.partner" :key="index">
+          <el-image class="image" :src="getFile(item.url)" fit="fill">
+            <template v-slot:error>
+              <el-image :src="friend" fit="fill" />
+            </template>
+          </el-image>
+          <div class="name">{{ item.name }}</div>
         </div>
       </div>
     </el-col>
@@ -32,23 +114,38 @@
 </template>
 
 <script setup>
+import moment from 'moment'
+import icon_slh from '/images/icon_slh.png'
+import icon_srh from '/images/icon_srh.png'
 import friend from '/images/friend.jpeg'
 import { get } from 'lodash-es'
-import left from '/images/top-left.png'
-import right from '/images/top-right.png'
+// Import Swiper Vue.js components
+import { Swiper, SwiperSlide } from 'swiper/vue'
+import { Autoplay, Pagination, Navigation, Virtual } from 'swiper/modules'
+// Import Swiper styles
+import 'swiper/css'
+import 'swiper/css/navigation'
+import 'swiper/css/pagination'
+import 'swiper/css/scrollbar'
+// 在 modules 加入要使用的模块
+const modules = reactive([Autoplay, Pagination, Navigation, Virtual])
 // 接口
 import { SectorStore } from '@/store/api/platform/sector'
 const store = SectorStore()
+
 // 加载中
 const loading = ref(false)
 // 路由
 const route = useRoute()
 
 const info = ref({})
+const activeName = ref(0)
+
 // 请求
 onMounted(async () => {
   loading.value = true
   await search()
+  await onSwiper()
   loading.value = false
 })
 const search = async () => {
@@ -59,90 +156,189 @@ const search = async () => {
   }
 }
 const getUrl = (item) => {
+  if (item) return `${import.meta.env.VITE_APP_HOST}${get(item, 'uri')}`
+}
+const getFile = (item) => {
   if (item) return `${import.meta.env.VITE_APP_HOST}${get(item, '0.uri')}`
 }
+let useSwiper = null
+// 初始化 swiper
+const onSwiper = (swiper) => {
+  useSwiper = swiper
+}
+
+// 滑动事件
+const onSliderChange = () => {
+  console.log('slide change')
+}
+
+// 通过实例方法自定义上一个下一个事件
+const prevBtn = () => {
+  useSwiper.slidePrev()
+}
+const nextBtn = () => {
+  useSwiper.slideNext()
+}
 </script>
 <style scoped lang="scss">
 .main {
   .one {
-    background: url(/images/friendbg.jpg) no-repeat;
-    background-position: center top;
-    .info_1 {
-      padding: 30px 0;
+    .image {
+      width: 100%;
+      height: 100%;
     }
-    .info_2 {
-      margin: 0 0 30px 0;
-      min-height: 700px;
-      padding: 40px;
-      background-color: #fff;
-      box-shadow: 0 0 13px 0 rgba(5, 88, 219, 0.18);
-      .info_name {
-        font-size: $global-font-size-22;
-        font-weight: bold;
+    .title {
+      margin: 20px 0;
+      .title_1 {
+        font-size: 28px;
+        font-family: FZLanTingHei-EB-GBK;
+        font-weight: 700;
+        color: #000;
         text-align: center;
-        margin: 0 0 40px 0;
+        margin: 0 0 10px 0;
       }
-      .info_friend {
-        .info_title {
-          display: flex;
-          align-items: flex-end;
-          justify-content: center;
-          margin: 40px 0;
-
-          .image:first-child {
-            margin: 0 10px 0 0;
-          }
-          .title {
-            font-size: $global-font-size-28;
-            font-weight: 600;
-          }
-          .image:last-child {
-            margin: 0 0 0 10px;
-          }
+      .title_2 {
+        font-size: 20px;
+        font-family: Arial;
+        font-weight: 400;
+        color: #ccc;
+        text-align: center;
+        letter-spacing: 4px;
+      }
+    }
+    .one_1 {
+      .list_1 {
+        width: 100%;
+        display: flex;
+        align-items: center;
+        height: 47px;
+        border-bottom: 1px dashed #e5e5e5;
+        line-height: 47px;
+        padding-left: 20px;
+        cursor: pointer;
+        .left {
+          width: 92%;
+          font-size: $global-font-size-16;
         }
-        .list {
-          display: flex;
-          justify-content: center;
-          .other_1 {
-            margin: 0 5px;
-            .image {
-              width: 200px;
-              height: 140px;
-            }
-            .name {
-              margin: 10px 0 0 0;
-              font-size: $global-font-size-20;
-              text-align: center;
-            }
-          }
+        .right {
+          color: #999;
+          font-size: $global-font-size-14;
         }
       }
-      .info_brief {
-        margin: 10px 0 0 0;
+      .list_2 {
+        margin: 10px 0;
+      }
+    }
+    .one_2 {
+      height: 600px;
+      .list {
+        margin: 10px;
+        width: 95%;
+        min-height: 562px;
+        background-color: #fff;
+        padding: 30px 0px;
+        -moz-transition: all 0.3s ease-out;
+        -o-transition: all 0.3s ease-out;
+        transition: all 0.3s ease-out;
+        -webkit-box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.15);
+        -moz-box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.15);
+        -o-box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.15);
+        box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.15);
+        text-align: center;
+        .image {
+          width: 100px;
+          height: 100px;
+          border-radius: 80px;
+        }
+        .name {
+          width: 100%;
+          height: 70px;
+          font-size: 25px;
+          line-height: 70px;
+          text-align: center;
+          color: #000;
+        }
+        .other_1 {
+          width: 100%;
+          height: 30px;
+          font-size: 16px;
+          line-height: 30px;
+          text-align: center;
+          color: #2dbef0;
+        }
+        .brief {
+          margin: 10px 20px;
+          max-height: 300px;
+        }
+      }
+    }
+    .one_3 {
+      min-height: 900px;
+      background: url(/images/industryBg.png) no-repeat;
+      background-size: 100% 100%;
+      .title {
+        margin: 20px 0;
+        .title_1 {
+          font-size: 28px;
+          font-family: FZLanTingHei-EB-GBK;
+          font-weight: 700;
+          color: #fff;
+          text-align: center;
+          margin: 0 0 10px 0;
+        }
+        .title_2 {
+          font-size: 20px;
+          font-family: Arial;
+          font-weight: 400;
+          color: #fff;
+          text-align: center;
+          letter-spacing: 4px;
+        }
+      }
+      .thr {
+        padding: 10px;
+        font-size: 20px;
+        font-family: FZLanTingHei-EB-GBK;
+        color: #fff !important;
+        text-align: center;
+      }
+    }
+    .one_4 {
+      display: flex;
+      flex-wrap: wrap;
+      justify-content: space-between;
+      margin: 20px auto;
+      .list {
+        width: 250px !important;
+        height: 330px;
+        box-shadow: 0 0 18px 2px #ececec;
+        transition: all 0.5s;
+        cursor: pointer;
+        padding: 15px;
+        box-sizing: border-box;
+        text-align: center;
+        .image {
+          width: 200px;
+          height: 140px;
+          margin: 40px auto;
+        }
+        .name {
+          font-size: 20px;
+          font-family: Microsoft YaHei;
+          font-weight: 400;
+          color: #767676;
+          margin: 20px 0 12px 0;
+          text-align: center;
+        }
+      }
+      .list:hover {
+        transform: sesle(1.02);
+        background: #189aee;
+        .name {
+          color: #fff;
+        }
       }
     }
-  }
-  :deep(table) {
-    border-collapse: collapse !important;
-    width: 100% !important;
-    text-align: center !important;
-  }
-
-  :deep(th) {
-    border: 1px solid #ddd !important;
-    padding: 8px !important;
-  }
-
-  :deep(td) {
-    border: 1px solid #ddd !important;
-    padding: 8px !important;
-  }
-  :deep(table tr:nth-child(even)) {
-    background-color: #f2f2f2 !important;
-  }
-
-  :deep(table tr:hover) {
-    background-color: #ddd !important;
   }
 }
 </style>

+ 1 - 0
src/views/eight/index.vue

@@ -84,6 +84,7 @@ const toView = async (item) => {
           color: $global-color-fff;
           font-size: $global-font-size-22;
           text-align: center;
+          cursor: default;
           .friend {
             margin: 20px 0;
           }

+ 5 - 1
src/views/one/page.vue

@@ -50,7 +50,7 @@
     </div>
     <div class="two">
       <div class="two_1">
-        <div class="twoList" v-for="(item, index) in recordList" :key="index">
+        <div class="twoList" v-for="(item, index) in recordList" :key="index" @click="toSelect(item)">
           <div class="two_num">
             <span>{{ item.num || 0 }}</span>
             <span>{{ item.unit || '' }}</span>
@@ -241,6 +241,10 @@ const handleMouseOver = (index) => {
 const handleMousOut = (index) => {
   incubatorList.value[index].hover = false
 }
+// 选择数据分析
+const toSelect = (item) => {
+  console.log(item)
+}
 </script>
 <style scoped lang="scss">
 .page {

+ 6 - 4
src/views/twelve/index.vue

@@ -7,7 +7,8 @@
           <div class="title_center">供给信息</div>
           <el-image class="image" :src="right" fit="fill" />
         </div>
-        <div class="leftOne">
+        <el-empty v-if="supplytotal == 0" description="暂无数据" />
+        <div class="leftOne" v-else>
           <div class="list" v-for="(item, index) in supplyList" :key="index">
             <div class="title">
               {{ item.name || '暂无供给名称' }}
@@ -37,7 +38,8 @@
           <div class="title_center">需求信息</div>
           <el-image class="image" :src="right" fit="fill" />
         </div>
-        <div class="leftOne">
+        <el-empty v-if="demandtotal == 0" description="暂无数据" />
+        <div v-else class="leftOne">
           <div class="list" v-for="(item, index) in demandList" :key="index">
             <div class="title">
               {{ item.name || '暂无供给名称' }}
@@ -160,7 +162,7 @@ const searchOther = async () => {}
 const searchsupply = async (query = { supplyskip, supplylimit }) => {
   supplyskip = query.supplyskip
   supplylimit = query.supplylimit
-  const info = { skip: query.supplyskip, limit: query.supplylimit, is_use: '0', status: '1' }
+  const info = { skip: query.supplyskip, limit: query.supplylimit, is_use: '0', status: '1', user: user.value.id }
   let res = await supplyStore.list(info)
   if (res.errcode == '0') {
     supplyList.value = res.data
@@ -171,7 +173,7 @@ const searchsupply = async (query = { supplyskip, supplylimit }) => {
 const searchdemand = async (query = { demandskip, demandlimit }) => {
   demandskip = query.demandskip
   demandlimit = query.demandlimit
-  const info = { skip: query.demandskip, limit: query.demandlimit, is_use: '0', status: '1' }
+  const info = { skip: query.demandskip, limit: query.demandlimit, is_use: '0', status: '1', user: user.value.id }
   let res = await demandStore.list(info)
   if (res.errcode == '0') {
     demandList.value = res.data

+ 8 - 2
src/views/two/add/achievement.vue

@@ -147,7 +147,10 @@ const toSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 const toDraftSave = async () => {
   const data = cloneDeep(form.value)
@@ -155,7 +158,10 @@ const toDraftSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 </script>
 <style scoped lang="scss"></style>

+ 8 - 2
src/views/two/add/demand.vue

@@ -132,7 +132,10 @@ const toSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 const toDraftSave = async () => {
   const data = cloneDeep(form.value)
@@ -145,7 +148,10 @@ const toDraftSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 </script>
 <style scoped lang="scss"></style>

+ 8 - 2
src/views/two/add/footplate.vue

@@ -101,7 +101,10 @@ const toSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 const toDraftSave = async () => {
   const data = cloneDeep(form.value)
@@ -109,7 +112,10 @@ const toDraftSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 // 上传图片
 const onUpload = (e) => {

+ 9 - 2
src/views/two/add/match.vue

@@ -187,6 +187,7 @@ const rulesFields = ref([
   { label: '赛事联络', model: 'rules11', custom: true },
   { label: '赛事交流', model: 'rules12', custom: true }
 ])
+const rules = reactive({ name: [{ required: true, message: '请输入赛事名称', trigger: 'blur' }], form: [{ required: true, message: '请选择类别', trigger: 'blur' }] })
 // 请求
 onMounted(async () => {
   loading.value = true
@@ -234,7 +235,10 @@ const toSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 const toDraftSave = async () => {
   const data = cloneDeep(form.value)
@@ -247,7 +251,10 @@ const toDraftSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 // 上传图片
 const onUpload = (e) => {

+ 8 - 2
src/views/two/add/news2.vue

@@ -81,7 +81,10 @@ const toSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 const toDraftSave = async () => {
   const data = cloneDeep(form.value)
@@ -89,7 +92,10 @@ const toDraftSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 
 // 上传图片

+ 8 - 2
src/views/two/add/project.vue

@@ -144,7 +144,10 @@ const toSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 const toDraftSave = async () => {
   const data = cloneDeep(form.value)
@@ -152,7 +155,10 @@ const toDraftSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 </script>
 <style scoped lang="scss"></style>

+ 8 - 2
src/views/two/add/supply.vue

@@ -125,7 +125,10 @@ const toSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 const toDraftSave = async () => {
   const data = cloneDeep(form.value)
@@ -138,7 +141,10 @@ const toDraftSave = async () => {
   let res
   if (get(data, 'id')) res = await store.update({ ...data, ...other })
   else res = await store.create({ ...data, ...other })
-  if ($checkRes(res, true)) ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+  if ($checkRes(res, true)) {
+    ElMessage({ message: `发布成功可以长历史发布查看`, type: 'success' })
+    form.value = {}
+  }
 }
 </script>
 <style scoped lang="scss"></style>

+ 16 - 14
src/views/two/index.vue

@@ -6,31 +6,33 @@
         <div class="tab_2" @click="toTabs('1')">历史发布</div>
       </div>
       <div class="content" v-if="active == '0'">
-        <el-select v-model="value1" placeholder="请选择要发布信息类型" size="large" style="width: 240px">
+        <el-select v-model="value1" clearable placeholder="请选择要发布信息类型" size="large" style="width: 240px">
           <el-option v-for="item in options" :key="item.route_name" :label="item.name" :value="item.route_name" />
         </el-select>
         <div class="content_1">
           <achievement v-if="value1 == 'achievement'"></achievement>
-          <demand v-if="value1 == 'demand'"></demand>
-          <news2 v-if="value1 == 'news2'"></news2>
-          <supply v-if="value1 == 'supply'"></supply>
-          <footplate v-if="value1 == 'footplate'"></footplate>
-          <match v-if="value1 == 'match'"></match>
-          <project v-if="value1 == 'project'"></project>
+          <demand v-else-if="value1 == 'demand'"></demand>
+          <news2 v-else-if="value1 == 'news2'"></news2>
+          <supply v-else-if="value1 == 'supply'"></supply>
+          <footplate v-else-if="value1 == 'footplate'"></footplate>
+          <match v-else-if="value1 == 'match'"></match>
+          <project v-else-if="value1 == 'project'"></project>
+          <el-alert v-else title="请选择发布信息类型" type="warning" effect="dark" :closable="false" />
         </div>
       </div>
       <div class="content" v-else>
-        <el-select v-model="value2" placeholder="请选择要历史信息类型" size="large" style="width: 240px">
+        <el-select v-model="value2" clearable placeholder="请选择要历史信息类型" size="large" style="width: 240px">
           <el-option v-for="item in options2" :key="item.route_name" :label="item.name" :value="item.route_name" />
         </el-select>
         <div class="content_1">
           <achievement2 v-if="value2 == 'achievement'"></achievement2>
-          <demand2 v-if="value2 == 'demand'"></demand2>
-          <news22 v-if="value2 == 'news2'"></news22>
-          <supply2 v-if="value2 == 'supply'"></supply2>
-          <footplate2 v-if="value2 == 'footplate'"></footplate2>
-          <match2 v-if="value2 == 'match'"></match2>
-          <project2 v-if="value2 == 'project'"></project2>
+          <demand2 v-else-if="value2 == 'demand'"></demand2>
+          <news22 v-else-if="value2 == 'news2'"></news22>
+          <supply2 v-else-if="value2 == 'supply'"></supply2>
+          <footplate2 v-else-if="value2 == 'footplate'"></footplate2>
+          <match2 v-else-if="value2 == 'match'"></match2>
+          <project2 v-else-if="value2 == 'project'"></project2>
+          <el-alert v-else title="请选择要历史信息类型" type="warning" effect="dark" :closable="false" />
         </div>
       </div>
     </div>