WorkRecord.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. <?php
  2. namespace catchAdmin\worklocation\model;
  3. use catchAdmin\api\Listen;
  4. use catchAdmin\hydraulic\model\DeviceMold as ModelDeviceMold;
  5. use catchAdmin\hydraulic\model\HydEquipment;
  6. use catchAdmin\hydraulic\model\Wrench;
  7. use catcher\base\CatchModel as Model;
  8. use catchAdmin\permissions\model\DataRangScopeTrait;
  9. use catchAdmin\wind\model\Fan;
  10. use catchAdmin\wind\model\Wind;
  11. use DeviceMold;
  12. use think\facade\Db;
  13. class WorkRecord extends Model
  14. {
  15. use Listen;
  16. use DataRangScopeTrait;
  17. // 表名
  18. public $name = 'work_record';
  19. // 数据库字段映射
  20. public $field = array(
  21. 'id',
  22. // 风场编号
  23. 'wind_number',
  24. // 风机编号
  25. 'fan_number',
  26. //风机模型
  27. 'fan_model',
  28. // 部件
  29. 'parts',
  30. // 螺栓型号
  31. 'boit_type',
  32. //工作位置
  33. 'work_sign',
  34. // 螺栓编号
  35. 'bolt_number',
  36. // 螺栓总数
  37. 'boit_total',
  38. // 扳手编号
  39. 'wrench_number',
  40. // 设定的扭矩1
  41. 'set_torque',
  42. // 紧固扭矩1
  43. 'fastening_torque',
  44. // 设定的压力
  45. 'set_stress',
  46. // 紧固压力
  47. 'fastening_stress',
  48. // 1 紧固正常,2紧固异常
  49. 'fastening_status',
  50. // 紧固时间
  51. 'fastening_time',
  52. // 搬动角度
  53. 'move_angle',
  54. // 网关imei
  55. 'imei',
  56. // 1 紧固模式,2维护模式
  57. 'type',
  58. //1、普通扳手 2、角度扳手,未转角度 3、角度扳手,转动角度
  59. 'wrench_type',
  60. // 创建人ID
  61. 'creator_id',
  62. // 创建时间
  63. 'created_at',
  64. // 更新时间
  65. 'updated_at',
  66. // 软删除
  67. 'deleted_at',
  68. );
  69. public function getList()
  70. {
  71. return $this->dataRange()
  72. ->catchSearch()
  73. ->append(['department_name', 'fan_model_name', 'wind_name', 'work_local_name', 'parts_name', 'boit_type_name', 'work_name', 'wrench_name'])
  74. ->field('*')
  75. ->catchOrder()
  76. ->creator()
  77. ->paginate();
  78. }
  79. /**
  80. * @Descripttion: 获取扳手的名称
  81. * @name: likang
  82. * @return {*}
  83. */
  84. public function getWrenchNameAttr()
  85. {
  86. $wrench = $this->wrench_number;
  87. $eq_id = Wrench::where('number', $wrench)->value('eq_id');
  88. $name = HydEquipment::where('id', $eq_id)->value('name');
  89. return $name;
  90. }
  91. public function getFanModelNameAttr()
  92. {
  93. $name = ModelDeviceMold::where('id', $this->fan_model)->where('device_type', 4)->value('name');
  94. return $name;
  95. }
  96. //获取部门名称
  97. public function getDepartmentNameAttr()
  98. {
  99. $dep_id = Db::name('wind')->where('number', $this->wind_number)->value('department_id');
  100. $name = Db::name('departments')->where('id', $dep_id)->where('status', 1)->value('department_name');
  101. return $name;
  102. }
  103. //风机模型
  104. public function getWindModelAttr()
  105. {
  106. $wind_number = $this->wind_number;
  107. $wind_name = Db::name('wind')->where('number', $wind_number)->value('name');
  108. return $wind_name;
  109. }
  110. /**
  111. * 获取风场名称
  112. *
  113. * @return void
  114. */
  115. public function getWindNameAttr()
  116. {
  117. $wind_number = $this->wind_number;
  118. $wind_name = Db::name('wind')->where('number', $wind_number)->value('name');
  119. return $wind_name;
  120. }
  121. //获取操作人员
  122. public function getWorkNameAttr()
  123. {
  124. $user_id = $this->creator_id;
  125. $name = Db::name("users")->where('id', $user_id)->value('realname');
  126. return $name;
  127. }
  128. //紧固模式
  129. public function getTypeAttr()
  130. {
  131. $type = $this->getData('type');
  132. if ($type == 1) {
  133. return '紧固模式';
  134. } else if ($type == 2) {
  135. return '维护模式';
  136. } else {
  137. return '未知模式';
  138. }
  139. }
  140. //扳手类型
  141. public function getWrenchTypeAttr()
  142. {
  143. $type = $this->getData('wrench_type');
  144. if ($type == 1) {
  145. return '普通扳手';
  146. } else if ($type == 2) {
  147. return '角度扳手,未转角度';
  148. } else if ($type == 3) {
  149. return '角度扳手,转动角度';
  150. } else {
  151. return '未知扳手';
  152. }
  153. }
  154. //紧固状态
  155. public function getFasteningStatusAttr()
  156. {
  157. $type = $this->getData('fastening_status');
  158. if ($type == 1) {
  159. return '紧固正常';
  160. } else if ($type == 2) {
  161. return '紧固异常';
  162. } else {
  163. return '未知状态';
  164. }
  165. }
  166. /**
  167. * 获取部件名称
  168. *
  169. * @return void
  170. */
  171. public function getPartsNameAttr()
  172. {
  173. $parts = $this->parts;
  174. $value = $this->get_dict_data(1, $parts);
  175. return $value;
  176. }
  177. //获取工作位置型号
  178. public function getWorkLocalNameAttr()
  179. {
  180. $code = $this->work_sign;
  181. $value = $this->get_dict_data(2, $code);
  182. return $value;
  183. }
  184. /**
  185. * 螺栓型号
  186. *
  187. * @return void
  188. */
  189. public function getBoitTypeNameAttr()
  190. {
  191. $code = $this->boit_type;
  192. $value = $this->get_dict_data(4, $code);
  193. return $value;
  194. }
  195. /**
  196. *
  197. * @param [type] $type 类型
  198. * @param [type] $value 唯一value
  199. * @return void
  200. */
  201. public function get_dict_data($type, $value)
  202. {
  203. $where[] = ['device_type', "=", $type];
  204. $where[] = ['value', '=', $value];
  205. $name = Db::name('maintenance_mapper')->where($where)->value('name');
  206. return $name;
  207. }
  208. /**
  209. * 监听转换
  210. */
  211. public function addContent(&$obj)
  212. {
  213. $data = null;
  214. $content = null;
  215. $data = [
  216. 'id' => $obj->wind_number . $obj->fan_number . $obj->fan_model . $obj->parts . $obj->work_local,
  217. 'wnum' => $obj->wind_number,
  218. 'fnum' => $obj->fan_number,
  219. 'fmodel' => ModelDeviceMold::where('device_type', 4)->where('id', $this->fan_model)->value('name'),
  220. 'parts' => $this->get_dict_data(1, $obj->parts),
  221. 'work' => $this->get_dict_data(2, $obj->work_local),
  222. 'bnum' => $this->bolt_num,
  223. 'torque' => $this->torque
  224. ];
  225. $content['data'] = $data;
  226. $content['type'] = 'WorkRecord';
  227. return $content;
  228. }
  229. }