MasterWorkerTemporaryLogic.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  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\adminapi\logic\master_worker;
  15. use think\facade\Db;
  16. use app\common\logic\BaseLogic;
  17. use PhpOffice\PhpSpreadsheet\IOFactory;
  18. use app\common\model\master_worker\MasterWorkerTemporary;
  19. /**
  20. * MasterWorkerTemporary逻辑
  21. * Class MasterWorkerLogicTemporary
  22. * @package app\adminapi\logic\master_worker
  23. */
  24. class MasterWorkerTemporaryLogic extends BaseLogic
  25. {
  26. /**
  27. * @notes 添加
  28. * @param array $params
  29. * @return bool
  30. * @author likeadmin
  31. * @date 2024/07/10 18:17
  32. */
  33. public static function add(array $params): bool
  34. {
  35. Db::startTrans();
  36. try {
  37. if (MasterWorkerTemporary::where('mobile', $params['mobile'])->value('mobile')) {
  38. self::setError('该手机号已存在!');
  39. return false;
  40. }
  41. if($params['category_ids']){
  42. foreach ($params['category_ids'] as $val){
  43. is_array($val)?($ids[] = end($val)):($ids[] = $val);
  44. }
  45. $params['category_ids'] = implode(',',$ids);
  46. }
  47. $number = MasterWorkerTemporary::max('id');
  48. $number++;
  49. $worker_number = str_pad($number, 6, '0', STR_PAD_LEFT);
  50. MasterWorkerTemporary::create([
  51. 'worker_number' => $worker_number,
  52. 'real_name' => $params['real_name'],
  53. 'mobile' => $params['mobile'],
  54. 'is_disable' => $params['is_disable'],
  55. 'work_status' => $params['work_status']??0,
  56. 'remark' => $params['remark']??'',
  57. 'category_ids' => $params['category_ids']??'',
  58. ]);
  59. Db::commit();
  60. return true;
  61. } catch (\Exception $e) {
  62. Db::rollback();
  63. self::setError($e->getMessage());
  64. return false;
  65. }
  66. }
  67. /**
  68. * @notes 编辑
  69. * @param array $params
  70. * @return bool
  71. * @author likeadmin
  72. * @date 2024/07/10 18:17
  73. */
  74. public static function edit(array $params): bool
  75. {
  76. Db::startTrans();
  77. try {
  78. if($params['category_ids']){
  79. foreach ($params['category_ids'] as $val){
  80. is_array($val)?($ids[] = end($val)):($ids[] = $val);
  81. }
  82. $params['category_ids'] = implode(',',$ids);
  83. }
  84. $update = [
  85. 'real_name' => $params['real_name'],
  86. 'is_disable' => $params['is_disable'],
  87. 'work_status' => $params['work_status']??0,
  88. 'remark' => $params['remark']??'',
  89. 'category_ids' => $params['category_ids']??'',
  90. ];
  91. MasterWorkerTemporary::where('id', $params['id'])->update($update);
  92. Db::commit();
  93. return true;
  94. } catch (\Exception $e) {
  95. Db::rollback();
  96. self::setError($e->getMessage());
  97. return false;
  98. }
  99. }
  100. /**
  101. * @notes 删除
  102. * @param array $params
  103. * @return bool
  104. * @author likeadmin
  105. * @date 2024/07/10 18:17
  106. */
  107. public static function delete(array $params): bool
  108. {
  109. return MasterWorkerTemporary::destroy($params['id']);
  110. }
  111. /**
  112. * @notes 获取详情
  113. * @param $params
  114. * @return array
  115. * @author likeadmin
  116. * @date 2024/07/10 18:17
  117. */
  118. public static function detail($params): array
  119. {
  120. $info = MasterWorkerTemporary::findOrEmpty($params['id'])->toArray();
  121. if(!empty($info['category_ids'])){
  122. $info['category_ids'] = explode(',',$info['category_ids']);
  123. $info['category_ids'] = array_map('intval', $info['category_ids']);
  124. }
  125. return $info;
  126. }
  127. /**
  128. * 导入工程师
  129. */
  130. public static function import($file) {
  131. $mobile = [];
  132. try {
  133. // 移动文件到指定目录
  134. $info = $file->move(root_path('public') . 'uploads');
  135. if ($info) {
  136. $filePath = $info->getPathname();
  137. // 读取 Excel 文件
  138. $spreadsheet = IOFactory::load($filePath);
  139. $worksheet = $spreadsheet->getActiveSheet();
  140. $highestRow = $worksheet->getHighestRow();
  141. $number = MasterWorkerTemporary::count();
  142. // 假设第一行为表头,从第二行开始读取数据
  143. for ($row = 2; $row <= $highestRow; $row++) {
  144. $data = [
  145. 'real_name' => $worksheet->getCell('A' . $row)->getValue(),
  146. 'mobile' => $worksheet->getCell('B' . $row)->getValue(),
  147. 'remark' => $worksheet->getCell('C' . $row)->getValue(),
  148. ];
  149. if (empty($data['mobile'])) {
  150. continue;
  151. }
  152. if(MasterWorkerTemporary::where('mobile', $data['mobile'])->value('mobile')){
  153. $mobile[] = $data['mobile'];
  154. continue;
  155. }
  156. $number += 1;
  157. $data['worker_number'] = str_pad($number, 6, '0', STR_PAD_LEFT);
  158. MasterWorkerTemporary::create($data);
  159. }
  160. if ($mobile) {
  161. self::setError('手机号'.implode(',',$mobile).'已存在');
  162. return false;
  163. }
  164. return true;
  165. } else {
  166. self::setError($file->getError());
  167. return false;
  168. }
  169. } catch (\Exception $e) {
  170. self::setError($e->getMessage());
  171. return false;
  172. }
  173. }
  174. }