OrderController.php 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  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. $arr[0]['name'] = '男';
  91. $arr[0]['sex'] = 1;
  92. $arr[1]['name'] = '女';
  93. $arr[1]['sex'] =2;
  94. $data = $this->repository->find($request->get('id'));
  95. return view('admin.medical.order.edit',compact('data','arr'));
  96. }
  97. public function export(Request $request){
  98. $data = MedicalOrderModel::where('single','!=','')->orwhere('combo','!=','')->get();
  99. foreach ($data as $key=>$val){
  100. if($val['single']!=''){
  101. $single=unserialize($val['single']);
  102. $data[$key]['single'] = '';
  103. foreach ($single as $k_s=>$v_s){
  104. $data[$key]['single'] .= '、'.$v_s->name;
  105. }
  106. $data[$key]['single'] =ltrim($data[$key]['single'], "、");
  107. }
  108. if($val['combo']!=''){
  109. $combo=unserialize($val['combo']);
  110. $data[$key]['combo'] = '';
  111. foreach ($combo as $k_c=>$v_c){
  112. $data[$key]['combo'] .= $v_c->name.':'.$v_c->content.';';
  113. }
  114. $data[$key]['combo']=str_replace('<p>','',$data[$key]['combo']);
  115. $data[$key]['combo']=str_replace('</p>','',$data[$key]['combo']);
  116. }
  117. unset($data[$key]['created_at']);
  118. unset($data[$key]['deleted_at']);
  119. unset($data[$key]['updated_at']);
  120. unset($data[$key]['pdf']);
  121. }
  122. $data =json_encode($data,true);
  123. $data =json_decode($data,true);
  124. //dd($data);
  125. Array_unshift($data,[
  126. '订单ID','联系电话','姓名','民族','性别',
  127. '邮件','籍贯','工作','地址','样本类型','单项','套餐','总价','条形码','备注','年龄'
  128. ]);
  129. //dd($data);
  130. return Excel::create(iconv('UTF-8', 'GBK', '用户数据'),function($excel) use ($data){
  131. $excel->sheet('用户数据', function($sheet) use ($data){
  132. $sheet->rows($data);
  133. });
  134. })->export('xls');
  135. die();
  136. }
  137. public function upload(Request $request)
  138. {
  139. if($request->method() == 'POST') {
  140. $data = $request->input();
  141. $url = str_replace(env('APP_URL'),public_path(),$data['file']);
  142. $ok = unlink($url);
  143. if($ok) {
  144. $data['status'] = 1;
  145. }else{
  146. $data['status'] = 0;
  147. }
  148. return $this->api($data);
  149. }
  150. }
  151. public function getCode($phone)
  152. {
  153. $ipkeyexist = $this->keySmsCodeExist . $_SERVER["REMOTE_ADDR"] . Carbon::now()->toDateString();
  154. $times = Cache::store('file')->get($ipkeyexist);
  155. $keyexist = $this->keySmsCodeExist . $phone . Carbon::now()->toDateString();;
  156. $times = Cache::store('file')->get($keyexist);
  157. $verify_code = (string)mt_rand(1000, 9999);
  158. $key = $this->keySmsCode . $phone;
  159. Cache::store('file')->put($key, $verify_code, 6000);
  160. $msg = '【精准医学】您的检测报告已完成,点击链接浏览下载 http://t19.9026.com';
  161. $result = $this->sendSms($msg, $phone);
  162. // dd($result);
  163. // \Log::info($msg . " res:" . $result);
  164. }
  165. public function sendSms($msg, $mobile) {
  166. $url = "http://api.106txt.com/smsGBK.aspx?";
  167. $account = "swufecredit2017";
  168. $password = "mask751002";
  169. $password = strtoupper(md5($password));
  170. $gwid = 53;
  171. $message = iconv("UTF-8", "GB2312", $msg);
  172. try {
  173. $client = new GuzzleHttpClient();
  174. $data = [
  175. 'action' => 'Send',
  176. 'username' => $account,
  177. 'password' => $password,
  178. 'gwid' => $gwid,
  179. 'mobile' => $mobile,
  180. 'message' => $message,
  181. ];
  182. $apiRequest = $client->post($url, [
  183. 'form_params' => $data,
  184. ]);
  185. $resp = $apiRequest->getBody()->getContents();
  186. $res = iconv("GB2312", "UTF-8", $resp);
  187. $re = json_decode($res, true);
  188. \Log::info("发送短信 到手机:$mobile 内容:$msg RESULT:".$re['RESULT']);
  189. if (trim($re['CODE']) == '1') {
  190. return true;
  191. }
  192. } catch (RequestException $re) {
  193. \Log::info("发送短信错误:".$re->getMessage());
  194. return false;
  195. }
  196. return false;
  197. }
  198. /**
  199. * 保存修改
  200. */
  201. private function _updateSave() {
  202. $data = (array) request('data');
  203. $data['pdf'] = $this->formatUrl($data['pdf']);
  204. $ok = $this->repository->update(request('id'),$data);
  205. $check = MedicalOrderModel::find(request('id'));
  206. $this->getCode($check->mobile);
  207. if($ok) {
  208. $url[] = array('url'=>U( 'Medical/Order/index'),'title'=>'返回列表');
  209. return $this->showMessage('操作成功',urldecode(request('_referer')));
  210. }else{
  211. $url[] = array('url'=>U( 'Medical/Order/index'),'title'=>'返回列表');
  212. return $this->showWarning('操作失败',$url);
  213. }
  214. }
  215. public function view(Request $request) {
  216. $data = $this->repository->find(request('id'));
  217. $data['single'] = unserialize($data['single']);
  218. $str = '';
  219. if(!empty($data['single'])){
  220. foreach ($data['single'] as $key_s=>$val_s){
  221. $str.=$val_s->name;
  222. }
  223. }
  224. $data['combo'] = unserialize($data['combo']);
  225. return view('admin.medical.order.view',compact('data','str'));
  226. }
  227. /**
  228. *
  229. * 状态改变
  230. *
  231. */
  232. public function status(Request $request) {
  233. $ok = $this->repository->updateStatus(request('id'),request('status'));
  234. if($ok) {
  235. return $this->showMessage('操作成功');
  236. }else{
  237. return $this->showWarning('操作失败');
  238. }
  239. }
  240. /**
  241. * 删除
  242. */
  243. public function destroy(Request $request) {
  244. $cat = MedicalOrderModel::find($request->get('id'));
  245. $bool = $cat->delete();
  246. if($bool) {
  247. return $this->showMessage('操作成功');
  248. }else{
  249. return $this->showWarning("操作失败");
  250. }
  251. }
  252. }