Workplan.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  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. 'pnum' => $obj->id,
  55. 'wnum' => Wind::where('id', $obj->wind_id)->value('number'),
  56. 'wname' => Wind::where('id', $obj->wind_id)->value('name'),
  57. 'fnum' => Fan::where('id', $obj->wind_id)->value('number'),
  58. 'fmode' => $obj->id,
  59. 'work' => $obj->work_sign,
  60. 'bm' => $obj->id,
  61. 'bn' => $obj->id,
  62. 'tm' => $obj->id,
  63. 'bias' => $obj->id,
  64. 'lt' => $obj->id,
  65. 'torque' => $obj->id
  66. ];
  67. $content['data'] = $data;
  68. $content['type'] = 'WorkPlan';
  69. return $content;
  70. }
  71. public function getList()
  72. {
  73. return $this->dataRange()
  74. ->catchSearch()
  75. ->append(['wind_name', 'fan_number', 'work_sign_name', 'parts_sign_name', 'boit_type_sign_name', 'status_name', 'creat_name', 'fan_model'])
  76. ->field('*')
  77. ->catchOrder()
  78. ->creator()
  79. ->paginate();
  80. }
  81. //获取风场名称
  82. public function getWindNameAttr()
  83. {
  84. $wind_id = $this->wind_id;
  85. $name = Wind::where('id', $wind_id)->value('name');
  86. return $name;
  87. }
  88. //获取风机机位号
  89. public function getFanNumberAttr()
  90. {
  91. $fan_id = $this->fan_id;
  92. $number = Fan::where('id', $fan_id)->value('number');
  93. return $number;
  94. }
  95. //获取工作位置
  96. public function getWorkSignNameAttr()
  97. {
  98. $name = ModelMaintenancemapper::where('device_type', 2)->where('value', $this->work_sign)->value('name');
  99. return $name;
  100. }
  101. //获取部件
  102. public function getPartsSignNameAttr()
  103. {
  104. $name = ModelMaintenancemapper::where('device_type', 1)->where('value', $this->parts_sign)->value('name');
  105. return $name;
  106. }
  107. //获取螺栓型号
  108. public function getBoitTypeSignNameAttr()
  109. {
  110. $name = ModelMaintenancemapper::where('device_type', 4)->where('value', $this->boit_type_sign)->value('name');
  111. return $name;
  112. }
  113. public function getCreatNameAttr()
  114. {
  115. $name = null;
  116. $name = Users::where('id', $this->creator_id)->value('realname');
  117. return $name;
  118. }
  119. //获取风机的型号id
  120. public function getFanModelAttr()
  121. {
  122. $fan_id = $this->fan_id;
  123. $fanModel = Fan::where('id', $fan_id)->value('fan_model');
  124. return $fanModel;
  125. }
  126. public function searchPlanNameAttr($query, $value, $data)
  127. {
  128. return $query->where('plan_name', 'like', '%' . $value . '%');
  129. }
  130. }