DeviceRepairController.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <?php
  2. namespace app\api\controller\store;
  3. use app\admin\model\store\DeviceRepair as DeviceRepairModel;
  4. //use think\Controller;
  5. use app\Request;
  6. use crmeb\services\UtilService;
  7. use think\facade\Validate;
  8. /**
  9. * 用户端设备报修表单控制器
  10. * 处理表单展示、提交验证
  11. */
  12. class DeviceRepairController
  13. {
  14. // /**
  15. // * 展示报修表单页面
  16. // * @return \think\response\View
  17. // */
  18. // public function index()
  19. // {
  20. // return $this->fetch();
  21. // }
  22. /**
  23. * 提交报修表单(AJAX接口)
  24. * @return \think\response\Json
  25. */
  26. public function submit(Request $request)
  27. {
  28. // 1. 获取表单数据
  29. // $data = Request::post([
  30. // 'device_name', // 设备名称
  31. // 'device_number', // 数量
  32. // 'order_id',
  33. // 'product_id',
  34. // 'repair_problem', // 报修问题
  35. // 'return_address', // 寄回地址
  36. // 'contact_name', // 联系人
  37. // 'contact_phone' // 联系电话
  38. // ]);
  39. $data= UtilService::postMore([
  40. 'device_name', // 设备名称
  41. 'device_number', // 数量
  42. 'order_id',
  43. 'product_id',
  44. 'repair_problem', // 报修问题
  45. 'return_address', // 寄回地址
  46. 'contact_name', // 联系人
  47. 'contact_phone' // 联系电话
  48. ], $request, true);
  49. // 2. 表单验证
  50. $validate = Validate::make([
  51. 'device_name' => 'require|max:100', // 设备名称必填,最多100字
  52. 'device_number' => 'require|integer|min:1', // 数量必填,正整数
  53. 'repair_problem' => 'require', // 问题描述必填
  54. 'return_address' => 'require|max:255', // 地址必填,最多255字
  55. 'contact_name' => 'require|max:50', // 联系人必填,最多50字
  56. 'contact_phone' => 'require|mobile', // 电话必填,手机号格式
  57. ], [
  58. 'device_name.require' => '请填写设备名称',
  59. 'device_number.require' => '请填写设备数量',
  60. 'device_number.min' => '设备数量至少1台',
  61. 'repair_problem.require' => '请描述报修问题',
  62. 'return_address.require' => '请填写寄回地址',
  63. 'contact_name.require' => '请填写联系人姓名',
  64. 'contact_phone.require' => '请填写联系电话',
  65. 'contact_phone.mobile' => '请填写正确的手机号'
  66. ]);
  67. if (!$validate->check($data)) {
  68. return json(['code' => 0, 'msg' => $validate->getError()]);
  69. }
  70. $rs=DeviceRepairModel::where('order_id', $data['order_id'])->where('product_id', $data['product_id'])->find();
  71. if ($rs){
  72. // return json(['code' => 0, 'msg' => '您已提交过报修单,请勿重复提交']);
  73. return app('json')->fail('您已提交过报修单,请勿重复提交');
  74. }
  75. // 3. 提交表单到数据库
  76. $result = DeviceRepairModel::addRepairForm($data);
  77. if (!$result) {
  78. // return json(['code' => 0, 'msg' => '报修表单提交失败,请重试']);
  79. return app('json')->fail('报修表单提交失败,请重试');
  80. }
  81. // 4. 返回成功(带报修单号)
  82. return app('json')->successful($result);
  83. // return json([
  84. // 'code' => 200,
  85. // 'msg' => '报修表单提交成功',
  86. // 'data' => [
  87. // 'repair_sn' => $result['repair_sn'], // 自动生成的单号
  88. // ]
  89. // ]);
  90. }
  91. }