Workplan.php 3.5 KB

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