style:库存查询-库区库存列字段调整

main
黄伟杰 5 days ago
parent 7d3ee0e1dd
commit 44abffdc3e

@ -117,36 +117,19 @@
</el-table-column>
<el-table-column :label="t('ErpStock.Stock.areaStockDisplay')" align="center" min-width="260">
<template #default="{ row }">
<el-popover
<div
v-if="getAreaStockDisplayList(row.areaStocks).length"
trigger="hover"
placement="top"
width="320"
class="area-stock-list"
:style="getStockDisplayStyle(row.categoryType)"
>
<template #reference>
<span class="area-stock-summary" :style="getStockDisplayStyle(row.categoryType)">
<span
v-for="item in getVisibleAreaStockDisplayList(row.areaStocks)"
:key="item"
class="area-stock-tag"
>
{{ item }}
</span>
<span v-if="getHiddenAreaStockCount(row.areaStocks)" class="area-stock-more">
+{{ getHiddenAreaStockCount(row.areaStocks) }}
</span>
</span>
</template>
<div class="area-stock-detail">
<div
v-for="item in getAreaStockDisplayList(row.areaStocks)"
:key="item"
class="area-stock-detail__item"
>
{{ item }}
</div>
<div
v-for="item in getAreaStockDisplayList(row.areaStocks)"
:key="item"
class="area-stock-list__item"
>
{{ item }}
</div>
</el-popover>
</div>
<span v-else>-</span>
</template>
</el-table-column>
@ -244,8 +227,6 @@ const formatStockDisplay = (value: string | undefined) => {
.filter(Boolean)
}
const AREA_STOCK_VISIBLE_COUNT = 2
const getAreaStockDisplayList = (value: StockVO['areaStocks']) => {
if (!Array.isArray(value)) return []
return value
@ -253,14 +234,6 @@ const getAreaStockDisplayList = (value: StockVO['areaStocks']) => {
.filter((item): item is string => Boolean(item))
}
const getVisibleAreaStockDisplayList = (value: StockVO['areaStocks']) => {
return getAreaStockDisplayList(value).slice(0, AREA_STOCK_VISIBLE_COUNT)
}
const getHiddenAreaStockCount = (value: StockVO['areaStocks']) => {
return Math.max(getAreaStockDisplayList(value).length - AREA_STOCK_VISIBLE_COUNT, 0)
}
const getStockDisplayStyle = (categoryType: number | string | undefined) => {
const dict = getDictObj(DICT_TYPE.MATERIAL_CLASSIFICATION_TYPE, categoryType)
if (dict?.cssClass && isHexColor(dict.cssClass)) {
@ -399,40 +372,16 @@ onMounted(async () => {
white-space: nowrap;
}
.area-stock-summary {
display: inline-flex;
.area-stock-list {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 6px;
max-width: 100%;
vertical-align: middle;
}
.area-stock-tag {
max-width: 108px;
padding: 1px 6px;
overflow: hidden;
gap: 4px;
line-height: 20px;
text-overflow: ellipsis;
white-space: nowrap;
background: var(--el-fill-color-light);
border: 1px solid var(--el-border-color-light);
border-radius: 4px;
}
.area-stock-more {
flex-shrink: 0;
font-weight: 500;
white-space: nowrap;
}
.area-stock-detail {
max-height: 260px;
overflow-y: auto;
line-height: 22px;
}
.area-stock-detail__item + .area-stock-detail__item {
margin-top: 6px;
.area-stock-list__item {
max-width: 100%;
word-break: break-all;
}
</style>

Loading…
Cancel
Save