OrderController.php 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  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->input();
  137. $url = str_replace(env('APP_URL'),public_path(),$data['file']);
  138. $ok = unlink($url);
  139. if($ok) {
  140. $data['status'] = 1;
  141. }else{
  142. $data['status'] = 0;
  143. }
  144. return $this->api($data);
  145. }
  146. }
  147. public function getCode($phone)
  148. {
  149. $ipkeyexist = $this->keySmsCodeExist . $_SERVER["REMOTE_ADDR"] . Carbon::now()->toDateString();
  150. $times = Cache::store('file')->get($ipkeyexist);
  151. $keyexist = $this->keySmsCodeExist . $phone . Carbon::now()->toDateString();;
  152. $times = Cache::store('file')->get($keyexist);
  153. $verify_code = (string)mt_rand(1000, 9999);
  154. $key = $this->keySmsCode . $phone;
  155. Cache::store('file')->put($key, $verify_code, 6000);
  156. $msg = '【精准医学】您的检测报告已完成,点击链接浏览下载 http://t19.9026.com';
  157. $result = $this->sendSms($msg, $phone);
  158. // dd($result);
  159. // \Log::info($msg . " res:" . $result);
  160. }
  161. public function sendSms($msg, $mobile) {
  162. $url = "http://api.106txt.com/smsGBK.aspx?";
  163. $account = "swufecredit2017";
  164. $password = "mask751002";
  165. $password = strtoupper(md5($password));
  166. $gwid = 53;
  167. $message = iconv("UTF-8", "GB2312", $msg);
  168. try {
  169. $client = new GuzzleHttpClient();
  170. $data = [
  171. 'action' => 'Send',
  172. 'username' => $account,
  173. 'password' => $password,
  174. 'gwid' => $gwid,
  175. 'mobile' => $mobile,
  176. 'message' => $message,
  177. ];
  178. $apiRequest = $client->post($url, [
  179. 'form_params' => $data,
  180. ]);
  181. $resp = $apiRequest->getBody()->getContents();
  182. $res = iconv("GB2312", "UTF-8", $resp);
  183. $re = json_decode($res, true);
  184. \Log::info("发送短信 到手机:$mobile 内容:$msg RESULT:".$re['RESULT']);
  185. if (trim($re['CODE']) == '1') {
  186. return true;
  187. }
  188. } catch (RequestException $re) {
  189. \Log::info("发送短信错误:".$re->getMessage());
  190. return false;
  191. }
  192. return false;
  193. }
  194. /**
  195. * 保存修改
  196. */
  197. private function _updateSave() {
  198. $data = (array) request('data');
  199. $data['pdf'] = $this->formatUrl($data['pdf']);
  200. $ok = $this->repository->update(request('id'),$data);
  201. $check = MedicalOrderModel::find(request('id'));
  202. $this->getCode($check->mobile);
  203. if($ok) {
  204. $url[] = array('url'=>U( 'Medical/Order/index'),'title'=>'返回列表');
  205. return $this->showMessage('操作成功',urldecode(request('_referer')));
  206. }else{
  207. $url[] = array('url'=>U( 'Medical/Order/index'),'title'=>'返回列表');
  208. return $this->showWarning('操作失败',$url);
  209. }
  210. }
  211. public function view(Request $request) {
  212. $data = $this->repository->find(request('id'));
  213. $data['single'] = unserialize($data['single']);
  214. $str = '';
  215. if(!empty($data['single'])){
  216. foreach ($data['single'] as $key_s=>$val_s){
  217. $str.=$val_s->name;
  218. }
  219. }
  220. $data['combo'] = unserialize($data['combo']);
  221. return view('admin.medical.order.view',compact('data','str'));
  222. }
  223. /**
  224. *
  225. * 状态改变
  226. *
  227. */
  228. public function status(Request $request) {
  229. $ok = $this->repository->updateStatus(request('id'),request('status'));
  230. if($ok) {
  231. return $this->showMessage('操作成功');
  232. }else{
  233. return $this->showWarning('操作失败');
  234. }
  235. }
  236. /**
  237. * 删除
  238. */
  239. public function destroy(Request $request) {
  240. $cat = MedicalOrderModel::find($request->get('id'));
  241. $bool = $cat->delete();
  242. if($bool) {
  243. return $this->showMessage('操作成功');
  244. }else{
  245. return $this->showWarning("操作失败");
  246. }
  247. }
  248. }