index.html 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. <link rel="stylesheet" href="__CDN__/assets/addons/shopro/libs/element/element.css">
  2. <link rel="stylesheet" href="__CDN__/assets/addons/shopro/libs/common.css">
  3. <style>
  4. #userWalletApply {
  5. padding-bottom: 30px;
  6. background: #fff;
  7. border-radius: 10px 10px 0px 0px;
  8. }
  9. .custom-tabs-wrap {
  10. padding: 12px 24px 0;
  11. border-bottom: 2px solid #e6e6e6;
  12. margin-bottom: 20px;
  13. position: relative;
  14. }
  15. .custom-tabs-wrap .el-tabs__header {
  16. margin: 0;
  17. }
  18. .custom-tabs-wrap .tabs-export {
  19. position: absolute;
  20. top: 24px;
  21. right: 24px;
  22. color: #7438D5;
  23. cursor: pointer;
  24. }
  25. .custom-tabs-wrap .tabs-export i {
  26. margin-right: 6px;
  27. }
  28. .custom-refresh-button {
  29. margin-right: 14px;
  30. }
  31. .custom-filter-wrap .custom-refresh-button {
  32. margin-bottom: 14px;
  33. }
  34. .custom-filter-wrap {
  35. flex-wrap: wrap;
  36. padding: 0 24px;
  37. }
  38. .custom-filter-wrap .custom-filter-item {
  39. margin-bottom: 14px;
  40. margin-right: 24px;
  41. }
  42. .custom-filter-wrap .custom-filter-button-wrap {
  43. margin-bottom: 14px;
  44. }
  45. .custom-filter-wrap .custom-filter-label {
  46. flex-shrink: 0;
  47. margin-right: 14px;
  48. font-size: 12px;
  49. color: #666;
  50. }
  51. .custom-filter-wrap .custom-filter-content-input {
  52. width: 104px;
  53. }
  54. .custom-table-wrap {
  55. margin: 0 24px;
  56. }
  57. .custom-margin-14 {
  58. margin-right: 14px !important;
  59. }
  60. .custom-table-operation-text {
  61. margin-right: 14px;
  62. cursor: pointer;
  63. }
  64. .custom-table-operation-text:last-child {
  65. margin-right: 0;
  66. }
  67. .custom-table-image {
  68. width: 32px;
  69. height: 32px;
  70. border-radius: 50%;
  71. border: 1px solid #E6E6E6;
  72. margin-right: 8px;
  73. flex-shrink: 0;
  74. overflow: hidden;
  75. }
  76. .custom-table-color-primary {
  77. color: #6E3DC8;
  78. }
  79. .custom-table-color-success {
  80. color: #70C140;
  81. }
  82. .custom-table-color-error {
  83. color: #ED5B56;
  84. }
  85. .custom-table-color-warning {
  86. color: #EFAF41;
  87. }
  88. .custom-table-color-info {
  89. color: #999999;
  90. }
  91. .pagination-container-b {
  92. justify-content: space-between;
  93. }
  94. .table-checked-all {
  95. margin-right: 12px !important;
  96. }
  97. .get-type-iamge {
  98. width: 60px;
  99. height: 60px;
  100. margin-right: 8px;
  101. border-radius: none;
  102. border: none;
  103. }
  104. .refuse-dialog.el-dialog {
  105. width: 474px !important;
  106. }
  107. .refuse-dialog.el-dialog .el-dialog__body {
  108. padding: 10px 20px 0;
  109. }
  110. .refuse-dialog.el-dialog .el-dialog__title {
  111. font-size: 18px !important;
  112. color: #444;
  113. }
  114. .agree-dialog.el-dialog .el-dialog__body {
  115. display: none;
  116. }
  117. .el-date-editor.el-input,
  118. .el-date-editor.el-input__inner {
  119. width: 350px;
  120. }
  121. .el-range-editor--small .el-range-separator {
  122. line-height: 25px;
  123. }
  124. .el-date-editor .el-range-separator {
  125. width: 7%;
  126. }
  127. .table-popover-jump {
  128. cursor: pointer;
  129. color: #7438D5;
  130. }
  131. .log-dialog.el-dialog {
  132. width: fit-content !important;
  133. }
  134. .custom-table-checkbox .el-table__header .el-table_1_column_1.el-table-column--selection .el-checkbox {
  135. display: none;
  136. }
  137. .custom-copy-message {
  138. margin-left: 14px;
  139. cursor: pointer;
  140. }
  141. .custom-copy-message:hover {
  142. color: #7438D5;
  143. }
  144. </style>
  145. <script src="__CDN__/assets/addons/shopro/libs/vue.js"></script>
  146. <script src="__CDN__/assets/addons/shopro/libs/element/element.js"></script>
  147. <script src="__CDN__/assets/addons/shopro/libs/moment.js"></script>
  148. <script src="__CDN__/assets/addons/shopro/libs/clipboard.min.js"></script>
  149. <div id="userWalletApply" v-cloak>
  150. <div class="custom-tabs-wrap">
  151. <el-tabs v-model="searchForm.status" @tab-click="changeApplyStatus">
  152. <el-tab-pane v-for="w in filterRule.status" :label="w.name" :name="w.type+''">
  153. </el-tab-pane>
  154. </el-tabs>
  155. <div class="tabs-export" @click="exportApply">
  156. <i class="el-icon-download"></i>
  157. 列表导出
  158. </div>
  159. </div>
  160. <div class="custom-filter-wrap display-flex">
  161. <div class="custom-refresh display-flex custom-refresh-button" @click="getWalletApply(offset,limit)">
  162. <i class="el-icon-refresh"></i>
  163. </div>
  164. <div class="custom-filter-item display-flex">
  165. <div class="custom-filter-label">申请时间</div>
  166. <div class="custom-filter-content">
  167. <el-date-picker v-model="searchForm.createtime" type="daterange" value-format="yyyy-MM-dd HH:mm:ss"
  168. format="yyyy-MM-dd HH:mm:ss" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"
  169. :picker-options="pickerOptions" align="right" size="small" :default-time="['00:00:00', '23:59:59']">
  170. </el-date-picker>
  171. </div>
  172. </div>
  173. <div class="custom-filter-item display-flex">
  174. <div class="custom-filter-label">上次操作时间</div>
  175. <div class="custom-filter-content">
  176. <el-date-picker v-model="searchForm.updatetime" type="daterange" value-format="yyyy-MM-dd HH:mm:ss"
  177. format="yyyy-MM-dd HH:mm:ss" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"
  178. :picker-options="pickerOptions" align="right" size="small" :default-time="['00:00:00', '23:59:59']">
  179. </el-date-picker>
  180. </div>
  181. </div>
  182. <div class="custom-filter-item display-flex">
  183. <div class="custom-filter-content">
  184. <el-input placeholder="请输入内容" v-model="searchForm.form_1_value" class="input-with-select" size="small">
  185. <el-select v-model="searchForm.form_1_key" slot="prepend" placeholder="请选择">
  186. <el-option label="用户ID" value="user_id"></el-option>
  187. <el-option label="用户昵称" value="user_nickname"></el-option>
  188. <el-option label="用户手机号" value="user_mobile"></el-option>
  189. </el-select>
  190. </el-input>
  191. </div>
  192. </div>
  193. <div class="custom-filter-item display-flex">
  194. <div class="custom-filter-label">提现方式</div>
  195. <div class="custom-filter-content custom-filter-content-input">
  196. <el-select v-model="searchForm.apply_type" size="small">
  197. <el-option v-for="type in filterRule.apply_type" :label="type.name" :value="type.type">
  198. </el-option>
  199. </el-select>
  200. </div>
  201. </div>
  202. <div class="custom-filter-button-wrap display-flex">
  203. <el-button class="filter-reset-button" @click="filterEmpty" size="small">重置</el-button>
  204. <el-button class="filter-button" @click="filterConfirm()" type="primary" size="small">筛选</el-button>
  205. </div>
  206. </div>
  207. <div class="custom-table-wrap"
  208. :class="(searchForm.status!='0' && searchForm.status!='1')?'custom-table-checkbox':''">
  209. <el-table ref="multipleTable" :data="walletApplyData" border stripe @selection-change="tableSelect">
  210. <el-table-column type="selection" width="40" align="center" :selectable="checkSelectable">
  211. </el-table-column>
  212. <el-table-column prop="id" min-width="74" label="ID">
  213. </el-table-column>
  214. <el-table-column min-width="120" label="申请用户" align="left">
  215. <template slot-scope="scope">
  216. <template v-if="scope.row.user">
  217. <div v-if="scope.row.user.avatar" class="custom-table-image">
  218. <el-image :src="Fast.api.cdnurl(scope.row.user.avatar)" fit="cover">
  219. <div slot="error" class="image-slot">
  220. <i class="el-icon-picture-outline"></i>
  221. </div>
  222. </el-image>
  223. </div>
  224. <el-popover placement="top" width="200" trigger="hover">
  225. <div class="table-popover-wrap">
  226. <div>
  227. <span>ID:</span>
  228. <span class="table-popover-jump"
  229. @click="openUser(scope.row.user.id)">{{scope.row.user.id}}</span>
  230. </div>
  231. <div>
  232. <span>手机号:</span>
  233. <span>{{scope.row.user.mobile?scope.row.user.mobile:'-'}}</span>
  234. </div>
  235. </div>
  236. <div class="ellipsis-item table-popover-jump" slot="reference">
  237. <span @click="openUser(scope.row.user.id)">{{scope.row.user.nickname}}</span>
  238. </div>
  239. </el-popover>
  240. </template>
  241. <template v-else>-</template>
  242. </template>
  243. </el-table-column>
  244. <el-table-column width="200" label="实际到账/提现金额">
  245. <template slot-scope="scope">
  246. {{scope.row.actual_money}} <span>元</span>/{{scope.row.money}} <span>元</span>
  247. </template>
  248. </el-table-column>
  249. <el-table-column min-width="150" label="费率/手续费">
  250. <template slot-scope="scope">
  251. <span>{{scope.row.service_fee*100}}%</span>/<span>{{scope.row.charge_money}}元</span>
  252. </template>
  253. </el-table-column>
  254. <el-table-column width="150" label="提现方式" align="left">
  255. <template slot-scope="scope">
  256. <div class="custom-table-image get-type-iamge">
  257. <el-image :src="'/assets/addons/shopro/img/user_wallet_apply/'+scope.row.apply_type+'.png'"
  258. fit="cover">
  259. <div slot="error" class="image-slot">
  260. <i class="el-icon-picture-outline"></i>
  261. </div>
  262. </el-image>
  263. </div>
  264. <div class="ellipsis-item">{{scope.row.apply_type_text}}</div>
  265. </template>
  266. </el-table-column>
  267. <el-table-column width="150" label="收款码" >
  268. <template slot-scope="scope">
  269. <div class="get-type-iamge" @click="openWechatCode(scope.row.wechat_code)">
  270. <el-image :src="Fast.api.cdnurl(scope.row.wechat_code)" style="width: 60px;height: 60px" fit="cover">
  271. </el-image>
  272. </div>
  273. </template>
  274. </el-table-column>
  275. <el-table-column width="240" label="打款信息" align="left">
  276. <template slot-scope="scope">
  277. <div>
  278. <template v-if="scope.row.apply_info">
  279. <div class="display-flex" v-for="(key,kindex) in scope.row.apply_info_text">
  280. <span class="ellipsis-item">{{kindex}}:&nbsp;{{key}}</span>
  281. <span class="custom-copy-message" :class="'custom-copy-message'+scope.$index+key"
  282. :data-clipboard-text="key" @click="copyMessage(scope.$index+key)">
  283. <i class="el-icon-copy-document"></i>
  284. </span>
  285. </div>
  286. </template>
  287. <template v-if="!scope.row.apply_info">-</template>
  288. </div>
  289. </template>
  290. </el-table-column>
  291. <el-table-column width="150" label="申请时间">
  292. <template slot-scope="scope">
  293. {{moment(scope.row.createtime*1000).format('YYYY-MM-DD HH:mm:ss')}}
  294. </template>
  295. </el-table-column>
  296. <el-table-column width="150" label="上次操作时间">
  297. <template slot-scope="scope">
  298. {{moment(scope.row.updatetime*1000).format('YYYY-MM-DD HH:mm:ss')}}
  299. </template>
  300. </el-table-column>
  301. <el-table-column width="88" fixed="right" label="状态">
  302. <template slot-scope="scope">
  303. <span v-if="scope.row.status==-1" class="custom-table-color-error">{{scope.row.status_text}}</span>
  304. <span v-if="scope.row.status==0" class="custom-table-color-info">{{scope.row.status_text}}</span>
  305. <span v-if="scope.row.status==1" class="custom-table-color-warning">{{scope.row.status_text}}</span>
  306. <span v-if="scope.row.status==2" class="custom-table-color-success">{{scope.row.status_text}}</span>
  307. </template>
  308. </el-table-column>
  309. <el-table-column min-width="140" fixed="right" label="操作" align="left">
  310. <template slot-scope="scope">
  311. <span v-if="scope.row.status==0" class="custom-table-operation-text custom-table-color-primary"
  312. @click="openAgreeDialog(scope.row)">同意</span>
  313. <span v-if="scope.row.status==1" class="custom-table-operation-text custom-table-color-primary"
  314. @click="openImmediatelyDialog(scope.row)">立即打款</span>
  315. <span v-if="scope.row.status==0 || scope.row.status==1"
  316. class="custom-table-operation-text custom-table-color-error"
  317. @click="openRefuseDialog(scope.row)">拒绝</span>
  318. <span class="custom-table-operation-text custom-table-color-primary"
  319. @click="openLogDialog(scope.row.id)">
  320. <i class="el-icon-time"></i>
  321. </span>
  322. </template>
  323. </el-table-column>
  324. </el-table>
  325. <div class="pagination-container"
  326. :class="(searchForm.status=='0' || searchForm.status=='1')?'pagination-container-b':''">
  327. <div v-if="searchForm.status=='0' || searchForm.status=='1'">
  328. <el-checkbox class="table-checked-all" :indeterminate="isIndeterminate"
  329. :disabled="walletApplyData.length==0" v-model="tableCheckedAll" @change="changeCheckedAll">
  330. </el-checkbox>
  331. <el-button v-if="searchForm.status=='0'" :type="tableCheckedAll?'primary':''"
  332. :disabled="!tableCheckedAll" plain size="small" @click="openAgreeDialog(multipleSelection)">同意
  333. </el-button>
  334. <el-button v-if="searchForm.status=='1'" :type="tableCheckedAll?'primary':''"
  335. :disabled="!tableCheckedAll" plain size="small" @click="openImmediatelyDialog(multipleSelection)">
  336. 立即打款
  337. </el-button>
  338. <el-button v-if="searchForm.status=='0' || searchForm.status=='1'" :type="tableCheckedAll?'danger':''"
  339. :disabled="!tableCheckedAll" plain size="small" @click="openRefuseDialog(multipleSelection)">拒绝
  340. </el-button>
  341. </div>
  342. <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange"
  343. :current-page="currentPage" :page-sizes="[10, 20, 30, 40]" :page-size="limit"
  344. layout="total, sizes, prev, pager, next, jumper" :total="totalPage">
  345. </el-pagination>
  346. </div>
  347. </div>
  348. <!-- 同意 -->
  349. <el-dialog custom-class="refuse-dialog agree-dialog" title="操作提示" :visible.sync="agreeDialogVisible"
  350. :before-close="closeAgreeDialog">
  351. <span slot="footer">
  352. <el-button @click="closeAgreeDialog" size="small">取消</el-button>
  353. <el-button type="primary" @click="agreePayment()" size="small" plain>同意</el-button>
  354. <el-button type="primary" @click="confirmPayment()" size="small">同意&打款</el-button>
  355. </span>
  356. </el-dialog>
  357. <!-- 立即打款 -->
  358. <el-dialog custom-class="refuse-dialog agree-dialog" title="操作提示" :visible.sync="immediatelyDialogVisible"
  359. :before-close="closeImmediatelyDialog">
  360. <span slot="footer">
  361. <el-button @click="closeImmediatelyDialog" size="small">取消</el-button>
  362. <el-button type="primary" @click="immediatelyPayment()" size="small" plain>确定</el-button>
  363. </span>
  364. </el-dialog>
  365. <!-- 拒绝 -->
  366. <el-dialog custom-class="refuse-dialog" title="拒绝理由" :visible.sync="refuseDialogVisible"
  367. :before-close="closeRefuseDialog">
  368. <div>
  369. <el-input v-model="refuseForm.status_msg" placeholder="请输入拒绝理由"></el-input>
  370. </div>
  371. <span slot="footer">
  372. <el-button @click="closeRefuseDialog" size="small">取消</el-button>
  373. <el-button type="danger" @click="refusePayment()" size="small">拒绝</el-button>
  374. </span>
  375. </el-dialog>
  376. <!-- 操作日志 -->
  377. <el-dialog custom-class="log-dialog" title="操作日志" :visible.sync="logDialogVisible" :before-close="closeLogDialog">
  378. <div>
  379. <el-table :data="logList" border stripe max-height="450">
  380. <el-table-column prop="oper_info" min-width="300" label="日志" align="left">
  381. <template slot-scope="scope">
  382. {{scope.row.oper_info}}
  383. </template>
  384. </el-table-column>
  385. <el-table-column width="100" label="操作人类型">
  386. <template slot-scope="scope">
  387. <span v-if="scope.row.oper">{{scope.row.oper.type}}</span>
  388. <span v-else>-</span>
  389. </template>
  390. </el-table-column>
  391. <el-table-column width="150" label="操作人" align="left">
  392. <template slot-scope="scope">
  393. <div v-if="scope.row.oper" class="display-flex">
  394. <div v-if="scope.row.oper.avatar" class="custom-table-image">
  395. <el-image :src="Fast.api.cdnurl(scope.row.oper.avatar)" fit="cover">
  396. <div slot="error" class="image-slot">
  397. <i class="el-icon-picture-outline"></i>
  398. </div>
  399. </el-image>
  400. </div>
  401. <span class="ellipsis-item">{{scope.row.oper.name}}</span>
  402. </div>
  403. <span v-else>-</span>
  404. </template>
  405. </el-table-column>
  406. <el-table-column width="150" label="操作时间">
  407. <template slot-scope="scope">
  408. {{moment(scope.row.oper_time*1000).format('YYYY-MM-DD HH:mm:ss')}}
  409. </template>
  410. </el-table-column>
  411. </el-table>
  412. </div>
  413. </el-dialog>
  414. <!--收款码-->
  415. <el-dialog custom-class="log-dialog" title="收款码" :visible.sync="wechatCodeVisible" :before-close="closeWechatCode">
  416. <div>
  417. <img width="400px" :src="Fast.api.cdnurl(wechatCodeUrl)"/>
  418. </div>
  419. </el-dialog>
  420. </div>