request->param('pid', 0, 'intval'); if ($this->request->isAjax()) { $post = $this->request->param(); $where = [ 'provider_id' => $pid ]; if (isset($post['ids']) and !empty($post['ids'])) { $where['id'] = ['in', $post['ids']]; } if (isset($post["daytime"]) and !empty($post["daytime"])) { $timerang = explode(' - ', $post["daytime"]); $min_time = strtotime($timerang[0]); $max_time = $timerang[0] == $timerang[1] ? $min_time + 24 * 3600 - 1 : strtotime($timerang[1]??''); $where["daytime"] = [['>=', $min_time], ['<=', $max_time]]; } if (isset($post["create_time"]) and !empty($post["create_time"])) { $timerang = explode(' - ', $post["create_time"]); $min_time = strtotime($timerang[0]); $max_time = $timerang[0] == $timerang[1] ? $min_time + 24 * 3600 - 1 : strtotime($timerang[1]??''); $where["create_time"] = [['>=', $min_time], ['<=', $max_time]]; } $model = $this->getModel(); $count = $model->where($where)->count(); $data = $model->where($where)->page($post['page']??0, $post['limit']??15)->order('daytime desc')->select(); foreach ($data as $key => $value) { $value['specialist_name'] = $value->specialist->name; $data[$key] = $value; } return array('code' => 0, 'count' => $count, 'data' => $data); } else { return $this->fetch(); } } public function publish() { $id = $this->request->param('id', 0, 'intval'); $pid = $this->request->param('pid', 0, 'intval'); $this->assign('pid', $pid); $post = $this->request->post(); $post['provider_id'] = $pid; if ($this->request->isPost()) { if (isset($post['start_time']) && !empty($post['start_time'])) { $timerang = explode(' - ', $post["start_time"]); $min_time = strtotime(str_replace(['年', '月'], '-', $timerang[0])); $max_time = $timerang[0] == $timerang[1] ? $min_time + 24 * 3600 - 1 : strtotime(str_replace(['年', '月'], '-', $timerang[1]??'')); $post['start_time'] = $min_time; $post['end_time'] = $max_time; } if (isset($post['morning_start_time']) && !empty($post['morning_start_time'])) { $timerang = explode(' - ', $post["morning_start_time"]); $post['morning_start_time'] = $timerang[0]; $post['morning_end_time'] = $timerang[1]; } if (isset($post['afternoon_start_time']) && !empty($post['afternoon_start_time'])) { $timerang = explode(' - ', $post["afternoon_start_time"]); $post['afternoon_start_time'] = $timerang[0]; $post['afternoon_end_time'] = $timerang[1]; } if (isset($post['night_start_time']) && !empty($post['night_start_time'])) { $timerang = explode(' - ', $post["night_start_time"]); $post['night_start_time'] = $timerang[0]; $post['night_end_time'] = $timerang[1]; } //验证 $validate = new \think\Validate([ ['title|服务名称', 'max:50'], ['provider_id', 'require|number'], ['phone|咨询电话', 'max:50'], ['start_time', 'number', '排号日期格式不对'], ['end_time', 'number', '排号日期格式不对'], ['morning_num|上午放号个数', 'number'], ['morning_start_time', 'length:8', '上午时间格式不对'], ['morning_end_time', 'length:8', '上午时间格式不对'], ['afternoon_num|下午放号个数', 'number'], ['afternoon_start_time', 'length:8', '下午时间格式不对'], ['afternoon_end_time', 'length:8', '下午时间格式不对'], ['night_num|晚上放号个数', 'number'], ['night_start_time', 'length:8', '晚上时间格式不对'], ['night_end_time', 'length:8', '晚上时间格式不对'], ]); if (!$validate->check($post)) { $this->error('提交失败:' . $validate->getError()); } } else { $this->assign('phone', (new \app\common\model\Specialist())->where('id', $pid)->value('phone')); } if ($id > 0) { //修改 } else { //新增 if ($this->request->isPost()) { //判断是否时间跨度重叠 $exits = $this->getModel()->where(['provider_id' => $pid, 'daytime' => [['>=', $post['start_time']], ['<=', $post['end_time']]]])->count(); if ($exits > 0) { $this->error('该时间跨度内,已存在排号,请重新选择时间'); } //生成号源 $daylist = DateHelper::dateTimeList(date('Y-m-d', $post['start_time']), date('Y-m-d', $post['end_time']), true); if (count($daylist) == 2 && end($daylist) == current($daylist)) { array_pop($daylist); } $addressId = (new \app\common\model\Specialist())->where('id', $post['provider_id'])->value('address_id'); foreach ($daylist as $datetime) { $post['daytime'] = strtotime($datetime); $post['address_id'] = $addressId; if (false == $this->getModel()->allowField(true)->save($post)) { $this->error('添加失败'); } } $this->success('添加成功', 'index', ['pid' => $pid]); } else { return $this->fetch(); } } } public function delete() { if ($this->request->isAjax()) { $id = $this->request->param('id', 0, 'intval'); if (false == $this->getModel()->where('id', $id)->delete()) { $this->error('删除失败'); } else { $this->success('删除成功', 'index'); } } } public function deletes() { if ($this->request->isAjax()) { $post = $this->request->param(); $ids = $post['ids']; if ($this->getModel()->where('id', 'in', $ids)->delete()) { $this->success('删除成功'); } } } }