MasterWorkerTemporaryLogic.php 6.5 KB

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