You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
475 lines
14 KiB
475 lines
14 KiB
<template> |
|
<!--pages/user/resourcesOrder/index.wxml--> |
|
<view class="order-page"> |
|
<view class="tabs-box acea-row row-between"> |
|
<view :class="'tab ' + (tabActive == 1 ? 'tab-a' : '')" data-i="1" @tap="tabClick">沟通中</view> |
|
<view :class="'tab ' + (tabActive == 2 ? 'tab-a' : '')" data-i="2" @tap="tabClick">进行中</view> |
|
<view :class="'tab ' + (tabActive == 3 ? 'tab-a' : '')" data-i="3" @tap="tabClick">已结束</view> |
|
</view> |
|
<view class="list"> |
|
<view class="no-list" v-if="list.length == 0"> |
|
<image src="https://download.cyjyyjy.com/no-needs.png"></image> |
|
<view>暂无订单</view> |
|
<view class="to-btn" @tap="toDemandHall">去需求广场</view> |
|
</view> |
|
<view v-for="(item, index) in list" :key="index" class="item" v-if="tabActive == 1"> |
|
<view class="needs-info-box"> |
|
<view class="n-title-box acea-row row-between"> |
|
<view>{{item.resourceInfo.name}}</view> |
|
<!-- <view class="status" wx:if="{{item.comminuteState == 3}}">项目已成立</view> --> |
|
</view> |
|
<view class="n-price">需求预算 <text class="colO">{{item.resourceInfo.budget}}</text></view> |
|
<view class="n-desc">{{item.resourceInfo.content}}</view> |
|
</view> |
|
<view class="concat-list-box"> |
|
<!-- <view class="open-btn acea-row row-middle" bindtap="openClick" data-idx="{{index}}"> |
|
<text>{{!item.open ? '展开' : '收起'}}</text> |
|
<image class="arrow-down {{!item.open ? '' : 'arrow-up'}}" src="../../../images/arrow-d.png"></image> |
|
</view> --> |
|
<!-- <view class="concat-list {{item.open ? 'list-open' : ''}}" > --> |
|
<view v-for="(info, index2) in item.partnerInfos" :key="index2" class="info-item"> |
|
<view class=" acea-row row-middle"> |
|
<image :src="info.logo"></image> |
|
<view class="info2"> |
|
<view class="projectinfo-box acea-row-nowrap row-between"> |
|
<view class="acea-row row-middle line1"> |
|
<view class="p-label">合作方:</view> |
|
<view>{{info.name}}</view> |
|
</view> |
|
<view class="status" v-if="info.comminuteState == 1">已申请</view> |
|
<view class="status" v-if="info.comminuteState == 2">等待立项</view> |
|
<view class="status" v-if="info.comminuteState == 3">项目成立中</view> |
|
<view class="status" v-if="info.comminuteState == 4">已取消立项</view> |
|
</view> |
|
<!-- <view cl哦ass="tag-item" wx:if="{{info.comminuteState == 1}}">{{info.cooperationMode}}</view> --> |
|
</view> |
|
</view> |
|
<view class="btn-box acea-row row-between row-middle"> |
|
<view class="start-time">{{info.createTime}}项目开启</view> |
|
<view class="btns acea-row"> |
|
<view class="btn-item" v-if="info.comminuteState == 1" @tap="cancelCommunicate" :data-info="info">取消沟通</view> |
|
<view class="btn-item" v-if="info.comminuteState == 2 || info.comminuteState == 3" @tap="toCreateProject" :data-item="info">查看立项书</view> |
|
<view class="btn-item" v-if="info.comminuteState == 2" @tap="confirm" :data-item="item" :data-id="info.communicateId">确认立项</view> |
|
<view class="btn-item default" v-if="info.comminuteState == 2" @tap="cancelProject" :data-item="item" :data-id="info.communicateId">取消立项</view> |
|
</view> |
|
</view> |
|
</view> |
|
<!-- </view> --> |
|
</view> |
|
</view> |
|
<view v-for="(item, index) in list" :key="index" class="item" v-if="tabActive != 1"> |
|
<view class="number acea-row row-between row-middle"> |
|
<text>项目编号 {{item.projectCode}}</text> |
|
<!-- <view class="status">{{tabActive == 2 ? '进行中' : '已结束'}}</view> --> |
|
<view class="status" v-if="item.projectState != 5">{{tabActive == 1 ? '沟通中' : tabActive == 2 ? '进行中' : '已结束'}}</view> |
|
<view class="status" v-else>平台介入中</view> |
|
</view> |
|
<view class="info-box acea-row row-middle"> |
|
<image :src="item.projectResource.logo"></image> |
|
<view class="info"> |
|
<view class="i-title line1">{{item.resourcesDto.title || item.projectResource.name}}</view> |
|
<view class="tag-item">{{item.cooperationMode}}</view> |
|
<view class="i-desc" v-if="tabActive == 1">{{item.resourcesDto.detailedDescription}}</view> |
|
<view class="projectinfo-box"> |
|
<view class="acea-row row-middle" v-if="tabActive != 1"> |
|
<view class="p-label">项目名称:</view> |
|
<view>{{item.projectName}}</view> |
|
</view> |
|
<view class="acea-row row-middle line1" v-if="tabActive != 1"> |
|
<view class="p-label">合作方:</view> |
|
<view>{{item.partner}}</view> |
|
</view> |
|
</view> |
|
</view> |
|
</view> |
|
<view class="progress-box" v-if="tabActive != 1"> |
|
<view v-for="(progress, index2) in item.stageResultsDtoList" :key="index2" class="progress-item acea-row row-between row-middle"> |
|
<view class="acea-row row-middle"> |
|
<image src="/static/images/home/progress.png"></image> |
|
<text>{{progress.name}} ¥{{progress.money}}</text> |
|
</view> |
|
<view class="progress-status" v-if="progress.state == 0">未开始</view> |
|
<view class="progress-status" v-if="progress.state == 1">申请开启</view> |
|
<view class="progress-status" v-if="progress.state == 2">进行中</view> |
|
<view class="progress-status colorO" v-if="progress.state == 3">已结束</view> |
|
</view> |
|
</view> |
|
<view class="btn-box acea-row row-between row-bottom" v-if="tabActive != 1"> |
|
<view class="start-time" v-if="tabActive == 2">{{item.examineTime}}项目开启</view> |
|
<view v-if="tabActive == 3">项目已圆满结束</view> |
|
<view class="btns acea-row"> |
|
<view class="btn-item" v-if="tabActive == 2 && item.nextStageFlag" @tap="agreenOpen" :data-item="item">同意开启</view> |
|
<view class="btn-item" v-if="tabActive == 2 && item.deliveryFlag" @tap="deliveryProject" :data-item="item">同意交付</view> |
|
<view class="btn-item" v-if="tabActive == 2" @tap="toPlatform" :data-item="item">平台介入</view> |
|
|
|
<!-- <view class="btn-item" wx:if="{{ tabActive == 3 }}">合作反馈</view> --> |
|
</view> |
|
</view> |
|
</view> |
|
</view> |
|
</view> |
|
</template> |
|
|
|
<script> |
|
// pages/user/needsOrder/index.js |
|
const app = getApp(); |
|
|
|
export default { |
|
data() { |
|
return { |
|
tabActive: 1, |
|
list: [] |
|
}; |
|
}, |
|
|
|
components: {}, |
|
props: {}, |
|
|
|
/** |
|
* 生命周期函数--监听页面加载 |
|
*/ |
|
onLoad: function (options) { |
|
this.getCommunicates(); |
|
}, |
|
|
|
/** |
|
* 生命周期函数--监听页面初次渲染完成 |
|
*/ |
|
onReady: function () {}, |
|
|
|
/** |
|
* 生命周期函数--监听页面显示 |
|
*/ |
|
onShow: function () {// this.getCommunicates() |
|
}, |
|
|
|
/** |
|
* 生命周期函数--监听页面隐藏 |
|
*/ |
|
onHide: function () {}, |
|
|
|
/** |
|
* 生命周期函数--监听页面卸载 |
|
*/ |
|
onUnload: function () {}, |
|
|
|
/** |
|
* 页面相关事件处理函数--监听用户下拉动作 |
|
*/ |
|
onPullDownRefresh: function () { |
|
if (this.tabActive == 1) { |
|
this.getCommunicates(); |
|
} else { |
|
this.getProjectList(); |
|
} |
|
}, |
|
|
|
/** |
|
* 页面上拉触底事件的处理函数 |
|
*/ |
|
onReachBottom: function () {}, |
|
|
|
/** |
|
* 用户点击右上角分享 |
|
*/ |
|
onShareAppMessage: function () {}, |
|
methods: { |
|
toDemandHall() { |
|
uni.switchTab({ |
|
url: '/pages/demandHall/index' |
|
}); |
|
}, |
|
|
|
tabClick(e) { |
|
let i = e.currentTarget.dataset.i; |
|
this.setData({ |
|
tabActive: i |
|
}); |
|
|
|
if (i == 1) { |
|
this.getCommunicates(); |
|
} else { |
|
this.getProjectList(); |
|
} |
|
}, |
|
|
|
// 获取 沟通中 |
|
getCommunicates() { |
|
app.http('get', 'Communicate/demandCommunicates').then(res => { |
|
if (res.data.success) { |
|
if (res.data.data.length > 0) { |
|
res.data.data.map(item => { |
|
item.open = false; |
|
}); |
|
res.data.data[0].open = true; |
|
} |
|
|
|
console.log(res.data.data); |
|
this.setData({ |
|
list: res.data.data |
|
}); |
|
uni.stopPullDownRefresh(); |
|
} |
|
}); |
|
}, |
|
|
|
//点击展开 |
|
openClick(e) { |
|
let idx = e.currentTarget.dataset.idx; |
|
console.log(idx); |
|
let list = this.list; |
|
list[idx].open = !list[idx].open; |
|
this.setData({ |
|
list: list |
|
}); |
|
}, |
|
|
|
//获取进行中、已结束列表 |
|
getProjectList() { |
|
app.http('get', 'Project/listProject', { |
|
projectState: this.tabActive - 1, |
|
projectType: 2 |
|
}).then(res => { |
|
if (res.data.success) { |
|
res.data.data.map(item => { |
|
item.stageResultsDtoList.map(stage => { |
|
if (stage.state == 1) { |
|
item.showBtn = true; |
|
} |
|
}); |
|
}); |
|
this.setData({ |
|
list: res.data.data |
|
}); |
|
uni.stopPullDownRefresh(); |
|
} |
|
}); |
|
}, |
|
|
|
//同意开启下一阶段 |
|
agreenOpen(e) { |
|
let item = e.currentTarget.dataset.item; |
|
console.log(item); |
|
const stage = item.stageResultsDtoList.filter(item => { |
|
return item.state == 1; |
|
}); |
|
uni.showModal({ |
|
title: '提示!', |
|
content: '是否同意开启下阶段?', |
|
|
|
success(res) { |
|
if (res.confirm) { |
|
app.http('get', 'Project/startNextStage', { |
|
stageResultId: stage[0].id |
|
}).then(res => { |
|
if (res.data.success) { |
|
uni.showToast({ |
|
title: '操作成功!', |
|
duration: 2000 |
|
}); |
|
this.getProjectList(); |
|
} |
|
}); |
|
} |
|
} |
|
|
|
}); |
|
}, |
|
|
|
// 平台介入 |
|
toPlatform(e) { |
|
let code = e.currentTarget.dataset.item.projectCode; |
|
uni.navigateTo({ |
|
url: '/pages/demandHall/platform/index?code=' + code |
|
}); |
|
}, |
|
|
|
// 取消沟通 |
|
cancelCommunicate(e) { |
|
let info = e.currentTarget.dataset.info; |
|
console.log(info); |
|
let that = this; |
|
uni.showModal({ |
|
title: '提示!', |
|
content: '是否取消沟通?', |
|
|
|
success(res) { |
|
if (res.confirm) { |
|
app.http('GET', 'Communicate/cancelCommunicates', { |
|
communicateId: info.communicateId |
|
}).then(res => { |
|
if (res.data.success) { |
|
uni.showToast({ |
|
title: '操作成功!', |
|
duration: 1500 |
|
}); |
|
setTimeout(() => { |
|
that.getCommunicates(); |
|
}, 1500); |
|
} |
|
}); |
|
} |
|
} |
|
|
|
}); |
|
}, |
|
|
|
//查看立项书 |
|
toCreateProject(e) { |
|
let item = e.currentTarget.dataset.item; |
|
uni.navigateTo({ |
|
url: '/pages/demandHall/createProject/index?state=' + item.comminuteState + '&id=' + item.communicateId |
|
}); |
|
}, |
|
|
|
confirm(e) { |
|
let item = e.currentTarget.dataset.item; |
|
let communicateId = e.currentTarget.dataset.id; |
|
let that = this; |
|
uni.showModal({ |
|
title: '提示!', |
|
content: '是否确认立项?', |
|
|
|
success(res) { |
|
if (res.confirm) { |
|
app.http('GET', 'Communicate/aggreProject', { |
|
projectId: item.partnerInfos[0].projectId |
|
}).then(res => { |
|
if (res.data.success) { |
|
uni.showToast({ |
|
title: '操作成功!', |
|
duration: 2000 |
|
}); |
|
setTimeout(() => { |
|
that.getCommunicates(); |
|
}, 2000); |
|
} |
|
}); |
|
} |
|
} |
|
|
|
}); |
|
}, |
|
|
|
cancelProject(e) { |
|
let item = e.currentTarget.dataset.item; |
|
let communicateId = e.currentTarget.dataset.id; |
|
let that = this; |
|
uni.showModal({ |
|
title: '提示!', |
|
content: '是否确认取消立项?', |
|
|
|
success(res) { |
|
if (res.confirm) { |
|
app.http('post', 'Communicate/cancelProject', { |
|
communicateId: communicateId, |
|
partnerInfos: item.partnerInfos |
|
}).then(res => { |
|
if (res.data.success) { |
|
uni.showToast({ |
|
title: '操作成功!', |
|
duration: 2000 |
|
}); |
|
that.getCommunicates(); |
|
} |
|
}); |
|
} |
|
} |
|
|
|
}); |
|
}, |
|
|
|
//同意交付 |
|
deliveryProject(e) { |
|
let item = e.currentTarget.dataset.item; |
|
uni.showModal({ |
|
title: '提示', |
|
content: '是否确认提交申请交付', |
|
success: r => { |
|
if (r.confirm) { |
|
app.http('GET', 'Project/deliveryProject', { |
|
projectId: item.id |
|
}).then(res => { |
|
if (res.data.success) { |
|
uni.showToast({ |
|
title: '操作成功!' |
|
}); |
|
this.getProjectList(); |
|
} |
|
}); |
|
} |
|
} |
|
}); |
|
} |
|
|
|
} |
|
}; |
|
</script> |
|
<style> |
|
/* pages/user/needsOrder/index.wxss */ |
|
@import "../resourcesOrder/index.css"; |
|
|
|
.needs-info-box{ |
|
border: none !important; |
|
} |
|
.info2{ |
|
width: calc(100% - 120rpx); |
|
} |
|
.info-item image{ |
|
width: 90rpx; |
|
height: 90rpx; |
|
margin-right: 24rpx; |
|
} |
|
.info-item{ |
|
font-size: 24rpx; |
|
border-top: 2rpx solid #F0F0F0; |
|
padding: 20rpx 0; |
|
} |
|
.projectinfo-box{ |
|
font-size: 26rpx; |
|
margin: 2rpx 0; |
|
} |
|
.tag-item{ |
|
/* transform: scale(0.8); */ |
|
margin: 0; |
|
} |
|
|
|
.needs-info-box{ |
|
/* padding-bottom: 22rpx; */ |
|
border-bottom: 2rpx solid #F0F0F0; |
|
margin-bottom: 22rpx; |
|
} |
|
.n-title{ |
|
color: #1D1D1D; |
|
font-size: 32rpx; |
|
line-height: 44rpx; |
|
} |
|
.n-price{ |
|
color: #707070; |
|
font-size: 28rpx; |
|
margin: 8rpx 0; |
|
} |
|
.n-desc{ |
|
font-size: 24rpx; |
|
line-height: 34rpx; |
|
color: #333333; |
|
} |
|
.btn-box{ |
|
margin-top: 10rpx; |
|
} |
|
.btn-item { |
|
font-size: 24rpx; |
|
width: 130rpx; |
|
height: 50rpx; |
|
line-height: 50rpx; |
|
text-align: center; |
|
background: #000; |
|
border-radius: 12rpx; |
|
color: #fff; |
|
margin-left: 8rpx; |
|
} |
|
.status { |
|
min-width: 150rpx; |
|
text-align: right; |
|
} |
|
</style> |