Item.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. <?php
  2. namespace App\Model;
  3. use App\Traits\HasCustomFields;
  4. class Item extends DataScopeBaseModel
  5. {
  6. protected $table = "item"; //指定表
  7. const CREATED_AT = 'crt_time';
  8. const UPDATED_AT = 'upd_time';
  9. protected $dateFormat = 'U';
  10. const employee_column = "crt_id";
  11. public static $field = ['title','id','code','start_time','end_time','mark','crt_id','crt_time','state','budget','charge_id','item_attribute','field','is_review_required','review_id','priority_id'];
  12. public static $report_field_1 = ['title','id','code','start_time','end_time','mark','budget','field'];
  13. const TYPE_MINUS_TWO = -2;
  14. const TYPE_MINUS_ONE = -1;
  15. const TYPE_ONE = 1;
  16. const TYPE_TWO = 2;
  17. const TYPE_THREE = 3;
  18. const State_Type = [
  19. self::TYPE_MINUS_ONE => '审核中',
  20. self::TYPE_MINUS_TWO => '已超期',
  21. self::TYPE_ONE => '待开始',
  22. self::TYPE_TWO => '进行中',
  23. self::TYPE_THREE => '已完成',
  24. ];
  25. const Attr_TYPE_ONE = 1;
  26. const Attr_TYPE_TWO = 2;
  27. const Item_Attribute = [
  28. self::TYPE_ONE => '自主开发',
  29. self::TYPE_TWO => '合作开发',
  30. ];
  31. // 引入自定义字段预加载关系
  32. use HasCustomFields;
  33. // 作用域 里面关联了客户自定义的表头数据
  34. public function scopeWithCustomData($query, $menuId, $user)
  35. {
  36. if (empty($menuId)) return $query;
  37. $top_depart_id = $user['top_depart_id'];
  38. return $query->with(['customFieldValues' => function ($subQuery) use ($menuId, $top_depart_id) {
  39. //只查询设置的id 和 自定义字段的值 还有业务单据/档案的id(这个必须要 预加载里没有主外键关联关系就查询失败)
  40. $subQuery->select(['definition_id', 'field_value', 'model_id', 'field_type'])
  41. ->where('top_depart_id', $top_depart_id)
  42. ->whereHas('definition', function ($q) use ($menuId) {
  43. $q->where('menu_id', $menuId);
  44. });
  45. }]);
  46. }
  47. }