Specialist.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <?php
  2. namespace app\admin\controller;
  3. use app\admin\controller\base\Permissions;
  4. use think\Db;
  5. class Specialist extends Permissions
  6. {
  7. private function getModel()
  8. {
  9. return new \app\common\model\Specialist();
  10. }
  11. public function index()
  12. {
  13. if ($this->request->isAjax()) {
  14. $post = $this->request->param();
  15. $where = [];
  16. if (isset($post['ids']) and !empty($post['ids'])) {
  17. $where['id'] = ['in', $post['ids']];
  18. }
  19. if (!empty($post["name"])) {
  20. $where["name"] = ['like', '%' . $post["name"] . '%'];
  21. }
  22. if (!empty($post["title"])) {
  23. $where["title"] = ['like', '%' . $post["title"] . '%'];
  24. }
  25. if (!empty($post["head_pic"])) {
  26. $where["head_pic"] = ['like', '%' . $post["head_pic"] . '%'];
  27. }
  28. if (isset($post["sex"]) and "" != $post["sex"]) {
  29. $where["sex"] = $post["sex"];
  30. }
  31. if (!empty($post["desc"])) {
  32. $where["desc"] = ['like', '%' . $post["desc"] . '%'];
  33. }
  34. if (!empty($post["consultation_direction"])) {
  35. $where["consultation_direction"] = ['like', '%' . $post["consultation_direction"] . '%'];
  36. }
  37. if (isset($post["address_id"]) and "" != $post["address_id"]) {
  38. $where["address_id"] = $post["address_id"];
  39. }
  40. $model = $this->getModel();
  41. $count = $model->where($where)->count();
  42. $data = $model->where($where)->page($post['page']??0, $post['limit']??15)->order('id desc')->select();
  43. foreach ($data as $key => $value) {
  44. $value['head_pic_url'] = geturl($value['head_pic']);
  45. $value['sex_text'] = $value->sex_text;
  46. $value['address_name'] = $value->address ? $value->address->title : '';
  47. $data[$key] = $value;
  48. }
  49. return array('code' => 0, 'count' => $count, 'data' => $data);
  50. } else {
  51. $this->assign('addresslist', \app\common\model\Address::all());
  52. return $this->fetch();
  53. }
  54. }
  55. public function publish()
  56. {
  57. $id = $this->request->param('id', 0, 'intval');
  58. $model = $this->getModel();
  59. $post = $this->request->post();
  60. if ($this->request->isPost()) {
  61. //验证
  62. $validate = new \think\Validate([
  63. ['name|名字', 'require|max:50'],
  64. ['title|职称', 'require|max:50'],
  65. ['head_pic|头像', 'max:255'],
  66. ['sex|性别', 'number'],
  67. ['desc|简介', 'max:500'],
  68. ['consultation_direction|咨询方向', 'max:500'],
  69. ['address_id|地址', 'require|number'],
  70. ]);
  71. if (!$validate->check($post)) {
  72. $this->error('提交失败:' . $validate->getError());
  73. }
  74. } else {
  75. $this->assign('addresslist', \app\common\model\Address::all());
  76. }
  77. if ($id > 0) {
  78. //修改
  79. $data = $model->where('id', $id)->find();
  80. if (empty($data)) {
  81. $this->error('id不正确');
  82. }
  83. if ($this->request->isPost()) {
  84. if (false == $model->allowField(true)->save($post, ['id' => $id])) {
  85. $this->error('修改失败');
  86. } else {
  87. $this->success('修改成功');
  88. }
  89. } else {
  90. $this->assign('data', $data);
  91. return $this->fetch();
  92. }
  93. } else {
  94. //新增
  95. if ($this->request->isPost()) {
  96. if (false == $model->allowField(true)->save($post)) {
  97. $this->error('添加失败');
  98. } else {
  99. $this->success('添加成功', 'index');
  100. }
  101. } else {
  102. return $this->fetch();
  103. }
  104. }
  105. }
  106. public function delete()
  107. {
  108. if ($this->request->isAjax()) {
  109. $id = $this->request->param('id', 0, 'intval');
  110. if (false == $this->getModel()->where('id', $id)->delete()) {
  111. $this->error('删除失败');
  112. } else {
  113. $this->success('删除成功', 'index');
  114. }
  115. }
  116. }
  117. public function deletes()
  118. {
  119. if ($this->request->isAjax()) {
  120. $post = $this->request->param();
  121. $ids = $post['ids'];
  122. if ($this->getModel()->where('id', 'in', $ids)->delete()) {
  123. $this->success('删除成功');
  124. }
  125. }
  126. }
  127. }