From 9ae2c0863a9e0a7bed5e00faf008160a2791f16a Mon Sep 17 00:00:00 2001
From: yyb <995253665@qq.com>
Date: 星期三, 31 十二月 2025 09:40:05 +0800
Subject: [PATCH] Pda盘点报告盘点页面开发,功能逻辑梳理,逻辑编写,接口测试联调,Pda版本号更改

---
 pages/wareHouse/inventory/index.vue |  978 +++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 712 insertions(+), 266 deletions(-)

diff --git a/pages/wareHouse/inventory/index.vue b/pages/wareHouse/inventory/index.vue
index dedccde..08944a5 100644
--- a/pages/wareHouse/inventory/index.vue
+++ b/pages/wareHouse/inventory/index.vue
@@ -1,272 +1,718 @@
 <template>
-	<view class="page">
-	  <view class="inventory-list-bg"/>
-	  <u-navbar title="鐩樼偣鍒楄〃" :background="background" :border-bottom="false" :title-bold="true" title-color="#000" back-icon-color="#000"/>
-	  <view class="inventory-list-search">
-	  	<u-search v-model="query.inyNo" shape="square" bg-color="rgba(250,252,255,0.36)" :show-action="false" placeholder="鐩樼偣缂栧彿" @clear="search" @custom="search" @search="search">
-	  	</u-search>
-	  </view>
-	  <view class="wrap">
-		<scroll-view class="inventory-list-scroll-list" scroll-y="true" @scrolltolower="loadMore">
-			<u-cell-group class="inventory-list-scroll-list-group" :border="false">
-				<view class="content" v-for="(item, index) in list" :key="index" :index="index"
-					@click="goDetail(item)">
-				    <view class="content-header">
-						<view class="content-header-left">
-							<view class="content-header-icon"></view>
-							<view class="content-header-title">鐩樼偣缂栧彿锛歿{ item.inyNo }}</view>
-						</view>
-						<view class="content-header-right">
-							{{item.inyStatus=='finished'?'宸插畬鎴�':'鑽夌'}}
-						</view>
-				    </view>
-				    <view class="content-body">
-				    	<view class="row-list">
-				    		<view class="_label">
-				    			<view class="_label-icon-1">
-				    			</view>
-				    			<view class="_label-name">鐩樼偣鎻忚堪锛�</view>	
-				    		</view>
-				    		<view class="_content">
-				    			{{ item.inyDesc||'鏃�' }}
-				    		</view>
-				    	</view>
-				    	<view class="row-list">
-				    		<view class="_label">
-				    			<view class="_label-icon-2">
-				    			</view>
-				    			<view class="_label-name">鍒� 寤� 浜猴細</view>	
-				    		</view>
-				    		<view class="_content">
-				    			{{ item.createUser }}
-				    		</view>
-				    	</view>
-				    	<view class="row-list">
-				    		<view class="_label">
-				    			<view class="_label-icon-3">
-				    			</view>
-				    			<view class="_label-name">鍒涘缓鏃堕棿锛�</view>	
-				    		</view>
-				    		<view class="_content">
-				    			{{ item.createTime }}
-				    		</view>
-				    	</view>
-				    </view>
-				</view>
-			</u-cell-group>
-			<view class="loadmore" @click="loadMore">
-				<u-loadmore :status="loadStatus"></u-loadmore>
-			</view>
-		</scroll-view>
-	</view>
+  <view class="page">
+    <view class="packing-registration-bg" />
+    <u-navbar
+      title="搴撳瓨鐩樼偣"
+      :background="background"
+      :border-bottom="false"
+      :title-bold="true"
+      title-color="#000"
+      back-icon-color="#000"
+    >
+      <template #right>
+        <text
+          style="font-size: 14px; margin-right: 14px; font-weight: bold"
+          @click="goSubmit"
+          >鎻愪氦</text
+        >
+      </template>
+    </u-navbar>
+    <view class="packing-registration-param">
+      <view class="packing-registration-param-view">
+        <view class="packing-registration-param-item param-extra">
+          <view class="packing-registration-param-item-left">
+            <text class="item-one">鐩樼偣鎶ュ憡鍙�</text>
+          </view>
+          <view class="packing-registration-param-item-right">
+            <text class="item-one item-two" @click="seaRchPersonnelNo()">{{
+              registerInfo.invListNo == "" ? "鐐瑰嚮閫夋嫨" : registerInfo.invListNo
+            }}</text>
+            <u-icon
+              name="arrow-right"
+              color="#687792"
+              size="28"
+              @click="seaRchPersonnelNo()"
+              v-show="registerInfo.invListNo == ''"
+            ></u-icon>
+          </view>
+        </view>
+        <view class="packing-registration-param-item param-extra">
+          <view class="packing-registration-param-item-left">
+            <text class="item-one">浠撳簱</text>
+          </view>
+          <view class="packing-registration-param-item-right">
+            <text class="item-one item-two">{{
+              registerInfo.warehouseId
+            }}</text>
+          </view>
+        </view>
+        <view class="packing-registration-param-item param-extra">
+          <view class="packing-registration-param-item-left">
+            <text class="item-one">闆朵欢鍙�</text>
+          </view>
+          <view class="packing-registration-param-item-right">
+            <view class="item-one item-two" @click="openPN()">
+              <text>{{
+                registerInfo.partNo == "" ? "鐐瑰嚮杈撳叆" : registerInfo.partNo
+              }}</text>
+            </view>
+            <u-icon
+              name="arrow-right"
+              color="#687792"
+              size="28"
+              v-show="registerInfo.partNo == ''"
+            ></u-icon>
+          </view>
+        </view>
+        <view class="packing-registration-param-item param-extra">
+          <view class="packing-registration-param-item-left">
+            <text class="item-one">鎵规鍙�</text>
+          </view>
+          <view
+            class="packing-registration-param-item-right"
+            @click="openBatch()"
+          >
+            <text class="item-one item-two">{{
+              registerInfo.ifsBatchNo == ""
+                ? "鐐瑰嚮杈撳叆"
+                : registerInfo.ifsBatchNo
+            }}</text>
+            <u-icon
+              name="arrow-right"
+              color="#687792"
+              size="28"
+              v-show="registerInfo.ifsBatchNo == ''"
+            ></u-icon>
+          </view>
+        </view>
+        <view class="packing-registration-param-item param-extra">
+          <view class="packing-registration-param-item-left">
+            <text class="item-one">搴撲綅鍙�</text>
+          </view>
+          <view
+            class="packing-registration-param-item-right"
+            @click="openLocation()"
+          >
+            <view class="item-one item-two">
+              <text>{{
+                registerInfo.locationNo == ""
+                  ? "鐐瑰嚮杈撳叆"
+                  : registerInfo.locationNo
+              }}</text>
+            </view>
+            <u-icon
+              name="arrow-right"
+              color="#687792"
+              size="28"
+              v-show="registerInfo.locationNo == ''"
+            ></u-icon>
+          </view>
+        </view>
+        <view class="packing-registration-param-item param-extra">
+          <view class="packing-registration-param-item-left">
+            <text class="item-one">鐩樼偣鏁伴噺</text>
+          </view>
+          <view
+            class="packing-registration-param-item-right"
+            @click="openPhysicalInventory()"
+          >
+            <view class="item-one item-two">
+              <text>{{
+                registerInfo.qtyAvailable == ""
+                  ? "鐐瑰嚮杈撳叆"
+                  : registerInfo.qtyAvailable
+              }}</text>
+            </view>
+            <u-icon
+              name="arrow-right"
+              color="#687792"
+              size="28"
+              v-show="registerInfo.qtyAvailable == ''"
+            ></u-icon>
+          </view>
+        </view>
+        <view class="packing-registration-param-item param-extra">
+          <view class="packing-registration-param-item-left">
+            <text class="item-one">鐩樼偣璁板綍锛�</text>
+          </view>
+        </view>
+      </view>
     </view>
