Set.php 6.5 KB

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