tixian1.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638
  1. <template>
  2. <view class="page">
  3. <view class="content">
  4. <view class="">
  5. <u-subsection mode="subsection" :list="list2" :current="current" @change="change"
  6. keyName="label"></u-subsection>
  7. <u-checkbox-group v-model="checkboxValue1" placement="column" @change="checkboxChange">
  8. <view class="yong" v-if="current==0" style="margin-top: 20rpx;" v-for="(item,index) in list"
  9. :key="index">
  10. <view class="u-flex">
  11. <u-checkbox :customStyle="{marginBottom: '8px'}" :name="item.id">
  12. </u-checkbox>
  13. <view class="" style="flex: 1;">
  14. <view class="">
  15. 订单编号:{{item.order.order_no}}
  16. </view>
  17. <view class="u-flex u-row-between"
  18. style="margin-top: 20rpx; border-top:2rpx solid #F6F6F6;padding-top: -18rpx;box-sizing: border-box;">
  19. <view class="left">
  20. <view class="top">
  21. <text class="left">
  22. {{item.order.recommend_info.username}}
  23. </text>
  24. <text class="right">
  25. {{item.order.job.job_name}}
  26. </text>
  27. </view>
  28. <view class="concent">
  29. <text class="left">佣金内容</text>
  30. <text class="right">{{item.type_name}}</text>
  31. </view>
  32. <view class="concent u-flex">
  33. <text class="left">佣金金额</text>
  34. <view class="money">
  35. <text style="font: 24rpx;">¥</text>
  36. <text style="font-size: 32rpx;">{{item.amount}}</text>
  37. </view>
  38. </view>
  39. </view>
  40. <view class="right">
  41. <view class="top u-flex">
  42. <text class="left">
  43. 职位负责人-
  44. </text>
  45. <text class="right">
  46. {{item.order.hr.name }}
  47. </text>
  48. </view>
  49. <view class="concent">
  50. <text class="left">offer时间</text>
  51. <text class="right">{{item.order.offered_time.slice(0,-3).replaceAll("-",".")}}</text>
  52. </view>
  53. <view class="concent">
  54. <text class="left">过保时间</text>
  55. <text class="right">{{item.order.over_protected_time.slice(0,-3).replaceAll("-",".")}}</text>
  56. </view>
  57. </view>
  58. </view>
  59. </view>
  60. </view>
  61. <view class="bottom u-flex u-row-between">
  62. <view class="left">
  63. <text>推荐时间:{{item.order.recommended_time}}</text>
  64. </view>
  65. <view class="right">
  66. <text v-if="item.is_confirm==1">回款时间:{{item.confirm_time.slice(0,-3).replaceAll("-",".")}}</text>
  67. <text v-if="item.is_confirm==0">回款时间:未回款</text>
  68. </view>
  69. </view>
  70. </view>
  71. </u-checkbox-group>
  72. <u-checkbox-group v-model="checkboxValue1" placement="column" @change="checkboxChange">
  73. <view class="yong" v-if="current == 1" style="margin-top: 20rpx;" v-for="(item,index) in list"
  74. :key="index">
  75. <view class="u-flex">
  76. <view class="" style="flex: 1;">
  77. <view class="u-flex u-row-between">
  78. <view class="order">
  79. 订单编号 287910109281003
  80. </view>
  81. <view class="deposit">
  82. 未提现
  83. </view>
  84. </view>
  85. <view class="u-flex u-row-between dan" style="margin-top: 18rpx;">
  86. <view class="u-flex">
  87. <u-checkbox :name="item.name">
  88. </u-checkbox>
  89. <view class="lietou">猎头成单</view>
  90. </view>
  91. <view class="red">
  92. <text style="24rpx">¥</text>
  93. <text style="32rpx">200.00</text>
  94. </view>
  95. </view>
  96. </view>
  97. </view>
  98. <view class="u-flex u-row-between" style="margin-top:26rpx;">
  99. <text class="date">邀请日期 2023.03.12 12:4</text>
  100. <text class="date1">回款时间:2023.03.12 23:1</text>
  101. </view>
  102. </view>
  103. </u-checkbox-group>
  104. </view>
  105. <!-- <view style="height: 88vh;justify-content: center;" class="u-flex" v-if="list.length == 0 ">
  106. <u-empty text="暂无数据" mode="list"></u-empty>
  107. </view> -->
  108. </view>
  109. <view class="" style="height: 186rpx;background: #F3F3F3;"></view>
  110. <!-- <view class="safe-area-inset-bottom"></view> -->
  111. <view class="bottom-end">
  112. <u-checkbox-group @change="arraly" v-model="arralylist">
  113. <view class="u-flex u-row-between" style="width: 100%;">
  114. <view class="u-flex">
  115. <u-checkbox name=1>
  116. </u-checkbox>
  117. <view class="">全选</view>
  118. </view>
  119. <view class="u-flex">
  120. <view class="">
  121. <text class="jine">金额</text>
  122. <text class="red" style="font-size: 24rpx;margin-left: 12rpx;">¥</text>
  123. <text class="red" style="font-size: 36rpx;">{{alla}}</text>
  124. <text class="red" style="font-size: 24rpx;">.{{00}}</text>
  125. </view>
  126. <view class="btn" style="margin-left: 20rpx;">
  127. 立即提现
  128. </view>
  129. </view>
  130. </view>
  131. <view class="safe-area-inset-bottom"></view>
  132. </u-checkbox-group>
  133. </view>
  134. <u-datetime-picker :show="showtime" mode="year-month" @confirm="changetime"
  135. @cancel="showtime = false"></u-datetime-picker>
  136. <u-picker :show="show" :columns="columns" keyName="label" @cancel="show = false" @confirm="enter"></u-picker>
  137. </view>
  138. </template>
  139. <script>
  140. import {
  141. commission_list
  142. } from "@/units/inquire.js"
  143. export default {
  144. data() {
  145. return {
  146. arralylist: [],
  147. checkboxValue1: [],
  148. money: 200.00,
  149. show: false,
  150. showtime: false,
  151. current: 0,
  152. date: "",
  153. all:"",
  154. moneylist:[],
  155. list: [],
  156. list2: [{
  157. label: '订单佣金',
  158. // 其他属性值
  159. source_type: "order"
  160. }, {
  161. label: '邀请佣金',
  162. source_type: "invite"
  163. }],
  164. alllll:0,
  165. source_type: "order",
  166. label: "订单佣金",
  167. columns: [
  168. [{
  169. label: '订单佣金',
  170. // 其他属性值
  171. source_type: "order"
  172. // ...
  173. }, {
  174. label: '邀请佣金',
  175. source_type: "invite"
  176. }]
  177. ],
  178. list4: [{
  179. name: "佣金明细"
  180. },
  181. {
  182. name: "提现记录"
  183. }
  184. ]
  185. }
  186. },
  187. onLoad(options) {
  188. this.source_type = options.source_type
  189. if (this.source_type == "order") {
  190. this.label = "订单佣金"
  191. } else {
  192. this.label = "邀请佣金"
  193. }
  194. this.commission_list()
  195. },
  196. computed: {
  197. alla(){
  198. // var all = ""
  199. return this.alllll+=Number(this.all)
  200. },
  201. bgImage() {
  202. return `url(${require('@/static/images/juxing.png')}) 100% 100%`
  203. }
  204. },
  205. methods: {
  206. arraly(n) {
  207. if (n.length > 0) {
  208. this.list.forEach(item=>{
  209. this.checkboxValue1.push(item.id)
  210. this.moneylist.push(item.amount)
  211. this.arralylist = this.checkboxValue1
  212. this.sum()
  213. })
  214. if(this.arralylist!=this.checkboxValue1){
  215. n.length = 0
  216. }
  217. }
  218. if (n.length == 0) {
  219. this.checkboxValue1 = []
  220. this.moneylist = []
  221. this.sum()
  222. }
  223. },
  224. checkboxChange(n) {
  225. this.arralylist = n
  226. this.list.forEach(item=>{
  227. if(n[n.length-1] == item.id){
  228. this.moneylist.push(item.amount)
  229. }
  230. })
  231. this.sum()
  232. },
  233. return1() {
  234. uni.navigateBack()
  235. },
  236. sum(){
  237. this.moneylist.forEach(item=>{
  238. this.all += Number(item)
  239. })
  240. console.log(this.all);
  241. },
  242. change(e) {
  243. this.current = e
  244. },
  245. enter(e) {
  246. this.label = e.value[0].label
  247. this.source_type = e.value[0].source_type
  248. this.show = false
  249. },
  250. async changetime(e) {
  251. const timeFormat = uni.$u.timeFormat;
  252. let timeValue = await timeFormat(e.value, 'yyyy-mm');
  253. this.date = timeValue;
  254. this.page = 1
  255. this.total = 0
  256. this.list = []
  257. this.commission_list()
  258. this.showtime = false
  259. },
  260. commission_list() {
  261. commission_list({
  262. source_type: this.source_type,
  263. job_name: "",
  264. is_confirm: "",
  265. begin_time: "",
  266. end_time: "",
  267. time_type: "",
  268. status: "unapplied"
  269. }).then(res => {
  270. this.list = res.data.data
  271. })
  272. }
  273. }
  274. }
  275. </script>
  276. <style lang="scss" scoped>
  277. .btn {
  278. width: 184rpx;
  279. height: 72rpx;
  280. background: #0C66C2;
  281. border-radius: 12rpx;
  282. font-size: 30rpx;
  283. font-family: PingFangSC, PingFang SC;
  284. font-weight: 400;
  285. color: #FFFFFF;
  286. line-height: 72rpx;
  287. text-align: center;
  288. }
  289. .jine {
  290. font-size: 24rpx;
  291. font-family: PingFangSC, PingFang SC;
  292. font-weight: 400;
  293. color: #444444;
  294. }
  295. .red {
  296. font-family: JDZhengHT, JDZhengHT;
  297. font-weight: 400;
  298. color: #F2413A;
  299. }
  300. .bottom-end {
  301. width: 750rpx;
  302. height: 166rpx;
  303. background: #FFFFFF;
  304. padding: 16rpx 32rpx 0;
  305. position: fixed;
  306. bottom: 0;
  307. left: 0;
  308. box-sizing: border-box;
  309. }
  310. .date {
  311. font-size: 24rpx;
  312. font-family: PingFangSC-Regular, PingFang SC;
  313. font-weight: 400;
  314. color: #888888;
  315. }
  316. .date1 {
  317. font-size: 24rpx;
  318. font-family: SFPro-Regular, SFPro;
  319. font-weight: 400;
  320. color: #222222;
  321. }
  322. .red {
  323. font-family: JDZhengHT-Regular, JDZhengHT;
  324. font-weight: 400;
  325. color: #F2413A;
  326. }
  327. .lietou {
  328. font-size: 32rpx;
  329. font-family: PingFangSC-Medium, PingFang SC;
  330. font-weight: 500;
  331. color: #222222;
  332. }
  333. .dan {
  334. margin-top: 20rpx;
  335. border-top: 2rpx solid #F6F6F6;
  336. padding-top: 18rpx;
  337. }
  338. .deposit {
  339. border-radius: 6rpx;
  340. background-color: rgba(12, 102, 194, 0.1);
  341. font-size: 24rpx;
  342. font-family: PingFangSC-Regular, PingFang SC;
  343. font-weight: 400;
  344. color: #0C66C2;
  345. padding: 4rpx;
  346. }
  347. .order {
  348. font-size: 24rpx;
  349. font-family: SFPro-Regular, SFPro;
  350. font-weight: 400;
  351. color: #666666;
  352. }
  353. .yong {
  354. background: #FFFFFF;
  355. border-radius: 16rpx;
  356. padding: 20rpx 20rpx 26rpx;
  357. box-sizing: border-box;
  358. .top {
  359. .left {
  360. font-size: 24rpx;
  361. font-family: PingFangSC-Regular, PingFang SC;
  362. font-weight: 400;
  363. color: #555555;
  364. }
  365. .right {
  366. font-family: SFPro-Regular, SFPro;
  367. font-weight: 400;
  368. color: #F2413A;
  369. }
  370. }
  371. .leftf {
  372. font-size: 26rpx;
  373. font-family: PingFangSC-Regular, PingFang SC;
  374. font-weight: 400;
  375. color: #555555;
  376. margin-top: 20rpx;
  377. }
  378. .leftff {
  379. font-size: 26rpx;
  380. font-family: PingFangSC-Regular, PingFang SC;
  381. font-weight: 400;
  382. color: #555555;
  383. }
  384. }
  385. .list1 {
  386. background: #FFFFFF;
  387. border-radius: 16rpx;
  388. .data {
  389. font-size: 24rpx;
  390. font-family: PingFangSC-Regular, PingFang SC;
  391. font-weight: 400;
  392. color: #888888;
  393. }
  394. .data1 {
  395. font-size: 24rpx;
  396. font-family: PingFangSC-Regular, PingFang SC;
  397. font-weight: 400;
  398. color: #222222;
  399. }
  400. .title {
  401. font-size: 32rpx;
  402. font-family: PingFangSC-Medium, PingFang SC;
  403. font-weight: 500;
  404. color: #222222;
  405. }
  406. .font {
  407. font-size: 24rpx;
  408. font-family: PingFangSC-Regular, PingFang SC;
  409. font-weight: 400;
  410. color: #fff;
  411. opacity: 1;
  412. }
  413. .back {
  414. background: #0C66C2;
  415. border-radius: 6rpx;
  416. padding: 4rpx 8rpx;
  417. opacity: 0.5;
  418. }
  419. .money {
  420. font-size: 24rpx;
  421. font-family: SFPro-Regular, SFPro;
  422. font-weight: 400;
  423. color: #F2413A;
  424. margin-left: 12rpx;
  425. }
  426. }
  427. .page {
  428. height: 100vh;
  429. .content {
  430. padding: 0 24rpx;
  431. background: #F3F3F3;
  432. min-height: 78vh;
  433. padding-top: 20rpx;
  434. min-height: 100vh;
  435. box-sizing: border-box;
  436. .list {
  437. background: #FFFFFF;
  438. border-radius: 16rpx;
  439. padding: 20rpx;
  440. box-sizing: border-box;
  441. }
  442. }
  443. }
  444. .bottom {
  445. border-top: 2rpx solid #F6F6F6;
  446. margin-top: 18rpx;
  447. padding-top: 18rpx;
  448. box-sizing: border-box;
  449. .left {
  450. font-size: 24rpx;
  451. font-family: PingFangSC-Regular, PingFang SC;
  452. font-weight: 400;
  453. color: #555555;
  454. }
  455. .right {
  456. font-size: 24rpx;
  457. font-family: PingFangSC-Regular, PingFang SC;
  458. font-weight: 400;
  459. color: #999999;
  460. }
  461. }
  462. .right {
  463. .concent {
  464. .left {
  465. font-size: 24rpx;
  466. font-family: PingFangSC-Regular, PingFang SC;
  467. font-weight: 400;
  468. color: #222222;
  469. }
  470. .money {
  471. font-size: 24rpx;
  472. font-family: SFPro-Regular, SFPro;
  473. font-weight: 400;
  474. color: #F2413A;
  475. margin-left: 12rpx;
  476. }
  477. .right {
  478. margin-left: 12rpx;
  479. font-size: 24rpx;
  480. font-family: PingFangSC-Regular, PingFang SC;
  481. font-weight: 400;
  482. color: #555555;
  483. }
  484. }
  485. .top {
  486. .left {
  487. font-size: 24rpx;
  488. font-family: PingFangSC-Regular, PingFang SC;
  489. font-weight: 400;
  490. color: #555555;
  491. }
  492. .right {
  493. font-size: 24rpx;
  494. font-family: PingFangSC-Regular, PingFang SC;
  495. font-weight: 400;
  496. color: #555555;
  497. display: inline-block;
  498. width: 170rpx;
  499. overflow: hidden;
  500. text-overflow: ellipsis;
  501. white-space: nowrap;
  502. }
  503. }
  504. }
  505. .left {
  506. // width: 300rpx;
  507. // overflow: hidden;
  508. // text-overflow: ellipsis;
  509. // white-space: nowrap;
  510. .concent {
  511. .left {
  512. font-size: 24rpx;
  513. font-family: PingFangSC-Regular, PingFang SC;
  514. font-weight: 400;
  515. color: #222222;
  516. }
  517. .money {
  518. font-size: 24rpx;
  519. font-family: SFPro-Regular, SFPro;
  520. font-weight: 400;
  521. color: #F2413A;
  522. margin-left: 12rpx;
  523. }
  524. .right {
  525. margin-left: 12rpx;
  526. font-size: 24rpx;
  527. font-family: PingFangSC-Regular, PingFang SC;
  528. font-weight: 400;
  529. color: #555555;
  530. }
  531. }
  532. .top {
  533. .left {
  534. height: 44rpx;
  535. font-size: 32rpx;
  536. font-family: PingFangSC-Medium, PingFang SC;
  537. font-weight: 500;
  538. color: #222222;
  539. }
  540. .right {
  541. margin-left: 12rpx;
  542. font-size: 24rpx;
  543. font-family: PingFangSC-Regular, PingFang SC;
  544. font-weight: 400;
  545. color: #141414;
  546. overflow: hidden;
  547. text-overflow: ellipsis;
  548. white-space: nowrap;
  549. width: 220rpx;
  550. display: inline-block;
  551. }
  552. }
  553. }
  554. .search {
  555. height: 68rpx;
  556. background: #F3F3F3;
  557. border-radius: 38rpx;
  558. padding: 14rpx 28rpx;
  559. box-sizing: border-box;
  560. }
  561. .index-header {
  562. padding: 0 32rpx;
  563. height: 50rpx;
  564. .index-search {
  565. width: 200rpx;
  566. height: 64rpx;
  567. background: #FFFFFF;
  568. border-radius: 20rpx;
  569. padding: 0 28rpx;
  570. .text1 {
  571. font-size: 24rpx;
  572. font-family: PingFangSC-Regular, PingFang SC;
  573. font-weight: 400;
  574. color: #999999;
  575. margin-left: 16rpx;
  576. }
  577. }
  578. }
  579. ::v-deep .u-navbar__content__left {
  580. padding: 0 !important;
  581. }
  582. // ::v-deep .u-subsection__item{
  583. // border-radius: 38rpx;
  584. // }
  585. // ::v-deep .u-subsection--subsection{
  586. // border-radius: 76rpx;
  587. // }
  588. </style>