+    <view class="wrap">
+      <scroll-view class="packing-registration-scroll-list" scroll-y="true">
+        <u-cell-group
+          class="packing-registration-scroll-list-group"
+          :border="false"
+        >
+          <!-- <div class="tip" style="text-align: center;" v-if="hasScanSnList.length==0">-璇锋壂鐮�-</div> -->
+          <view
+            class="content"
+            v-for="(item, index) in hasScanSnList"
+            :key="index"
+            :index="index"
+          >
+            <view class="content-header">
+              <view class="content-header-title">{{
+                hasScanSnList.length - index
+              }}</view>
+            </view>
+            <view class="content-body">
+              <view class="row-list">
+                <view class="_label">
+                  <view class="_label-name">闆朵欢鍙凤細</view>
+                </view>
+                <view class="_content">
+                  {{ item.partNo }}
+                </view>
+              </view>
+              <view class="row-list">
+                <view class="_label">
+                  <view class="_label-name">鎵规鍙凤細</view>
+                </view>
+                <view class="_content">
+                  {{ item.ifsBatchNo }}
+                </view>
+              </view>
+              <view class="row-list">
+                <view class="_label">
+                  <view class="_label-name">搴撲綅鍙凤細</view>
+                </view>
+                <view class="_content">
+                  {{ item.locationNo }}
+                </view>
+              </view>
+              <view class="row-list">
+                <view class="_label">
+                  <view class="_label-name">鐩樼偣鏁伴噺锛�</view>
+                </view>
+                <view class="_content">
+                  {{ item.qtyAvailable }}
+                </view>
+              </view>
+            </view>
+          </view>
+        </u-cell-group>
+      </scroll-view>
+      <scan></scan>
+      <!-- 闆朵欢鍙� -->
+      <modalBg ref="openPN" :confirm="confirmPN">
+        <u-field
+          v-model="registerInfo.partNo"
+          label="闆朵欢鍙凤細"
+          placeholder="璇疯緭鍏�"
+          :border-bottom="false"
+        >
+        </u-field>
+      </modalBg>
+      <!-- 鎵规鍙� -->
+      <modalBg ref="openBatch" :confirm="confirmBatch">
+        <u-field
+          v-model="registerInfo.ifsBatchNo"
+          label="鎵规鍙凤細"
+          placeholder="璇疯緭鍏�"
+          :border-bottom="false"
+        >
+        </u-field>
+      </modalBg>
+      <!-- 搴撲綅鍙� -->
+      <modalBg ref="openLocation" :confirm="confirmLocation">
+        <u-field
+          v-model="registerInfo.locationNo"
+          label="搴撲綅鍙凤細"
+          placeholder="璇疯緭鍏�"
+          :border-bottom="false"
+        >
+        </u-field>
+      </modalBg>
+      <!-- 鐩樼偣鏁伴噺 -->
+      <modalBg ref="openPhysicalInventory" :confirm="confirmPhysicalInventory">
+        <u-field
+          v-model="registerInfo.qtyAvailable"
+          label="鐩樼偣鏁伴噺锛�"
+          label-width="140"
+          placeholder="璇疯緭鍏�"
+          :border-bottom="false"
+        >
+        </u-field>
+      </modalBg>
+    </view>
+  </view>
 </template>
 <script>
