goods.blade.php 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613
  1. @extends('layouts.base')
  2. @section('title', "代客下单")
  3. @section('content')
  4. <style>
  5. .rightlist #app .rightlist-head{line-height:50px;padding:15px 0;}
  6. .rightlist #app{margin-left:30px;}
  7. .rightlist #app .el-breadcrumb{padding:30px 0;font-size:16px;}
  8. /* .el-form-item__label{padding-right:30px;} */
  9. .tip{font-size:12px;color:#999;font-weight:500}
  10. .rightlist-head-con{padding-right:20px;font-size:16px;color:#888;}
  11. /* .rightlist-head-con{float:left;padding-right:20px;font-size:16px;color:#888;} */
  12. .el-tag{font-weight:700;font-size:15px;margin-bottom:30px;}
  13. .el-icon-edit{font-size:16px;padding:0 15px;color:#409EFF;cursor: pointer;}
  14. /* 滑块选择小白点 */
  15. .el-switch.is-checked .el-switch__core::after {left: 100%;margin-left: -17px;}
  16. .el-switch__core::after {content: "";position: absolute;top: 1px;left: 1px;border-radius: 100%;transition: all .3s;width: 16px;height: 16px;background-color: #fff;}
  17. .tip1{font-size:12px;color:red;font-weight:500}
  18. [v-cloak]{
  19. display:none;
  20. }
  21. /* 计数器样式 */
  22. .el-input-number__decrease, .el-input-number__increase {width: 25px;}
  23. .el-input-number .el-input__inner {padding-left: 0px;padding-right: 0px;}
  24. </style>
  25. <div class="rightlist">
  26. <div id="app" v-cloak v-loading="loading">
  27. <el-breadcrumb separator-class="el-icon-arrow-right">
  28. <el-breadcrumb-item><a href="{{ yzWebFullUrl('plugin.help-user-buying.admin.index.index') }}">返回选择</a></el-breadcrumb-item>
  29. {{--<el-breadcrumb-item>[[store.id==0?'平台自营':store.store_name]]</el-breadcrumb-item>--}}
  30. <el-breadcrumb-item v-html="title"></el-breadcrumb-item>
  31. </el-breadcrumb>
  32. <el-form :inline="true" :model="search_form" ref="search_form">
  33. <el-form-item>
  34. <el-input v-model="search_form.goods_name" placeholder="请输入商品名称"></el-input>
  35. </el-form-item>
  36. <el-form-item>
  37. <el-select v-model="search_form.id_v1" placeholder="请选择一级分类" clearable @change="changeV1()">
  38. <el-option v-for="item in category_list" :key="item.id" :label="item.name" :value="item.id"></el-option>
  39. </el-select>
  40. </el-form-item>
  41. <el-form-item>
  42. <el-select v-model="search_form.id_v2" placeholder="请选择二级分类" clearable @change="changeV2()">
  43. <el-option v-for="item in category_list_v2" :key="item.id" :label="item.name" :value="item.id"></el-option>
  44. </el-select>
  45. </el-form-item>
  46. <el-form-item>
  47. <el-select v-model="search_form.id_v3" placeholder="请选择三级分类" clearable v-if="category_level==3">
  48. <el-option v-for="item in category_list_v3" :key="item.id" :label="item.name" :value="item.id"></el-option>
  49. </el-select>
  50. </el-form-item>
  51. <el-form-item style="float:right;text-align:right;">
  52. <el-button type="success" icon="el-icon-search" @click="search(1)">搜索</el-button>
  53. </el-form-item>
  54. </el-form>
  55. <el-row :gutter="50">
  56. <!-- left -->
  57. <el-col :span="12">
  58. <!-- 表格start -->
  59. <el-table :data="list" style="width: 100%" max-height="500" v-loading="all_loading">
  60. <el-table-column prop="id" label="ID" width="80" align="center"></el-table-column>
  61. <el-table-column label="商品" min-width="180">
  62. <template slot-scope="scope">
  63. <div style="overflow:hidden;white-space:nowrap;text-overflow:ellipsis;">
  64. <img :src="scope.row.thumb" style="width:40px;height:40px;">
  65. [[scope.row.title]]
  66. </div>
  67. </template>
  68. </el-table-column>
  69. <el-table-column prop="price" label="价格" max-width="120" align="center"></el-table-column>
  70. <el-table-column label="库存" prop="stock" max-width="120" align="center"></el-table-column>
  71. <el-table-column label="选择" width="80" align="center">
  72. <template slot-scope="scope">
  73. <el-button size="mini" @click="choose(scope.row)">选择</el-button>
  74. </template>
  75. </el-table-column>
  76. </el-table>
  77. <el-col :span="24" align="right" migra style="padding:15px 5% 15px 0" v-loading="loading">
  78. <el-pagination background layout="prev, pager, next" @current-change="currentChange" :total="total"
  79. :page-size="per_size" :current-page="current_page"></el-pagination>
  80. </el-col>
  81. <!-- 表格end -->
  82. </el-col>
  83. <!-- right -->
  84. <el-col :span="12">
  85. <div style="background:#f9f9f9;padding:15px 10px;font-weight:900;border:1px solid #e9e9e9;">
  86. 订单信息
  87. <el-button type="danger" size="small" style="margin-left:20px" @click="delAll">清空购物车</el-button>
  88. </div>
  89. <!-- 表格start -->
  90. <el-table :data="cart_list" style="width: 100%;border:1px solid #e9e9e9" v-loading="loading" max-height="500">
  91. <el-table-column prop="id" label="商品名称" min-width="150" align="center">
  92. <template slot-scope="scope">
  93. <div style="overflow:hidden;white-space:nowrap;text-overflow:ellipsis;">
  94. <div>[[scope.row.title]]</div>
  95. <div v-if="scope.row.option_title" style="color:#999;font-size:12px;">[ [[scope.row.option_title]] ]</div>
  96. </div>
  97. </template>
  98. </el-table-column>
  99. <el-table-column prop="price" label="价格" max-width="120" align="center"></el-table-column>
  100. <el-table-column prop="digitization_name" label="数量" width="120" align="center">
  101. <template slot-scope="scope">
  102. <el-input-number v-model="scope.row.num" :step="1" :min="0" style="width:110px;" @change="changeNum(scope.$index)"></el-input-number>
  103. </template>
  104. </el-table-column>
  105. <el-table-column label="金额" prop="total" max-width="120" align="center"></el-table-column>
  106. <el-table-column label="操作" align="center">
  107. <template slot-scope="scope">
  108. <el-button size="mini" type="danger" width="80" @click="del(scope.row)">删除</el-button>
  109. </template>
  110. </el-table-column>
  111. </el-table>
  112. <!-- 表格end -->
  113. <div style="background:#f9f9f9;padding:15px 10px;font-weight:900;border:1px solid #e9e9e9;">
  114. <span>(不包含运费)</span>
  115. <span>合计:<span style="color:red">[[total_money]]</span>元</span>
  116. <el-button type="primary" size="small" style="margin-left:20px" @click="openMember">结算</el-button>
  117. </div>
  118. </el-col>
  119. </el-row>
  120. <!-- 选择会员弹出框 -->
  121. <el-dialog title="选择会员" :visible.sync="is_choose_member" width="60%">
  122. <div>
  123. <div v-if="member.uid" style="font-weight:900;margin-bottom:30px;">
  124. <div>已选会员:</div>
  125. <div style="float:left;width:120px">
  126. <img :src="member.avatar_image" alt="" style="width:100px;height:100px">
  127. </div>
  128. <div style="display:inline-block;">
  129. <div>[[member.nickname]]</div>
  130. <div>[[member.mobile]]</div>
  131. <el-button type="danger" size="small" @click="delMember">清除选择</el-button>
  132. </div>
  133. </div>
  134. <el-form>
  135. <el-form-item label="" prop="">
  136. <el-input v-model="member_info" placeholder="请输入粉丝昵称/姓名/手机号" style="width:90%;"></el-input>
  137. <el-button type="success" icon="el-icon-search" @click="searchMember()" v-loading="table_loading">搜索</el-button>
  138. </el-form-item>
  139. </el-form>
  140. <template>
  141. <!-- 表格start -->
  142. <el-table :data="member_list" style="width: 100%;" max-height="500" v-if="member_list.length>0" v-loading="table_loading">
  143. <el-table-column label="头像" align="center">
  144. <template slot-scope="scope">
  145. <img :src="scope.row.avatar_image" alt="" style="width:30px;height:30px;">
  146. </template>
  147. </el-table-column>
  148. <el-table-column prop="nickname" label="姓名" min-width="120" align="center"></el-table-column>
  149. <el-table-column prop="mobile" label="手机号" min-width="120" align="center"></el-table-column>
  150. <el-table-column label="操作" min-width="80" align="center">
  151. <template slot-scope="scope">
  152. <el-button @click="chooseMember(scope.row)" size="small">选择</el-button>
  153. </template>
  154. </el-table-column>
  155. </el-table>
  156. <!-- 表格end -->
  157. </template>
  158. </div>
  159. <span slot="footer" class="dialog-footer">
  160. <el-button @click="is_choose_member = false">取 消</el-button>
  161. <el-button type="primary" @click="confirm">确 定</el-button>
  162. </span>
  163. </el-dialog>
  164. <!-- 选择规格弹出框 -->
  165. <el-dialog title="选择商品规格" :visible.sync="is_option" width="60%">
  166. <div>
  167. <div v-for="(item,index) in option_list" :key="index">
  168. <h5 style="border-bottom:1px solid #ddd;font-weight:900;">
  169. [[item.title]]
  170. </h5>
  171. <div style="display:inline-block;margin:5px;" >
  172. <el-radio-group v-model="status[index]" v-for="(item1,index1) in item.specitem" :key="index1" style="margin-bottom: 30px;">
  173. <el-radio-button :label="item1.id">[[item1.title]]</el-radio-button>
  174. </el-radio-group>
  175. </div>
  176. </div>
  177. </div>
  178. <span slot="footer" class="dialog-footer">
  179. <el-button @click="is_option = false">取 消</el-button>
  180. <el-button type="primary" @click="confirmOption">确 定</el-button>
  181. </span>
  182. </el-dialog>
  183. </div>
  184. <script>
  185. var app = new Vue({
  186. el:"#app",
  187. delimiters: ['[[', ']]'],
  188. data() {
  189. let goods_url = '{!! $goods_url !!}';
  190. let category_level = {!! $category_level !!};
  191. console.log(category_level)
  192. let category_list = {!! $category_list !!};
  193. console.log(category_list)
  194. let owner_id = {!! $owner_id !!};
  195. let order_type = {!! $order_type !!};
  196. let title = '{!! $title!!}';
  197. // console.log(store);
  198. return{
  199. title:title,
  200. type:1,
  201. loading:false,
  202. table_loading:false,
  203. all_loading:false,
  204. order_type:order_type,
  205. owner_id:owner_id,//门店数据
  206. total_money:"0",//总金额
  207. is_exist:0,//商品是否已存在购物车
  208. is_choose_member:false,//选择会员弹出框
  209. is_option:false,//选择规格弹出框
  210. option_list:[],//规格列表
  211. choose_row:{},//选择商品的信息
  212. status:[],//选择的商品规格的值
  213. goods_url:goods_url,//搜索商品接口
  214. member_info:"",
  215. member:{},//选择的会员信息回显
  216. member_list:[],//会员列表
  217. search_form:{
  218. id_v1:"",
  219. id_v2:"",
  220. id_v3:"",
  221. },
  222. category_level:category_level,//分类等级
  223. category_list:category_list,
  224. category_list_v2:[],
  225. category_list_v3:[],
  226. list:[],
  227. cart_list:[],
  228. rules:{},
  229. //分页
  230. total:0,
  231. per_size:0,
  232. current_page:0,
  233. rules:{},
  234. }
  235. },
  236. created() {
  237. document.onkeydown = function(){
  238. if(window.event.keyCode == 13) {
  239. window.event.keyCode = 0;
  240. window.event.returnValue = false;
  241. }
  242. };
  243. let json = {search:{owner_id:this.owner_id}};
  244. this.getGoodsList(json);
  245. },
  246. methods: {
  247. // 获得商品列表
  248. getGoodsList(json) {
  249. var that = this;
  250. that.all_loading = true;
  251. that.$http.post(this.goods_url,json).then(response => {
  252. console.log(response);
  253. if(response.data.result==1){
  254. console.log(response);
  255. this.list = response.data.data.data;
  256. this.total = response.data.data.total;
  257. this.current_page = response.data.data.current_page;
  258. this.per_size = response.data.data.per_page;
  259. that.all_loading = false;
  260. }
  261. else{
  262. that.$message.error(response.data.msg);
  263. that.all_loading = false;
  264. }
  265. }),function(res){
  266. console.log(res);
  267. that.all_loading = false;
  268. };
  269. },
  270. // 选择商品
  271. choose(row) {
  272. this.is_exist = 0;
  273. this.choose_row = row;
  274. // 如果商品有规格
  275. if(row.has_option == 1){
  276. this.status = [];//初始化规格选择状态
  277. this.is_option = true;
  278. this.option_list = row.has_many_specs;
  279. }
  280. else {
  281. this.cart_list.some((item,index) =>{
  282. if(item.id == row.id){
  283. this.is_exist = 1;
  284. item.num++;
  285. this.changeNum(index);
  286. this.countTotalPrice();
  287. return true;
  288. }
  289. })
  290. if(this.is_exist==1){//如果购物车已存在此商品或商品规格
  291. return false;
  292. }
  293. this.pushCart(row)
  294. console.log(this.cart_list)
  295. this.countTotalPrice();
  296. }
  297. },
  298. // 加入购物车
  299. pushCart(row) {
  300. this.cart_list.push(
  301. {
  302. id:row.id,
  303. num:1,
  304. total:row.price,
  305. price:row.price,
  306. thumb:row.thumb,
  307. title:row.title,
  308. option_id:0,//规格id
  309. }
  310. );
  311. },
  312. // 改变数量
  313. changeNum(index) {
  314. var that = this;
  315. console.log(index)
  316. if(this.cart_list[index].num < 1) {
  317. this.del(index);
  318. return false;
  319. }
  320. that.$http.post("{!! yzWebUrl('plugin.help-user-buying.admin.index.goods-increase') !!}",{'id':this.cart_list[index].id, 'num':this.cart_list[index].num,'option_id':this.cart_list[index].option_id}).then(response => {
  321. console.log(response);
  322. if(response.data.result==1){
  323. console.log(response);
  324. that.all_loading = false;
  325. if(response.data.data.code==1){
  326. that.$message.error("超过库存");
  327. this.cart_list[index].num = response.data.data.num;
  328. }
  329. }
  330. else{
  331. that.$message.error(response.data.msg);
  332. that.all_loading = false;
  333. this.cart_list[index].num--;
  334. }
  335. }),function(res){
  336. console.log(res);
  337. that.all_loading = false;
  338. };
  339. this.cart_list[index].total = this.cart_list[index].num * this.cart_list[index].price;
  340. this.countTotalPrice();
  341. },
  342. // 删除
  343. del(index) {
  344. this.$confirm('确定删除吗', '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {
  345. // this.delGoods(index);
  346. this.cart_list.splice(index,1);
  347. this.countTotalPrice();
  348. }).catch(() => {
  349. this.cart_list[index].num++;
  350. this.$message({type: 'info',message: '已取消删除'});
  351. });
  352. },
  353. // 清空购物车
  354. delAll() {
  355. this.$confirm('确定清空购物车吗', '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {
  356. // this.delGoods(index);
  357. this.cart_list = []
  358. this.countTotalPrice();
  359. }).catch(() => {
  360. this.$message({type: 'info',message: '已取消操作'});
  361. });
  362. },
  363. // 打开会员弹出框
  364. openMember(json) {
  365. var that = this;
  366. if(this.cart_list.length<=0) {
  367. this.$message.error("请选择下单商品!");
  368. return false;
  369. }
  370. that.is_choose_member = true;
  371. // that.searchMember('{}');
  372. },
  373. // 搜索会员
  374. searchMember(json) {
  375. var that = this;
  376. that.is_choose_member = true;
  377. that.table_loading = true;
  378. that.$http.post("{!! yzWebFullUrl('plugin.help-user-buying.admin.index.getSearchMember') !!}",{keyword:this.member_info}).then(response => {
  379. console.log(response);
  380. if(response.data.result==1){
  381. console.log(response);
  382. this.member_list = response.data.data;
  383. that.table_loading = false;
  384. }
  385. else{
  386. that.$message.error(response.data);
  387. that.table_loading = false;
  388. }
  389. }),function(res){
  390. console.log(res);
  391. that.table_loading = false;
  392. };
  393. },
  394. // 选择会员
  395. chooseMember(row) {
  396. this.member = row;
  397. },
  398. // 确认选择会员
  399. confirm() {
  400. // 判断是否选择了会员
  401. if(!this.member.uid){
  402. this.$message.error("请选择会员")
  403. return false;
  404. }
  405. console.log(this.cart_list);
  406. let new_arr = [];
  407. // let dispatch_type_id: 1
  408. this.cart_list.forEach((item,index) => {
  409. new_arr.push({
  410. goods_id:item.id,
  411. total:item.num,
  412. option_id:item.option_id,
  413. })
  414. });
  415. console.log()
  416. // let store_name = ""
  417. // if(this.title){
  418. // store_name = this.store.store_name
  419. // }
  420. let data = {
  421. uid:this.member.uid,
  422. goods:new_arr,
  423. owner_id:this.owner_id,
  424. order_type:this.order_type,
  425. title:this.title,
  426. }
  427. console.log(data)
  428. {{--window.location.href="{!! yzWebFullUrl('plugin.help-user-buying.admin.index.set-member-id',['data' => '']) !!}"+JSON.stringify(data);--}}
  429. this.$http.post("{!! yzWebFullUrl('plugin.help-user-buying.admin.index.set-member-id') !!}",{data:JSON.stringify(data)}).then(response => {
  430. console.log(response,123);
  431. if(response.data.msg == "该类型订单无配送方式,无法正常下单"){
  432. this.$message({
  433. message: response.data.msg,
  434. type: 'error'
  435. });
  436. location.reload();
  437. return
  438. }
  439. window.location.href="{!! yzWebFullUrl('plugin.help-user-buying.admin.index.set-member-id',['data' => '']) !!}"+JSON.stringify(data);
  440. }),function(res){
  441. console.log(res);
  442. };
  443. this.is_choose_member = false;
  444. },
  445. // 清除选择会员
  446. delMember() {
  447. this.member = {};
  448. },
  449. // 确认选择规格
  450. confirmOption() {
  451. // 判断是否所有规格都已经选择
  452. for(let i=0;i<this.option_list.length;i++) {
  453. if(!this.status[i]){
  454. this.$message.error("请选择完整规格信息")
  455. return false;
  456. }
  457. }
  458. // 拼接id
  459. let id = this.status.join("_");
  460. //重新排序,处理后台返回的规格拼接id没规律问题
  461. console.log(this.permute(this.status));
  462. let arr_ids = this.permute(this.status);
  463. let str_ids = [];
  464. for(let i=0;i<arr_ids.length;i++) {
  465. str_ids[i] = arr_ids[i].join("_");
  466. }
  467. // 判断选中的规格是否已存在购物车
  468. for(let i=0;i<str_ids.length;i++) {
  469. this.cart_list.some((item,index) =>{
  470. if(item.specs == str_ids[i]){
  471. console.log(id)
  472. this.is_exist = 1;
  473. item.num++;
  474. this.changeNum(index);
  475. this.countTotalPrice();
  476. return true;
  477. }
  478. })
  479. }
  480. if(this.is_exist == 1) {
  481. this.is_option = false;
  482. return false;
  483. }
  484. // 加入购物车
  485. for(let i=0;i<this.choose_row.has_many_options.length;i++){
  486. for(let j=0;j<str_ids.length;j++) {
  487. if(str_ids[j]==this.choose_row.has_many_options[i].specs){
  488. this.cart_list.push({
  489. id:this.choose_row.has_many_options[i].goods_id,
  490. specs:this.choose_row.has_many_options[i].specs,
  491. option_id:this.choose_row.has_many_options[i].id,//规格id
  492. title:this.choose_row.title,
  493. option_title:this.choose_row.has_many_options[i].title,
  494. thumb:this.choose_row.thumb,
  495. num:1,
  496. total:this.choose_row.has_many_options[i].product_price,
  497. price:this.choose_row.has_many_options[i].product_price,
  498. })
  499. this.is_option = false;
  500. break;
  501. }
  502. }
  503. }
  504. this.countTotalPrice();
  505. console.log(this.cart_list)
  506. },
  507. // 分页
  508. currentChange(page) {
  509. var that = this;
  510. // let json = {page:page};
  511. that.search(page);
  512. },
  513. // 一级分类改变
  514. changeV1(){
  515. this.search_form.id_v2 = "";
  516. this.search_form.id_v3 = "";
  517. this.category_list_v2 = [];
  518. this.category_list_v3 = [];
  519. this.category_list.find(item => {
  520. if(item.id == this.search_form.id_v1) {
  521. this.category_list_v2 = item.childrens;
  522. }
  523. });
  524. },
  525. // 二级分类改变
  526. changeV2(){
  527. this.search_form.id_v3 = "";
  528. this.category_list_v3 = [];
  529. if(this.category_level==3) {
  530. this.category_list_v2.find(item => {
  531. if(item.id == this.search_form.id_v2) {
  532. this.category_list_v3 = item.childrens;
  533. }
  534. })
  535. }
  536. },
  537. // 搜索
  538. search(page) {
  539. var that = this;
  540. console.log(that.search_form)
  541. var arr = [];
  542. if(this.search_form.id_v1){
  543. arr.push(this.search_form.id_v1)
  544. }
  545. if(this.search_form.id_v2){
  546. arr.push(this.search_form.id_v2)
  547. }
  548. if(this.search_form.id_v3){
  549. arr.push(this.search_form.id_v3)
  550. }
  551. let str;
  552. let json;
  553. if(arr.length<=0) {
  554. str = "";
  555. json = {page:page,search:{keyword:this.search_form.goods_name,owner_id:this.owner_id}};
  556. }
  557. else{
  558. str = arr.join(",");
  559. json = {page:page,search:{category:str,keyword:this.search_form.goods_name,owner_id:this.owner_id}};
  560. }
  561. that.getGoodsList(json);
  562. },
  563. //计算总价格&总数
  564. countTotalPrice() {
  565. this.total_money = 0.0; //初始化
  566. for (var i = 0; i < this.cart_list.length; i++) {
  567. this.total_money += this.cart_list[i].price * this.cart_list[i].num;
  568. }
  569. this.total_money = Number(this.total_money.toString().match(/^\d+(?:\.\d{0,2})?/));
  570. },
  571. // 数组全排序
  572. permute(arr){
  573. var rst=[],cur=[]
  574. function fn(arr){
  575. var ch
  576. for(var i=0;i<arr.length;i++){
  577. ch=arr.splice(i,1)[0]
  578. cur.push(ch)
  579. if(arr.length==0){
  580. rst.push(cur.slice())
  581. }
  582. fn(arr)
  583. arr.splice(i,0,ch)
  584. cur.pop()
  585. }
  586. return rst
  587. }
  588. return fn(arr)
  589. }
  590. },
  591. })
  592. </script>
  593. @endsection