From 676e73b8780c6cb49596865de81e6d806544ef10 Mon Sep 17 00:00:00 2001
From: 张诺 <zhang_12370@163.com>
Date: 星期四, 09 四月 2026 13:29:28 +0800
Subject: [PATCH] fix: 阳光印刷:添加附件功能,新增时可以上传附件、审核时要求可以预览附件.公司电话为必填项,改为选填 fix:调整供应商管理表单验证及优化知识库文件处理 - 将供应商管理中的公司电话字段改为非必填 - 移除销售报价中未使用的 delLedgerFile 导入 - 优化知识库文件上传组件,添加文件操作按钮和预览功能 - 修复知识库编辑时文件列表显示异常问题 - 统一文件下载和预览的处理逻辑

---
 src/views/reportAnalysis/PSIDataAnalysis/components/center-top.vue |   81 ++++++++++++++--------------------------
 1 files changed, 28 insertions(+), 53 deletions(-)

diff --git a/src/views/reportAnalysis/PSIDataAnalysis/components/center-top.vue b/src/views/reportAnalysis/PSIDataAnalysis/components/center-top.vue
index 15df549..0937b32 100644
--- a/src/views/reportAnalysis/PSIDataAnalysis/components/center-top.vue
+++ b/src/views/reportAnalysis/PSIDataAnalysis/components/center-top.vue
@@ -2,39 +2,19 @@
   <div>
     <!-- 椤堕儴缁熻鍗$墖 -->
     <div class="stats-cards">
-      <div class="stat-card">
+      <div
+        v-for="item in statItems"
+        :key="item.name"
+        class="stat-card"
+      >
         <img src="@/assets/BI/icon@2x.png" alt="鍥炬爣" class="card-icon" />
         <div class="card-content">
-          <span class="card-label">閿�鍞骇鍝佹暟</span>
-          <span class="card-value">{{ totalStaff }}</span>
-          <div class="card-compare" :class="compareClass(staffYoY)">
+          <span class="card-label">{{ item.name }}</span>
+          <span class="card-value">{{ item.value }}</span>
+          <div class="card-compare" :class="compareClass(Number(item.rate))">
             <span>鍚屾瘮</span>
-            <span class="compare-value">{{ formatPercent(staffYoY) }}</span>
-            <span class="compare-icon">{{ staffYoY >= 0 ? '鈫�' : '鈫�' }}</span>
-          </div>
-        </div>
-      </div>
-      <div class="stat-card">
-        <img src="@/assets/BI/icon@2x.png" alt="鍥炬爣" class="card-icon" />
-        <div class="card-content">
-          <span class="card-label">閲囪喘浜у搧鏁�</span>
-          <span class="card-value">{{ totalCustomers }}</span>
-          <div class="card-compare" :class="compareClass(customersYoY)">
-            <span>鍚屾瘮</span>
-            <span class="compare-value">{{ formatPercent(customersYoY) }}</span>
-            <span class="compare-icon">{{ customersYoY >= 0 ? '鈫�' : '鈫�' }}</span>
-          </div>
-        </div>
-      </div>
-      <div class="stat-card">
-        <img src="@/assets/BI/icon@2x.png" alt="鍥炬爣" class="card-icon" />
-        <div class="card-content">
-          <span class="card-label">搴撳瓨鏁�</span>
-          <span class="card-value">{{ totalSuppliers }}</span>
-          <div class="card-compare" :class="compareClass(suppliersYoY)">
-            <span>鍚屾瘮</span>
-            <span class="compare-value">{{ formatPercent(suppliersYoY) }}</span>
-            <span class="compare-icon">{{ suppliersYoY >= 0 ? '鈫�' : '鈫�' }}</span>
+            <span class="compare-value">{{ formatPercent(item.rate) }}</span>
+            <span class="compare-icon">{{ Number(item.rate) >= 0 ? '鈫�' : '鈫�' }}</span>
           </div>
         </div>
       </div>
@@ -45,40 +25,35 @@
 
 <script setup>
 import { ref, onMounted } from 'vue'
-import { summaryStatistics } from '@/api/viewIndex.js'
+import { salesPurchaseStorageProductCount } from '@/api/viewIndex.js'
 
-// 缁熻鏁版嵁
-const totalStaff = ref(0)
-const totalCustomers = ref(0)
-const totalSuppliers = ref(0)
-// 鍚屾瘮
-const staffYoY = ref(0)
-const customersYoY = ref(0)
-const suppliersYoY = ref(0)
+const statItems = ref([])
 
 const formatPercent = (val) => {
   const num = Number(val) || 0
-  return `${Math.abs(num).toFixed(2)}%`
+  return `${num.toFixed(2)}%`
 }
 
 const compareClass = (val) => (val >= 0 ? 'compare-up' : 'compare-down')
 
-// 鑾峰彇鍛樺伐銆佸鎴枫�佷緵搴斿晢鏁伴噺
-const getNum = () => {
-  summaryStatistics().then((res) => {
-    totalStaff.value = res.data.totalStaff
-    staffYoY.value = res.data.staffGrowthRate
-    totalCustomers.value = res.data.totalCustomer
-    customersYoY.value = res.data.customerGrowthRate
-    totalSuppliers.value = res.data.totalSupplier
-    suppliersYoY.value = res.data.supplierGrowthRate
-  }).catch(err => {
-    console.error('鑾峰彇鍩虹缁熻鏁版嵁澶辫触:', err)
-  })
+const fetchData = () => {
+  salesPurchaseStorageProductCount()
+    .then((res) => {
+      if (res.code === 200 && Array.isArray(res.data)) {
+        statItems.value = res.data.map((item) => ({
+          name: item.name,
+          value: item.value,
+          rate: item.rate,
+        }))
+      }
+    })
+    .catch((err) => {
+      console.error('鑾峰彇閿�鍞�/閲囪喘/鍌ㄥ瓨浜у搧鏁板け璐�:', err)
+    })
 }
 
 onMounted(() => {
-  getNum()
+  fetchData()
 })
 </script>
 

--
Gitblit v1.9.3