Rechargeorder.php 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. <?php
  2. namespace app\admin\controller\trade;
  3. use app\common\controller\Backend;
  4. /**
  5. * 充值订单管理
  6. *
  7. * @icon fa fa-circle-o
  8. */
  9. class Rechargeorder extends Backend
  10. {
  11. /**
  12. * Rechargeorder模型对象
  13. * @var \app\admin\model\trade\Rechargeorder
  14. */
  15. protected $model = null;
  16. public function _initialize()
  17. {
  18. parent::_initialize();
  19. $this->model = new \app\admin\model\trade\Rechargeorder;
  20. $this->view->assign("payMethodList", $this->model->getPayMethodList());
  21. $this->view->assign("statusList", $this->model->getStatusList());
  22. }
  23. public function import()
  24. {
  25. parent::import();
  26. }
  27. /**
  28. * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
  29. * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
  30. * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
  31. */
  32. public function index()
  33. {
  34. //设置过滤方法
  35. $this->request->filter(['strip_tags', 'trim']);
  36. if ($this->request->isAjax()) {
  37. //如果发送的来源是Selectpage,则转发到Selectpage
  38. if ($this->request->request('keyField')) {
  39. return $this->selectpage();
  40. }
  41. list($where, $sort, $order, $offset, $limit) = $this->buildparams();
  42. $list = $this->model->alias('order')
  43. ->field('order.*')
  44. ->field('user.nickname,user.avatar')
  45. ->join('user user', 'user.id = order.user_id', 'left')
  46. ->where($where)
  47. ->order($sort, $order)
  48. ->paginate($limit)
  49. ->each(function ($item) {
  50. $item->avatar = $item->avatar ? cdnurl($item->avatar, true) : letter_avatar($item->nickname);
  51. });
  52. $totalMoney = $this->model->alias('order')->join('user user', 'user.id = order.user_id', 'left')->where($where)->sum('rmb_amount');
  53. // 清空对应角标
  54. $filter = json_decode(input('filter'), true);
  55. if ($filter && !$list->isEmpty()) {
  56. \app\admin\model\trade\Rechargeorder::where('backend_read', 0)->where('status', $list[0]->status)->update(['backend_read' => 1]);
  57. }
  58. $result = array("total" => $list->total(), "rows" => $list->items(), 'totalmoney' => $totalMoney);
  59. return json($result);
  60. }
  61. // 渲染角标数字
  62. $sidebar = [
  63. 'all' => \app\admin\model\trade\Rechargeorder::where('backend_read', 0)->count(),
  64. 'unpay' => \app\admin\model\trade\Rechargeorder::where('backend_read', 0)->where('status', 'unpay')->count(),
  65. 'paid' => \app\admin\model\trade\Rechargeorder::where('backend_read', 0)->where('status', 'paid')->count(),
  66. ];
  67. $this->assignconfig('sidebar_number', $sidebar);
  68. $this->assign('sidebar_number', $sidebar);
  69. return $this->view->fetch();
  70. }
  71. }