Item.php 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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'];
  12. public static $report_field_1 = ['title','id','code','start_time','end_time','mark','budget','field'];
  13. const TYPE_ONE = 1;
  14. const TYPE_TWO = 2;
  15. const TYPE_THREE = 3;
  16. const State_Type = [
  17. self::TYPE_ONE => '待开始',
  18. self::TYPE_TWO => '进行中',
  19. self::TYPE_THREE => '已完成',
  20. ];
  21. const Attr_TYPE_ONE = 1;
  22. const Attr_TYPE_TWO = 2;
  23. const Item_Attribute = [
  24. self::TYPE_ONE => '自主开发',
  25. self::TYPE_TWO => '合作开发',
  26. ];
  27. // 引入自定义字段预加载关系
  28. use HasCustomFields;
  29. // 作用域 里面关联了客户自定义的表头数据
  30. public function scopeWithCustomData($query, $menuId, $user)
  31. {
  32. if (empty($menuId)) {
  33. return $query;
  34. }
  35. $top_depart_id = $user['top_depart_id'];
  36. return $query->with(['customFieldValues' => function ($subQuery) use ($menuId, $top_depart_id) {
  37. //只查询设置的id 和 自定义字段的值 还有业务单据/档案的id(这个必须要 预加载里没有主外键关联关系就查询失败)
  38. $subQuery->select(['definition_id', 'field_value', 'model_id'])
  39. ->where('top_depart_id', $top_depart_id)
  40. ->whereHas('definition', function ($q) use ($menuId) {
  41. $q->where('menu_id', $menuId);
  42. });
  43. }]);
  44. }
  45. }