-	import content_bg from '@/static/custom/inventory/locNoBg.png'
-	export default {
-		data() {
-			return {
-				background:{
-					backgroundImage: `url(${content_bg})`,
-					backgroundAttachment: 'fixed',
-					backgroundSize: '100% auto',
-					backgroundRepeat: 'no-repeat',
-				},
-				keywords: '',
-				query: {
-					current: 1,
-					size: 20,
-					criteria:JSON.stringify({
-						orderBy:{
-							column:'createTime',
-							direction:'desc'
-						}
-					})
-				},
-				list: [],
-				count: 0,
-				loadStatus: 'loading'
-			};
-		},
-		onLoad() {
-			this.loadList();
-		},
-		onShow() {
+import modalBg from "@/components/modal/modal-bg.vue";
+import scan from "@/components/scan/scan.vue";
+import content_bg from "@/static/custom/packing/backBg.png";
+export default {
+  components: {
+    scan,
+    modalBg,
+  },
+  data() {
+    return {
+      background: {
+        backgroundImage: `url(${content_bg})`,
+        backgroundAttachment: "fixed",
+        backgroundSize: "100% auto",
+        backgroundRepeat: "no-repeat",
+      },
+      labelStyle: {
+        fontSize: "32rpx",
+        whiteSpace: "nowrap",
+      },
+      registerInfo: {
+        invListNo: "",
+        warehouseId: "",
+        partNo: "",
+        ifsBatchNo: "",
+        locationNo: "",
+        qtyAvailable: "",
+      },
+      hasScanSnList: [],
+      delContent: null,
+      staffList: [],
+      submitList: {},
+      scanHandleList: {},
+    };
+  },
+  onLoad(option) {},
+  onShow() {
+    let that = this;
 
-		},
-		filters: {
-			inyStatus(val) {
-				let inyStatus = {
-					finished: '宸插畬鎴�',
-					draft: '鑽夌',
-				}
-				return inyStatus[val]
-			}
-		},
-		methods: {
-			loadMore() {
-				if(this.loadStatus == "nomore"){
-					return
-				}
-				this.loadStatus = "loading";
-				setTimeout(() => {
-					this.query.current += 1;
-					this.loadList();
-				}, 100);
-			},
-			loadList() {
-				this.$u.api.inventory.getMain(this.query).then(res => {
-					this.list = this.list.concat(res.data.records);
-					//this.total = res.data.total;
-					this.query.current = res.data.current;
-					this.query.size = res.data.size;
-					this.loadStatus = "loadmore";
-					if (!res.data.records || res.data.records.length < this.query.size) {
-						this.loadStatus = "nomore";
-					}
-				});
-			},
-			search(value) {
-				this.list = [];
-				this.query.current = 1;
-				this.loadList();
-			},
-			goDetail(item) {
-				if(item.inyStatus === 'finished'){
-					uni.showToast({
-						title: "鐩樼偣宸插畬鎴愩��",
-						icon: "none"
-					});
-					return
-				}
-				uni.navigateTo({
-					url: `/pages/wareHouse/inventory/detail?id=${item.id}&no=${item.inyNo}`
-				})
-			}
-		}
-	};
+    uni.$off("scan"); // 姣忔杩涙潵鍏� 绉婚櫎鍏ㄥ眬鑷畾涔変簨浠剁洃鍚櫒
+
+    uni.$on("scan", function (data) {
+      if (that.registerInfo.invListNo == "") {
+        uni.showToast({
+          title: "璇峰厛閫夋嫨鐩樼偣鎶ュ憡鍙�",
+          icon: "none",
+        });
+        return;
+      }
+      console.log("onscan");
+      //鎵爜鎴愬姛鍚庣殑鍥炶皟锛屼綘鍙互鍐欒嚜宸辩殑閫昏緫浠g爜鍦ㄨ繖閲�
+      console.log("鎵爜缁撴灉锛�", data.code);
+      if (data.code) {
+        let codeInfo = JSON.parse(data.code);
+        // if (codeInfo.BN) {
+        // 鎵弿鎶ュ伐鍗曚簩缁寸爜
+        that.scanHandleList = codeInfo;
+        that.scanHandle(codeInfo);
+        // that.$forceUpdate();
+        // }
+      }
+    });
+  },
+  //   onNavigationBarButtonTap() {
+  //     this.goScan();
+  //   },
+  onReady() {},
+  methods: {
+    //闆朵欢鍙�
+    openPN() {
+      this.$refs.openPN.open();
+    },
+    // 寮规淇濆瓨
+    confirmPN() {
+      console.log("淇濆瓨", this.registerInfo.partNo);
+      // 璇锋眰鎺ュ彛锛屾牴鎹伐鍗曞彿鏌ヨ鍏朵粬淇℃伅骞惰祴鍊�
+    },
+    //鎵规鍙�
+    openBatch() {
+      this.$refs.openBatch.open();
+    },
+    // 寮规淇濆瓨
+    confirmBatch() {
+      console.log("淇濆瓨", this.registerInfo.ifsBatchNo);
+      // 璇锋眰鎺ュ彛锛屾牴鎹伐鍗曞彿鏌ヨ鍏朵粬淇℃伅骞惰祴鍊�
+    },
+    //搴撲綅鍙�
+    openLocation() {
+      this.$refs.openLocation.open();
+    },
+    // 寮规淇濆瓨
+    confirmLocation() {
+      console.log("淇濆瓨", this.registerInfo.locationNo);
+      // 璇锋眰鎺ュ彛锛屾牴鎹伐鍗曞彿鏌ヨ鍏朵粬淇℃伅骞惰祴鍊�
+    },
+    //鐩樼偣鏁伴噺
+    openPhysicalInventory() {
+      this.$refs.openPhysicalInventory.open();
+    },
+    // 寮规淇濆瓨
+    confirmPhysicalInventory() {
+      console.log("淇濆瓨", this.registerInfo.qtyAvailable);
+      // this.registerInfo.qtyAvailable = Number(this.registerInfo.qtyAvailable);
+      // 璇锋眰鎺ュ彛锛屾牴鎹伐鍗曞彿鏌ヨ鍏朵粬淇℃伅骞惰祴鍊�
+    },
+
+    setNo(val) {
+      console.log("val", val);
+      this.registerInfo.invListNo = val.INV_LIST_NO;
+      this.registerInfo.warehouseId = val.WAREHOUSE_ID;
+    },
+    //鐩樼偣鎶ュ憡鍙�
+    seaRchPersonnelNo() {
+      uni.navigateTo({
+        url: "/pages/wareHouse/inventory/orderList",
+      });
+    },
+    scanHandle(val) {
+      this.submitList = {};
+      const { PN, BN, NW } = val;
+      this.$u.api.shiftingParking
+        .selPartInfoPDA({ outBatchNo: BN })
+        .then((res) => {
+          console.log("res", res);
+          this.submitList = res.data;
+          // 妫�鏌ユ槸鍚﹀凡鐩樼偣
+          if (this.hasScanSnList && this.hasScanSnList.length > 0) {
+            // 鏌ユ壘鏄惁宸插瓨鍦ㄧ浉鍚岀殑 ifsBatchNo
+            const isAlreadyScanned = this.hasScanSnList.some(
+              (item) => item.ifsBatchNo === this.submitList.ifsBatchNo
+            );
+
+            if (isAlreadyScanned) {
+              uni.showModal({
+                title: "鎻愮ず",
+                content: "褰撳墠搴撳瓨宸茬洏鐐癸紝璇峰嬁閲嶅鐩樼偣",
+                showCancel: false,
+                confirmText: "纭畾",
+              });
+              return;
+            }
+          }
+          this.registerInfo = {
+            ...this.registerInfo,
+            partNo: this.submitList.partNo,
+            ifsBatchNo: this.submitList.ifsBatchNo,
+            // locationNo: this.registerInfo.locationNo,
+            qtyAvailable: this.submitList.qtyAvailable,
+          };
+
+          this.goSubmit();
+        })
+        .catch((err) => {
+          console.log("err", err);
+          uni.showModal({
+            title: "鎻愮ず",
+            content: err.message || "缃戠粶寮傚父锛岃閲嶈瘯",
+            showCancel: true,
+            success: function (res) {},
+          });
+          return;
+        });
+    },
+    getDifferentFields(obj1, obj2, mapping) {
+      const differences = {};
+
+      for (const [key1, mapRule] of Object.entries(mapping)) {
+        let value2;
+
+        if (typeof mapRule === "string") {
+          value2 = obj2[mapRule];
+        } else if (
+          mapRule &&
+          typeof mapRule === "object" &&
+          "fixed" in mapRule
+        ) {
+          value2 = mapRule.fixed;
+        } else {
+          continue;
+        }
+
+        if (obj1[key1] !== value2) {
+          differences[key1] = {
+            value1: obj1[key1],
+            value2,
+          };
+        }
+      }
+
+      return differences;
+    },
+    // 鐐瑰嚮鎻愪氦鎸夐挳鐨勪簨浠跺鐞嗗嚱鏁�
+    goSubmit() {
+      if (!this.registerInfo.invListNo) {
+        this.$u.toast("璇烽�夋嫨鐩樼偣鎶ュ憡鍙�");
+        return;
+      }
+      const diff = this.getDifferentFields(
+        this.registerInfo,
+        this.scanHandleList,
+        {
+          partNo: { fixed: this.scanHandleList.PN },
+          // qtyAvailable: { fixed: Number(this.scanHandleList.NW) },
+          ifsBatchNo: { fixed: this.scanHandleList.BN },
+        }
+      );
+      console.log("宸紓瀛楁:", diff);
+      console.log("鏄惁鏈夊樊寮�:", Object.keys(diff).length > 0);
+      if (this.registerInfo.locationNo !== this.submitList.locationNo) {
+        uni.showModal({
+          title: "鎻愮ず",
+          content: "鎵弿搴撲綅鍙蜂笌绯荤粺鏁版嵁涓嶄竴鑷�",
+          showCancel: true,
+          success: function (res) {},
+        });
+        return;
+      }
+      if (Object.keys(diff).length > 0) {
+        if (diff.partNo) {
+          uni.showModal({
+            title: "鎻愮ず",
+            content: "鎵弿闆朵欢鍙蜂笌绯荤粺鏁版嵁涓嶄竴鑷�",
+            showCancel: true,
+            success: function (res) {},
+          });
+          return;
+        }
+        if (diff.ifsBatchNo) {
+          uni.showModal({
+            title: "鎻愮ず",
+            content: "鎵弿鎵规鍙蜂笌绯荤粺鏁版嵁涓嶄竴鑷�",
+            showCancel: true,
+            success: function (res) {},
+          });
+          return;
+        }
+        if (diff.qtyAvailable) {
+          uni.showModal({
+            title: "鎻愮ず",
+            content: "鎵弿鐩樼偣鏁伴噺涓庣郴缁熸暟鎹笉涓�鑷�",
+            showCancel: true,
+            success: function (res) {},
+          });
+          return;
+        }
+      }
+      uni.showLoading({
+        mask: true,
+        title: "鎻愪氦涓�...",
+      });
+      console.log("鎻愪氦鐨勬暟鎹�", this.submitList);
+      // 澶勭悊鎻愪氦閫昏緫
+      this.$u.api.inventoryVerification
+        .erpInventorySubmit({
+          ...this.submitList,
+          invListNo: this.registerInfo.invListNo,
+        })
+        .then((res) => {
+          // uni.hideLoading();
+          this.$u.toast("鎻愪氦鎴愬姛");
+          !this.hasScanSnList.some(
+            (item) => item.ifsBatchNo === this.registerInfo.ifsBatchNo
+          ) && this.hasScanSnList.unshift(this.registerInfo);
+          // this.registerInfo = {};
+        })
+        .catch((err) => {
+          console.log("err", err);
+          // uni.hideLoading();
+          uni.showModal({
+            title: "鎻愮ず",
+            content: err.message || "缃戠粶寮傚父锛岃閲嶈瘯",
+            showCancel: true,
+            success: function (res) {},
+          });
+        });
+    },
+  },
+};
 </script>
