cartList_body.html 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338
  1. <!DOCTYPE html>
  2. <html class="">
  3. <!--STATUS OK-->
  4. <head>
  5. <meta name="referrer" content="always" />
  6. <meta charset='utf-8' />
  7. <meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no" />
  8. <meta http-equiv="x-dns-prefetch-control" content="on">
  9. <meta name="description" content="">
  10. <meta name="format-detection" content="telephone=no" />
  11. <link rel="stylesheet" type="text/css" href="css/vant-ui.css" />
  12. <link rel="stylesheet" type="text/css" href="css/iconfont.css">
  13. <link rel="stylesheet" type="text/css" href="css/main.css" />
  14. <script src="js/vue.js"></script>
  15. <script src="js/vant-ui.js"></script>
  16. <script src="js/main.js"></script>
  17. <title></title>
  18. </head>
  19. <style>
  20. .zmq-flex {
  21. display: flex;
  22. position: fixed;
  23. width: 100%;
  24. height: 1rem;
  25. background-color: #fff;
  26. left: 0;
  27. bottom: 0;
  28. z-index: 2222;
  29. justify-content: space-between;
  30. padding-left: .2rem;
  31. }
  32. .allcheck {
  33. font-size: .3rem;
  34. line-height: 1rem;
  35. margin-left: -2.8rem;
  36. }
  37. .zmq-downOrder {
  38. width: 2rem;
  39. height: 1rem;
  40. background-color: #005AA9;
  41. color: #fff;
  42. float: right;
  43. line-height: 1rem;
  44. text-align: center;
  45. font-size: .3rem;
  46. }
  47. </style>
  48. <body>
  49. <div id="app" v-cloak>
  50. <div class="pageView gouwuche">
  51. <div class="gouwucheBackground" style="padding-bottom:.5rem">
  52. <div class="cardGouwuche" v-show="list.length > 0">
  53. <div class="item flex jlr a-center" v-for="(item,index) in list">
  54. <van-checkbox v-model="item.checked" style="z-index : 2222" v-on:change="getTotalMoney">
  55. </van-checkbox>
  56. <div class="flex jlr a-center" style="flex: 1; padding-left: 0.3rem;">
  57. <div class="image"><img src="img/tire.png">
  58. </div>
  59. <div class="infos flex col jlr">
  60. <div class="flex a-center jlr">
  61. <h2>{{ item.maktx }}</h2>
  62. <van-icon name="delete" size="0.3rem" v-on:click="delCarMatax(item.id)"></van-icon>
  63. </div>
  64. <div class="setp flex jlr">
  65. <div class="left flex a-center j-center" v-on:click="minusSign(index,0)">
  66. -
  67. </div>
  68. <div class="value flex a-center j-center">
  69. {{item.purchaseNumber ? item.purchaseNumber : 0}}
  70. </div>
  71. <div class="right flex a-center j-center" v-on:click="minusSign(index,1)">
  72. +
  73. </div>
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. <!-- <div class="cardFooter flex a-center jlr">
  79. <h4>优惠劵</h4>
  80. <div class="flex a-center gouwuquan">
  81. 20元优惠卷 <i class="iconfont icon-right"></i>
  82. </div>
  83. </div>-->
  84. </div>
  85. <div v-show="list.length == 0" style="text-align:center">
  86. <img src="./image/noData.png" style="margin:2rem auto" />
  87. </div>
  88. </div>
  89. </div>
  90. <!-- 购物车 价格全选 -->
  91. <div class="zmq-flex">
  92. <van-checkbox v-model="allCheck" v-on:click="changeAllCheck"></van-checkbox>
  93. <p class="allcheck">
  94. 全选
  95. </p>
  96. <div style="display: flex;line-height: 1rem;padding-left: .1rem">
  97. <div class="zmq-downOrder" v-on:click="downOrder">
  98. 立即下单
  99. </div>
  100. </div>
  101. </div>
  102. </div>
  103. </body>
  104. <script type="text/javascript" src="../script/api.js"></script>
  105. <script type="text/javascript" src="../script/httpRequest.js"></script>
  106. <script type="text/javascript" src="../script/vue_plugins.js"></script>
  107. <script type="text/javascript">
  108. apiready = function () {
  109. new Vue({
  110. el: '#app',
  111. data: {
  112. list: [],
  113. startTimeShow: false,
  114. startCurrentDate: new Date(),
  115. cartList: [], // 购物车详情
  116. allCheck: false, // 全选
  117. totalCount: 0, // 总价
  118. checked: false,
  119. },
  120. watch: {
  121. // "allCheck" : function(nw, ow) {
  122. // if (nw == false) {
  123. // this.list.map(function(cart, index) {
  124. // cart.checked = false;
  125. // })
  126. // this.totalCount = 0;
  127. // } else {
  128. // this.list.map(function(cart, index) {
  129. // cart.checked = true;
  130. // })
  131. // }
  132. // },
  133. },
  134. methods: {
  135. init: function () {
  136. this.userId = $api.getStorage('userid');
  137. this.status = $api.getStorage('status');
  138. this.getCarList();
  139. },
  140. // 获取购物车列表
  141. getCarList: function () {
  142. var url = "getCarListU", _this = this, data = {
  143. "storeId": this.userId,
  144. "url": "json",
  145. "type": "body"
  146. };
  147. this.$post(url, data, function (ret) {
  148. if (ret.code == 0 || ret.code == '0') {
  149. ret.data.map(function (store, index) {
  150. store.checked = false;
  151. })
  152. _this.list = ret.data;
  153. }
  154. })
  155. },
  156. // 控制数量
  157. minusSign: function (index, type) {
  158. var number = this.list[index].purchaseNumber ? this.list[index].purchaseNumber : 0;
  159. if (type == 0) {
  160. // -
  161. if (number > 1) {
  162. this.$set(this.list[index], "purchaseNumber", (parseInt(number) - 1));
  163. } else {
  164. this.list[index].purchaseNumber = 1;
  165. this.showToast("最少购买1件")
  166. }
  167. } else {
  168. this.$set(this.list[index], "purchaseNumber", (parseInt(number) + 1));
  169. }
  170. this.getTotalMoney();
  171. var data = {
  172. "url": "json",
  173. "type": "body",
  174. "id": this.list[index].id,
  175. "purchaseNumber": this.list[index].purchaseNumber
  176. }
  177. _this = this,
  178. url = "updateCarNum";
  179. this.$post(url, data, function (ret) { })
  180. },
  181. // 下单
  182. downOrder: function () {
  183. var count = 0, price = 0, hasChoose = new Array();
  184. this.list.map(function (cart, index) {
  185. if (cart.checked == true) {
  186. price = price + (parseInt(cart.purchaseNumber) ? parseInt(cart.purchaseNumber) : 0) * 1;
  187. count = count + (parseInt(cart.purchaseNumber) ? parseInt(cart.purchaseNumber) : 0);
  188. hasChoose.push({
  189. "id": cart.id,
  190. "storeId": cart.storeId,
  191. "purchaseNumber": cart.purchaseNumber,
  192. "cartType": cart.cartType,
  193. "kunnr": cart.kunnr,
  194. "matnr": cart.matnr,
  195. "maktx": cart.maktx,
  196. "brand": cart.brand,
  197. "spec": cart.spec,
  198. "pattern": cart.pattern
  199. });
  200. }
  201. })
  202. if (hasChoose.length == 0) {
  203. api.toast({ msg: '至少选择一件商品' });
  204. return;
  205. }
  206. if (this.status == 3) {
  207. api.alert({
  208. title: '系统提示',
  209. msg: '门店已冻结,请找相关业务经理解冻!',
  210. }, function (ret, err) {
  211. });
  212. return;
  213. }
  214. var data = {
  215. "retailerId": this.userId,
  216. "amount": count,
  217. "orderType": "0",
  218. "bizCartDtoList": hasChoose,
  219. "type": "body",
  220. "url": "json"
  221. }, _this = this, url = "downOrderU";
  222. this.$post(url, data, function (ret) {
  223. if (ret.code == 0 || ret.code == '0') {
  224. if (!ret.message) {
  225. api.toast({
  226. msg: '下单成功'
  227. });
  228. api.sendEvent({
  229. name: 'refushCarList',
  230. });
  231. var msg = {
  232. id: ret.msg
  233. }
  234. _this.getCarList();
  235. setTimeout(function () {
  236. _this.goWin("orderInfo", "orderInfo_win.html", msg);
  237. }, 200);
  238. } else {
  239. api.toast({
  240. msg: ret.message
  241. });
  242. }
  243. }
  244. })
  245. },
  246. // 控制购物车对应商品数量
  247. openTimer: function () {
  248. this.startTimeShow = true
  249. },
  250. startConfirm: function (e) {
  251. this.startTimeShow = false
  252. },
  253. /**
  254. * 控制算出购物车的总金额
  255. */
  256. getTotalMoney: function () {
  257. var totalCount = 0;
  258. var isok = true;
  259. this.list.map(function (cart, index) {
  260. if (cart.checked == true) {
  261. totalCount = totalCount + (parseInt(cart.purchaseNumber) ? parseInt(cart.purchaseNumber) : 0) * 1;
  262. } else {
  263. isok = false;
  264. }
  265. })
  266. if (isok == true) {
  267. this.allCheck = true;
  268. } else {
  269. this.allCheck = false;
  270. }
  271. this.totalCount = totalCount;
  272. },
  273. /**
  274. * 全选改变
  275. */
  276. changeAllCheck: function () {
  277. if (this.allCheck == false) {
  278. this.list.map(function (cart, index) {
  279. cart.checked = false;
  280. })
  281. this.totalCount = 0;
  282. } else {
  283. this.list.map(function (cart, index) {
  284. cart.checked = true;
  285. })
  286. }
  287. },
  288. /**
  289. * 删除购物车中的物料
  290. */
  291. delCarMatax: function (id) {
  292. var url = "delCarMataxU", _this = this;
  293. var data = {
  294. "id": id,
  295. "url": "json",
  296. "type": "body"
  297. }
  298. this.$post(url, data, function (ret) {
  299. if (ret.code == 0 || ret.code == '0') {
  300. api.toast({
  301. msg: '删除成功',
  302. });
  303. api.sendEvent({
  304. name: 'refushCarList',
  305. });
  306. setTimeout(function () {
  307. _this.getCarList();
  308. }, 500)
  309. }
  310. })
  311. }
  312. },
  313. filters: {
  314. timer: function (v) {
  315. if (v) {
  316. var y = v.getFullYear()
  317. var m = v.getMonth() + 1
  318. var d = v.getDate()
  319. return y + '-' + m + '-' + d
  320. } else {
  321. return '请选择'
  322. }
  323. }
  324. },
  325. mounted: function () {
  326. this.init();
  327. }
  328. })
  329. }
  330. </script>
  331. </html>