AgentController.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace app\admin\controller;
  3. use think\exception\ValidateException;
  4. use app\model\Incomelog;
  5. use app\model\Member;
  6. use app\model\Order;
  7. use app\model\Agent;
  8. use app\model\AgentLevel;
  9. use app\model\RegisterField;
  10. class AgentController extends Base
  11. {
  12. function index()
  13. {
  14. $weid = weid();
  15. $page = input('post.page', 1, 'intval');
  16. $ptype = 'agent';
  17. $Fielddata = RegisterField::where(['weid' => $weid, 'ptype' => $ptype])->select()->toArray();
  18. if (empty($Fielddata)) {
  19. RegisterField::datainitial($ptype);
  20. }
  21. $query = $this->setSearch();
  22. $res = $query->order('sort asc,id desc')
  23. ->paginate(getpage())
  24. ->toArray();
  25. if (!empty($res['data'])) {
  26. foreach ($res['data'] as &$vo) {
  27. $vo = Agent::conversion($vo);
  28. }
  29. }
  30. $data['data'] = $res;
  31. if ($page == 1) {
  32. $data['field_data']['RegisterField'] = RegisterField::getlistViewField($ptype);
  33. }
  34. return $this->json($data);
  35. }
  36. function setSearch()
  37. {
  38. $keyword = trim(input('post.keyword', '', 'serach_in'));
  39. $status = input('post.status', '', 'serach_in');
  40. $create_time = input('post.create_time', '', 'serach_in');
  41. $path = input('post.path', '', 'serach_in');
  42. $weid = weid();
  43. if ($path == "/agent/audit") {
  44. $status = "0";
  45. }
  46. $query = Agent::where(['weid' => $weid]);
  47. if (!empty($create_time)) {
  48. $query->where('create_time', 'between', [strtotime($create_time[0]), strtotime($create_time[1])]);
  49. }
  50. if (!empty($keyword)) {
  51. $query->where('title|tel', 'like', '%' . $keyword . '%');
  52. }
  53. if (!empty($status) || $status === "0") {
  54. $query->where(['status' => $status]);
  55. }
  56. return $query;
  57. }
  58. function listUpdate()
  59. {
  60. $data = only('id,status');
  61. if (!$data['id']) throw new ValidateException('参数错误');
  62. Agent::update($data);
  63. return $this->json(['msg' => '操作成功']);
  64. }
  65. function delete()
  66. {
  67. return $this->del(new Agent());
  68. }
  69. function subordinates()
  70. {
  71. $weid = weid();
  72. $uid = input('post.uid', '', 'serach_in');
  73. $keyword = input('post.keyword', '', 'serach_in');
  74. if (empty($uid)) {
  75. $uid = -1;
  76. }
  77. $query = Member::where(['weid' => $weid, 'pid' => $uid]);
  78. if (!empty($keyword)) {
  79. $query->where('title', 'like', '%' . $keyword . '%');
  80. }
  81. $res = $query->order('id asc')
  82. ->paginate(getpage())
  83. ->toArray();
  84. foreach ($res['data'] as &$vo) {
  85. $vo['is_agent'] = yesno(Agent::is_agent($vo['id']));
  86. $vo['subordinatescount'] = Member::where(['pid' => $vo['id']])->count();
  87. $vo['ordercount'] = Incomelog::where(['weid' => $weid, 'uid' => $vo['id']])->count();
  88. }
  89. $data['data'] = $res;
  90. return $this->json($data);
  91. }
  92. //导出
  93. function dumpdata()
  94. {
  95. $page = $this->request->post('page', 1, 'intval');
  96. $ptype = 'agent';
  97. $query = $this->setSearch();
  98. $data = RegisterField::dumpdata($query, $ptype, $page);
  99. return $this->json($data);
  100. }
  101. public function agentorder()
  102. {
  103. $weid = weid();
  104. $uid = input('post.uid', '', 'serach_in');
  105. $keyword = input('post.keyword', '', 'serach_in');
  106. if (empty($uid)) {
  107. $uid = -1;
  108. }
  109. $where['weid'] = $weid;
  110. $where['uid'] = $uid;
  111. $query = Incomelog::where($where);
  112. $res = $query->order('id desc')
  113. ->paginate(getpage())
  114. ->toArray();
  115. foreach ($res['data'] as &$vo) {
  116. $vo['username'] = Member::get_name($vo['buyer_id']);
  117. $vo['pay_time'] = time_format($vo['pay_time']);
  118. }
  119. $data['data'] = $res;
  120. return $this->json($data);
  121. }
  122. }