Order_set.php 6.1 KB

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