order_addcart.vue 48 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698
  1. <template>
  2. <view class="order_addcart" :style="colorStyle">
  3. <view class="order_addcart-header-area">
  4. <view class="received">
  5. <view class="pictrue">
  6. <image
  7. src="http://wine.gzzzyd.com/wx/order_addcart/qiandai.png"
  8. ></image>
  9. </view>
  10. <view class="text-info" @click="goReceived()">
  11. <view class="received-count">
  12. {{ moneyObj.receiveItemAmount }}
  13. </view>
  14. <view class="received-info"> 已领取红包 </view>
  15. </view>
  16. </view>
  17. <view class="loss" @click="goMissed()">
  18. <view class="text-info">
  19. <view class="received-count">
  20. {{ moneyObj.lossTotalAmount }}
  21. </view>
  22. <view class="received-info"> 已错失红包 </view>
  23. </view>
  24. </view>
  25. </view>
  26. <view class="loop">
  27. <view class="loop-title"> 当前红包池 </view>
  28. <view class="loop-count">
  29. {{ moneyObj.totalRemainItemAmount }}
  30. </view>
  31. </view>
  32. <view class="tab-area">
  33. <view
  34. @click="
  35. isactiveTab = 'todayRank';
  36. leaderboard();
  37. "
  38. :class="{
  39. 'tab-area-active1': isactiveTab === 'todayRank',
  40. 'base-tab': true,
  41. }"
  42. >
  43. <text> 今日红包排行榜</text>
  44. </view>
  45. <view
  46. @click="
  47. isactiveTab = 'allRank';
  48. leaderboard();
  49. "
  50. :class="{
  51. 'tab-area-active2': isactiveTab === 'allRank',
  52. 'base-tab': true,
  53. }"
  54. >
  55. <text> 红包领取总榜</text>
  56. </view>
  57. </view>
  58. <view class="rank-list">
  59. <view class="rank-list-item" v-for="(src, i) in rankList" :key="src.id">
  60. <img
  61. v-show="i === 0"
  62. src="http://wine.gzzzyd.com/wx/order_addcart/rank1.png"
  63. alt=""
  64. />
  65. <img
  66. v-show="i === 1"
  67. src="http://wine.gzzzyd.com/wx/order_addcart/rank2.png"
  68. alt=""
  69. />
  70. <img
  71. v-show="i === 2"
  72. src="http://wine.gzzzyd.com/wx/order_addcart/rank3.png"
  73. alt=""
  74. />
  75. <img v-show="i !== 0 && i !== 1 && i !== 2" :src="src.avatar" alt="" />
  76. <text class="nuber"> {{ src.userName }}</text>
  77. <text class="mosaic"> {{ src.phone }}</text>
  78. <text class="litem-info"> 共领取了</text>
  79. <text class="balance">{{ src.totalAmount }}</text>
  80. </view>
  81. </view>
  82. <u-overlay :show="show" @click="show = false">
  83. <view class="warp">
  84. <view class="rect" @tap.stop>
  85. <view class="cover-img">
  86. <img class="avatar" :src="userInfo.avatar" />
  87. </view>
  88. <view class="h-info"
  89. >当前红包
  90. {{ ["随机红包", "专属红包", "共富红包"][activeRedPer.type] }}
  91. <view class="paper_list">
  92. <text
  93. :class="{
  94. acitiveRedper: activeRedPer.type === item.type,
  95. }"
  96. @click="activeRedPer = item;grabAmountFlag = false;"
  97. v-for="item in redPaper"
  98. :key="item.type"
  99. >
  100. {{ ["随机红包", "专属红包", "共富红包"][item.type] }}
  101. </text>
  102. </view>
  103. <view class="grabAmount_count" v-if="grabAmountFlag">
  104. <text>恭喜您获得</text>
  105. <text>¥ {{ currentRedpaper.grabAmount }}</text>
  106. </view>
  107. </view>
  108. <img
  109. class="op-img"
  110. @click="doGrab"
  111. src="http://wine.gzzzyd.com/wx/order_addcart/ling.png"
  112. alt=""
  113. />
  114. <!-- <img class="op-img" src="http://wine.gzzzyd.com/wx/order_addcart/kai.png" alt=""> -->
  115. <view class="b-info">
  116. 今日已领取{{
  117. redPaper.filter((e) => {
  118. return e.flag === 0;
  119. }).length
  120. }}/3
  121. </view>
  122. <view class="b-box">
  123. <text> 参与共富模式,用户可下单领取红包 </text>
  124. </view>
  125. </view>
  126. </view>
  127. </u-overlay>
  128. </view>
  129. </template>
  130. <script>
  131. // #ifdef APP-PLUS
  132. let sysHeight = uni.getSystemInfoSync().statusBarHeight + 'px';
  133. // #endif
  134. // #ifndef APP-PLUS
  135. let sysHeight = 0
  136. // #endif
  137. import {
  138. grabFlag,
  139. leaderboard,
  140. doGrab,
  141. todayStatistics
  142. } from '@/api/home.js';
  143. import {
  144. getProductHot,
  145. collectAll,
  146. getProductDetail
  147. } from '@/api/store.js';
  148. import {
  149. toLogin
  150. } from '@/libs/login.js';
  151. import {
  152. mapGetters
  153. } from "vuex";
  154. import recommend from '@/components/recommend';
  155. import productWindow from '@/components/productWindow';
  156. // #ifdef MP
  157. import authorize from '@/components/Authorize';
  158. // #endif
  159. import pageFooter from '@/components/pageFooter/index.vue'
  160. import colors from "@/mixins/color";
  161. import {
  162. HTTP_REQUEST_URL
  163. } from '@/config/app';
  164. const hot_res = require('@/mock/json/hot_res.json')
  165. import {
  166. getNavigation
  167. } from '@/api/public.js'
  168. import {
  169. colorChange
  170. } from '../../api/api';
  171. export default {
  172. components: {
  173. pageFooter,
  174. recommend,
  175. productWindow,
  176. // #ifdef MP
  177. authorize
  178. // #endif
  179. },
  180. mixins: [colors],
  181. data () {
  182. return {
  183. isactiveTab: 'todayRank',
  184. grabFlagisOpen: false,
  185. grabAmountFlag: false,
  186. show: false,
  187. userInfo: {},
  188. activeRedPer: {
  189. type: 0
  190. },
  191. currentRedpaper: {
  192. // 抢到的金额
  193. grabAmount: '0.00'
  194. },
  195. moneyObj: {
  196. lossTotalAmount: "0",
  197. receiveItemAmount: "0",
  198. receiveItemCount: 0,
  199. redEnvelopeItemCount: 0,
  200. remainItemCount: 0,
  201. totalReceivedRedEnvelopeAmount: "0",
  202. totalRedEnvelopeAmount: "0",
  203. totalRemainItemAmount: "0"
  204. },
  205. imgHost: HTTP_REQUEST_URL,
  206. is_diy: uni.getStorageSync('is_diy'),
  207. canShow: false,
  208. cartCount: 0,
  209. goodsHidden: true,
  210. footerswitch: true,
  211. hostProduct: [],
  212. cartList: {
  213. valid: [],
  214. invalid: []
  215. },
  216. isAllSelect: false, //全选
  217. selectValue: [], //选中的数据
  218. selectCountPrice: 0.00,
  219. isAuto: false, //没有授权的不会自动授权
  220. isShowAuth: false, //是否隐藏授权
  221. hotScroll: false,
  222. hotPage: 1,
  223. hotLimit: 10,
  224. loading: false,
  225. loadend: false,
  226. loadTitle: this.$t(`我也是有底线的`), //提示语
  227. page: 1,
  228. limit: 20,
  229. loadingInvalid: false,
  230. loadendInvalid: false,
  231. loadTitleInvalid: this.$t(`加载更多`), //提示语
  232. pageInvalid: 1,
  233. limitInvalid: 20,
  234. attr: {
  235. cartAttr: false,
  236. productAttr: [],
  237. productSelect: {}
  238. },
  239. rankList: [],
  240. redPaper: [],
  241. productValue: [], //系统属性
  242. storeInfo: {},
  243. attrValue: '', //已选属性
  244. attrTxt: this.$t(`请选择`), //属性页面提示
  245. cartId: 0,
  246. product_id: 0,
  247. sysHeight: sysHeight,
  248. newData: {},
  249. activeRouter: '',
  250. is_diy_set: false
  251. };
  252. },
  253. computed: mapGetters(['isLogin']),
  254. onPullDownRefresh () {
  255. this.grabFlag()
  256. console.log('下拉刷新');
  257. },
  258. onLoad (options) {
  259. let that = this;
  260. if (that.isLogin == false) {
  261. toLogin();
  262. }
  263. let routes = getCurrentPages(); // 获取当前打开过的页面路由数组
  264. let curRoute = routes[routes.length - 1].route //获取当前页面路由
  265. this.activeRouter = '/' + curRoute
  266. },
  267. onShow () {
  268. this.canShow = false
  269. if (this.isLogin == true) {
  270. this.hotPage = 1;
  271. this.hostProduct = [],
  272. this.hotScroll = false,
  273. this.getHostProduct();
  274. this.loadend = false;
  275. this.page = 1;
  276. this.cartList.valid = [];
  277. this.getCartList();
  278. this.loadendInvalid = false;
  279. this.pageInvalid = 1;
  280. this.cartList.invalid = [];
  281. this.getInvalidList();
  282. this.getCartNum();
  283. this.goodsHidden = true;
  284. this.footerswitch = true;
  285. this.hostProduct = [];
  286. this.hotScroll = false;
  287. this.hotPage = 1;
  288. this.hotLimit = 10;
  289. this.cartList = {
  290. valid: [],
  291. invalid: []
  292. },
  293. this.isAllSelect = false; //全选
  294. this.selectValue = []; //选中的数据
  295. this.selectCountPrice = 0.00;
  296. this.cartCount = 0;
  297. this.isShowAuth = false;
  298. };
  299. },
  300. created () {
  301. this.userInfo = JSON.parse(this.$Cache.get("USER_INFO"));
  302. console.log(this.userInfo, this.userInfo.avatar);
  303. this.grabFlag('created')
  304. this.leaderboard()
  305. this.todayStatistics()
  306. },
  307. methods: {
  308. change (e) {
  309. this.show = e.show
  310. },
  311. goReceived () {
  312. uni.navigateTo({
  313. url: '/pages/order_addcart/wallet_received/index'
  314. })
  315. },
  316. goMissed () {
  317. uni.navigateTo({
  318. url: '/pages/order_addcart/wallet_missed/index'
  319. })
  320. },
  321. doGrab () {
  322. doGrab({
  323. type: this.activeRedPer.type
  324. }).then(res => {
  325. // if (res.code === 200) {
  326. // this.grabFlag('dograbAmountFlag')
  327. // }
  328. this.currentRedpaper = res.data
  329. this.grabAmountFlag = true
  330. })
  331. },
  332. // 授权关闭
  333. authColse: function (e) {
  334. this.isShowAuth = e;
  335. },
  336. // 修改购物车
  337. reGoCat: function () {
  338. let that = this,
  339. productSelect = that.productValue[this.attrValue];
  340. //如果有属性,没有选择,提示用户选择
  341. if (
  342. that.attr.productAttr.length &&
  343. productSelect === undefined
  344. )
  345. return that.$util.Tips({
  346. title: that.$t(`产品库存不足,请选择其它`)
  347. });
  348. let q = {
  349. id: that.cartId,
  350. product_id: that.product_id,
  351. num: that.attr.productSelect.cart_num,
  352. unique: that.attr.productSelect !== undefined ?
  353. that.attr.productSelect.unique : ""
  354. };
  355. getResetCart(q)
  356. .then(function (res) {
  357. that.attr.cartAttr = false;
  358. that.$util.Tips({
  359. title: that.$t(`添加购物车成功`),
  360. success: () => {
  361. that.loadend = false;
  362. that.page = 1;
  363. that.cartList.valid = [];
  364. that.getCartList();
  365. that.getCartNum();
  366. }
  367. });
  368. })
  369. .catch(res => {
  370. return that.$util.Tips({
  371. title: res.msg
  372. });
  373. });
  374. },
  375. onMyEvent: function () {
  376. this.$set(this.attr, 'cartAttr', false);
  377. },
  378. reElection: function (item) {
  379. this.getGoodsDetails(item)
  380. },
  381. leaderboard () {
  382. let that = this
  383. uni.showLoading({
  384. title: this.$t(`加载中`),
  385. mask: true
  386. });
  387. let postData = {
  388. flag: this.isactiveTab === 'todayRank' ? 1 : 0
  389. }
  390. leaderboard(postData).then(res => {
  391. if (res.data.length > 0) {
  392. that.$set(that, "rankList", res.data)
  393. } else {
  394. that.$set(that, "rankList", [])
  395. }
  396. uni.hideLoading();
  397. })
  398. },
  399. grabFlag (params) {
  400. grabFlag().then(res => {
  401. this.redPaper = res.data
  402. if (!params) {
  403. this.grabAmountFlag = false
  404. }
  405. if (params === 'created') {
  406. let flag = redPaper.filter((e) => {
  407. return e.flag === 0;
  408. }).length
  409. if (flag === 0) {
  410. this.show = false
  411. uni.stopPullDownRefresh();
  412. return
  413. }
  414. }
  415. this.activeRedPer = res.data[0]
  416. this.show = true
  417. uni.stopPullDownRefresh();
  418. })
  419. },
  420. todayStatistics () {
  421. uni.showLoading({
  422. title: this.$t(`加载中`),
  423. mask: true
  424. });
  425. let postData = {
  426. flag: this.isactiveTab === 'todayRank' ? 1 : 0
  427. }
  428. todayStatistics().then(res => {
  429. this.moneyObj = res.data
  430. uni.hideLoading();
  431. })
  432. },
  433. /**
  434. * 属性变动赋值
  435. *
  436. */
  437. ChangeAttr: function (res) {
  438. let productSelect = this.productValue[res];
  439. if (productSelect && productSelect.stock > 0) {
  440. this.$set(this.attr.productSelect, "image", productSelect.image);
  441. this.$set(this.attr.productSelect, "price", productSelect.price);
  442. this.$set(this.attr.productSelect, "stock", productSelect.stock);
  443. this.$set(this.attr.productSelect, "unique", productSelect.unique);
  444. this.$set(this.attr.productSelect, "cart_num", 1);
  445. this.$set(this, "attrValue", res);
  446. this.$set(this, "attrTxt", this.$t(`已选择`));
  447. } else {
  448. this.$set(this.attr.productSelect, "image", this.storeInfo.image);
  449. this.$set(this.attr.productSelect, "price", this.storeInfo.price);
  450. this.$set(this.attr.productSelect, "stock", 0);
  451. this.$set(this.attr.productSelect, "unique", "");
  452. this.$set(this.attr.productSelect, "cart_num", 0);
  453. this.$set(this, "attrValue", "");
  454. this.$set(this, "attrTxt", this.$t(`请选择`));
  455. }
  456. },
  457. /**
  458. * 默认选中属性
  459. *
  460. */
  461. DefaultSelect: function () {
  462. let productAttr = this.attr.productAttr;
  463. let value = [];
  464. for (var key in this.productValue) {
  465. if (this.productValue[key].stock > 0) {
  466. value = this.attr.productAttr.length ? key.split(",") : [];
  467. break;
  468. }
  469. }
  470. for (let i = 0; i < productAttr.length; i++) {
  471. this.$set(productAttr[i], "index", value[i]);
  472. }
  473. //sort();排序函数:数字-英文-汉字;
  474. let productSelect = this.productValue[value.sort().join(",")];
  475. if (productSelect && productAttr.length) {
  476. this.$set(
  477. this.attr.productSelect,
  478. "store_name",
  479. this.storeInfo.store_name
  480. );
  481. this.$set(this.attr.productSelect, "image", productSelect.image);
  482. this.$set(this.attr.productSelect, "price", productSelect.price);
  483. this.$set(this.attr.productSelect, "stock", productSelect.stock);
  484. this.$set(this.attr.productSelect, "unique", productSelect.unique);
  485. this.$set(this.attr.productSelect, "cart_num", 1);
  486. this.$set(this, "attrValue", value.sort().join(","));
  487. this.$set(this, "attrTxt", this.$t(`已选择`));
  488. } else if (!productSelect && productAttr.length) {
  489. this.$set(
  490. this.attr.productSelect,
  491. "store_name",
  492. this.storeInfo.store_name
  493. );
  494. this.$set(this.attr.productSelect, "image", this.storeInfo.image);
  495. this.$set(this.attr.productSelect, "price", this.storeInfo.price);
  496. this.$set(this.attr.productSelect, "stock", 0);
  497. this.$set(this.attr.productSelect, "unique", "");
  498. this.$set(this.attr.productSelect, "cart_num", 0);
  499. this.$set(this, "attrValue", "");
  500. this.$set(this, "attrTxt", this.$t(`请选择`));
  501. } else if (!productSelect && !productAttr.length) {
  502. this.$set(
  503. this.attr.productSelect,
  504. "store_name",
  505. this.storeInfo.store_name
  506. );
  507. this.$set(this.attr.productSelect, "image", this.storeInfo.image);
  508. this.$set(this.attr.productSelect, "price", this.storeInfo.price);
  509. this.$set(this.attr.productSelect, "stock", this.storeInfo.stock);
  510. this.$set(
  511. this.attr.productSelect,
  512. "unique",
  513. this.storeInfo.unique || ""
  514. );
  515. this.$set(this.attr.productSelect, "cart_num", 1);
  516. this.$set(this, "attrValue", "");
  517. this.$set(this, "attrTxt", this.$t(`请选择`));
  518. }
  519. },
  520. attrVal (val) {
  521. this.$set(this.attr.productAttr[val.indexw], 'index', this.attr.productAttr[val.indexw].attr_values[val
  522. .indexn]);
  523. },
  524. /**
  525. * 购物车数量加和数量减
  526. *
  527. */
  528. ChangeCartNum: function (changeValue) {
  529. //changeValue:是否 加|减
  530. //获取当前变动属性
  531. let productSelect = this.productValue[this.attrValue];
  532. //如果没有属性,赋值给商品默认库存
  533. if (productSelect === undefined && !this.attr.productAttr.length)
  534. productSelect = this.attr.productSelect;
  535. //无属性值即库存为0;不存在加减;
  536. if (productSelect === undefined) return;
  537. let stock = productSelect.stock || 0;
  538. let num = this.attr.productSelect;
  539. if (changeValue) {
  540. num.cart_num++;
  541. if (num.cart_num > stock) {
  542. this.$set(this.attr.productSelect, "cart_num", stock ? stock : 1);
  543. this.$set(this, "cart_num", stock ? stock : 1);
  544. }
  545. } else {
  546. num.cart_num--;
  547. if (num.cart_num < 1) {
  548. this.$set(this.attr.productSelect, "cart_num", 1);
  549. this.$set(this, "cart_num", 1);
  550. }
  551. }
  552. },
  553. /**
  554. * 购物车手动填写
  555. *
  556. */
  557. iptCartNum: function (e) {
  558. this.$set(this.attr.productSelect, 'cart_num', e);
  559. },
  560. subDel: function (event) {
  561. let that = this,
  562. selectValue = that.selectValue;
  563. if (selectValue.length > 0)
  564. cartDel(selectValue).then(res => {
  565. that.loadend = false;
  566. that.page = 1;
  567. that.cartList.valid = [];
  568. that.getCartList();
  569. that.getCartNum();
  570. });
  571. else
  572. return that.$util.Tips({
  573. title: that.$t(`请选择产品`)
  574. });
  575. },
  576. getSelectValueProductId: function () {
  577. let that = this;
  578. let validList = that.cartList.valid;
  579. let selectValue = that.selectValue;
  580. let productId = [];
  581. if (selectValue.length > 0) {
  582. for (let index in validList) {
  583. if (that.inArray(validList[index].id, selectValue)) {
  584. productId.push(validList[index].product_id);
  585. }
  586. }
  587. };
  588. return productId;
  589. },
  590. subCollect: function (event) {
  591. let that = this,
  592. selectValue = that.selectValue;
  593. if (selectValue.length > 0) {
  594. let selectValueProductId = that.getSelectValueProductId();
  595. collectAll(that.getSelectValueProductId().join(',')).then(res => {
  596. return that.$util.Tips({
  597. title: res.msg,
  598. icon: 'success'
  599. });
  600. }).catch(err => {
  601. return that.$util.Tips({
  602. title: err
  603. });
  604. });
  605. } else {
  606. return that.$util.Tips({
  607. title: that.$t(`请选择产品`)
  608. });
  609. }
  610. },
  611. subOrder (event) {
  612. console.log(event)
  613. let that = this,
  614. selectValue = that.selectValue;
  615. if (selectValue.length > 0) {
  616. uni.navigateTo({
  617. url: '/pages/goods/order_confirm/index?cartId=' + selectValue.join(',')
  618. });
  619. } else {
  620. return that.$util.Tips({
  621. title: that.$t(`请选择产品`)
  622. });
  623. }
  624. },
  625. checkboxAllChange: function (event) {
  626. let value = event.detail.value;
  627. if (value.length > 0) {
  628. this.setAllSelectValue(1)
  629. } else {
  630. this.setAllSelectValue(0)
  631. }
  632. },
  633. setAllSelectValue: function (status) {
  634. let that = this;
  635. let selectValue = [];
  636. let valid = that.cartList.valid;
  637. if (valid.length > 0) {
  638. let newValid = valid.map(item => {
  639. if (status) {
  640. if (that.footerswitch) {
  641. if (item.attrStatus) {
  642. item.checked = true;
  643. selectValue.push(item.id);
  644. } else {
  645. item.checked = false;
  646. }
  647. } else {
  648. item.checked = true;
  649. selectValue.push(item.id);
  650. }
  651. that.isAllSelect = true;
  652. } else {
  653. item.checked = false;
  654. that.isAllSelect = false;
  655. }
  656. return item;
  657. });
  658. that.$set(that.cartList, 'valid', newValid);
  659. that.selectValue = selectValue;
  660. that.switchSelect();
  661. }
  662. },
  663. checkboxChange: function (event) {
  664. let that = this;
  665. let value = event.detail.value;
  666. let valid = that.cartList.valid;
  667. let arr1 = [];
  668. let arr2 = [];
  669. let arr3 = [];
  670. let newValid = valid.map(item => {
  671. if (that.inArray(item.id, value)) {
  672. if (that.footerswitch) {
  673. if (item.attrStatus) {
  674. item.checked = true;
  675. arr1.push(item);
  676. } else {
  677. item.checked = false;
  678. }
  679. } else {
  680. item.checked = true;
  681. arr1.push(item);
  682. }
  683. } else {
  684. item.checked = false;
  685. arr2.push(item);
  686. }
  687. return item;
  688. });
  689. if (that.footerswitch) {
  690. arr3 = arr2.filter(item => !item.attrStatus);
  691. }
  692. // for (let index in valid) {
  693. // if (that.inArray(valid[index].id, value)){
  694. // if(valid[index].attrStatus){
  695. // valid[index].checked = true;
  696. // }else{
  697. // valid[index].checked = false;
  698. // }
  699. // } else {
  700. // valid[index].checked = false;
  701. // }
  702. // }
  703. that.$set(that.cartList, 'valid', newValid);
  704. // let newArr = that.cartList.valid.filter(item => item.attrStatus);
  705. that.isAllSelect = newValid.length === arr1.length + arr3.length;
  706. that.selectValue = value;
  707. that.switchSelect();
  708. },
  709. inArray: function (search, array) {
  710. for (let i in array) {
  711. if (array[i] == search) {
  712. return true;
  713. }
  714. }
  715. return false;
  716. },
  717. switchSelect: function () {
  718. let that = this;
  719. let validList = that.cartList.valid;
  720. let selectValue = that.selectValue;
  721. let selectCountPrice = 0.00;
  722. if (selectValue.length < 1) {
  723. that.selectCountPrice = selectCountPrice;
  724. } else {
  725. for (let index in validList) {
  726. if (that.inArray(validList[index].id, selectValue)) {
  727. selectCountPrice = that.$util.$h.Add(selectCountPrice, that.$util.$h.Mul(validList[index]
  728. .cart_num, validList[
  729. index].truePrice))
  730. }
  731. }
  732. that.selectCountPrice = selectCountPrice;
  733. }
  734. },
  735. /**
  736. * 购物车手动填写
  737. *
  738. */
  739. iptCartNum: function (index) {
  740. let item = this.cartList.valid[index];
  741. if (item.cart_num) {
  742. this.setCartNum(item.id, item.cart_num);
  743. }
  744. this.switchSelect();
  745. },
  746. blurInput: function (index) {
  747. let item = this.cartList.valid[index];
  748. console.log(item)
  749. if (!item.cart_num) {
  750. item.cart_num = 1;
  751. this.$set(this.cartList, 'valid', this.cartList.valid)
  752. }
  753. },
  754. subCart: function (index) {
  755. let that = this;
  756. let status = false;
  757. let item = that.cartList.valid[index];
  758. item.cart_num = Number(item.cart_num) - 1;
  759. if (item.cart_num < 1) status = true;
  760. if (item.cart_num <= 1) {
  761. item.cart_num = 1;
  762. item.numSub = true;
  763. } else {
  764. item.numSub = false;
  765. item.numAdd = false;
  766. }
  767. if (false == status) {
  768. that.setCartNum(item.id, item.cart_num, function (data) {
  769. that.cartList.valid[index] = item;
  770. that.getCartNum();
  771. that.switchSelect();
  772. });
  773. }
  774. },
  775. addCart: function (index) {
  776. let that = this;
  777. let item = that.cartList.valid[index];
  778. item.cart_num = Number(item.cart_num) + 1;
  779. let productInfo = item.productInfo;
  780. if (productInfo.hasOwnProperty('attrInfo') && item.cart_num >= item.productInfo.attrInfo.stock) {
  781. item.cart_num = item.productInfo.attrInfo.stock;
  782. item.numAdd = true;
  783. item.numSub = false;
  784. } else {
  785. item.numAdd = false;
  786. item.numSub = false;
  787. }
  788. that.setCartNum(item.id, item.cart_num, function (data) {
  789. that.cartList.valid[index] = item;
  790. that.getCartNum();
  791. that.switchSelect();
  792. });
  793. },
  794. setCartNum (cartId, cartNum, successCallback) {
  795. let that = this;
  796. changeCartNum(cartId, cartNum).then(res => {
  797. console.log(res)
  798. successCallback && successCallback(res.data);
  799. }).catch(err => {
  800. console.log(err)
  801. return that.$util.Tips({
  802. title: err
  803. });
  804. })
  805. },
  806. getCartNum: function () {
  807. let that = this;
  808. // getCartCounts().then(res => {
  809. that.cartCount = 0;
  810. this.$store.commit('indexData/setCartNum', that.cartCount > 99 ? '..' : that.cartCount)
  811. if (that.cartCount > 0) {
  812. wx.setTabBarBadge({
  813. index: 2,
  814. text: that.cartCount + ''
  815. })
  816. } else {
  817. wx.hideTabBarRedDot({
  818. index: 2
  819. })
  820. }
  821. // });
  822. },
  823. getCartData (data) {
  824. let resData = {
  825. "valid": [],
  826. "invalid": [],
  827. "deduction": {
  828. "seckill_id": 0,
  829. "bargain_id": 0,
  830. "combination_id": 0,
  831. "discount_id": 0
  832. }
  833. }
  834. this.loading = false;
  835. this.canShow = true
  836. return resData;
  837. // return new Promise((resolve, reject) => {
  838. // getCartList(data).then((res) => {
  839. // resolve(res.data);
  840. // }).catch((err) => {
  841. // this.loading = false;
  842. // this.canShow = true
  843. // this.$util.Tips({
  844. // title: err
  845. // });
  846. // })
  847. // });
  848. },
  849. async getCartList () {
  850. uni.showLoading({
  851. title: this.$t(`加载中`),
  852. mask: true
  853. });
  854. let that = this;
  855. let data = {
  856. page: that.page,
  857. limit: that.limit,
  858. status: 1
  859. }
  860. let countResData = {
  861. "count": 0,
  862. "ids": [
  863. 9671,
  864. 9670,
  865. 9669
  866. ],
  867. "sum_price": "955.00"
  868. }
  869. // getCartCounts().then(async c => {
  870. that.cartCount = countResData.count;
  871. let n = Math.ceil(countResData.ids.length / that.limit)
  872. for (let i = 0; i < n; i++) {
  873. // let cartList = await this.getCartData(data)
  874. let cartListData = {
  875. "valid": [{
  876. "id": 9671,
  877. "uid": 34391,
  878. "type": "0",
  879. "product_id": 97,
  880. "product_attr_unique": "fd6d98f3",
  881. "cart_num": 1,
  882. "add_time": 1666709939,
  883. "is_pay": 0,
  884. "is_del": 0,
  885. "is_new": 0,
  886. "combination_id": 0,
  887. "seckill_id": 0,
  888. "bargain_id": 0,
  889. "advance_id": 0,
  890. "status": 1,
  891. "productInfo": {
  892. "id": 97,
  893. "mer_id": 0,
  894. "image": "https://demo26.crmeb.net/uploads/attach/2021/11/20211113/small_0d407b8541efd8c8f87e5ac581d1421c.png",
  895. "recommend_image": "",
  896. "slider_image": [
  897. "https://demo26.crmeb.net/uploads/attach/2021/11/13/2d97c9bd7abcdb65049c97bbe9ba61d1.jpg",
  898. "https://demo26.crmeb.net/uploads/attach/2021/11/13/a48cce02122f4046193bdda67d970b55.jpg",
  899. "https://demo26.crmeb.net/uploads/attach/2021/11/13/5c4754f2b647b9e240e08f48c9889ebf.jpg",
  900. "https://demo26.crmeb.net/uploads/attach/2021/11/13/e8f6b1235f10f83d8a43bd91def20332.jpg",
  901. "https://demo26.crmeb.net/uploads/attach/2021/11/13/634a51ad34590eab005063742d086b87.jpg"
  902. ],
  903. "store_name": "仟佰家 干花花束真花手工落地高枝装饰摆件招财莲蓬插花居客厅摆设 干花组合6025【不含花瓶】 干花包",
  904. "store_info": "仟佰家 干花花束真花手工落地高枝装饰摆件招财莲蓬插花居客厅摆设 干花组合6025【不含花瓶】 干花包",
  905. "keyword": "",
  906. "bar_code": "",
  907. "cate_id": "22,24",
  908. "price": "306.00",
  909. "vip_price": "0.00",
  910. "ot_price": "299.00",
  911. "postage": "0.00",
  912. "unit_name": "件",
  913. "sort": 100,
  914. "sales": 2,
  915. "stock": 12384,
  916. "is_show": 1,
  917. "is_hot": 0,
  918. "is_benefit": 0,
  919. "is_best": 0,
  920. "is_new": 1,
  921. "is_virtual": 0,
  922. "virtual_type": 0,
  923. "add_time": 1636791973,
  924. "is_postage": 0,
  925. "is_del": 0,
  926. "mer_use": 0,
  927. "give_integral": "0.00",
  928. "cost": "258.00",
  929. "is_seckill": 0,
  930. "is_bargain": null,
  931. "is_good": 0,
  932. "is_sub": 0,
  933. "is_vip": 0,
  934. "ficti": 0,
  935. "browse": 0,
  936. "code_path": "",
  937. "soure_link": "",
  938. "temp_id": 57,
  939. "spec_type": 1,
  940. "activity": "0,1,2,3",
  941. "spu": "5310153503736",
  942. "label_id": "0",
  943. "video_link": "",
  944. "command_word": "",
  945. "recommend_list": "",
  946. "vip_product": 0,
  947. "presale": 0,
  948. "presale_start_time": 0,
  949. "presale_end_time": 0,
  950. "presale_day": 0,
  951. "logistics": "1,2",
  952. "freight": 2,
  953. "custom_form": "",
  954. "is_limit": 0,
  955. "limit_type": 0,
  956. "limit_num": 0,
  957. "express_delivery": true,
  958. "store_mention": true,
  959. "attrInfo": {
  960. "id": 967,
  961. "product_id": 97,
  962. "suk": "干花组合6025【不含花瓶】,干花包",
  963. "stock": 562,
  964. "sales": 1,
  965. "price": "306.00",
  966. "image": "https://demo26.crmeb.net/uploads/attach/2021/11/13/small_634a51ad34590eab005063742d086b87.jpg",
  967. "bar_code": "",
  968. "ot_price": "299.00",
  969. "volume": "0.00",
  970. "weight": "0.00",
  971. "brokerage": "0.00",
  972. "brokerage_two": "0.00",
  973. "type": 0,
  974. "unique": "fd6d98f3",
  975. "cost": "258.00",
  976. "quota": 0,
  977. "quota_show": 0,
  978. "vip_price": "0.00",
  979. "is_virtual": 0,
  980. "coupon_id": 0,
  981. "disk_info": ""
  982. }
  983. },
  984. "attrStatus": true,
  985. "vip_truePrice": 0,
  986. "costPrice": "258.00",
  987. "trueStock": 562,
  988. "truePrice": 306,
  989. "sum_price": "306.00",
  990. "price_type": "level",
  991. "is_valid": 1
  992. },
  993. {
  994. "id": 9670,
  995. "uid": 34391,
  996. "type": "0",
  997. "product_id": 102,
  998. "product_attr_unique": "02cce37e",
  999. "cart_num": 1,
  1000. "add_time": 1666709927,
  1001. "is_pay": 0,
  1002. "is_del": 0,
  1003. "is_new": 0,
  1004. "combination_id": 0,
  1005. "seckill_id": 0,
  1006. "bargain_id": 0,
  1007. "advance_id": 0,
  1008. "status": 1,
  1009. "productInfo": {
  1010. "id": 102,
  1011. "mer_id": 0,
  1012. "image": "https://demo26.crmeb.net/uploads/attach/2021/11/15/small_a79f5d2ea6bf0c3c11b2127332dfe2df.jpg",
  1013. "recommend_image": "",
  1014. "slider_image": [
  1015. "https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg",
  1016. "https://demo26.crmeb.net/uploads/attach/2021/11/15/7f46e98ece1920e1a4082dfc72bcd72a.jpg",
  1017. "https://demo26.crmeb.net/uploads/attach/2021/11/15/bfb275263d02ab081b8670a752f2823f.jpg",
  1018. "https://demo26.crmeb.net/uploads/attach/2021/11/15/e499a4dc489cda7b8d472cb3a3b348b7.jpg",
  1019. "https://demo26.crmeb.net/uploads/attach/2021/11/15/06fa150a47163e973bb4806a380afaab.jpg"
  1020. ],
  1021. "store_name": "索尼(SONY)WH-CH510 无线立体声耳机 学生网课 白色",
  1022. "store_info": "索尼(SONY)WH-CH510 无线立体声耳机 学生网课 白色",
  1023. "keyword": "耳机",
  1024. "bar_code": "",
  1025. "cate_id": "18,27,25",
  1026. "price": "299.00",
  1027. "vip_price": "0.00",
  1028. "ot_price": "349.00",
  1029. "postage": "0.00",
  1030. "unit_name": "件",
  1031. "sort": 0,
  1032. "sales": 3,
  1033. "stock": 297,
  1034. "is_show": 1,
  1035. "is_hot": 0,
  1036. "is_benefit": 0,
  1037. "is_best": 0,
  1038. "is_new": 0,
  1039. "is_virtual": 0,
  1040. "virtual_type": 0,
  1041. "add_time": 1636958921,
  1042. "is_postage": 0,
  1043. "is_del": 0,
  1044. "mer_use": 0,
  1045. "give_integral": "0.00",
  1046. "cost": "259.00",
  1047. "is_seckill": 0,
  1048. "is_bargain": null,
  1049. "is_good": 0,
  1050. "is_sub": 0,
  1051. "is_vip": 0,
  1052. "ficti": 0,
  1053. "browse": 0,
  1054. "code_path": "",
  1055. "soure_link": "",
  1056. "temp_id": 57,
  1057. "spec_type": 1,
  1058. "activity": "0,1,2,3",
  1059. "spu": "5757529716664",
  1060. "label_id": "0",
  1061. "video_link": "",
  1062. "command_word": "",
  1063. "recommend_list": "",
  1064. "vip_product": 0,
  1065. "presale": 0,
  1066. "presale_start_time": 0,
  1067. "presale_end_time": 0,
  1068. "presale_day": 0,
  1069. "logistics": "1,2",
  1070. "freight": 2,
  1071. "custom_form": "",
  1072. "is_limit": 0,
  1073. "limit_type": 0,
  1074. "limit_num": 0,
  1075. "express_delivery": true,
  1076. "store_mention": true,
  1077. "attrInfo": {
  1078. "id": 9,
  1079. "product_id": 102,
  1080. "suk": "黑色,CH510",
  1081. "stock": 98,
  1082. "sales": 2,
  1083. "price": "299.00",
  1084. "image": "https://demo26.crmeb.net/uploads/attach/2021/11/15/small_a79f5d2ea6bf0c3c11b2127332dfe2df.jpg",
  1085. "bar_code": "",
  1086. "ot_price": "349.00",
  1087. "volume": "0.00",
  1088. "weight": "0.00",
  1089. "brokerage": "0.00",
  1090. "brokerage_two": "0.00",
  1091. "type": 0,
  1092. "unique": "02cce37e",
  1093. "cost": "259.00",
  1094. "quota": 0,
  1095. "quota_show": 0,
  1096. "vip_price": "0.00",
  1097. "is_virtual": 0,
  1098. "coupon_id": 0,
  1099. "disk_info": ""
  1100. }
  1101. },
  1102. "attrStatus": true,
  1103. "vip_truePrice": 0,
  1104. "costPrice": "259.00",
  1105. "trueStock": 98,
  1106. "truePrice": 299,
  1107. "sum_price": "299.00",
  1108. "price_type": "level",
  1109. "is_valid": 1
  1110. },
  1111. {
  1112. "id": 9669,
  1113. "uid": 34391,
  1114. "type": "0",
  1115. "product_id": 89,
  1116. "product_attr_unique": "89807c67",
  1117. "cart_num": 1,
  1118. "add_time": 1666709911,
  1119. "is_pay": 0,
  1120. "is_del": 0,
  1121. "is_new": 0,
  1122. "combination_id": 0,
  1123. "seckill_id": 0,
  1124. "bargain_id": 0,
  1125. "advance_id": 0,
  1126. "status": 1,
  1127. "productInfo": {
  1128. "id": 89,
  1129. "mer_id": 0,
  1130. "image": "https://demo26.crmeb.net/uploads/attach/2021/11/20211113/small_2fbe723632427b0768df24c4f23c6cad.png",
  1131. "recommend_image": "",
  1132. "slider_image": [
  1133. "https://demo26.crmeb.net/uploads/attach/2021/11/20211113/2fbe723632427b0768df24c4f23c6cad.png",
  1134. "https://demo26.crmeb.net/uploads/attach/2021/11/20211113/64d188477292aa4ae2df8da7e63aca79.png"
  1135. ],
  1136. "store_name": "家居梵高系列联名款饭盒袋大容量手拎保温实用方便 星月夜饭盒袋",
  1137. "store_info": "",
  1138. "keyword": "家居梵高系列联名款饭盒袋大容量手拎保温实用方便 星月夜饭盒袋",
  1139. "bar_code": "",
  1140. "cate_id": "35",
  1141. "price": "350.00",
  1142. "vip_price": "0.00",
  1143. "ot_price": "300.00",
  1144. "postage": "0.00",
  1145. "unit_name": "件",
  1146. "sort": 553,
  1147. "sales": 19,
  1148. "stock": 185,
  1149. "is_show": 1,
  1150. "is_hot": 1,
  1151. "is_benefit": 0,
  1152. "is_best": 0,
  1153. "is_new": 0,
  1154. "is_virtual": 0,
  1155. "virtual_type": 0,
  1156. "add_time": 1636777038,
  1157. "is_postage": 0,
  1158. "is_del": 0,
  1159. "mer_use": 0,
  1160. "give_integral": "0.00",
  1161. "cost": "300.00",
  1162. "is_seckill": 0,
  1163. "is_bargain": null,
  1164. "is_good": 1,
  1165. "is_sub": 0,
  1166. "is_vip": 0,
  1167. "ficti": 0,
  1168. "browse": 0,
  1169. "code_path": "",
  1170. "soure_link": "",
  1171. "temp_id": 0,
  1172. "spec_type": 1,
  1173. "activity": "0,1,2,3",
  1174. "spu": "1015710267816",
  1175. "label_id": "",
  1176. "video_link": "",
  1177. "command_word": "",
  1178. "recommend_list": "",
  1179. "vip_product": 0,
  1180. "presale": 0,
  1181. "presale_start_time": 0,
  1182. "presale_end_time": 0,
  1183. "presale_day": 0,
  1184. "logistics": "1,2",
  1185. "freight": 2,
  1186. "custom_form": "[]",
  1187. "is_limit": 0,
  1188. "limit_type": 0,
  1189. "limit_num": 0,
  1190. "express_delivery": true,
  1191. "store_mention": true,
  1192. "attrInfo": {
  1193. "id": 1017,
  1194. "product_id": 89,
  1195. "suk": "梵高自画像饭盒",
  1196. "stock": 88,
  1197. "sales": 8,
  1198. "price": "350.00",
  1199. "image": "https://demo26.crmeb.net/uploads/attach/2021/11/20211113/small_2fbe723632427b0768df24c4f23c6cad.png",
  1200. "bar_code": "",
  1201. "ot_price": "300.00",
  1202. "volume": "0.00",
  1203. "weight": "0.00",
  1204. "brokerage": "0.00",
  1205. "brokerage_two": "0.00",
  1206. "type": 0,
  1207. "unique": "89807c67",
  1208. "cost": "300.00",
  1209. "quota": 0,
  1210. "quota_show": 0,
  1211. "vip_price": "0.00",
  1212. "is_virtual": 0,
  1213. "coupon_id": 0,
  1214. "disk_info": ""
  1215. }
  1216. },
  1217. "attrStatus": true,
  1218. "vip_truePrice": 0,
  1219. "costPrice": "300.00",
  1220. "trueStock": 88,
  1221. "truePrice": 350,
  1222. "sum_price": "350.00",
  1223. "price_type": "level",
  1224. "is_valid": 1
  1225. }
  1226. ],
  1227. "invalid": [],
  1228. "deduction": {
  1229. "seckill_id": 0,
  1230. "bargain_id": 0,
  1231. "combination_id": 0,
  1232. "discount_id": 0
  1233. }
  1234. }
  1235. let cartList = cartListData
  1236. let valid = cartList.valid
  1237. let validList = that.$util.SplitArray(valid, that.cartList.valid);
  1238. let numSub = [{
  1239. numSub: true
  1240. }, {
  1241. numSub: false
  1242. }];
  1243. let numAdd = [{
  1244. numAdd: true
  1245. }, {
  1246. numAdd: false
  1247. }],
  1248. selectValue = [];
  1249. if (validList.length > 0) {
  1250. for (let index in validList) {
  1251. if (validList[index].cart_num == 1) {
  1252. validList[index].numSub = true;
  1253. } else {
  1254. validList[index].numSub = false;
  1255. }
  1256. let productInfo = validList[index].productInfo;
  1257. if (productInfo.hasOwnProperty('attrInfo') && validList[index].cart_num ==
  1258. validList[index].productInfo.attrInfo
  1259. .stock) {
  1260. validList[index].numAdd = true;
  1261. } else if (validList[index].cart_num == validList[index].productInfo
  1262. .stock) {
  1263. validList[index].numAdd = true;
  1264. } else {
  1265. validList[index].numAdd = false;
  1266. }
  1267. if (validList[index].attrStatus) {
  1268. validList[index].checked = true;
  1269. selectValue.push(validList[index].id);
  1270. } else {
  1271. validList[index].checked = false;
  1272. }
  1273. }
  1274. }
  1275. that.$set(that.cartList, 'valid', validList);
  1276. data.page = that.page + 1;
  1277. // that.goodsHidden = cartList.valid.length <= 0 ? false : true;
  1278. that.selectValue = selectValue;
  1279. let newArr = validList.filter(item => item.attrStatus);
  1280. that.isAllSelect = newArr.length == selectValue.length && newArr.length;
  1281. that.switchSelect();
  1282. }
  1283. that.loading = false;
  1284. this.canShow = true
  1285. uni.hideLoading();
  1286. // });
  1287. },
  1288. getInvalidList: function () {
  1289. let that = this;
  1290. if (this.loadendInvalid) return false;
  1291. if (this.loadingInvalid) return false;
  1292. let data = {
  1293. page: that.pageInvalid,
  1294. limit: that.limitInvalid,
  1295. status: 0
  1296. }
  1297. let resData = {
  1298. "valid": [],
  1299. "invalid": [],
  1300. "deduction": {
  1301. "seckill_id": 0,
  1302. "bargain_id": 0,
  1303. "combination_id": 0,
  1304. "discount_id": 0
  1305. }
  1306. }
  1307. // getCartList(data).then(res => {
  1308. let cartList = resData,
  1309. invalid = cartList.invalid,
  1310. loadendInvalid = invalid.length < that.limitInvalid;
  1311. let invalidList = that.$util.SplitArray(invalid, that.cartList.invalid);
  1312. that.$set(that.cartList, 'invalid', invalidList);
  1313. that.loadendInvalid = loadendInvalid;
  1314. that.loadTitleInvalid = loadendInvalid ? that.$t(`我也是有底线的`) : that.$t(`加载更多`);
  1315. that.pageInvalid = that.pageInvalid + 1;
  1316. that.loadingInvalid = false;
  1317. // }).catch(res => {
  1318. // that.loadingInvalid = false;
  1319. // that.loadTitleInvalid = that.$t(`加载更多`);
  1320. // })
  1321. },
  1322. getHostProduct: function () {
  1323. let that = this;
  1324. if (that.hotScroll) return
  1325. that.hotPage++
  1326. that.hotScroll = hot_res.length < that.hotLimit
  1327. that.hostProduct = that.hostProduct.concat(hot_res)
  1328. // getProductHot(
  1329. // that.hotPage,
  1330. // that.hotLimit,
  1331. // ).then(res => {
  1332. // that.hotPage++
  1333. // that.hotScroll = res.data.length < that.hotLimit
  1334. // that.hostProduct = that.hostProduct.concat(res.data)
  1335. // });
  1336. },
  1337. goodsOpen: function () {
  1338. let that = this;
  1339. that.goodsHidden = !that.goodsHidden;
  1340. },
  1341. goRouter (item) {
  1342. var pages = getCurrentPages();
  1343. var page = (pages[pages.length - 1]).$page.fullPath;
  1344. if (item.link == page) return
  1345. uni.switchTab({
  1346. url: item.link,
  1347. fail (err) {
  1348. uni.redirectTo({
  1349. url: item.link
  1350. })
  1351. }
  1352. })
  1353. },
  1354. manage: function () {
  1355. let that = this;
  1356. that.footerswitch = !that.footerswitch;
  1357. let arr1 = [];
  1358. let arr2 = [];
  1359. let newValid = that.cartList.valid.map(item => {
  1360. if (that.footerswitch) {
  1361. if (item.attrStatus) {
  1362. if (item.checked) {
  1363. arr1.push(item.id);
  1364. }
  1365. } else {
  1366. item.checked = false;
  1367. arr2.push(item);
  1368. }
  1369. } else {
  1370. if (item.checked) {
  1371. arr1.push(item.id);
  1372. }
  1373. }
  1374. return item;
  1375. });
  1376. that.cartList.valid = newValid;
  1377. if (that.footerswitch) {
  1378. that.isAllSelect = newValid.length === arr1.length + arr2.length;
  1379. } else {
  1380. that.isAllSelect = newValid.length === arr1.length;
  1381. }
  1382. that.selectValue = arr1;
  1383. that.switchSelect();
  1384. },
  1385. unsetCart: function () {
  1386. let that = this,
  1387. ids = [];
  1388. for (let i = 0, len = that.cartList.invalid.length; i < len; i++) {
  1389. ids.push(that.cartList.invalid[i].id);
  1390. }
  1391. cartDel(ids).then(res => {
  1392. that.$util.Tips({
  1393. title: that.$t(`清除成功`)
  1394. });
  1395. that.$set(that.cartList, 'invalid', []);
  1396. that.getCartNum();
  1397. }).catch(res => {
  1398. });
  1399. }
  1400. },
  1401. onReachBottom () {
  1402. let that = this;
  1403. if (that.loadend) {
  1404. that.getInvalidList();
  1405. }
  1406. if (that.cartList.valid.length == 0 && that.cartList.invalid.length == 0) {
  1407. that.getHostProduct();
  1408. }
  1409. }
  1410. }
  1411. </script>
  1412. <style scoped lang="scss">
  1413. .order_addcart {
  1414. padding: 20rpx;
  1415. }
  1416. .rank-list {
  1417. background: white;
  1418. margin-top: 20rpx;
  1419. padding-top: 20rpx;
  1420. padding-bottom: 10rpx;
  1421. height: 600rpx;
  1422. overflow: auto;
  1423. .rank-list-item {
  1424. margin: 20rpx;
  1425. margin-bottom: 40rpx;
  1426. width: calc(100% - 40rpx);
  1427. height: 50rpx;
  1428. display: flex;
  1429. image {
  1430. width: 50rpx;
  1431. height: 50rpx;
  1432. margin-right: 20rpx;
  1433. margin-left: 10rpx;
  1434. }
  1435. .nuber {
  1436. font-size: 18rpx;
  1437. margin-right: 20rpx;
  1438. line-height: 0rpx;
  1439. }
  1440. .mosaic {
  1441. font-size: 18rpx;
  1442. margin-right: 20rpx;
  1443. color: #999999;
  1444. line-height: 0rpx;
  1445. }
  1446. .litem-info {
  1447. text-align: right;
  1448. flex-grow: 1;
  1449. font-size: 24rpx;
  1450. line-height: 50rpx;
  1451. margin-right: 20rpx;
  1452. color: #666666;
  1453. }
  1454. .balance {
  1455. line-height: 50rpx;
  1456. color: #eb4c63;
  1457. }
  1458. }
  1459. }
  1460. .loop {
  1461. background: url("http://wine.gzzzyd.com/wx/order_addcart/hongbaochi.png")
  1462. no-repeat;
  1463. width: 100%;
  1464. height: 250rpx;
  1465. background-size: 100% 100%;
  1466. position: relative;
  1467. .loop-title {
  1468. padding: 20rpx;
  1469. padding-left: 35rpx;
  1470. font-size: 32rpx;
  1471. }
  1472. .loop-count {
  1473. text-align: center;
  1474. line-height: 97rpx;
  1475. font-size: 48rpx;
  1476. color: #eb4c63;
  1477. width: 420rpx;
  1478. height: 97rpx;
  1479. background: #ffffff;
  1480. border-radius: 23px;
  1481. border: 1px solid #eb4c63;
  1482. position: absolute;
  1483. left: 50%;
  1484. top: 47%;
  1485. transform: translateX(-50%);
  1486. }
  1487. // image {
  1488. // width: 100%;
  1489. // }
  1490. }
  1491. .tab-area {
  1492. margin-top: 20rpx;
  1493. display: flex;
  1494. flex-wrap: nowrap;
  1495. justify-content: space-between;
  1496. line-height: 90rpx;
  1497. text-align: center;
  1498. .base-tab {
  1499. width: 48%;
  1500. height: 90rpx;
  1501. }
  1502. .tab-area-active1 {
  1503. background: url("http://wine.gzzzyd.com/wx/order_addcart/tab1.png")
  1504. no-repeat;
  1505. background-size: 340rpx 120rpx;
  1506. }
  1507. .tab-area-active2 {
  1508. background: url("http://wine.gzzzyd.com/wx/order_addcart/tab2.png")
  1509. no-repeat;
  1510. background-size: 340rpx 120rpx;
  1511. }
  1512. }
  1513. .order_addcart-header-area {
  1514. display: flex;
  1515. .received {
  1516. width: 405rpx;
  1517. height: 175rpx;
  1518. padding: 20rpx;
  1519. margin-bottom: 20rpx;
  1520. margin-right: 20rpx;
  1521. background-color: #fff;
  1522. border-radius: 20rpx;
  1523. overflow: hidden;
  1524. position: relative;
  1525. display: flex;
  1526. .pictrue {
  1527. display: flex;
  1528. align-items: center;
  1529. image {
  1530. width: 98rpx;
  1531. height: 98rpx;
  1532. }
  1533. margin-right: 20rpx;
  1534. }
  1535. .text-info {
  1536. display: flex;
  1537. flex-direction: column;
  1538. justify-content: center;
  1539. color: #6eb03a;
  1540. .received-count {
  1541. font-size: 38rpx;
  1542. margin-bottom: 10rpx;
  1543. letter-spacing: 2px;
  1544. }
  1545. .received-info {
  1546. font-size: 28rpx;
  1547. }
  1548. }
  1549. }
  1550. .loss {
  1551. flex-grow: 1;
  1552. height: 175rpx;
  1553. padding: 20rpx;
  1554. margin-bottom: 20rpx;
  1555. background-color: #fff;
  1556. border-radius: 20rpx;
  1557. overflow: hidden;
  1558. position: relative;
  1559. display: flex;
  1560. .text-info {
  1561. width: 100%;
  1562. display: flex;
  1563. flex-direction: column;
  1564. justify-content: center;
  1565. text-align: center;
  1566. color: #d08d5b;
  1567. .received-count {
  1568. font-size: 38rpx;
  1569. margin-bottom: 10rpx;
  1570. letter-spacing: 2px;
  1571. }
  1572. .received-info {
  1573. font-size: 28rpx;
  1574. }
  1575. }
  1576. }
  1577. }
  1578. .warp {
  1579. display: flex;
  1580. align-items: center;
  1581. justify-content: center;
  1582. height: 100%;
  1583. }
  1584. .rect {
  1585. position: relative;
  1586. width: 700rpx;
  1587. height: 950rpx;
  1588. background: url("http://wine.gzzzyd.com/wx/order_addcart/hongbao_bg.png")
  1589. no-repeat;
  1590. background-size: 700rpx 950rpx;
  1591. .cover-img {
  1592. margin-top: 80rpx;
  1593. position: relative;
  1594. left: 50%;
  1595. transform: translate(-50%, 0%);
  1596. width: 120rpx;
  1597. height: 120rpx;
  1598. border-radius: 50%;
  1599. overflow: hidden;
  1600. .avatar {
  1601. position: absolute;
  1602. z-index: 9999;
  1603. width: 120rpx;
  1604. height: 120rpx;
  1605. }
  1606. }
  1607. .h-info {
  1608. position: relative;
  1609. text-align: center;
  1610. padding: 10rpx;
  1611. height: 390rpx;
  1612. color: white;
  1613. .paper_list {
  1614. margin: 20rpx;
  1615. text {
  1616. margin-right: 10rpx;
  1617. }
  1618. }
  1619. .grabAmount_count {
  1620. margin-top: 80rpx;
  1621. color: rgb(244, 180, 53);
  1622. &:nth-child(1) {
  1623. font-size: 32rpx;
  1624. }
  1625. }
  1626. }
  1627. .op-img {
  1628. cursor: pointer;
  1629. position: relative;
  1630. left: 50%;
  1631. transform: translate(-50%, 0rpx);
  1632. width: 150rpx;
  1633. height: 150rpx;
  1634. }
  1635. .b-info {
  1636. font-size: 22rpx;
  1637. width: 100%;
  1638. text-align: center;
  1639. color: rgb(244, 180, 53);
  1640. margin-bottom: 30rpx;
  1641. }
  1642. .b-box {
  1643. margin: 0 auto;
  1644. color: rgb(244, 180, 53);
  1645. border-radius: 50rpx;
  1646. width: 55%;
  1647. font-size: 22rpx;
  1648. height: 40rpx;
  1649. line-height: 40rpx;
  1650. background: rgb(196, 40, 62);
  1651. text-align: center;
  1652. }
  1653. }
  1654. .acitiveRedper {
  1655. color: rgb(244, 180, 53);
  1656. text-decoration: underline;
  1657. }
  1658. </style>