PositionCheck.php 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. /**
  3. +-----------------------------------------------------------------------------------------------
  4. * GouGuOPEN [ 左手研发,右手开源,未来可期!]
  5. +-----------------------------------------------------------------------------------------------
  6. * @Copyright (c) 2021~2024 http://www.gouguoa.com All rights reserved.
  7. +-----------------------------------------------------------------------------------------------
  8. * @Licensed 勾股OA,开源且可免费使用,但并不是自由软件,未经授权许可不能去除勾股OA的相关版权信息
  9. +-----------------------------------------------------------------------------------------------
  10. * @Author 勾股工作室 <hdm58@qq.com>
  11. +-----------------------------------------------------------------------------------------------
  12. */
  13. namespace app\user\validate;
  14. use think\facade\Db;
  15. use think\Validate;
  16. class PositionCheck extends Validate
  17. {
  18. // 自定义验证规则
  19. protected function checkUnique($value, $rule, $data)
  20. {
  21. [$table, $field, $id] = explode(',', $rule);
  22. $idField = $id ?: 'id';
  23. $idValue = $data[$idField] ?? null;
  24. $map = [
  25. [$field, '=', $value],
  26. ];
  27. if (!is_null($idValue)) {
  28. $map[] = [$idField, '<>', $idValue];
  29. }
  30. $map[] = ['status', '=', 1];
  31. return !Db::name($table)->where($map)->count();
  32. }
  33. protected $rule = [
  34. 'title' => 'require|checkUnique:Position,title,id',
  35. 'work_price' => 'require|number',
  36. 'group_id' => 'require',
  37. 'id' => 'require'
  38. ];
  39. protected $message = [
  40. 'title.require' => '岗位名称不能为空',
  41. 'title.checkUnique' => '同样的岗位名称已经存在',
  42. 'work_price.require' => '岗位工时单价不能为空',
  43. 'work_price.number' => '岗位工时单价只能是整数',
  44. 'group_id.require' => '至少要选择一个角色权限',
  45. 'id.require' => '缺少更新条件',
  46. ];
  47. protected $scene = [
  48. 'add' => ['title', 'work_price', 'group_id'],
  49. 'edit' => ['title', 'work_price', 'group_id', 'id'],
  50. ];
  51. }