123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- <?php
- namespace app\admin\controller;
- use app\admin\controller\base\Permissions;
- use app\common\model\Appointment as appointmentModel;
- use time\DateHelper;
- class Appointment extends Permissions
- {
- private function getModel()
- {
- return new appointmentModel();
- }
- public function index()
- {
- $pid = $this->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('删除成功');
- }
- }
- }
- }
|