|
@@ -7,7 +7,7 @@
|
|
|
<text class="grid-area_center_item_title" style="color: #fff;">详情</text>
|
|
|
</template>
|
|
|
</u-navbar>
|
|
|
- <view class="menu-list m0" style="overflow-y:scroll">
|
|
|
+ <view class="menu-list m0" style="overflow-y:scroll !important; height: 100%;" v-if="state.loading">
|
|
|
<view class="list-cell" style="color: #666666; line-height: 25px; width: auto; ">
|
|
|
<view class="content-area-top menu-item">
|
|
|
<view class="content-area-top-name" >{{ state?.detail?.createBy + '提交的' + state?.detail?.formName }} </view>
|
|
@@ -29,7 +29,7 @@
|
|
|
<view class="content-area-row_wrap-view gray black" v-if="state.detail.reason">{{ state.detail.reason }}</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
- <view class="list-cell" style="color: #666666; line-height: 25px; width: auto;margin:10px 0 60px 0;">
|
|
|
+ <view class="list-cell" style="color: #666666; line-height: 25px; width: auto;margin-top:10px;">
|
|
|
<view class="content-area-top">
|
|
|
<view style="width:100%;">流程</view>
|
|
|
<view class="stepBar">
|
|
@@ -74,7 +74,8 @@
|
|
|
<view class="right">
|
|
|
<!-- 2021-08-01 10:30:00 -->
|
|
|
</view>
|
|
|
- <view class="center" v-if="item.nodeType == 2 && item.appointApprover.indexOf(',') && item.appointApprover.split(',').length > 1">
|
|
|
+ <view class="center" v-if="item.nodeType == 2 && item.appointApprover.indexOf(',') && item.appointApprover.split(',').length > 1"
|
|
|
+ :style="{paddingBottom:state.approvalStatus == 1 || (state.approvalStatus == 2 || state.approvalStatus == 3) && state.detail.proposer == useStore.userId && state.detail.docNo.split('-')[0] == 'JBD' ? '0px' : '30px'}">
|
|
|
<view class="content-area-header mb10 text-center" style="display: inline-block" v-for="(approver, index2) in item.appointApprover.split(',')" :key="index2">
|
|
|
<img v-if='proxy.$common.mapping("avatar", "userId", approver, state.userData)' class="content-area-header-avatarImg mlr5" :src='proxy.$common.mapping("avatar", "userId", approver, state.userData)' style="display: block; width: 40px; height: 40px" />
|
|
|
<u-avatar
|
|
@@ -90,20 +91,32 @@
|
|
|
<u-text :text='proxy.$common.mapping("nickName", "userId", approver, state.userData)' color="#000000" size="14" align="center"></u-text>
|
|
|
</view>
|
|
|
</view>
|
|
|
- <view class="line gray" v-if="item.nodeType == 1">
|
|
|
+ <view class="line gray" v-if="item.nodeType == 1 && nodeList.length-1 != index">
|
|
|
</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
- <view class="fixedBottom" v-if="(state.approvalStatus == 2 || state.approvalStatus == 3) && state.detail.proposer == useStore.userId && state.detail.docNo.split('-')[0] == 'JBD'" @click="handle('again')">
|
|
|
+ <view class="list-cell list-cell-bottom againWrap" v-if="(state.approvalStatus == 2 || state.approvalStatus == 3) && state.detail.proposer == useStore.userId && state.detail.docNo.split('-')[0] == 'JBD'" @click="handle('again')">
|
|
|
+ <view class="again">
|
|
|
+ <img src="@/static/images/oa/loading.png" alt="">
|
|
|
+ <span>再次提交</span>
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ <view class="list-cell list-cell-bottom approvalWrap" v-if="state.approvalStatus == 1">
|
|
|
+ <view class="approval">
|
|
|
+ <button class="refuse" @click="handle('refuse',2)">拒绝</button>
|
|
|
+ <button class="pass" @click="handle('pass',2)">同意</button>
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ <!-- <view class="fixedBottom" v-if="(state.approvalStatus == 2 || state.approvalStatus == 3) && state.detail.proposer == useStore.userId && state.detail.docNo.split('-')[0] == 'JBD'" @click="handle('again')">
|
|
|
<img src="@/static/images/oa/loading.png" alt="">
|
|
|
<span>再次提交</span>
|
|
|
</view>
|
|
|
<view class="approval" v-if="state.approvalStatus == 1">
|
|
|
<button class="refuse" @click="handle('refuse',2)">拒绝</button>
|
|
|
<button class="pass" @click="handle('pass',2)">同意</button>
|
|
|
- </view>
|
|
|
+ </view> -->
|
|
|
</view>
|
|
|
</template>
|
|
|
<script setup>
|
|
@@ -173,11 +186,12 @@ function handle(type) {
|
|
|
* @api接口查询
|
|
|
*/
|
|
|
function getDetail(type) {
|
|
|
- state.loading = true;
|
|
|
+ state.loading = false;
|
|
|
// getFormName().then((res1) => {
|
|
|
// state.formList = res1.data;
|
|
|
getDocumentDetails(state.queryParams)
|
|
|
.then((requset) => {
|
|
|
+ if(requset.data){
|
|
|
state.detail = requset.data;
|
|
|
state.detail.id = state.id;
|
|
|
listDept({id:state.detail.deptId}).then((res2) => {
|
|
@@ -190,10 +204,17 @@ function getDetail(type) {
|
|
|
var info = res4.data[0]
|
|
|
state.nodeList = JSON.parse(info.flowInfo).node
|
|
|
state.detail.formName = info.formName
|
|
|
+ state.loading = true;
|
|
|
}
|
|
|
})
|
|
|
})
|
|
|
- state.loading = false;
|
|
|
+
|
|
|
+ }else{
|
|
|
+ proxy.$modal.msgError("详情数据异常");
|
|
|
+ setTimeout(()=>{
|
|
|
+ returnTo("business/oa/toDo/index")
|
|
|
+ },2000)
|
|
|
+ }
|
|
|
})
|
|
|
.catch((err) => {
|
|
|
state.loading = false;
|
|
@@ -324,25 +345,6 @@ onLoad((options) => {
|
|
|
top:25px;
|
|
|
right:10px;
|
|
|
}
|
|
|
- .fixedBottom{
|
|
|
- width:100%;
|
|
|
- height:36px;
|
|
|
- line-height: 36px;
|
|
|
- position: fixed;
|
|
|
- bottom: 0;
|
|
|
- left:0;
|
|
|
- background-color: #fff;
|
|
|
- text-align: center;
|
|
|
- color:#000;
|
|
|
- img{
|
|
|
- vertical-align: middle;
|
|
|
- margin-right:10px;
|
|
|
- margin-top:-2px;
|
|
|
- }
|
|
|
- span{
|
|
|
- vertical-align: middle;
|
|
|
- }
|
|
|
- }
|
|
|
.stepBar{
|
|
|
margin-top:-20px;
|
|
|
font-weight: 400;
|
|
@@ -402,7 +404,7 @@ onLoad((options) => {
|
|
|
background: #999;
|
|
|
}
|
|
|
.center{
|
|
|
- width:100%;
|
|
|
+ width:calc(100% - 40px);
|
|
|
margin:10px 0 0 40px;
|
|
|
padding-right:10px;
|
|
|
}
|
|
@@ -438,25 +440,51 @@ onLoad((options) => {
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
- .approval{
|
|
|
- position: fixed;
|
|
|
- width:100%;
|
|
|
- bottom: 10px;
|
|
|
- left:0;
|
|
|
- button{
|
|
|
- width:calc(50% - 15px);
|
|
|
- height:50px;
|
|
|
- margin-left:10px;
|
|
|
- display: inline-block;
|
|
|
- border-radius: 16px !important;
|
|
|
-
|
|
|
- }
|
|
|
- button.pass{
|
|
|
- background: #2A98FF;
|
|
|
- color:#fff;
|
|
|
+ .list-cell-bottom{
|
|
|
+ padding:0;
|
|
|
+ margin-top:10px;
|
|
|
+ background-color: #fff;
|
|
|
+ .approval{
|
|
|
+ height:auto;
|
|
|
+ button{
|
|
|
+ width:calc(50% - 15px);
|
|
|
+ height:50px;
|
|
|
+ margin-left:10px;
|
|
|
+ display: inline-block;
|
|
|
+ border-radius: 16px !important;
|
|
|
+
|
|
|
+ }
|
|
|
+ button.pass{
|
|
|
+ background: #2A98FF;
|
|
|
+ color:#fff;
|
|
|
+ }
|
|
|
+ button.refuse{
|
|
|
+ border:1px solid #CFCFCF;
|
|
|
+ }
|
|
|
}
|
|
|
- button.refuse{
|
|
|
- border:1px solid #CFCFCF;
|
|
|
+ .again{
|
|
|
+ width:100%;
|
|
|
+ height:36px;
|
|
|
+ line-height: 36px;
|
|
|
+ text-align: center;
|
|
|
+ color:#000;
|
|
|
+ img{
|
|
|
+ vertical-align: middle;
|
|
|
+ margin-right:10px;
|
|
|
+ margin-top:-2px;
|
|
|
+ }
|
|
|
+ span{
|
|
|
+ vertical-align: middle;
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
+ .approvalWrap{
|
|
|
+ height:133px;
|
|
|
+ padding:20px 0;
|
|
|
+ }
|
|
|
+ .againWrap{
|
|
|
+ height:90px;
|
|
|
+ padding:5px 0;
|
|
|
+ }
|
|
|
+
|
|
|
</style>
|