From 1156fbe1fa77e4a6b7d890604d25e98edf8a7059 Mon Sep 17 00:00:00 2001
From: zhangwencui <1064582902@qq.com>
Date: 星期三, 28 一月 2026 17:40:09 +0800
Subject: [PATCH] Merge branch 'dev_New' of http://114.132.189.42:9002/r/product-inventory-management into dev_New

---
 src/views/reportAnalysis/PSIDataAnalysis/components/left-top.vue |   84 +++++++++++++----------------------------
 1 files changed, 27 insertions(+), 57 deletions(-)

diff --git a/src/views/reportAnalysis/PSIDataAnalysis/components/left-top.vue b/src/views/reportAnalysis/PSIDataAnalysis/components/left-top.vue
index a282389..d4c1b76 100644
--- a/src/views/reportAnalysis/PSIDataAnalysis/components/left-top.vue
+++ b/src/views/reportAnalysis/PSIDataAnalysis/components/left-top.vue
@@ -22,7 +22,7 @@
 
 <script setup>
 import { ref, onMounted, computed } from 'vue'
-import { deptStaffDistribution } from '@/api/viewIndex.js'
+import { productSalesAnalysis } from '@/api/viewIndex.js'
 import PanelHeader from './PanelHeader.vue'
 import CarouselCards from './CarouselCards.vue'
 import Echarts from '@/components/Echarts/echarts.vue'
@@ -65,13 +65,13 @@
   return {
     orient: 'vertical',
     top: 'center',
-    left: '60%',
+    left: '52%',
     itemGap: 30,
     data: data,
     formatter: function (name) {
       const item = pieObjData.value[name]
       if (!item) return name
-      return `{title|${name}}{value|${item.value}}{unit|浜簘{percent|${item.rate}}{unit|%}`
+      return `{title|${name}}{value|${item.value}}{unit|鍏儅{percent|${item.rate}}{unit|%}`
     },
     textStyle: {
       rich: {
@@ -79,7 +79,7 @@
           color: '#43e8fc',
           fontSize: 14,
           fontWeight: 600,
-          padding: [0, 0, 0, 30],
+          padding: [0, 0, 0, 10],
         },
         unit: {
           color: '#82baff',
@@ -104,7 +104,7 @@
 
 const pieTooltip = {
   trigger: 'item',
-  formatter: '{a} <br/>{b} : {c} ({d}%)',
+  formatter: '{a} <br/>{b} : {c}鍏� ({d}%)',
 }
 
 const pieSeries = computed(() => [
@@ -137,61 +137,31 @@
 
 const cardItems = ref([])
 
-// 鍋囨暟鎹�
-const mockData = [
-  { name: '鐢熶骇閮�', value: 125, rate: '35.2' },
-  { name: '鎶�鏈儴', value: 85, rate: '23.9' },
-  { name: '閿�鍞儴', value: 65, rate: '18.3' },
-  { name: '璐㈠姟閮�', value: 32, rate: '9.0' },
-  { name: '浜轰簨閮�', value: 28, rate: '7.9' },
-  { name: '琛屾斂閮�', value: 20, rate: '5.6' },
-]
-
-const getDeptStaffDistribution = () => {
-  setMockData()
-  // deptStaffDistribution().then(res => {
-  //   if (res.code === 200) {
-  //     const items = res.data.items || []
-  //     // 鍗$墖鏁版嵁
-  //     cardItems.value = items.map(item => ({
-  //       label: item.name,
-  //       value: parseInt(item.value),
-  //       unit: '浜�'
-  //     }))
-  //     // 鍥捐〃鏁版嵁
-  //     pieDatas.value = items.map(item => ({
-  //       name: item.name,
-  //       value: parseInt(item.value),
-  //       rate: item.rate
-  //     }))
-  //   } else {
-  //     // 浣跨敤鍋囨暟鎹�
-  //     setMockData()
-  //   }
-  // }).catch(err => {
-  //   console.error('鑾峰彇閮ㄩ棬浜哄憳鍒嗗竷鏁版嵁澶辫触:', err)
-  //   // 浣跨敤鍋囨暟鎹�
-  //   setMockData()
-  // })
-}
-
-const setMockData = () => {
-  // 鍗$墖鏁版嵁
-  cardItems.value = mockData.map(item => ({
-    label: item.name,
-    value: item.value,
-    unit: '浜�'
-  }))
-  // 鍥捐〃鏁版嵁
-  pieDatas.value = mockData.map(item => ({
-    name: item.name,
-    value: item.value,
-    rate: item.rate
-  }))
+const fetchData = () => {
+  productSalesAnalysis()
+    .then((res) => {
+      if (res.code === 200 && Array.isArray(res.data)) {
+        const items = res.data
+        cardItems.value = items.map((item) => ({
+          label: item.name,
+          value: item.value,
+          unit: '鍏�',
+          rate: item.rate,
+        }))
+        pieDatas.value = items.map((item) => ({
+          name: item.name,
+          value: parseFloat(item.value) || 0,
+          rate: item.rate,
+        }))
+      }
+    })
+    .catch((err) => {
+      console.error('鑾峰彇浜у搧閿�鍞噾棰濆垎鏋愬け璐�:', err)
+    })
 }
 
 onMounted(() => {
-  getDeptStaffDistribution()
+  fetchData()
 })
 </script>
 

--
Gitblit v1.9.3