ComplaintList.vue 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. <template><page-meta :root-font-size="fontSize+'px'"></page-meta>
  2. <member-base :show="false"><view style="position: absolute;top:0;right:0;left:0;bottom:0" class="scroll-view-wrapper div container">
  3. <view class="div common-header-wrap">
  4. <view class="status-holder"></view>
  5. <view :style="'height:'+navHeight+'px'"></view>
  6. <view class="common-header-holder"></view>
  7. <view class="common-header-fixed">
  8. <title-header />
  9. <uni-nav-bar title="商家投诉" class="common-header" left-icon="back" @clickLeft="goBack()">
  10. </uni-nav-bar>
  11. </view>
  12. </view>
  13. <view class="scroll-view div" style="position:relative">
  14. <scroll-view style="position: absolute;top:0;right:0;left:0;bottom:0" class="div" @scrolltolower="loadMore" scroll-y="true">
  15. <view class="div" v-if="complaintList && complaintList.length">
  16. <view class="div complaint-item" v-for="(item, index) in complaintList" :key="index">
  17. <view class="head">
  18. <view class="type">{{item.complain_subject_content}}</view>
  19. <view class="time">{{ $moment.unix(item.complain_datetime).format('YYYY年MM月DD日') }}</view>
  20. </view>
  21. <view class="goods_info" @click="goNavigate('/pages/home/goodsdetail/Goodsdetail',{goods_id:item.order_goods_id})">
  22. <view class="image-wrapper" :style="'width:'+windowWidth+'px;height:'+windowWidth+'px;flex:0 0 ' + windowWidth + 'px'">
  23. <image mode="aspectFit" class="img" :src="goodsList[item.order_goods_id].goods_image_url"/>
  24. </view>
  25. <view class="p-info">
  26. <view class="goods_name">{{goodsList[item.order_goods_id].goods_name}}</view>
  27. <view class="goods_price">¥{{goodsList[item.order_goods_id].goods_price}}</view>
  28. </view>
  29. </view>
  30. <view class="div complaint-info">
  31. <view class="complaint_content"><text>投诉内容:</text>{{item.complain_content}}</view>
  32. </view>
  33. <view class="div complaint-btn">
  34. <view class="div btn-wrapper"><view class="div common-btn btn-1" v-if="item.complain_state=='10'" @click="cancelComplaint(item.complain_id)">取消</view></view>
  35. <view class="div btn-wrapper" v-if="item.complain_state==30">
  36. <view class="div common-btn btn-1" @click="handleComplain(item.complain_id)">提交仲裁</view>
  37. </view>
  38. <view class="div btn-wrapper"><view class="div common-btn btn-2" @click="goNavigate('/pages/member/complaint/ComplaintForm',{complain_id:item.complain_id})">查看</view></view>
  39. </view>
  40. </view>
  41. </view>
  42. <empty-record v-else-if="complaintList && !complaintList.length"></empty-record>
  43. </scroll-view>
  44. </view>
  45. </view>
  46. <uni-popup background-color="#fff" ref="confirm" type="dialog">
  47. <uni-popup-dialog :mode="dialog.mode" :title="dialog.title" :content="dialog.content" :placeholder="dialog.content" @confirm="confirmDialog" @close="closeDialog"></uni-popup-dialog>
  48. </uni-popup>
  49. </member-base>
  50. </template>
  51. <script>
  52. import {getFontSize} from '@/util/common'
  53. import TitleHeader from '../../TitleHeader'
  54. import { urlencode } from '@/util/common'
  55. import MemberBase from '../MemberBase'
  56. import EmptyRecord from '../../EmptyRecord'
  57. import { getComplaintList, cancelComplaint, handleComplain } from '../../../api/memberCompliant'
  58. export default {
  59. name: 'BillList',
  60. components:{
  61. TitleHeader,
  62. MemberBase,
  63. EmptyRecord
  64. },
  65. mounted(){
  66. // #ifdef MP-WEIXIN
  67. this.navHeight = uni.getMenuButtonBoundingClientRect().top
  68. // #endif
  69. },
  70. computed:{
  71. fontSize(){
  72. return getFontSize()
  73. },
  74. windowWidth: function () {
  75. const res = uni.getSystemInfoSync()
  76. var width=res.windowWidth
  77. var size=getFontSize()
  78. return (width-3*.6*size)/4
  79. }
  80. },
  81. data(){
  82. return {
  83. navHeight: 0,
  84. dialog:{},
  85. params: { 'page': 0, 'per_page': 10 },
  86. loading: false, // 是否加载更多
  87. isMore: true, // 是否有更多
  88. complaintList: false, // 商品列表
  89. goodsList: false
  90. }
  91. },
  92. onShow () {
  93. this.reload()
  94. },
  95. methods:{
  96. closeDialog(){
  97. },
  98. confirmDialog(value){
  99. cancelComplaint(this.dialog.data).then(res => {
  100. uni.showToast({icon:'none',title: res.message})
  101. this.reload()
  102. }).catch(function (error) {
  103. uni.showToast({icon:'none',title: error.message})
  104. })
  105. },
  106. goNavigate(path,query=false){
  107. uni.navigateTo({url:path+(query?('?'+urlencode(query)):'')})
  108. },
  109. goBack(){uni.navigateBack({delta:1})},
  110. handleComplain (complaint_id) {
  111. handleComplain(complaint_id).then(res => {
  112. uni.showToast({icon:'none',title: res.message})
  113. this.reload()
  114. }).catch(function (error) {
  115. uni.showToast({icon:'none',title: error.message})
  116. })
  117. },
  118. cancelComplaint (order_id) {
  119. this.dialog={content:'你确定要取消吗?',data:order_id}
  120. this.$refs.confirm.open()
  121. },
  122. getComplaintList (ispush) {
  123. uni.showLoading({ title: '加载中' })
  124. let params = this.params
  125. getComplaintList(params).then(res => {
  126. uni.hideLoading()
  127. if (res) {
  128. if (ispush && this.complaintList) {
  129. this.complaintList = this.complaintList.concat(res.result.complaint_list)
  130. this.goodsList = Object.assign(this.goodsList, res.result.goods_list)
  131. } else {
  132. this.complaintList = res.result.complaint_list
  133. this.goodsList = res.result.goods_list
  134. }
  135. if (res.result.hasmore) {
  136. this.isMore = true
  137. } else {
  138. this.isMore = false
  139. }
  140. }
  141. })
  142. },
  143. loadMore () {
  144. this.loading = true
  145. this.params.page = ++this.params.page
  146. if (this.isMore) {
  147. this.loading = false
  148. this.getComplaintList(true)
  149. }
  150. },
  151. reload(){
  152. // 重新加载数据
  153. this.params.page = 0
  154. this.isMore = true
  155. this.loading = false
  156. this.complaintList = false
  157. this.goodsList = false
  158. this.loadMore()
  159. },
  160. }
  161. }
  162. </script>
  163. <style scoped lang="scss">
  164. .scroll-view-wrapper{display: flex;flex-direction: column;}
  165. .scroll-view{flex:1}
  166. .complaint-item{
  167. background:#fff;
  168. border-bottom:1px solid #e1e1e1;
  169. margin-top: $modelSpace;
  170. border-radius: .5rem;
  171. padding: 0 $pageSpace;
  172. box-sizing: border-box;
  173. .head{
  174. padding: .3rem 0;
  175. display: flex;
  176. align-items: center;
  177. .type{
  178. font-size: .8rem;
  179. color: #333;
  180. }
  181. .time{
  182. font-size: .6rem;
  183. color: #999;
  184. margin-left: auto;
  185. }
  186. }
  187. .goods_info{
  188. display: flex;
  189. box-shadow: 0px 2px 4px 0px rgba(0,0,0,0.06);
  190. .image-wrapper{
  191. border-radius: .5rem;
  192. overflow: hidden;
  193. }
  194. .p-info{
  195. margin-left: .5rem;
  196. .goods_name{
  197. color: #333;
  198. font-size: .7rem;
  199. line-height: .8rem;
  200. height: 1.6rem;
  201. margin-top: .4rem;
  202. overflow: hidden;
  203. display: -webkit-box;
  204. -webkit-box-orient: vertical;
  205. -webkit-line-clamp: 2;
  206. padding: 0 .3rem;
  207. box-sizing: border-box;
  208. }
  209. .goods_price{
  210. color: $primaryColor;
  211. font-size: .8rem;
  212. margin-top: 1rem;
  213. }
  214. }
  215. }
  216. .complaint-info{
  217. padding: $modelSpace 0;
  218. .complaint_content{
  219. font-size: .7rem;
  220. color: #666;
  221. text{
  222. color: #333;
  223. }
  224. }
  225. }
  226. .complaint-btn{
  227. padding:.5rem;
  228. border-top:1px solid #e4e4e4;
  229. display: flex;
  230. justify-content: flex-end;
  231. .btn-1{border:1px solid $primaryColor;color:$primaryColor;min-width: 2rem}
  232. .btn-2{border:1px solid #333;color:#333;min-width: 2rem}
  233. .btn-wrapper{
  234. margin-left:.5rem
  235. }
  236. .buyer-info{
  237. flex:1;
  238. font-size:$subFontSize;
  239. line-height:1.4rem
  240. }
  241. }
  242. }
  243. </style>