Order_set.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  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. return Dever::load('agent/lib/set')->getData($id);
  16. }
  17. # 设置商品
  18. public function home_api()
  19. {
  20. $data = array();
  21. $data['total'] = Dever::input('total', 1);
  22. $data['order_id'] = Dever::input('order_id');
  23. $data['role_id'] = Dever::input('role_id', 1);
  24. $data['host'] = Dever::url('lib/order_set.home?id=' . $data['role_id'] . '&order_id=' . $data['order_id'], 'agent');
  25. $data['url'] = Dever::url('lib/order_set.goods?total='.$data['total'].'&role_id=' . $data['role_id'] . '&order_id=' . $data['order_id'], 'agent');
  26. $data['submit'] = Dever::url('lib/order_set.action_commit?json=1', 'agent');
  27. return Dever::render('setOrderGoods', $data);
  28. }
  29. # 设置生产能力
  30. public function action_commit_api()
  31. {
  32. $goods = Dever::input('goods');
  33. if (!$goods) {
  34. Dever::alert('请传入商品');
  35. }
  36. $goods = Dever::json_decode($goods);
  37. $order_id = Dever::input('order_id');
  38. $role_id = Dever::input('role_id');
  39. $where['option_order_id'] = $order_id;
  40. $where['set_state'] = 2;
  41. Dever::db('agent/order_goods')->updates($where);
  42. foreach ($goods as $k => $v) {
  43. $type = 1;
  44. $type_id = $k;
  45. $sku_id = -1;
  46. if (strstr($k, '_')) {
  47. $temp = explode('_', $k);
  48. $type_id = $temp[0];
  49. $type = $temp[1];
  50. } elseif (strstr($k, '-')) {
  51. $temp = explode('-', $k);
  52. $type_id = $temp[0];
  53. $sku_id = $temp[1];
  54. }
  55. if ($v['total'] <= 0) {
  56. continue;
  57. }
  58. $w = array();
  59. $w['type'] = $type;
  60. $w['type_id'] = $type_id;
  61. $w['sku_id'] = $sku_id;
  62. $w['order_id'] = $order_id;
  63. $info = Dever::db('agent/order_goods')->one($w);
  64. if ($v['del'] == 2) {
  65. if ($info) {
  66. Dever::db('agent/order_goods')->update(array('where_id' => $info['id'], 'state' => 2));
  67. }
  68. } else {
  69. $w['num'] = $v['total'];
  70. if (!$info) {
  71. Dever::db('agent/order_goods')->insert($w);
  72. } else {
  73. $w['where_id'] = $info['id'];
  74. $w['state'] = 1;
  75. Dever::db('agent/order_goods')->update($w);
  76. }
  77. /*
  78. $wp = array();
  79. $wp['order_id'] = $order_id;
  80. $wp['status'] = 3;
  81. $process = Dever::db('agent/order_process')->find($wp);
  82. if ($process) {
  83. $process['type'] = explode(',', $process['type']);
  84. $wp['audit'] = 1;
  85. $wp['type'] = '1,2';
  86. Dever::db('agent/order_process')->insert($wp);
  87. } else {
  88. $wp['audit'] = 1;
  89. $wp['type'] = '1,2';
  90. Dever::db('agent/order_process')->insert($wp);
  91. }
  92. */
  93. }
  94. }
  95. return Dever::url('project/database/list&table=order_process&project=agent&order_id='.$order_id.'&page_type=1', 'manage');
  96. }
  97. }