OrderController.php 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. <?php
  2. /**
  3. * 单据管理1
  4. * @author system
  5. * @version 1.0
  6. * @date 2018-09-06 03:23:12
  7. *
  8. */
  9. namespace App\Http\Controllers\Admin\Medical;
  10. use App\Http\Controllers\Admin\Controller;
  11. use App\Models\MedicalOrderModel;
  12. use Illuminate\Http\Request;
  13. use App\Repositories\Base\Criteria\OrderBy;
  14. use App\Repositories\Medical\Criteria\MultiWhere;
  15. use App\Repositories\Medical\OrderRepository;
  16. use Maatwebsite\Excel\Facades\Excel;
  17. use Auth, Validator;
  18. use Illuminate\Support\Facades\Cache;
  19. use Carbon\Carbon;
  20. use GuzzleHttp\Client as GuzzleHttpClient;
  21. use GuzzleHttp\Exception\RequestException;
  22. class OrderController extends Controller
  23. {
  24. public $keySmsCodeExist = 'keySmsCodeExist';
  25. public $expireTimeExist = '';
  26. public $keySmsCode = 'keySmsCode';
  27. public $expireTime = '';
  28. private $repository;
  29. public function __construct(OrderRepository $repository) {
  30. if(!$this->repository) $this->repository = $repository;
  31. }
  32. function index(Request $request) {
  33. $search['keyword'] = $request->input('keyword');
  34. $query = $this->repository->pushCriteria(new MultiWhere($search));
  35. if(isset($request['sort_field']) && $request['sort_field'] && isset($request['sort_field_by'])) {
  36. $query = $query->pushCriteria(new OrderBy($request['sort_field'],$request['sort_field_by']));
  37. }else{
  38. $query = $query->pushCriteria(new OrderBy('id','DESC'));
  39. }
  40. $list = $query->paginate();
  41. return view('admin.medical.order.index',compact('list'));
  42. }
  43. function check(Request $request) {
  44. $request = $request->all();
  45. $search['keyword'] = $request->input('keyword');
  46. $orderby = array();
  47. if(isset($request['sort_field']) && $request['sort_field'] && isset($request['sort_field_by'])) {
  48. $orderby[$request['sort_field']] = $request['sort_field_by'];
  49. }
  50. $list = $this->repository->search($search,$orderby);
  51. return view('admin.medical.order.check',compact('list'));
  52. }
  53. /**
  54. * 添加
  55. *
  56. */
  57. public function create(Request $request)
  58. {
  59. if($request->method() == 'POST') {
  60. return $this->_createSave();
  61. }
  62. return view('admin.medical.order.edit');
  63. }
  64. /**
  65. * 保存修改
  66. */
  67. private function _createSave(){
  68. $data = (array) request('data');
  69. $data['pdf'] = $this->formatUrl($data['pdf']);
  70. $id = $this->repository->create($data);
  71. if($id) {
  72. $url[] = array('url'=>U( 'Medical/Order/index'),'title'=>'返回列表');
  73. $url[] = array('url'=>U( 'Medical/Order/create'),'title'=>'继续添加');
  74. $this->showMessage('添加成功',$url);
  75. }else{
  76. $url[] = array('url'=>U( 'Medical/Order/index'),'title'=>'返回列表');
  77. return $this->showWarning('添加失败',$url);
  78. }
  79. }
  80. /**
  81. *
  82. * 修改
  83. *
  84. *
  85. */
  86. public function update(Request $request) {
  87. if($request->method() == 'POST') {
  88. return $this->_updateSave();
  89. }
  90. $data = $this->repository->find($request->get('id'));
  91. return view('admin.medical.order.edit',compact('data'));
  92. }
  93. public function export(Request $request){
  94. $data = MedicalOrderModel::where('single','!=','')->orwhere('combo','!=','')->get();
  95. foreach ($data as $key=>$val){
  96. if($val['single']!=''){
  97. $single=unserialize($val['single']);
  98. $data[$key]['single'] = '';
  99. foreach ($single as $k_s=>$v_s){
  100. $data[$key]['single'] .= '、'.$v_s->name;
  101. }
  102. $data[$key]['single'] =ltrim($data[$key]['single'], "、");
  103. }
  104. if($val['combo']!=''){
  105. $combo=unserialize($val['combo']);
  106. $data[$key]['combo'] = '';
  107. foreach ($combo as $k_c=>$v_c){
  108. $data[$key]['combo'] .= $v_c->name.':'.$v_c->content.';';
  109. }
  110. $data[$key]['combo']=str_replace('<p>','',$data[$key]['combo']);
  111. $data[$key]['combo']=str_replace('</p>','',$data[$key]['combo']);
  112. }
  113. unset($data[$key]['created_at']);
  114. unset($data[$key]['deleted_at']);
  115. unset($data[$key]['updated_at']);
  116. unset($data[$key]['pdf']);
  117. }
  118. $data =json_encode($data,true);
  119. $data =json_decode($data,true);
  120. //dd($data);
  121. Array_unshift($data,[
  122. '订单ID','联系电话','姓名','民族','性别',
  123. '邮件','籍贯','工作','地址','样本类型','单项','套餐','总价','条形码','备注','年龄'
  124. ]);
  125. //dd($data);
  126. return Excel::create(iconv('UTF-8', 'GBK', '用户数据'),function($excel) use ($data){
  127. $excel->sheet('用户数据', function($sheet) use ($data){
  128. $sheet->rows($data);
  129. });
  130. })->export('xls');
  131. die();
  132. }
  133. public function upload(Request $request)
  134. {
  135. if($request->method() == 'POST') {
  136. $data = $request->all();
  137. $file=$request->file('pdf');
  138. if ( $file->isValid()) { //判断文件是否有效
  139. //$filename = $file->getClientOriginalName(); //文件原名称
  140. $extension = $file->getClientOriginalExtension(); //扩展名
  141. $filename = time() . "." . $extension; //重命名
  142. // echo public_path().'\upload\pdf';die;
  143. $res =$file->move(public_path().'/upload/pdf', $filename); //移动至指定目录
  144. if($res){
  145. $url = '/upload/pdf/'.$filename;
  146. $update['pdf'] = $this->formatUrl($url);
  147. $res = MedicalOrderModel::where('id',$data['id'])->update($update);
  148. $check = MedicalOrderModel::find($data['id']);
  149. $this->getCode($check->mobile);
  150. return $this->showMessage('操作成功');
  151. }else{
  152. return $this->showWarning('操作失败');
  153. }
  154. }
  155. }
  156. }
  157. public function getCode($phone)
  158. {
  159. $ipkeyexist = $this->keySmsCodeExist . $_SERVER["REMOTE_ADDR"] . Carbon::now()->toDateString();
  160. $times = Cache::store('file')->get($ipkeyexist);
  161. $keyexist = $this->keySmsCodeExist . $phone . Carbon::now()->toDateString();;
  162. $times = Cache::store('file')->get($keyexist);
  163. $verify_code = (string)mt_rand(1000, 9999);
  164. $key = $this->keySmsCode . $phone;
  165. Cache::store('file')->put($key, $verify_code, 6000);
  166. $msg = '【精准医学】您的检测报告已完成,点击链接浏览下载 http://t19.9026.com/web/Index';
  167. $result = $this->sendSms($msg, $phone);
  168. // dd($result);
  169. // \Log::info($msg . " res:" . $result);
  170. }
  171. public function sendSms($msg, $mobile) {
  172. $url = "http://api.106txt.com/smsGBK.aspx?";
  173. $account = "swufecredit2017";
  174. $password = "mask751002";
  175. $password = strtoupper(md5($password));
  176. $gwid = 53;
  177. $message = iconv("UTF-8", "GB2312", $msg);
  178. try {
  179. $client = new GuzzleHttpClient();
  180. $data = [
  181. 'action' => 'Send',
  182. 'username' => $account,
  183. 'password' => $password,
  184. 'gwid' => $gwid,
  185. 'mobile' => $mobile,
  186. 'message' => $message,
  187. ];
  188. $apiRequest = $client->post($url, [
  189. 'form_params' => $data,
  190. ]);
  191. $resp = $apiRequest->getBody()->getContents();
  192. $res = iconv("GB2312", "UTF-8", $resp);
  193. $re = json_decode($res, true);
  194. \Log::info("发送短信 到手机:$mobile 内容:$msg RESULT:".$re['RESULT']);
  195. if (trim($re['CODE']) == '1') {
  196. return true;
  197. }
  198. } catch (RequestException $re) {
  199. \Log::info("发送短信错误:".$re->getMessage());
  200. return false;
  201. }
  202. return false;
  203. }
  204. /**
  205. * 保存修改
  206. */
  207. private function _updateSave() {
  208. $data = (array) request('data');
  209. $data['pdf'] = $this->formatUrl($data['pdf']);
  210. $ok = $this->repository->update(request('id'),$data);
  211. if($ok) {
  212. $url[] = array('url'=>U( 'Medical/Order/index'),'title'=>'返回列表');
  213. return $this->showMessage('操作成功',urldecode(request('_referer')));
  214. }else{
  215. $url[] = array('url'=>U( 'Medical/Order/index'),'title'=>'返回列表');
  216. return $this->showWarning('操作失败',$url);
  217. }
  218. }
  219. public function view(Request $request) {
  220. $data = $this->repository->find(request('id'));
  221. $data['single'] = unserialize($data['single']);
  222. $str = '';
  223. if(!empty($data['single'])){
  224. foreach ($data['single'] as $key_s=>$val_s){
  225. $str.=$val_s->name;
  226. }
  227. }
  228. $data['combo'] = unserialize($data['combo']);
  229. return view('admin.medical.order.view',compact('data','str'));
  230. }
  231. /**
  232. *
  233. * 状态改变
  234. *
  235. */
  236. public function status(Request $request) {
  237. $ok = $this->repository->updateStatus(request('id'),request('status'));
  238. if($ok) {
  239. return $this->showMessage('操作成功');
  240. }else{
  241. return $this->showWarning('操作失败');
  242. }
  243. }
  244. /**
  245. * 删除
  246. */
  247. public function destroy(Request $request) {
  248. $cat = MedicalOrderModel::find($request->get('id'));
  249. $bool = $cat->delete();
  250. if($bool) {
  251. return $this->showMessage('操作成功');
  252. }else{
  253. return $this->showWarning("操作失败");
  254. }
  255. }
  256. }