Staff.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <?php
  2. namespace app\admin\model\equipment;
  3. use app\admin\model\User;
  4. use think\Db;
  5. use think\Exception;
  6. use think\Model;
  7. use traits\model\SoftDelete;
  8. class Staff extends Model
  9. {
  10. use SoftDelete;
  11. // 表名
  12. protected $name = 'equipment_staff';
  13. // 自动写入时间戳字段
  14. protected $autoWriteTimestamp = 'int';
  15. // 定义时间戳字段名
  16. protected $createTime = 'createtime';
  17. protected $updateTime = 'updatetime';
  18. protected $deleteTime = 'deletetime';
  19. // 追加属性
  20. protected $append = [
  21. 'status_text'
  22. ];
  23. public function getStatusList()
  24. {
  25. return ['normal' => __('Normal'), 'hidden' => __('Hidden')];
  26. }
  27. public function getStatusTextAttr($value, $data)
  28. {
  29. $value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
  30. $list = $this->getStatusList();
  31. return isset($list[$value]) ? $list[$value] : '';
  32. }
  33. public function addStaff($data)
  34. {
  35. Db::startTrans();
  36. try {
  37. // 注册会员
  38. $auth = \app\common\library\Auth::instance();
  39. $extend = ['nickname' => $data['nickname']];
  40. $result = $auth->register($data['mobile'], $data['password'], '', $data['mobile'], $extend);
  41. if (!$result) {
  42. throw new Exception($auth->getError());
  43. }
  44. $userinfo = $auth->getUserinfo();
  45. $params = [
  46. 'user_id' => $userinfo['id'],
  47. 'department_id' => isset($data['department_id']) ? $data['department_id'] : 0,
  48. 'workno' => isset($data['workno']) ? $data['workno'] : '',
  49. 'position' => isset($data['position']) ? $data['position'] : '',
  50. 'status' => isset($data['status']) ? $data['status'] : 'normal'
  51. ];
  52. $saveResult = $this->insertGetId($params);
  53. if (!$saveResult) {
  54. throw new Exception($this->getError());
  55. }
  56. Db::commit();
  57. return $userinfo['id'];
  58. } catch (\Exception $e) {
  59. Db::rollback();
  60. return $e->getMessage();
  61. }
  62. }
  63. public function editStaff($data, $ids)
  64. {
  65. $rawData = $this->with(['user'])->find($ids);
  66. Db::startTrans();
  67. try {
  68. $userData = [];
  69. if ($data['nickname'] != $rawData['user']['nickname']) {
  70. $userData['nickname'] = $data['nickname'];
  71. }
  72. if ($data['mobile'] != $rawData['user']['mobile']) {
  73. // 检测手机号是否存在
  74. if (User::getByUsername($data['mobile']) || User::getByMobile($data['mobile'])) {
  75. throw new Exception(__("Mobile already exist"));
  76. }
  77. $userData['username'] = $data['mobile'];
  78. $userData['mobile'] = $data['mobile'];
  79. }
  80. if (!empty($data['password'])) {
  81. $userData['password'] = $data['password'];
  82. }
  83. if (!empty($userData)) {
  84. $userModel = new User();
  85. $result = $userModel->isUpdate(true)->save($userData, ['id' => $rawData['user_id']]);
  86. if (!$result) {
  87. throw new Exception($userModel->getError());
  88. }
  89. }
  90. $params = [
  91. 'id' => $ids,
  92. 'department_id' => $data['department_id'],
  93. 'workno' => $data['workno'],
  94. 'position' => $data['position'],
  95. 'status' => $data['status']
  96. ];
  97. $saveResult = $this->isUpdate(true)->save($params);
  98. if (!$saveResult) {
  99. throw new Exception($this->getError());
  100. }
  101. Db::commit();
  102. return true;
  103. } catch (\Exception $e) {
  104. Db::rollback();
  105. return $e->getMessage();
  106. }
  107. }
  108. public function user()
  109. {
  110. return $this->belongsTo(User::class, 'user_id', 'id', [], 'LEFT')->setEagerlyType(0);
  111. }
  112. public function department()
  113. {
  114. return $this->belongsTo(Department::class, 'department_id', 'id', [], 'LEFT')->setEagerlyType(0);
  115. }
  116. public function multiUser()
  117. {
  118. return $this->belongsTo(User::class, 'user_id');
  119. }
  120. public function multiDepartment()
  121. {
  122. return $this->belongsTo(Department::class, 'department_id');
  123. }
  124. public function getSelectpicker($keyword = [], $manage = 0)
  125. {
  126. $where = ['staff.status' => 'normal'];
  127. $query = $this::where($where);
  128. if (!empty($keyword)) {
  129. if (is_array($keyword)) {
  130. if (count($keyword) == 1) {
  131. $query = $query->where('user.nickname|user.mobile', 'like', '%' . $keyword[0] . '%');
  132. } else {
  133. $query = $query->where(function ($query) use ($keyword) {
  134. foreach ($keyword as $item) {
  135. $query->whereOr(function ($query) use ($item) {
  136. $query->where('user.nickname|user.mobile', 'like', '%' . $item . '%');
  137. });
  138. }
  139. });
  140. }
  141. } else {
  142. $query = $query->where('user.nickname|user.mobile', 'like', '%' . $keyword . '%');
  143. }
  144. }
  145. if ($manage) {
  146. $query = $query->where('department.equipment_manage', 1);
  147. }
  148. return $query->with(['user', 'department'])->order('staff.id desc')->column('user_id, concat(user.nickname, ",", user.mobile)');
  149. }
  150. }