Member_set.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. <?php
  2. namespace Agent\Lib;
  3. use Dever;
  4. # 批量设置商品
  5. class Member_set
  6. {
  7. public function __construct()
  8. {
  9. Dever::load('manage/auth.init');
  10. }
  11. # 获取商品列表
  12. public function goods_api()
  13. {
  14. $mid = Dever::input('mid');
  15. $col = 'mid';
  16. $table = 'agent/member_goods';
  17. $value = $mid;
  18. $data = array();
  19. /*
  20. $prize = Dever::db('setting/role_goods')->config['set']['prize'];
  21. $data[0]['id'] = -1;
  22. $data[0]['name'] = '名额';
  23. $data[0]['price'] = 0;
  24. $data[0]['price_type'] = 2;
  25. $data[0]['select'] = 2;
  26. $data[0]['del'] = 1;
  27. $data[0]['total'] = 0;
  28. foreach ($prize as $k => $v) {
  29. $data[0]['children'][$k-1]['id'] = $k . '_3';
  30. $data[0]['children'][$k-1]['name'] = $v;
  31. $data[0]['children'][$k-1]['price'] = 0;
  32. $data[0]['children'][$k-1]['price_type'] = 2;
  33. $data[0]['children'][$k-1]['select'] = 2;
  34. $data[0]['children'][$k-1]['del'] = 1;
  35. $data[0]['children'][$k-1]['total'] = 0;
  36. $data[0]['children'][$k-1]['end'] = true;
  37. $info = Dever::db($table)->find(array('type' => 3, 'type_id' => $k, $col => $value));
  38. if ($info) {
  39. $data[0]['children'][$k-1]['select'] = 1;
  40. $data[0]['children'][$k-1]['total'] = $info['num'];
  41. }
  42. }
  43. $card = Dever::db('card/info')->select(array('status' => 1));
  44. if ($card) {
  45. $data[1]['id'] = -2;
  46. $data[1]['name'] = '厨人E卡';
  47. $data[1]['price'] = 0;
  48. $data[1]['price_type'] = 2;
  49. $data[1]['select'] = 2;
  50. $data[1]['del'] = 1;
  51. $data[1]['total'] = 0;
  52. foreach ($card as $k => $v) {
  53. $data[1]['children'][$k]['id'] = $v['id'] . '_2';
  54. $data[1]['children'][$k]['name'] = $v['name'];
  55. $data[1]['children'][$k]['price'] = $v['price'];
  56. $data[1]['children'][$k]['price_type'] = 2;
  57. $data[1]['children'][$k]['select'] = 2;
  58. $data[1]['children'][$k]['del'] = 1;
  59. $data[1]['children'][$k]['total'] = 0;
  60. $data[1]['children'][$k]['end'] = true;
  61. $info = Dever::db($table)->find(array('type' => 2, 'type_id' => $k, $col => $value));
  62. if ($info) {
  63. $data[1]['children'][$k]['select'] = 1;
  64. $data[1]['children'][$k]['total'] = $info['num'];
  65. }
  66. }
  67. }*/
  68. $data = array_merge($data, Dever::load('goods/lib/set.getGoodsList', $value, $col, $table, 'type_id'));
  69. return Dever::outDiy($data);
  70. }
  71. # 设置商品
  72. public function home_api()
  73. {
  74. $data = array();
  75. $data['mid'] = Dever::input('mid');
  76. $data['host'] = Dever::url('lib/member_set.home?mid=' . $data['mid'], 'agent');
  77. $data['url'] = Dever::url('lib/member_set.goods?mid=' . $data['mid'], 'agent');
  78. $data['submit'] = Dever::url('lib/member_set.action_cmmmit?json=1', 'agent');
  79. return Dever::render('setMemberGoods', $data);
  80. }
  81. # 设置生产能力
  82. public function action_cmmmit_api()
  83. {
  84. $goods = Dever::input('goods');
  85. if (!$goods) {
  86. Dever::alert('请传入商品');
  87. }
  88. $goods = Dever::json_decode($goods);
  89. $mid = Dever::input('mid');
  90. $desc = Dever::input('desc');
  91. $where['option_mid'] = $mid;
  92. $where['set_state'] = 2;
  93. Dever::db('agent/member_goods')->updates($where);
  94. foreach ($goods as $k => $v) {
  95. $type = 1;
  96. $type_id = $k;
  97. $sku_id = -1;
  98. if (strstr($k, '_')) {
  99. $temp = explode('_', $k);
  100. $type_id = $temp[0];
  101. $type = $temp[1];
  102. } elseif (strstr($k, '-')) {
  103. $temp = explode('-', $k);
  104. $type_id = $temp[0];
  105. $sku_id = $temp[1];
  106. }
  107. if ($v['total'] <= 0) {
  108. continue;
  109. }
  110. $w = array();
  111. $w['type'] = $type;
  112. $w['type_id'] = $type_id;
  113. $w['sku_id'] = $sku_id;
  114. $w['mid'] = $mid;
  115. $info = Dever::db('agent/member_goods')->one($w);
  116. if ($v['del'] == 2) {
  117. if ($info) {
  118. Dever::db('agent/member_goods')->update(array('where_id' => $info['id'], 'state' => 2));
  119. }
  120. } else {
  121. $w['total_num'] = $v['total'];
  122. if (!$info) {
  123. $state = Dever::db('agent/member_goods')->insert($w);
  124. if ($state) {
  125. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], $v['total'], 0, $w['total_num'], $desc);
  126. }
  127. } else {
  128. $w['where_id'] = $info['id'];
  129. $w['state'] = 1;
  130. $state = Dever::db('agent/member_goods')->update($w);
  131. $num = $w['total_num']-$info['total_num'];
  132. if ($state && $num > 0) {
  133. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], $num, $info['total_num'], $w['total_num'], $desc);
  134. }
  135. }
  136. }
  137. # 记录日志
  138. }
  139. return Dever::url('project/database/list&table=member_goods&project=agent&search_option_mid='.$mid, 'manage');
  140. }
  141. # 记录日志
  142. public function log($mid, $parent_order_num, $type, $type_id, $sku_id, $num, $pnum, $fnum, $desc = '')
  143. {
  144. $data['mid'] = $mid;
  145. $data['parent_order_num'] = $parent_order_num;
  146. $data['type'] = $type;
  147. $data['type_id'] = $type_id;
  148. $data['sku_id'] = $sku_id;
  149. $data['num'] = $num;
  150. $data['pnum'] = $pnum;
  151. $data['fnum'] = $fnum;
  152. $data['desc'] = $desc;
  153. $data['order_num'] = $this->getOrderId();
  154. $id = Dever::db('agent/member_goods_log')->insert($data);
  155. return $id;
  156. }
  157. /**
  158. * 生成日志订单号
  159. *
  160. * @return mixed
  161. */
  162. public function getOrderId()
  163. {
  164. $where['order_num'] = Dever::order('QY');
  165. $state = Dever::db('agent/member_goods_log')->one($where);
  166. if (!$state) {
  167. return $where['order_num'];
  168. } else {
  169. return $this->getOrderId();
  170. }
  171. }
  172. }