Set.php 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  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. $prize_id = Dever::input('prize_id');
  17. $reward_give_id = Dever::input('reward_give_id');
  18. $total = Dever::input('total', 1);
  19. $col = 'role_id';
  20. $table = 'setting/role_goods';
  21. $value = $id;
  22. if ($mid) {
  23. $col = 'mid';
  24. $table = 'agent/member_goods';
  25. $value = $mid;
  26. } elseif ($prize_id) {
  27. $col = 'prize_id';
  28. $table = 'setting/prize_goods';
  29. $value = $prize_id;
  30. } elseif ($reward_give_id) {
  31. $col = 'reward_give_id';
  32. $table = 'setting/role_reward_goods';
  33. $value = $reward_give_id;
  34. } elseif ($order_id) {
  35. $check = Dever::db('agent/order_goods')->find(array('order_id' => $order_id));
  36. if ($check) {
  37. $col = 'order_id';
  38. $table = 'agent/order_goods';
  39. $value = $order_id;
  40. }
  41. }
  42. $data = array();
  43. if (!$prize_id) {
  44. $prize = Dever::db('setting/prize')->select();
  45. if ($prize) {
  46. $data[0]['id'] = -1;
  47. $data[0]['name'] = '名额';
  48. $data[0]['price'] = 0;
  49. $data[0]['price_type'] = 2;
  50. $data[0]['select'] = 2;
  51. $data[0]['del'] = 1;
  52. $data[0]['total'] = 0;
  53. foreach ($prize as $k => $v) {
  54. $data[0]['children'][$k]['id'] = $v['id'] . '_3';
  55. $data[0]['children'][$k]['name'] = $v['name'];
  56. $data[0]['children'][$k]['price'] = $v['price'];
  57. $data[0]['children'][$k]['price_type'] = 2;
  58. $data[0]['children'][$k]['select'] = 2;
  59. $data[0]['children'][$k]['del'] = 1;
  60. $data[0]['children'][$k]['total'] = 0;
  61. $data[0]['children'][$k]['end'] = true;
  62. $info = Dever::db($table)->find(array('type' => 3, 'type_id' => $v['id'], $col => $value));
  63. if ($info) {
  64. if ($table == 'agent/member_goods') {
  65. $info['num'] = $info['total_num'] - $info['sell_num'];
  66. //$info['num'] = $info['total_num'];
  67. }
  68. $data[0]['children'][$k]['select'] = 1;
  69. $data[0]['children'][$k]['total'] = $info['num'] * $total;
  70. }
  71. }
  72. }
  73. }
  74. $card = Dever::db('card/info')->getDataByType(array('type_id' => '1,4,6'));
  75. if ($card) {
  76. $data[1]['id'] = -2;
  77. $data[1]['name'] = '厨人E卡';
  78. $data[1]['price'] = 0;
  79. $data[1]['price_type'] = 2;
  80. $data[1]['select'] = 2;
  81. $data[1]['del'] = 1;
  82. $data[1]['total'] = 0;
  83. foreach ($card as $k => $v) {
  84. $data[1]['children'][$k]['id'] = $v['id'] . '_2';
  85. $data[1]['children'][$k]['name'] = $v['name'];
  86. if ($v['create_type'] == 3) {
  87. if ($mid) {
  88. $data[1]['children'][$k]['name'] .= '(自定义面值卡-已发卡无法更改价值)';
  89. } else {
  90. $data[1]['children'][$k]['name'] .= '(自定义面值卡-数量即百分比)';
  91. }
  92. }
  93. $data[1]['children'][$k]['price'] = $v['value'];
  94. $data[1]['children'][$k]['price_type'] = 2;
  95. $data[1]['children'][$k]['select'] = 2;
  96. $data[1]['children'][$k]['del'] = 1;
  97. $data[1]['children'][$k]['total'] = 0;
  98. $data[1]['children'][$k]['end'] = true;
  99. if ($table == 'agent/member_goods') {
  100. $info = Dever::db($table)->select(array('type' => 2, 'type_id' => $v['id'], $col => $value));
  101. if ($info) {
  102. $num = 0;
  103. $data[1]['children'][$k]['price'] = 0;
  104. $sku_id = array();
  105. foreach ($info as $k1 => $v1) {
  106. $num += ($v1['total_num']-$v1['sell_num']);
  107. if ($v1['sku_id'] > 0) {
  108. $code = Dever::db('card/code')->find($v1['sku_id']);
  109. $data[1]['children'][$k]['price'] += $code['total_cash'];
  110. $sku_id[] = $v1['sku_id'];
  111. }
  112. }
  113. $data[1]['children'][$k]['id'] = $v['id'] . '-' . implode('i', $sku_id) . '_2';;
  114. $data[1]['children'][$k]['select'] = 1;
  115. $data[1]['children'][$k]['total'] = $num;
  116. }
  117. } else {
  118. $info = Dever::db($table)->find(array('type' => 2, 'type_id' => $v['id'], $col => $value));
  119. if ($info) {
  120. $data[1]['children'][$k]['select'] = 1;
  121. $data[1]['children'][$k]['total'] = $info['num'] * $total;
  122. }
  123. }
  124. }
  125. }
  126. $data = array_merge($data, Dever::load('goods/lib/set.getGoodsList', $value, $col, $table, 'type_id'));
  127. return Dever::outDiy($data);
  128. }
  129. # 获取商品列表
  130. public function goods_api()
  131. {
  132. $id = Dever::input('id', 1);
  133. return $this->getData($id);
  134. }
  135. # 设置商品
  136. public function home_api()
  137. {
  138. $data = array();
  139. $data['link'] = Dever::decode(Dever::input('refer'));
  140. $data['role_id'] = Dever::input('id', 1);
  141. $data['give'] = Dever::input('give', 1);
  142. $data['host'] = Dever::url('lib/set.home?id=' . $data['role_id'], 'agent');
  143. $data['url'] = Dever::url('lib/set.goods?id=' . $data['role_id'] . '&give=' . $data['give'], 'agent');
  144. $data['search'] = Dever::db('setting/role_goods')->config['set']['give'];
  145. $data['submit'] = Dever::url('lib/set.action_commit?json=1', 'agent');
  146. return Dever::render('setGoods', $data);
  147. }
  148. # 设置生产能力
  149. public function action_commit_api()
  150. {
  151. $goods = Dever::input('goods');
  152. if (!$goods) {
  153. Dever::alert('请传入商品');
  154. }
  155. $goods = Dever::json_decode($goods);
  156. $role_id = Dever::input('role_id');
  157. $give = Dever::input('give');
  158. $where['option_role_id'] = $role_id;
  159. $where['option_give'] = $give;
  160. $where['set_state'] = 2;
  161. Dever::db('setting/role_goods')->updates($where);
  162. foreach ($goods as $k => $v) {
  163. $type = 1;
  164. $type_id = $k;
  165. $sku_id = -1;
  166. if (strstr($k, '_')) {
  167. $temp = explode('_', $k);
  168. $type_id = $temp[0];
  169. $type = $temp[1];
  170. } elseif (strstr($k, '-')) {
  171. $temp = explode('-', $k);
  172. $type_id = $temp[0];
  173. $sku_id = $temp[1];
  174. }
  175. if ($v['total'] <= 0) {
  176. continue;
  177. }
  178. $w = array();
  179. $w['type'] = $type;
  180. $w['type_id'] = $type_id;
  181. $w['role_id'] = $role_id;
  182. $w['sku_id'] = $sku_id;
  183. $w['give'] = $give;
  184. $info = Dever::db('setting/role_goods')->one($w);
  185. if ($v['del'] == 2) {
  186. if ($info) {
  187. Dever::db('setting/role_goods')->update(array('where_id' => $info['id'], 'state' => 2));
  188. }
  189. } else {
  190. $w['num'] = $v['total'];
  191. if (!$info) {
  192. Dever::db('setting/role_goods')->insert($w);
  193. } else {
  194. $w['where_id'] = $info['id'];
  195. $w['state'] = 1;
  196. Dever::db('setting/role_goods')->update($w);
  197. }
  198. }
  199. }
  200. return 'reload';
  201. }
  202. }