MasterWorkerTemporaryLogic.php 6.6 KB

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