model = new \app\admin\model\zy\game\Game; parent::__construct(); } public function index() { $params = $this->request->param(); $query = $this->model->alias('g') ->join([Stadium::$tableName => 's'], 's.id = g.gym_id', 'LEFT') ->join([Club::$tableName => 'c'], 'c.id = g.club_id', 'LEFT') ->field('g.*, s.name as gym_name, c.name as club_name'); if (isset($params['name'])) { $query->where('g.name', 'like', '%' . $params['name'] . '%'); } if (isset($params['club_id'])) { $query->where('g.club_id', $params['club_id']); } if (isset($params['week'])) { $query->where('g.week', $params['week']); } if (isset($params['pid'])) { $query->where('pid', $params['pid']); } else { $query->where('pid', 0); } if (isset($params['public_time'])) { $query->where('public_time', $params['public_time']); } else { $query->where('public_time', '<=', date('Y-m-d H:i:s')); } if (isset($params['page'])) { $pageSize = intval($params['pageSize'] ?? 10); $offeset = (intval($params['page']) - 1) * $pageSize; $query->limit($offeset, $pageSize); } $res = $query->select(); foreach ($res as &$v) { $v['cost'] = json_decode($v['cost'] ?? '[]', true); $v['referee'] = explode(',', $v['referee']); } $this->success('Success', ['list' => $res, 'count' => $query->count()]); } public function view() { $model = $this->model->get($this->request->param('id')); if (empty($model)) { $this->error(__('No rows were found')); } $model['cost'] = json_decode($model['cost'] ?? '[]', true); $model['referee'] = explode(',', $model['referee']); $this->success('Success', $model); } }