需求变更进行调整

This commit is contained in:
2026-01-30 09:01:38 +08:00
parent 44a4b33502
commit 79a21ff0a5
30 changed files with 1482 additions and 1707 deletions

View File

@@ -28,10 +28,31 @@
<!-- 新增留言弹窗 -->
<u-popup v-model="showAddPopup" mode="center" length="60%">
<view class="popup-content">
<view class="asset-select" @click="showAssetsPopup = true">
<text v-if="!selectedAsset" class="placeholder">
请选择资产
</text>
<text v-else class="asset-text">
{{ selectedAsset.assetsName }}
</text>
</view>
<textarea v-model="newMessageContent" placeholder="请输入留言内容" class="textarea" />
<button class="popup-btn" @click="addFallback()">提交留言</button>
</view>
</u-popup>
<checkbox-group @change="onAssetChange">
<label
v-for="asset in filteredAssets"
:key="asset.assetsNo"
class="asset-item"
>
<checkbox
:value="asset.assetsNo"
:checked="selectedAssetKey === asset.assetsNo"
/>
{{ asset.assetsName }}
</label>
</checkbox-group>
</view>
</template>
@@ -52,7 +73,12 @@
loadStatus: 'loadmore',
isRefreshing: false,
// 滚动距离
scrollTop: 0
scrollTop: 0,
showAssetsPopup: false,
assetSearch: '',
assetsList: [],
selectedAssetKey: '', // 单个 assetsNo
selectedAsset: null // 单个资产对象
}
},
onPageScroll(e) {
@@ -73,6 +99,16 @@
url: `/pages-assets/fallback/fallbackDetail?id=${item.id}`,
});
},
onAssetChange(e) {
const val = e.detail.value;
// 只取最后一个
this.selectedAssetKey = val.length ? val[val.length - 1] : '';
},
confirmAssets() {
this.selectedAsset =
this.assetsList.find(a => a.assetsNo === this.selectedAssetKey) || null;
this.showAssetsPopup = false;
},
fetchFallback() {
if (this.loadStatus !== 'loadmore') return;
this.loadStatus = 'loading';
@@ -109,6 +145,15 @@
},
addFallback() {
const content = this.newMessageContent.trim();
let userInfo = uni.getStorageSync('userInfo');
if(!userInfo.cusNo) {
uni.showToast({
title: '您还未实名',
icon: 'none'
});
this.showAddPopup = false;
return;
}
if (!content) {
uni.showToast({
title: '请输入留言内容',
@@ -123,13 +168,21 @@
WT: token
})
.then(res => {
uni.showToast({
title: '留言成功',
icon: 'success'
});
if(res.flag){
uni.showToast({
title: '留言成功',
icon: 'success'
});
}else{
uni.showToast({
title: res.message,
icon: 'none'
});
}
this.showAddPopup = false;
this.newMessageContent = '';
this.refresh();
})
.catch(err => {
console.error('新增留言失败:', err);
@@ -245,7 +298,29 @@
font-size: 24rpx;
color: #ADADB1;
}
/* 资产选择入口 */
.asset-select {
margin-top: 20rpx;
padding: 20rpx 24rpx;
background: #ffffff;
border-radius: 8rpx;
font-size: 26rpx;
display: flex;
align-items: center;
justify-content: space-between;
border: 1rpx solid #eee;
}
/* 未选择时的占位文字 */
.asset-select .placeholder {
color: #999;
}
/* 已选择资产文字 */
.asset-select .asset-text {
color: #333;
font-weight: 500;
}
.add-btn-container {
position: fixed;
bottom: 0;