mirror of
http://36.133.248.69:3088/admin/RentWeAppFront.git
synced 2026-03-07 17:32:25 +08:00
需求变更进行调整
This commit is contained in:
@@ -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;
|
||||
|
||||
Reference in New Issue
Block a user