Verify_bak.php 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace app\shop\controller;
  11. use app\model\member\Member;
  12. use app\model\store\Store;
  13. use app\model\verify\Verifier;
  14. use app\model\verify\Verify as VerifyModel;
  15. use app\model\verify\VerifyRecord;
  16. use app\model\web\Config as ConfigModel;
  17. /**
  18. * 核销
  19. * Class Verify
  20. * @package app\shop\controller
  21. */
  22. class Verify extends BaseShop
  23. {
  24. /**
  25. * 核销码
  26. * @return array|mixed
  27. */
  28. public function lists()
  29. {
  30. $verify_model = new VerifyModel();
  31. if (request()->isAjax()) {
  32. $page = input('page', 1);
  33. $page_size = input('page_size', PAGE_LIST_ROWS);
  34. $order = input("order", "create_time desc");
  35. $verify_type = input('verify_type', "");//验证类型
  36. $verify_code = input('verify_code', "");//验证码
  37. $verifier_name = input('verifier_name', "");
  38. $start_time = input("start_time", '');
  39. $end_time = input("end_time", '');
  40. $verify_from = input('verify_from', '');
  41. $condition = [
  42. [ 'site_id', "=", $this->site_id ],
  43. [ 'is_verify', '=', 1 ]
  44. ];
  45. if (!empty($verify_type)) {
  46. $condition[] = [ "verify_type", "=", $verify_type ];
  47. }
  48. if (!empty($verify_from)) {
  49. $condition[] = [ "verify_from", "=", $verify_from ];
  50. }
  51. if (!empty($verify_code)) {
  52. $condition[] = [ "verify_code", 'like', '%' . $verify_code . '%' ];
  53. }
  54. if (!empty($verifier_name)) {
  55. $condition[] = [ 'verifier_name', 'like', '%' . $verifier_name . '%' ];
  56. }
  57. if (!empty($start_time) && empty($end_time)) {
  58. $condition[] = [ 'verify_time', '>=', date_to_time($start_time) ];
  59. } elseif (empty($start_time) && !empty($end_time)) {
  60. $condition[] = [ "verify_time", "<=", date_to_time($end_time) ];
  61. } elseif (!empty($start_time) && !empty($end_time)) {
  62. $condition[] = [ 'verify_time', 'between', [ date_to_time($start_time), date_to_time($end_time) ] ];
  63. }
  64. $list = $verify_model->getVerifyPageList($condition, $page, $page_size, $order, $field = 'id, verify_code, verify_type, verify_type_name, verify_content_json, verifier_id, verifier_name,verify_from,verify_remark, is_verify, create_time, verify_time');
  65. return $list;
  66. } else {
  67. $verify_type = $verify_model->getVerifyType();
  68. $verify_from = $verify_model->verifyFrom;
  69. $this->assign('verify_from', $verify_from);
  70. $this->assign('verify_type', $verify_type);
  71. return $this->fetch("verify/lists");
  72. }
  73. }
  74. /**
  75. * 核销记录
  76. * @return mixed
  77. */
  78. public function records()
  79. {
  80. $verify_model = new VerifyModel();
  81. $verify_record_model = new VerifyRecord();
  82. $verify_code = input('verify_code', "");//验证码
  83. if (request()->isAjax()) {
  84. $page = input('page', 1);
  85. $page_size = input('page_size', PAGE_LIST_ROWS);
  86. $order = input("order", "create_time desc");
  87. $verify_type = input('verify_type', "");//验证类型
  88. $verifier_name = input('verifier_name', "");
  89. $start_time = input("start_time", '');
  90. $end_time = input("end_time", '');
  91. $store_id = input('store_id', '');
  92. $condition = [
  93. [ 'vr.site_id', "=", $this->site_id ],
  94. // ['is_verify', '=', 1]
  95. ];
  96. if (!empty($verify_type)) {
  97. $condition[] = [ "v.verify_type", "=", $verify_type ];
  98. }
  99. if (!empty($store_id)) {
  100. $condition[] = [ "vr.store_id", "=", $store_id ];
  101. }
  102. if (!empty($verify_code)) {
  103. $condition[] = [ "vr.verify_code", 'like', '%' . $verify_code . '%' ];
  104. }
  105. if (!empty($verifier_name)) {
  106. $condition[] = [ 'vr.verifier_name', 'like', '%' . $verifier_name . '%' ];
  107. }
  108. if (!empty($start_time) && empty($end_time)) {
  109. $condition[] = [ 'vr.verify_time', '>=', date_to_time($start_time) ];
  110. } elseif (empty($start_time) && !empty($end_time)) {
  111. $condition[] = [ "vr.verify_time", "<=", date_to_time($end_time) ];
  112. } elseif (!empty($start_time) && !empty($end_time)) {
  113. $condition[] = [ 'vr.verify_time', 'between', [ date_to_time($start_time), date_to_time($end_time) ] ];
  114. }
  115. $list = $verify_record_model->getVerifyRecordsViewPageList($condition, $page, $page_size, $order, $field = 'id, verify_code, verify_type, verify_type_name, verify_content_json, verifier_id, verifier_name,verify_from,verify_remark, is_verify, create_time, verify_time');
  116. return $list;
  117. } else {
  118. $verify_type = $verify_model->getVerifyType();
  119. $verify_from = $verify_model->verifyFrom;
  120. $this->assign('verify_code', $verify_code);
  121. $this->assign('verify_from', $verify_from);
  122. $this->assign('verify_type', $verify_type);
  123. $store_list = ( new Store() )->getStoreList([ [ 'site_id', '=', $this->site_id ] ], 'store_name,store_id');
  124. $this->assign('store_list', $store_list[ 'data' ]);
  125. return $this->fetch("verify/records");
  126. }
  127. }
  128. /**
  129. * 订单核销
  130. * @return mixed
  131. */
  132. public function orderverify()
  133. {
  134. $verify_model = new VerifyModel();
  135. if (request()->isAjax()) {
  136. $page = input('page', 1);
  137. $page_size = input('page_size', PAGE_LIST_ROWS);
  138. $verify_code = input('verify_code', "");
  139. $start_time = input("start_time", '');
  140. $end_time = input("end_time", '');
  141. $verify_from = input('verify_from', '');
  142. $verify_type = input('verify_type', '');
  143. $is_verify = input('is_verify', '');
  144. $condition = [
  145. [ 'site_id', "=", $this->site_id ],
  146. ];
  147. if (!empty($verify_type)) {
  148. $condition[] = [ "verify_type", "=", $verify_type ];
  149. }
  150. if ($is_verify !== '') {
  151. $condition[] = [ "is_verify", "=", $is_verify ];
  152. }
  153. if (!empty($verify_from)) {
  154. $condition[] = [ "verify_from", "=", $verify_from ];
  155. }
  156. if (!empty($verify_code)) {
  157. $condition[] = [ "verify_code", 'like', '%' . $verify_code . '%' ];
  158. }
  159. if (!empty($start_time) && empty($end_time)) {
  160. $condition[] = [ 'create_time', '>=', date_to_time($start_time) ];
  161. } elseif (empty($start_time) && !empty($end_time)) {
  162. $condition[] = [ "create_time", "<=", date_to_time($end_time) ];
  163. } elseif (!empty($start_time) && !empty($end_time)) {
  164. $condition[] = [ 'create_time', 'between', [ date_to_time($start_time), date_to_time($end_time) ] ];
  165. }
  166. $list = $verify_model->getVerifyPageList($condition, $page, $page_size, 'id desc');
  167. return $list;
  168. } else {
  169. $verify_count = $verify_model->getVerifyInfo([ [ 'site_id', '=', $this->site_id ] ], 'count(id) as total_count, sum(verify_use_num) as verify_use_num,is_verify,verify_content_json')[ 'data' ] ?? [];
  170. $this->assign('total_count', $verify_count[ 'total_count' ] ?? 0);
  171. $this->assign('verify_use_num', $verify_count[ 'verify_use_num' ] ?? 0);
  172. $verify_info = $verify_model->getVerifyInfo([ [ 'site_id', '=', $this->site_id ], [ 'verify_type', '=', 'virtualgoods' ] ], 'count(id) as total_count, sum(verify_total_count) as verify_total_count, sum(verify_use_num) as verify_use_num,is_verify,verify_content_json')[ 'data' ] ?? [];
  173. $this->assign('verify_goods_num', (int) abs($verify_info[ 'verify_total_count' ] - $verify_info[ 'verify_use_num' ]));
  174. $this->assign('verify_goods_count', $verify_info[ 'total_count' ]);
  175. $verify_info = $verify_model->getVerifyInfo([ [ 'site_id', '=', $this->site_id ], [ 'verify_type', '=', 'pickup' ] ], 'count(id) as total_count,sum(verify_total_count) as verify_total_count, sum(verify_use_num) as verify_use_num,is_verify,verify_content_json')[ 'data' ] ?? [];
  176. $this->assign('pickup_num', (int) abs($verify_info[ 'verify_total_count' ] - $verify_info[ 'verify_use_num' ]));
  177. $this->assign('pickup_count', $verify_info[ 'total_count' ]);
  178. $card_goods_count = $verify_model->getVerifyCount([ [ 'site_id', '=', $this->site_id ], [ 'verify_type', '=', 'cardgoods' ] ], 'id')[ 'data' ] ?? [];
  179. $verify_info = $verify_model->getVerifyInfo([ [ 'site_id', '=', $this->site_id ], [ 'verify_type', '=', 'cardgoods' ], [ 'verify_total_count', '>', 0 ] ], 'sum(verify_total_count) as verify_total_count, sum(verify_use_num) as verify_use_num,is_verify,verify_content_json')[ 'data' ] ?? [];
  180. $card_goods_num = (int) abs($verify_info[ 'verify_total_count' ] - $verify_info[ 'verify_use_num' ]);
  181. $card_goods_num += $verify_model->getVerifyCount([ [ 'site_id', '=', $this->site_id ], [ 'verify_type', '=', 'cardgoods' ], [ 'verify_total_count', '=', 0 ], [ 'expire_time', '>', 0 ], [ 'expire_time', '<', time() ] ], 'id')[ 'data' ];
  182. $this->assign('card_goods_num', $card_goods_num);
  183. $this->assign('card_goods_count', $card_goods_count);
  184. $verify_type = $verify_model->getVerifyType();
  185. $this->assign('verify_type', $verify_type);
  186. return $this->fetch("verify/order_verify");
  187. }
  188. }
  189. /**
  190. * 核销信息
  191. */
  192. public function verifyInfo()
  193. {
  194. $id = input('id', '');
  195. $verify_model = new VerifyModel();
  196. $info = $verify_model->getVerifyInfo([ [ 'id', '=', $id ], [ 'site_id', '=', $this->site_id ] ]);
  197. return $info;
  198. }
  199. /**
  200. * 核销台
  201. * @return mixed
  202. */
  203. public function verifyCard()
  204. {
  205. if (request()->isAjax()) {
  206. $verify_code = input("verify_code", "");
  207. $verify_model = new VerifyModel();
  208. $res = $verify_model->getVerifyInfo([ [ "verify_code", "=", $verify_code ], [ "site_id", "=", $this->site_id ] ]);
  209. return $res;
  210. } else {
  211. return $this->fetch("verify/verify_card");
  212. }
  213. }
  214. /**
  215. * 核销人员
  216. * @return mixed
  217. */
  218. public function user()
  219. {
  220. if (request()->isAjax()) {
  221. $verifier = new Verifier();
  222. $page = input('page', 1);
  223. $page_size = input('page_size', PAGE_LIST_ROWS);
  224. $order = input("order", "v.create_time desc");
  225. $verifier_name = input('verifier_name', '');
  226. $verifier_type = input('verifier_type', 0);
  227. $store_id = input('store_id', 0);
  228. $condition = [];
  229. $condition[] = [ 'v.site_id', "=", $this->site_id ];
  230. if ($verifier_name) {
  231. $condition[] = [ 'v.verifier_name', '=', $verifier_name ];
  232. }
  233. if ($verifier_type != '') {
  234. $condition[] = [ 'v.verifier_type', '=', $verifier_type ];
  235. }
  236. if ($store_id) {
  237. $condition[] = [ 'v.store_id', '=', $store_id ];
  238. }
  239. $list = $verifier->getVerifierPageList($condition, $page, $page_size, $order);
  240. return $list;
  241. } else {
  242. // 门店列表
  243. $store_model = new Store();
  244. $store_list = $store_model->getStoreList([ [ 'site_id', "=", $this->site_id ], [ 'is_frozen', '=', 0 ] ], 'store_id,store_name', 'store_id desc')[ 'data' ];
  245. $this->assign('store_list', $store_list);
  246. return $this->fetch("verify/user");
  247. }
  248. }
  249. /**
  250. * 添加核销人员
  251. * @return mixed
  252. */
  253. public function addUser()
  254. {
  255. if (request()->isAjax()) {
  256. $verifier_name = input("verifier_name", "");
  257. $member_id = input("member_id", 0);//会员账号
  258. $uid = input("uid", 0);//管理员账号
  259. $verifier_type = input('verifier_type', 0);//核销员类型:0平台核销员,1门店核销员
  260. $store_id = input('store_id', 0);//门店ID
  261. $model = new Verifier();
  262. $data = [
  263. 'site_id' => $this->site_id,
  264. "verifier_name" => $verifier_name,
  265. "member_id" => $member_id,
  266. "uid" => $uid,
  267. 'verifier_type' => $verifier_type,
  268. 'store_id' => $store_id
  269. ];
  270. $result = $model->addVerifier($data);
  271. return $result;
  272. } else {
  273. $upload_config_model = new ConfigModel();
  274. $upload_config_result = $upload_config_model->getDefaultImg($this->site_id, $this->app_module)[ 'data' ][ 'value' ];
  275. $this->assign("default_headimg", $upload_config_result[ 'head' ]);
  276. // 门店列表
  277. $store_model = new Store();
  278. $store_list = $store_model->getStoreList([ [ 'site_id', "=", $this->site_id ], [ 'is_frozen', '=', 0 ] ], 'store_id,store_name', 'store_id desc')[ 'data' ];
  279. $this->assign('store_list', $store_list);
  280. return $this->fetch("verify/add_user");
  281. }
  282. }
  283. /**
  284. * 编辑核销人员
  285. * @return mixed
  286. */
  287. public function editUser()
  288. {
  289. $verifier_id = input("verifier_id", 0);//核销员id
  290. $model = new Verifier();
  291. if (request()->isAjax()) {
  292. $verifier_name = input("verifier_name", "");
  293. $member_id = input("member_id", 0);//会员账号
  294. $verifier_type = input('verifier_type', 0);//核销员类型:0平台核销员,1门店核销员
  295. $store_id = input('store_id', 0);//门店ID
  296. $data = [
  297. 'verifier_name' => $verifier_name,
  298. 'member_id' => $member_id,
  299. 'uid' => 0,
  300. 'verifier_type' => $verifier_type,
  301. 'store_id' => $verifier_type == 1 ? $store_id : 0
  302. ];
  303. $condition = array (
  304. [ 'verifier_id', '=', $verifier_id ],
  305. [ 'site_id', '=', $this->site_id ],
  306. );
  307. $result = $model->editVerifier($data, $condition);
  308. return $result;
  309. } else {
  310. $this->assign("verifier_id", $verifier_id);
  311. //用户信息
  312. $info = $model->getVerifierInfo([
  313. [ "verifier_id", "=", $verifier_id ],
  314. [ "site_id", "=", $this->site_id ],
  315. ])[ 'data' ];
  316. if (empty($info)) $this->error('未获取到核销员数据', addon_url('shop/verify/user'));
  317. $info[ "member_name" ] = '';
  318. if (!empty($info[ "member_id" ])) {
  319. $member_model = new Member();
  320. $member_info = $member_model->getMemberInfo([ [ "member_id", "=", $info[ "member_id" ] ] ], "username")[ "data" ];
  321. $info[ "member_name" ] = $member_info[ "username" ];
  322. }
  323. if ($info[ 'verifier_type' ] == 1) {
  324. // 门店列表
  325. $store_model = new Store();
  326. $store = $store_model->getStoreInfo([ [ 'store_id', '=', $info[ 'store_id' ] ] ], 'store_name')[ 'data' ];
  327. $info[ 'store_name' ] = $store[ 'store_name' ];
  328. }
  329. $this->assign("data", $info);
  330. $upload_config_model = new ConfigModel();
  331. $upload_config_result = $upload_config_model->getDefaultImg($this->site_id, $this->app_module)[ 'data' ][ 'value' ];
  332. $this->assign("default_headimg", $upload_config_result[ 'head' ]);
  333. // 门店列表
  334. $store_model = new Store();
  335. $store_list = $store_model->getStoreList([ [ 'site_id', "=", $this->site_id ], [ 'is_frozen', '=', 0 ] ], 'store_id,store_name', 'store_id desc')[ 'data' ];
  336. $this->assign('store_list', $store_list);
  337. return $this->fetch("verify/edit_user");
  338. }
  339. }
  340. /**
  341. * 删除核销人员
  342. * @return mixed
  343. */
  344. public function deleteUser()
  345. {
  346. if (request()->isAjax()) {
  347. $verifier = new Verifier();
  348. $verifier_id = input('ids', 0);
  349. $res = $verifier->deleteVerifier($verifier_id, $this->site_id);
  350. return $res;
  351. }
  352. }
  353. /**
  354. * 核销
  355. */
  356. public function verify()
  357. {
  358. $info = array (
  359. "verifier_id" => $this->uid,
  360. "verifier_name" => $this->user_info[ 'username' ],
  361. "verify_from" => 'shop'
  362. );
  363. $verify_code = input("verify_code", "");
  364. $verify_model = new VerifyModel();
  365. $res = $verify_model->verify($info, $verify_code);
  366. return $res;
  367. }
  368. /**
  369. * 搜索会员
  370. * 不是菜单 不入权限
  371. */
  372. public function searchMember()
  373. {
  374. if (request()->isAjax()) {
  375. $search_text = input('search_text', '');
  376. $member_model = new Member();
  377. $member_info = $member_model->getMemberInfo([ [ 'username|mobile', '=', $search_text ], [ 'site_id', '=', $this->site_id ] ]);
  378. return $member_info;
  379. }
  380. }
  381. /**
  382. * 核销记录导出
  383. */
  384. public function exportVerify()
  385. {
  386. $verify_model = new VerifyModel();
  387. $page = input('page', 1);
  388. $page_size = 0;
  389. $order = input("order", "create_time desc");
  390. $verify_type = input('verify_type', "");//验证类型
  391. $verify_code = input('verify_code', "");//验证码
  392. $verifier_name = input('verifier_name', "");
  393. $start_time = input("start_time", '');
  394. $end_time = input("end_time", '');
  395. $condition = [
  396. [ 'site_id', "=", $this->site_id ],
  397. [ 'is_verify', '=', 1 ]
  398. ];
  399. if (!empty($verify_type)) {
  400. $condition[] = [ "verify_type", "=", $verify_type ];
  401. }
  402. if (!empty($verify_code)) {
  403. $condition[] = [ "verify_code", 'like', '%' . $verify_code . '%' ];
  404. }
  405. if (!empty($verifier_name)) {
  406. $condition[] = [ 'verifier_name', 'like', '%' . $verifier_name . '%' ];
  407. }
  408. if (!empty($start_time) && empty($end_time)) {
  409. $condition[] = [ 'verify_time', '>=', date_to_time($start_time) ];
  410. } elseif (empty($start_time) && !empty($end_time)) {
  411. $condition[] = [ "verify_time", "<=", date_to_time($end_time) ];
  412. } elseif (!empty($start_time) && !empty($end_time)) {
  413. $condition[] = [ 'verify_time', 'between', [ date_to_time($start_time), date_to_time($end_time) ] ];
  414. }
  415. $list_result = $verify_model->getVerifyPageList($condition, $page, $page_size, $order, $field = 'id, verify_code, verify_type, verify_type_name, verify_content_json, verifier_id, verifier_name, is_verify, create_time, verify_time');
  416. $list = $list_result[ 'data' ][ 'list' ];
  417. // 实例化excel
  418. $phpExcel = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
  419. $phpExcel->getProperties()->setTitle("核销记录");
  420. $phpExcel->getProperties()->setSubject("核销记录");
  421. //单独添加列名称
  422. $phpExcel->setActiveSheetIndex(0);
  423. $phpExcel->getActiveSheet()->setCellValue("A1", '核销码');
  424. $phpExcel->getActiveSheet()->setCellValue("B1", '核销类型');
  425. $phpExcel->getActiveSheet()->setCellValue("C1", '核销员');
  426. $phpExcel->getActiveSheet()->setCellValue("D1", '状态');
  427. $phpExcel->getActiveSheet()->setCellValue("E1", '创建时间');
  428. $phpExcel->getActiveSheet()->setCellValue("F1", '核销时间');
  429. if (!empty($list)) {
  430. foreach ($list as $k => $v) {
  431. $start = $k + 2;
  432. $phpExcel->getActiveSheet()->setCellValue('A' . $start, $v[ 'verify_code' ] . "\t");
  433. $phpExcel->getActiveSheet()->setCellValue('B' . $start, $v[ 'verify_type_name' ] . "\t");
  434. $phpExcel->getActiveSheet()->setCellValue('C' . $start, $v[ 'verifier_name' ] . "\t");
  435. if ($v[ 'is_verify' ] == 1) {
  436. $verify_status = "已核销";
  437. } else {
  438. $verify_status = "尚未核销";
  439. }
  440. $phpExcel->getActiveSheet()->setCellValue('D' . $start, $verify_status . "\t");
  441. $phpExcel->getActiveSheet()->setCellValue('E' . $start, time_to_date($v[ 'create_time' ]) . "\t");
  442. $phpExcel->getActiveSheet()->setCellValue('F' . $start, time_to_date($v[ 'verify_time' ]) . "\t");
  443. }
  444. }
  445. // 重命名工作sheet
  446. $phpExcel->getActiveSheet()->setTitle('核销记录');
  447. // 设置第一个sheet为工作的sheet
  448. $phpExcel->setActiveSheetIndex(0);
  449. // 保存Excel 2007格式文件,保存路径为当前路径,名字为export.xlsx
  450. $objWriter = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($phpExcel, 'Xlsx');
  451. $file = date('Y年m月d日-核销记录', time()) . '.xlsx';
  452. $objWriter->save($file);
  453. header("Content-type:application/octet-stream");
  454. $filename = basename($file);
  455. header("Content-Disposition:attachment;filename = " . $filename);
  456. header("Accept-ranges:bytes");
  457. header("Accept-length:" . filesize($file));
  458. readfile($file);
  459. unlink($file);
  460. exit;
  461. }
  462. }