add
zongzhibin
2024-11-29 c6dad51bdd23cf8425a2e6bb47b9b9412a0dabbe
LA24030_LuLiPackageLine_Web/src/views/main/ReportCenter/storageView/component/ContentView.vue
@@ -1,61 +1,63 @@
<template>
   <div>
      <div v-for="(itemW,indexW) in storageList" :key="indexW">
         <p> 巷道:{{itemW.laneCode}}</p>
         <div v-for="(itemIN,indexIN) in itemW.rows" :key="indexIN" >
               <div class="content-view" >
                  <!-- 每个库位方块    查询库位全部库存 -->
                  <div class="mask100" v-for="(itemSmall,itemSmallIndex) in itemIN.rowLocations2" :key="itemSmallIndex">
                     <content-item v-for="item in itemSmall" :key="item.wareLocationCode" :itemData="item"
                     :index="item.wareLocationCode" @show="show(item,item.wareLocationCode)"
                     @click="openDialog(item.wareLocationCode)"
                     :class="'laneCodeBox_' + (item.showInventoryType)">
                     </content-item>
      <!-- 库位列表 -->
                  </div>
      <div v-for="(itemW, indexW) in storageList" :key="indexW">
         <p>巷道:{{ itemW.laneCode }}</p>
         <div v-for="(itemIN, indexIN) in itemW.rows" :key="indexIN">
            <div class="content-view">
               <!-- 每个库位方块    查询库位全部库存 -->
               <div class="mask100" v-for="(itemSmall, itemSmallIndex) in itemIN.rowLocations2" :key="itemSmallIndex">
                  <content-item
                     v-for="item in itemSmall"
                     :key="item.wareLocationCode"
                     :itemData="item"
                     :index="item.wareLocationCode"
                     @show="show(item, item.wareLocationCode)"
                     @click="openDialog(item.wareLocationCode)"
                     :class="'laneCodeBox_' + item.showInventoryType"
                  >
                  </content-item>
               </div>
            <div v-if="itemW.rows.length>1" class="stripe stripeM"></div>
            </div>
            <div v-if="itemW.rows.length > 1" class="stripe stripeM"></div>
         </div>
      </div>
      <!-- 库位悬浮层 -->
      <teleport :to="'#item' + count" v-if="itemVisible">
         <div class="item-detail" v-if="!detailData.isDeleted">
            <p > {{ setKwStauts(detailData.inventoryType) }} </p>
            <p>{{ setKwStauts(detailData.inventoryType) }}</p>
            {{ containerCodeSHsow }}
         </div>
      </teleport>
      <!-- 详情弹框 -->
      <prop-detail ref="propDetailRef"></prop-detail>
   </div>
</template>
<script lang="ts" setup>
import { ElMessage } from 'element-plus';
import { ref, defineProps, computed, getCurrentInstance } from 'vue'
import ContentItem from './ContentItem.vue'
import { ref, defineProps, computed, getCurrentInstance } from 'vue';
import ContentItem from './ContentItem.vue';
import PropDetail from './propDetail.vue';
const { proxy} :any = getCurrentInstance();// 访问实例上下文 proxy同时支持开发 线上环境
const { proxy }: any = getCurrentInstance(); // 访问实例上下文 proxy同时支持开发 线上环境
//props
const props = defineProps({
   contentData: {
      type: Array,
      required: true,
      default: []
   }
})
const containerCodeSHsow = ref('')
      default: [],
   },
});
const containerCodeSHsow = ref('');
//库位列表
const storageList: Record<any, any> = computed(() => props.contentData);
//每个库位详情的显示
const itemVisible = ref(false);
//详情数据
const detailData = ref({} as Record<string, any>)
const detailData = ref({} as Record<string, any>);
//当前选中的库位
const count = ref(String)
const count = ref(String);
//显示 隐藏详情
const show = (item: any, index: any) => {
   // console.log('item:'+JSON.stringify(item) )
@@ -64,18 +66,18 @@
      itemVisible.value = true;
      count.value = index;
      detailData.value = item;
      containerCodeSHsow.value  = item.wareContainerCode;
      containerCodeSHsow.value = item.wareContainerCode;
   } else {
      itemVisible.value = false;
      count.value = index;
      detailData.value = {};
      containerCodeSHsow.value  = "";
      containerCodeSHsow.value = '';
   }
}
};
// 显示库位状态
const setKwStauts = (type: number): string => {
   let status = ''
   let status = '';
   switch (type) {
      case 0:
         status = '空库位';
@@ -87,13 +89,14 @@
         status = '有货库位(物料)';
   }
   return status;
}
};
//打开窗口
const openDialog = (type: string) => { //托盘号
const openDialog = (type: string) => {
   //托盘号
   if (!type || type == null) {
      ElMessage.warning("不存在托盘号!");
      return
      ElMessage.warning('不存在托盘号!');
      return;
   }
   proxy.$refs['propDetailRef'].openDialog(type);
};
@@ -135,7 +138,6 @@
         margin: 5px;
      }
   }
}
.stripe {
@@ -150,21 +152,20 @@
/*斑马条纹*/
.stripeM {
   background: linear-gradient(#dbd4b4 50%, #f5be6a 50%, );
   background: linear-gradient(#dbd4b4 50%, #f5be6a 50%);
   background-size: 100% 40px;
}
.laneCodeBox_0{
.laneCodeBox_0 {
   visibility: hidden;
}
.laneCodeBox_1{
.laneCodeBox_1 {
   visibility: visible;
}
.mask100{
.mask100 {
   height: 100%;
   display: flex;
    flex-direction: column-reverse;
   flex-direction: column-reverse;
}
// #item3-4-3-3,#item3-4-1-3,#item3-4-2-3,#item3-4-4-3{
//    margin-bottom: 104px;
@@ -173,5 +174,4 @@
//    margin-bottom: 149px;
// }
</style>
</style>