detail.vue 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. <template>
  2. <view class="safe-area-inset-bottom">
  3. <view class="card">
  4. <view class="title">
  5. 申请信息
  6. </view>
  7. <view class="item">
  8. <text class="left">状态</text>
  9. <text v-if="detail.auditStatus==0" class="right" style="color: #ff9900;">待审核</text>
  10. <text v-if="detail.auditStatus==1" class="right" style="color: #19be6b;">已通过</text>
  11. <text v-if="detail.auditStatus==2" class="right" style="color: #E13939;">已拒绝</text>
  12. <text v-if="detail.auditStatus==3" class="right" style="color: #E13939;">已停用</text>
  13. </view>
  14. <view class="item" v-if="detail.auditStatus==2">
  15. <text class="left">拒绝原因</text>
  16. <text class="right">{{detail.auditAdvice}}</text>
  17. </view>
  18. <view class="item">
  19. <text class="left">申请时间</text>
  20. <text class="right">{{detail.createTime}}</text>
  21. </view>
  22. <view class="item">
  23. <text class="left">商户名</text>
  24. <text class="right">{{detail.name}}</text>
  25. </view>
  26. <view class="item">
  27. <text class="left">申请人</text>
  28. <text class="right">{{detail.personName}}</text>
  29. </view>
  30. <view class="item">
  31. <text class="left">身份证号码</text>
  32. <text class="right">{{detail.personIdCard}}</text>
  33. </view>
  34. <view class="item" style="justify-content: space-around;">
  35. <image @click="$util.preview(detail.idCardFront)" style="width: 48%;height: 160rpx;" :src="detail.idCardFront"></image>
  36. <image @click="$util.preview(detail.idCardContrary)" style="width: 48%;height: 160rpx;" :src="detail.idCardContrary" ></image>
  37. </view>
  38. </view>
  39. <view class="card">
  40. <text class="title">商户信息</text>
  41. <view class="item">
  42. <text class="left">门店地区</text>
  43. <text class="right">{{detail.province}} - {{detail.city}} - {{detail.area}}</text>
  44. </view>
  45. <view class="item">
  46. <text class="left">所属商场</text>
  47. <text class="right">{{detail.mallName}}</text>
  48. </view>
  49. <view class="item">
  50. <text class="left">具体地址</text>
  51. <text class="right">{{detail.address || '暂无'}}</text>
  52. </view>
  53. <view class="item">
  54. <text class="left">商场区域</text>
  55. <text class="right">{{detail.mallAreaName || '暂无'}}</text>
  56. </view>
  57. <view class="item">
  58. <text class="left">单位全称</text>
  59. <text class="right">{{detail.fullName}}</text>
  60. </view>
  61. <view class="item">
  62. <text class="left">公司网址</text>
  63. <text class="right">{{detail.webUrl}}</text>
  64. </view>
  65. <view class="item">
  66. <text class="left">公司法人姓名</text>
  67. <text class="right">{{detail.legalPersonName}}</text>
  68. </view>
  69. <view class="item">
  70. <text class="left">公司总类</text>
  71. <view class="right">
  72. <view class="cu-tag tag-bg round sm" v-for="(item,index) in tags" :key="index">
  73. {{item}}
  74. </view>
  75. </view>
  76. </view>
  77. <view class="item" style="justify-content: flex-start;flex-direction: column;">
  78. <text class="left">营业执照</text>
  79. <view class="center padding-top-20">
  80. <image @click="$util.preview(detail.businessLicense)" style="width: 50%;height: 250rpx;" :src="detail.businessLicense" mode=""></image>
  81. </view>
  82. </view>
  83. <view class="item" style="justify-content: flex-start;flex-direction: column;">
  84. <text class="left">店铺实况</text>
  85. <view class="flex justify-start padding-top-20 flex-wrap">
  86. <image @click="$util.preview(detail.businessLicense)" style="width: 30%;height: 120rpx;margin: 10rpx;" :src="detail.businessLicense" mode=""></image>
  87. </view>
  88. </view>
  89. </view>
  90. <block v-if="detail.auditStatus==0">
  91. <view class="" style="height: 90rpx;"></view>
  92. <view :style="{paddingBottom:safeAreaBottom}" class="footer-fixed padding-20 bg-white flex justify-end margin-right-30" style="box-sizing: border-box;z-index: 999;border-top: 1rpx solid #f1f1f1;">
  93. <view @click="pass" class="cu-btn df btn-bg-color round margin-right-20" style="padding-left: 46rpx;padding-right: 46rpx;">
  94. 通过
  95. </view>
  96. <view @click="opinionShow=true" class="cu-btn df btn-line-color round " style="padding-left: 46rpx;padding-right: 46rpx;">
  97. 拒绝
  98. </view>
  99. </view>
  100. </block>
  101. <u-modal :show-cancel-button="true" confirm-color="#FF9447" @confirm="opinionConfirm" title="审核意见" :mask-close-able="true"
  102. v-model="opinionShow">
  103. <view class="slot-content" style="margin: 20rpx;">
  104. <u-form label-width="150" ref="uForm">
  105. <u-form-item :border-bottom="false">
  106. <u-input height="150" placeholder="请输入审核意见(选填)" v-model="opinion" />
  107. </u-form-item>
  108. </u-form>
  109. </view>
  110. </u-modal>
  111. </view>
  112. </template>
  113. <script>
  114. export default {
  115. data() {
  116. return {
  117. id:'',
  118. detail:{},
  119. tags:[],
  120. opinionShow:false,
  121. auditAdvice:''
  122. }
  123. },
  124. onLoad(options) {
  125. this.id=options.id
  126. this.fetchDetail()
  127. },
  128. methods: {
  129. fetchDetail(){
  130. this.$api.shop.detail({id:this.id}).then(res=>{
  131. this.detail=res.data
  132. this.tags=this.detail.labelNames.split(',')
  133. })
  134. },
  135. opinionConfirm() {
  136. let item = this.$u.deepClone(this.detail)
  137. item.auditStatus = 2
  138. this.$api.shop.submit(item).then(res => {
  139. if (res.success == true) {
  140. this.$u.toast(res.msg)
  141. this.fetchDetail()
  142. }
  143. })
  144. },
  145. pass(data){
  146. let item=this.$u.deepClone(this.detail)
  147. this.$dialog.showModal("确定通过?").then(res=>{
  148. item.auditStatus=1
  149. this.$api.shop.submit(item).then(res=>{
  150. if (res.success==true) {
  151. this.$u.toast(res.msg)
  152. this.fetchDetail()
  153. }
  154. })
  155. })
  156. },
  157. }
  158. }
  159. </script>
  160. <style lang="scss" scoped>
  161. .card{
  162. margin: 30rpx;
  163. padding: 20rpx;
  164. border-radius: 20rpx;
  165. background-color: #FFFFFF;
  166. .title{
  167. font-size: 32rpx;
  168. font-weight: 800;
  169. padding-bottom: 10rpx;
  170. }
  171. .item{
  172. padding: 20rpx 0;
  173. display: flex;
  174. justify-content: space-between;
  175. .left{
  176. color: #999999;
  177. }
  178. .right{
  179. color: #252525;
  180. }
  181. }
  182. }
  183. </style>