WorkRecord.php 5.6 KB

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