-<style scoped lang="scss">
-	.inventory-list-bg{
-		background-color: #F6F9FF;
-		background-image: url('~@/static/custom/inventory/locNoBg.png');
-		// background: linear-gradient(180deg,rgba(206,227,254,1),rgba(206,227,254,1) 20%,rgba(206,227,254,0.5) 40%,rgba(206,227,254,0.25) 60%,rgba(206,227,254,0.08) 80%,rgba(206,227,254,0));
-		padding: 0 20rpx;
-		background-attachment: fixed;
-		background-size: 100% auto;
-		background-repeat: no-repeat;
-		position: fixed;
-		top: 0;
-		bottom: 0;
-		width: 100%;
-		z-index: -1;
-	}
-	
-	.inventory-list-search{
-		padding: 40rpx 30rpx 20rpx 30rpx;
-	}
-	.wrap .inventory-list-scroll-list{
-		height:calc(100vh - var(--window-top) - var(--window-bottom) - 242rpx);
-	    width:100%;
-	}
-	.inventory-list-scroll-list-group{
-		::v-deep .u-cell-item-box {
-			background-color:rgba(250,252,255,0.36) !important;
-			padding:0rpx 30rpx ;
-	    }
-		.content {
-			font-size: 12px;
-			background-color: #FFFFFF;
-			box-sizing: border-box;
-			border-radius: 10rpx;
-			margin: 0rpx 0rpx 16rpx;
-			height: 298rpx;
-			padding: 10rpx 20rpx;
-			box-shadow: none;
-			.content-header{
-				height: 90rpx;
-				display: flex;
-				align-items:center;
-				justify-content: space-between;
-				.content-header-left{
-					display: flex;
-					align-items:center;
-					.content-header-icon{
-						background-image: url('~@/static/custom/inventory/icon_5.png');
-						background-size: 100% auto;
-						background-repeat: no-repeat;
-						height:28rpx;
-						width:28rpx;
-					}
-					.content-header-title{
-						margin-left: 11rpx;
-						font-size: 28rpx;
-						font-weight: bold;
-						color: #333333;
-					}
-				}
-				.content-header-right{
-					text-align: right;
-					font-weight: bold;
-					color: #FB5B25;
-				}
-			}
-			.content-body{
-				height:184rpx;
-				background: #F5F9FF;
-				border-radius: 10rpx;
-				padding: 0rpx 23rpx;
-				.row-list {
-					height: 60rpx;
-					display: flex;
-					flex-direction: row;
-					padding: 0px;
-					align-items: center;
-				}
-				.row-list ._label {
-					display: flex;
-					flex: 0.6;
-					color: #909399;
-					align-items: center;
-					._label-icon-1{
-						background-image: url('~@/static/custom/inventory/label-icon-1.png');
-						background-size: 100% auto;
-						background-repeat: no-repeat;
-						height:26rpx;
-						width:26rpx;
-					}
-					._label-icon-2{
-						background-image: url('~@/static/custom/inventory/icon3.png');
-						background-size: 100% auto;
-						background-repeat: no-repeat;
-						height:26rpx;
-						width:26rpx;
-					}
-					._label-icon-3{
-						background-image: url('~@/static/custom/inventory/icon4.png');
-						background-size: 100% auto;
-						background-repeat: no-repeat;
-						height:26rpx;
-						width:26rpx;
-					}
-					._label-name{
-						margin-left: 11rpx;
-						font-size: 26rpx;
-						font-weight: 500;
-						color: #909399;
-						
-					}
-				}
-				
-				.row-list ._content {
-					flex: 1.5;
-					color: #666666;
-					font-size: 24rpx;
-				}
-				.row-list .s1 {
-					color:#D35651;
-				}
-			}
-		}
-	}
-</style>
+<style lang="scss" scoped>
+.transparent-border {
+  border: none;
+}
+.packing-registration-bg {
+  background-color: #f6f9ff;
+  background-image: url("~@/static/custom/packing/backBg.png");
+  padding: 0 20rpx;
+  background-attachment: fixed;
+  background-size: 100% auto;
+  background-repeat: no-repeat;
+  position: fixed;
+  top: 0;
+  bottom: 0;
+  width: 100%;
+  z-index: -1;
+}
+
+.packing-registration-param {
+  padding: 40rpx 30rpx 10rpx 30rpx;
+
+  .packing-registration-param-title {
+    display: flex;
+    flex-direction: row;
+    align-items: center;
+    margin-bottom: 30rpx;
+
+    .title-label {
+      margin-left: 14rpx;
+      font-size: 34rpx;
+      font-weight: bold;
+      color: #283e65;
+    }
+  }
+
+  .packing-registration-param-view {
+    height: 615rpx;
+    background-color: #fff;
+    border-radius: 10rpx;
+    padding: 0rpx 23rpx;
+    margin-bottom: 30rpx;
+
+    .packing-registration-param-item {
+      height: 90rpx;
+      border: 1px solid #adc8e4;
+      line-height: 90rpx;
+      display: flex;
+      justify-content: space-between;
+      border: none;
+
+      .packing-registration-param-item-left {
+        .item-one {
+          font-size: 30rpx;
+          color: #666666;
+        }
+      }
+
+      .packing-registration-param-item-right {
+        display: flex;
+        justify-content: space-between;
+
+        .item-one {
+          font-size: 30rpx;
+          color: #333333;
+          margin-right: 6rpx;
+        }
+
+        .item-two {
+          font-size: 30rpx;
+          color: #a6b4cc;
+          margin-right: 6rpx;
+        }
+
+        .item-three {
+          font-size: 30rpx;
+          color: #214ded;
+          margin-right: 6rpx;
+        }
+      }
+    }
+
+    .param-extra {
+      border-bottom: 1px solid #ededed;
+    }
+  }
+}
+
+.wrap .packing-registration-scroll-list {
+  height: calc(100vh - var(--window-top) - var(--window-bottom) - 930rpx);
+  width: 100%;
+}
+
+.packing-registration-scroll-list-group {
+  ::v-deep .u-cell-item-box {
+    background-color: rgba(250, 252, 255, 0.36) !important;
+    padding: 0rpx 30rpx;
+  }
+
+  .content {
+    font-size: 12px;
+    background-color: #ffffff;
+    box-sizing: border-box;
+    border-radius: 10rpx;
+    margin: 0rpx 0rpx 16rpx;
+    padding: 20rpx 8rpx;
+    box-shadow: none;
+    display: flex;
+    align-items: center;
+
+    .content-header {
+      height: 90rpx;
+      display: flex;
+      align-items: center;
+      max-width: 300rpx;
+
+      .content-header-icon {
+        background-image: url("~@/static/custom/moveWareHouse/header_icon.png");
+        background-size: 100% auto;
+        background-repeat: no-repeat;
+        height: 28rpx;
+        width: 28rpx;
+        flex-shrink: 0;
+      }
+
+      .content-header-title {
+        flex: 1; 
+        min-width: 0;
+        white-space: pre-wrap;
+        margin-left: 11rpx;
+        font-size: 20rpx;
+        font-weight: bold;
+        color: #626369;
+        word-wrap: break-word;
+        overflow-wrap: break-word;
+      }
+    }
+
+    .content-body {
+      flex: 1;
+      background-color: #ffffff;
+      border-radius: 10rpx;
+      padding: 0rpx 23rpx;
+
+      .row-list {
+        height: 60rpx;
+        display: flex;
+        flex-direction: row;
+        padding: 0px;
+        align-items: center;
+      }
+
+      .row-list ._label {
+        display: flex;
+        flex: 0.8;
+        color: #909399;
+        align-items: center;
+
+        ._label-name {
+          margin-left: 11rpx;
+          font-size: 26rpx;
+          font-weight: 500;
+          color: #666666;
+        }
+      }
+
+      .row-list ._content {
+        flex: 1.5;
+        text-align: right;
+        color: #909399;
+        font-size: 24rpx;
+      }
+
+      .row-list .s1 {
+        color: #d35651;
+      }
+    }
+  }
+}
+
+.registration-form-footer {
+  display: flex;
+  margin-top: 10rpx;
+  margin-bottom: 10rpx;
+  margin-left: 20rpx;
+  margin-right: 20rpx;
+  padding-bottom: 14rpx;
+
+  .btn {
+    flex: 1;
+    margin: 10rpx;
+    background: #214ded;
+    box-shadow: 0rpx 6rpx 8rpx 0rpx rgba(4, 49, 212, 0.3);
+    font-weight: bold;
+    color: #fefefe;
+    font-family: PingFang SC;
+  }
+}
+</style>
\ No newline at end of file

--
Gitblit v1.9.3