Set.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <?php
  2. namespace Store\Lib;
  3. use Dever;
  4. # 批量设置商品
  5. class Set
  6. {
  7. # 导出订单
  8. public function __construct()
  9. {
  10. Dever::load('manage/auth.init');
  11. }
  12. # 获取门店
  13. public function search_api()
  14. {
  15. return Dever::search('store/info');
  16. }
  17. # 获取商品列表
  18. public function goods_api()
  19. {
  20. $store_id = Dever::input('store_id', 1);
  21. return Dever::outDiy(Dever::load('goods/lib/set')->getGoodsList($store_id, 'store_id', 'store/goods_sku'));
  22. }
  23. # 设置生产能力
  24. public function home_api()
  25. {
  26. $data = array();
  27. $data['store_id'] = Dever::input('id', 1);
  28. $data['host'] = Dever::url('lib/set.home', 'store');
  29. $data['url'] = Dever::url('lib/set.goods?store_id=' . $data['store_id'], 'store');
  30. $data['search'] = Dever::url('lib/set.search?yes='.$data['store_id'].'&json=1', 'store');
  31. $data['submit'] = Dever::url('lib/set.action_cmmmit?json=1', 'store');
  32. return Dever::render('setGoodsNum', $data);
  33. }
  34. # 设置生产能力
  35. public function action_cmmmit_api()
  36. {
  37. $goods = Dever::input('goods');
  38. if (!$goods) {
  39. Dever::alert('请传入商品');
  40. }
  41. $goods = Dever::json_decode($goods);
  42. $store_id = Dever::input('store_id');
  43. foreach ($goods as $k => $v) {
  44. $temp = explode('-', $k);
  45. $goods_id = $temp[0];
  46. if (isset($temp[1])) {
  47. $sku_id = $temp[1];
  48. } else {
  49. $sku_id = -1;
  50. }
  51. if ($v['num'] < 0) {
  52. continue;
  53. }
  54. if ($v['del'] == 2) {
  55. $w = array();
  56. $w['goods_id'] = $goods_id;
  57. $w['store_id'] = $store_id;
  58. $w['sku_id'] = $sku_id;
  59. $sku_info = Dever::db('store/goods_sku')->one($w);
  60. if ($sku_info) {
  61. Dever::db('store/goods_sku')->update(array('where_id' => $sku_info['id'], 'state' => 2));
  62. }
  63. unset($w['sku_id']);
  64. $t = $w;
  65. $t['state'] = 1;
  66. $total = Dever::db('store/goods_sku')->total($t);
  67. if ($total <= 0) {
  68. $info = Dever::db('store/goods')->one($w);
  69. if ($info) {
  70. Dever::db('store/goods')->update(array('where_id' => $info['id'], 'state' => 2));
  71. }
  72. }
  73. } else {
  74. $w = array();
  75. $w['goods_id'] = $goods_id;
  76. $w['store_id'] = $store_id;
  77. $info = Dever::db('store/goods')->one($w);
  78. $w['total_num'] = $v['num'];
  79. if (!$info) {
  80. Dever::db('store/goods')->insert($w);
  81. } else {
  82. $w['total_num'] += $info['total_num'];
  83. $w['where_id'] = $info['id'];
  84. $w['state'] = 1;
  85. Dever::db('store/goods')->update($w);
  86. }
  87. $w = array();
  88. $w['goods_id'] = $goods_id;
  89. $w['store_id'] = $store_id;
  90. $w['sku_id'] = $sku_id;
  91. $info = Dever::db('store/goods_sku')->one($w);
  92. $w['total_num'] = $v['num'];
  93. if (!$info) {
  94. Dever::db('store/goods_sku')->insert($w);
  95. } else {
  96. $w['total_num'] += $info['total_num'];
  97. $w['where_id'] = $info['id'];
  98. $w['state'] = 1;
  99. Dever::db('store/goods_sku')->update($w);
  100. }
  101. }
  102. }
  103. return Dever::url('project/database/list&project=store&&table=info&menu=store&search_option_state=1', 'manage');
  104. }
  105. }