Workplan.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. namespace catchAdmin\worklocation\model;
  3. use catchAdmin\hydraulic\model\MaintenanceMapper as ModelMaintenancemapper;
  4. use catchAdmin\permissions\model\DataRangScopeTrait;
  5. use catchAdmin\permissions\model\Users;
  6. use catchAdmin\wind\model\Fan;
  7. use catchAdmin\wind\model\Wind;
  8. use catcher\base\CatchModel as Model;
  9. use Maintenancemapper;
  10. class Workplan extends Model
  11. {
  12. use DataRangScopeTrait;
  13. // 表名
  14. public $name = 'work_plan';
  15. // 数据库字段映射
  16. public $field = array(
  17. 'id',
  18. // 风场id
  19. 'wind_id',
  20. // 风机id
  21. 'fan_id',
  22. // 工作位置
  23. 'work_sign',
  24. // 部件类型
  25. 'parts_sign',
  26. // 螺栓型号
  27. 'boit_type_sign',
  28. // 计划名称
  29. 'plan_name',
  30. // 详情
  31. 'info',
  32. // 状态 1 启用,-1 失效
  33. 'status',
  34. // 创建人ID
  35. 'creator_id',
  36. // 创建时间
  37. 'created_at',
  38. // 更新时间
  39. 'updated_at',
  40. // 软删除
  41. 'deleted_at',
  42. );
  43. public function getList()
  44. {
  45. return $this->dataRange()
  46. ->catchSearch()
  47. ->append(['wind_name', 'fan_number', 'work_sign_name', 'parts_sign_name', 'boit_type_sign_name', 'status_name', 'creat_name', 'fan_model'])
  48. ->field('*')
  49. ->catchOrder()
  50. ->creator()
  51. ->paginate();
  52. }
  53. //获取风场名称
  54. public function getWindNameAttr()
  55. {
  56. $wind_id = $this->wind_id;
  57. $name = Wind::where('id', $wind_id)->value('name');
  58. return $name;
  59. }
  60. //获取风机机位号
  61. public function getFanNumberAttr()
  62. {
  63. $fan_id = $this->fan_id;
  64. $number = Fan::where('id', $fan_id)->value('number');
  65. return $number;
  66. }
  67. //获取工作位置
  68. public function getWorkSignNameAttr()
  69. {
  70. $name = ModelMaintenancemapper::where('device_type', 2)->where('value', $this->work_sign)->value('name');
  71. return $name;
  72. }
  73. //获取部件
  74. public function getPartsSignNameAttr()
  75. {
  76. $name = ModelMaintenancemapper::where('device_type', 1)->where('value', $this->parts_sign)->value('name');
  77. return $name;
  78. }
  79. //获取螺栓型号
  80. public function getBoitTypeSignNameAttr()
  81. {
  82. $name = ModelMaintenancemapper::where('device_type', 4)->where('value', $this->boit_type_sign)->value('name');
  83. return $name;
  84. }
  85. public function getCreatNameAttr()
  86. {
  87. $name = null;
  88. $name = Users::where('id', $this->creator_id)->value('realname');
  89. return $name;
  90. }
  91. //获取风机的型号id
  92. public function getFanModelAttr()
  93. {
  94. $fan_id = $this->fan_id;
  95. $fanModel = Fan::where('id', $fan_id)->value('fan_model');
  96. return $fanModel;
  97. }
  98. public function searchPlanNameAttr($query, $value, $data)
  99. {
  100. return $query->where('plan_name', 'like', '%' . $value . '%');
  101. }
  102. }