SalaryItemPermanently.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeadmin快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
  8. // | github下载:https://github.com/likeshop-github/likeadmin
  9. // | 访问官网:https://www.likeadmin.cn
  10. // | likeadmin团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: likeadminTeam
  13. // +----------------------------------------------------------------------
  14. namespace app\common\model\master_worker;
  15. use app\common\model\BaseModel;
  16. use app\common\model\dict\DictData;
  17. use app\common\model\works\ReturnWork;
  18. use app\common\model\works\ServiceWork;
  19. use think\facade\Log;
  20. /**
  21. * SalaryItemPermanently模型
  22. * Class SalaryItemPermanently
  23. * @package app\common\model
  24. */
  25. class SalaryItemPermanently extends BaseModel
  26. {
  27. protected $name = 'salary_item_permanently';
  28. public function workerInfo()
  29. {
  30. return $this->hasOne(MasterWorkerInfo::class, 'worker_id', 'master_worker_id');
  31. }
  32. public function getTermTextAttr($value,$data):string
  33. {
  34. $dictData = DictData::whereIn('type_value', 'salary_item')->column('name','value');
  35. return $dictData[$data['term']] ?? '';
  36. }
  37. // 接单服务费
  38. public function salary_item_1($permanently_settlement_id,$master_worker_id,$params,$extra = [])
  39. {
  40. try {
  41. //$params['start_time'] $params['end_time']
  42. $promotion_level = MasterWorker::where('id',$master_worker_id)->value('promotion_level');
  43. $ratio = 0.00;
  44. switch ($promotion_level){
  45. case 1:
  46. $ratio = 0.65;
  47. break;
  48. case 2:
  49. $ratio = 0.63;
  50. break;
  51. case 3:
  52. $ratio = 0.61;
  53. break;
  54. case 4:
  55. $ratio = 0.59;
  56. break;
  57. case 5:
  58. $ratio = 0.57;
  59. break;
  60. case 6:
  61. $ratio = 0.55;
  62. break;
  63. case 7:
  64. $ratio = 0.5;
  65. break;
  66. }
  67. //$ratio
  68. // 查询时间范围内所有已经完单的工单
  69. $order_list = ServiceWork::where('master_worker_id',$master_worker_id)->
  70. where('finished_time','between',[$params['start_time'],$params['end_time']])->
  71. where('service_status',3)->where('work_pay_status',2)->
  72. field(['id','work_sn','work_amount','spare_total','master_worker_id','finished_time','service_status','work_pay_status'])->
  73. select()->toArray();
  74. $amount = 0.00;
  75. $spare_total = 0.00;
  76. foreach ($order_list as $item) {
  77. $amount += (float)bcsub($item['work_amount'] ,$item['spare_total']);//(float)bcmul(, $ratio,2);
  78. $spare_total += $item['spare_total'];
  79. }
  80. $term_amount = (float)bcmul($amount, $ratio,2);
  81. $itemData = [
  82. 'permanently_settlement_id' => $permanently_settlement_id,
  83. 'master_worker_id' => $master_worker_id,
  84. 'term' => 1,
  85. 'term_amount' => $term_amount,
  86. 'remark' => $params['item_name'].':配件总金额--'.$spare_total.': 奖励总金额--'.$term_amount.';比例:--'.$ratio,
  87. 'extra' => json_encode([
  88. 'step_days'=>$params['step_days'],'item_name'=>$params['item_name'],
  89. 'start_time'=>$params['start_time'],'end_time'=>$params['end_time'],'promotion_level'=>$promotion_level,'ratio'=>$ratio,
  90. 'amount'=>$amount,'count_order'=>count($order_list),'order_ids'=> array_column($order_list,'id')
  91. ]),
  92. ];
  93. self::salaryCreateUpdate($itemData);
  94. return true;
  95. } catch (\Exception $e) {
  96. Log::info('permanently_settlement_id:'.$permanently_settlement_id.':'.$e->getFile().':'.$e->getLine().':'.$e->getMessage());
  97. return false;
  98. }
  99. }
  100. // 加单奖励
  101. public function salary_item_2($permanently_settlement_id,$master_worker_id,$params,$extra = [])
  102. {
  103. try {
  104. // work_type = 2
  105. $ratio = 0.1;
  106. // 查询时间范围内所有已经完单的工单
  107. $order_list = ServiceWork::where('master_worker_id',$master_worker_id)->
  108. where('finished_time','between',[$params['start_time'],$params['end_time']])->
  109. where('service_status','=',3)->where('work_pay_status','=',2)->where('work_type','=',2)->
  110. field(['id','work_sn','work_amount','spare_total','master_worker_id','finished_time','service_status','work_pay_status'])->
  111. select()->toArray();
  112. $amount = 0.00;
  113. foreach ($order_list as $item) {
  114. $amount += (float)bcsub($item['work_amount'] ,$item['spare_total']);//(float)bcmul(, $ratio,2);
  115. }
  116. $term_amount = (float)bcmul($amount, $ratio,2);
  117. $itemData = [
  118. 'permanently_settlement_id' => $permanently_settlement_id,
  119. 'master_worker_id' => $master_worker_id,
  120. 'term' => 2,
  121. 'term_amount' => $term_amount,
  122. 'remark' => $params['item_name'].': 金额--'.$term_amount.';比例:--'.$ratio,
  123. 'extra' => json_encode([
  124. 'step_days'=>$params['step_days'],'item_name'=>$params['item_name'],
  125. 'start_time'=>$params['start_time'],'end_time'=>$params['end_time'],'ratio'=>$ratio,
  126. 'amount'=>$amount,'count_order'=>count($order_list),'order_ids'=> array_column($order_list,'id')
  127. ]),
  128. ];
  129. self::salaryCreateUpdate($itemData);
  130. return true;
  131. } catch (\Exception $e) {
  132. Log::info('permanently_settlement_id:'.$permanently_settlement_id.':'.$e->getFile().':'.$e->getLine().':'.$e->getMessage());
  133. return false;
  134. }
  135. }
  136. // 月度TOP3
  137. public function salary_item_3($permanently_settlement_id,$master_worker_id,$params,$extra = [])
  138. {
  139. try {
  140. $term_amount = 0;
  141. $ranking = 3;
  142. // 查询时间范围内所有已经完单的工单工程师排名 - 可以为当月月度
  143. $order_list = ServiceWork::
  144. where('finished_time','between',[$params['start_time'],$params['end_time']])->
  145. where('service_status','=',3)->where('work_pay_status','=',2)->
  146. field('master_worker_id,count(id) as work_counts')->
  147. group('master_worker_id')->
  148. order('work_counts desc')->
  149. limit(3)->
  150. select()->toArray();
  151. $master_worker_ids = array_column($order_list,'master_worker_id');
  152. if(in_array($master_worker_id,$master_worker_ids)){
  153. $term_amount = 500;
  154. }
  155. $itemData = [
  156. 'permanently_settlement_id' => $permanently_settlement_id,
  157. 'master_worker_id' => $master_worker_id,
  158. 'term' => 3,
  159. 'term_amount' => $term_amount,
  160. 'remark' => $params['item_name'].': 金额--'.$term_amount.';排名:前三',
  161. 'extra' => json_encode([
  162. 'step_days'=>$params['step_days'],'item_name'=>$params['item_name'],
  163. 'start_time'=>$params['start_time'],'end_time'=>$params['end_time']
  164. ]),
  165. ];
  166. self::salaryCreateUpdate($itemData);
  167. return true;
  168. } catch (\Exception $e) {
  169. Log::info('permanently_settlement_id:'.$permanently_settlement_id.':'.$e->getFile().':'.$e->getLine().':'.$e->getMessage());
  170. return false;
  171. }
  172. }
  173. // ≥4.8分且≥80单
  174. public function salary_item_4($permanently_settlement_id,$master_worker_id,$params,$extra = [])
  175. {
  176. try {
  177. $comprehensive_score = MasterWorkerScore::where('worker_id',$master_worker_id)->value('comprehensive_score');
  178. // 查询时间范围内所有已经完单的工单
  179. $order_count = ServiceWork::where('master_worker_id',$master_worker_id)->
  180. where('finished_time','between',[$params['start_time'],$params['end_time']])->
  181. where('service_status','=',3)->where('work_pay_status','=',2)->count();
  182. $term_amount = 0;
  183. if( 4.8 <= (float)$comprehensive_score && 80 <= $order_count){
  184. $term_amount = 500;
  185. }
  186. $itemData = [
  187. 'permanently_settlement_id' => $permanently_settlement_id,
  188. 'master_worker_id' => $master_worker_id,
  189. 'term' => 4,
  190. 'term_amount' => $term_amount,
  191. 'remark' => $params['item_name'].': 金额--'.$term_amount.';评分:--'.$comprehensive_score.';总单量:--'.$order_count,
  192. 'extra' => json_encode([
  193. 'step_days'=>$params['step_days'],'item_name'=>$params['item_name'],
  194. 'start_time'=>$params['start_time'],'end_time'=>$params['end_time'],'comprehensive_score'=>$comprehensive_score,'order_count'=>$order_count,
  195. 'amount'=>$term_amount
  196. ]),
  197. ];
  198. self::salaryCreateUpdate($itemData);
  199. return true;
  200. } catch (\Exception $e) {
  201. Log::info('permanently_settlement_id:'.$permanently_settlement_id.':'.$e->getFile().':'.$e->getLine().':'.$e->getMessage());
  202. return false;
  203. }
  204. }
  205. // 工程师晋升
  206. public function salary_item_5($permanently_settlement_id,$master_worker_id,$params,$extra = [])
  207. {
  208. try {
  209. $title_promotion = MasterWorker::where('id',$master_worker_id)->value('title_promotion');
  210. $amount = 0.00;
  211. switch ($title_promotion){
  212. case 2:
  213. $amount = 1000;
  214. break;
  215. case 3:
  216. $amount = 1500;
  217. break;
  218. }
  219. $itemData = [
  220. 'permanently_settlement_id' => $permanently_settlement_id,
  221. 'master_worker_id' => $master_worker_id,
  222. 'term' => 5,
  223. 'term_amount' => $amount,
  224. 'remark' => $params['item_name'].': 金额--'.$amount.';称号:--'.$title_promotion,
  225. 'extra' => json_encode([
  226. 'step_days'=>$params['step_days'],'item_name'=>$params['item_name'],
  227. 'title_promotion'=>$title_promotion,
  228. 'amount'=>$amount
  229. ]),
  230. ];
  231. self::salaryCreateUpdate($itemData);
  232. return true;
  233. } catch (\Exception $e) {
  234. Log::info('permanently_settlement_id:'.$permanently_settlement_id.':'.$e->getFile().':'.$e->getLine().':'.$e->getMessage());
  235. return false;
  236. }
  237. }
  238. // 投诉订单
  239. public function salary_item_6($permanently_settlement_id,$master_worker_id,$params,$extra = [])
  240. {
  241. try {
  242. // 查询时间范围内所有投诉的工单
  243. $order_count = ReturnWork::where('master_worker_id',$master_worker_id)->
  244. where('finished_time','between',[$params['start_time'],$params['end_time']])->
  245. where('return_work_status','=',4)->count();
  246. $amount = 50.00;
  247. $term_amount = -(float)bcmul($order_count, $amount,2);
  248. $itemData = [
  249. 'permanently_settlement_id' => $permanently_settlement_id,
  250. 'master_worker_id' => $master_worker_id,
  251. 'term' => 6,
  252. 'term_amount' => $term_amount,
  253. 'remark' => $params['item_name'].': 扣减金额--'.$term_amount.';投诉单量:--'.$order_count,// .'xx:--'.$ranking
  254. 'extra' => json_encode([
  255. 'step_days'=>$params['step_days'],'item_name'=>$params['item_name'],
  256. 'start_time'=>$params['start_time'],'end_time'=>$params['end_time'],
  257. 'amount'=>$amount,'order_count'=>$order_count
  258. ]),
  259. ];
  260. self::salaryCreateUpdate($itemData);
  261. return true;
  262. } catch (\Exception $e) {
  263. Log::info('permanently_settlement_id:'.$permanently_settlement_id.':'.$e->getFile().':'.$e->getLine().':'.$e->getMessage());
  264. return false;
  265. }
  266. }
  267. public function salaryCreateUpdate($itemData = [])
  268. {
  269. $wh = ['permanently_settlement_id' => $itemData['permanently_settlement_id'], 'master_worker_id' => $itemData['master_worker_id'], 'term' => $itemData['term']];
  270. $info = self::where($wh)->findOrEmpty();
  271. if($info->isEmpty()){
  272. self::create($itemData);
  273. }else{
  274. self::where($wh)->update($itemData);
  275. }
  276. return true;
  277. }
  278. }