WithdrawCashController.php 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: tandunzhao
  5. * Date: 2017/11/20
  6. * Time: 下午4:12
  7. */
  8. namespace App\Http\Controllers\Manage\Finance;
  9. use App\Http\Controllers\Manage\Finance\Transformers\WithdrawCashFinancialTransformer;
  10. use App\Http\Controllers\Manage\Finance\Transformers\WithdrawCashTransformer;
  11. use App\Modules\Finance\Services\CashAccountService;
  12. use App\Modules\Finance\Services\FinanceService;
  13. use App\Modules\Finance\Services\FinancialConfigService;
  14. use App\Modules\Finance\Services\FinancialStatService;
  15. use App\Modules\Finance\Services\WithdrawCashService;
  16. use Illuminate\Http\Request;
  17. class WithdrawCashController extends BaseController
  18. {
  19. /**
  20. * @apiDefine Finance 结算提现模块
  21. */
  22. /**
  23. * @apiVersion 1.0.0
  24. * @apiDescription 申请提现
  25. * @api {POST} addWithdrawCash 添加提现信息
  26. * @apiGroup Finance
  27. * @apiName addWithdrawCash
  28. * @apiParam {Number} distribution_channel_id 渠道id.
  29. * @apiParam {Number} amount 提现金额.
  30. * @apiParam {String} [remark] 备注说明.
  31. * @apiSuccess {Number} enable_amount 可提现总额.
  32. * @apiSuccess {Number} withdraw_pending_amount 提现中金额.
  33. * @apiSuccessExample {json} Success-Response:
  34. *
  35. * {
  36. * "code": 0,
  37. * "msg": "",
  38. * "data":{
  39. * "enable_amount": 70,
  40. * "withdraw_pending_amount": 1100
  41. * }
  42. * }
  43. */
  44. function add_withdrawCash(Request $request)
  45. {
  46. $distribution_channel_id = $request->has('distribution_channel_id') ? $request->input('distribution_channel_id') : '';
  47. if (empty($distribution_channel_id)) {
  48. return response()->error("PARAM_EMPTY");
  49. }
  50. $amount = $request->has('amount') ? $request->input('amount') : '';
  51. if (!is_numeric($amount)) {
  52. return response()->error("PARAM_ERROR");
  53. }
  54. if ($amount < 100) {
  55. return response()->error("WITHDRAW_CASH_AMOUNT");
  56. }
  57. $remark = $request->has('remark') ? $request->input('remark') : '';
  58. $financialStat = FinancialStatService::getFinancialStatSingle($distribution_channel_id);
  59. if (empty($financialStat) || $financialStat['enable_withdrawal_amount'] < $amount) {
  60. //可提现金额不够
  61. return response()->error("WITHDRAW_CASH_AMOUNT_INSUFFICIEN");
  62. }
  63. if (FinancialConfigService::isFrozenDistributionChannel($distribution_channel_id)) {
  64. //渠道被冻结
  65. return response()->error("WITHDRAW_CASH_AMOUNT_FROZEN");
  66. }
  67. //判断账户是否设置
  68. if (!CashAccountService::isCashAccountExits($distribution_channel_id)) {
  69. return response()->error("WITHDRAW_CASH_AMOUNT_ACCOUNT");
  70. }
  71. //判断今天是否已经提现
  72. if (WithdrawCashService::isWithdrawCashChannelToToday($distribution_channel_id)) {
  73. return response()->error("WITHDRAW_CASH_TODAY_USE");
  74. }
  75. WithdrawCashService::addWithdrawCash($distribution_channel_id, $amount, $remark);
  76. $financialStatUp = FinancialStatService::updateFinancialStatByWithdraw($distribution_channel_id, $amount);
  77. //修改可提现总额
  78. $enable_amount = $financialStatUp['enable_withdrawal_amount'];
  79. //修改提现中金额
  80. $withdraw_pending_amount = $financialStatUp['withdraw_pending_amount'];
  81. return response()->success(compact('enable_amount', 'withdraw_pending_amount'));
  82. }
  83. /**
  84. * @apiVersion 1.0.0
  85. * @apiDescription 修改提现状态
  86. * @api {POST} updateWithdrawCash 修改提现状态信息
  87. * @apiGroup Finance
  88. * @apiName updateWithdrawCash
  89. * @apiParam {Number} id 提现id.
  90. * @apiParam {Number} status 状态 查看接口 api/getWithdrawCashStatus (可不传,获取所有状态)
  91. * @apiParam {String} remark 备注说明.
  92. * @apiSuccessExample {json} Success-Response:
  93. *
  94. * {
  95. * "code": 0,
  96. * "msg": "",
  97. * "data":{
  98. * }
  99. * }
  100. */
  101. function update_withdrawCash(Request $request)
  102. {
  103. $id = $request->has('id') ? $request->input('id') : '';
  104. if (!is_numeric($id)) {
  105. return response()->error("PARAM_ERROR");
  106. }
  107. // $userId = $request->has('user_id') ? $request->input('user_id') : '';
  108. // if(!is_numeric($userId)) {
  109. // return response()->error("PARAM_ERROR");
  110. // }
  111. $userId = $this->getLoginUserId();
  112. $remark = $request->has('remark') ? $request->input('remark') : '';
  113. $statusIn = $request->has('status') ? $request->input('status') : '';
  114. if (!is_numeric($statusIn)) {
  115. return response()->error("PARAM_ERROR");
  116. }
  117. //审核通过 2, 审核失败 9, 待打款 10, 自动待打款 11 人工待打款 12
  118. if ($statusIn == 2 || $statusIn == 9 || $statusIn == 10 || $statusIn == 12) {
  119. } else {
  120. return response()->error("PARAM_ERROR");
  121. }
  122. $withdrawCash = WithdrawCashService::getWithdrawCash($id);
  123. if (empty($withdrawCash)) {
  124. return response()->error("PARAM_ERROR");
  125. }
  126. if (WithdrawCashService::isEditWithdrawCashStatus($id)) {
  127. return response()->error("WITHDRAW_CASH_AMOUNT_NO_CHANGE");
  128. }
  129. if ($statusIn == 2) {
  130. //已审核 , 私
  131. if ($withdrawCash['is_company'] == 0) {
  132. $statusIn = 11;//,'name' => "自动待打款"
  133. }
  134. if ($withdrawCash['is_company'] == 1) {
  135. //对公,直接 人工打款
  136. $statusIn = 12;//,12,'name' => "人工待打款"
  137. }
  138. }
  139. WithdrawCashService::updateWithdrawCashStatus($id, $userId, $statusIn, $remark);
  140. return response()->success();
  141. }
  142. /**
  143. * @apiVersion 1.0.0
  144. * @apiDescription 获取提现列表
  145. * @api {GET} withdrawCashs 获取提现列表信息
  146. * @apiGroup Finance
  147. * @apiName withdrawCashs
  148. * @apiParam {Number} [distribution_channel_id] 渠道id.(可不传,获取所有渠道)
  149. * @apiParam {String} [distribution_channel_name] 渠道名称.(可不传,获取所有渠道)
  150. * @apiParam {Number} [status] 状态 查看接口 api/getWithdrawCashStatus (可不传,获取所有状态)
  151. * @apiParam {String} [start_time] 开始时间(可不传)
  152. * @apiParam {String} [end_time] 结束时间(可不传)
  153. * @apiSuccess {Number} channel_id 渠道ID.
  154. * @apiSuccess {String} channel_name 渠道名称.
  155. * @apiSuccess {Number} amount 提现金额.
  156. * @apiSuccess {Number} tallage 扣税金额.
  157. * @apiSuccess {String} status 状态.
  158. * @apiSuccess {String} remark 备注.
  159. * @apiSuccess {Number} check_user_id 审核人ID.
  160. * @apiSuccess {String} check_user_name 审核人姓名.
  161. * @apiSuccess {String} created_time 提现时间.
  162. * @apiSuccess {String} updated_time 最后更新时间.
  163. * @apiSuccessExample {json} Success-Response:
  164. *
  165. * {
  166. * "code": 0,
  167. * "msg": "",
  168. * "data": {
  169. * "list": [
  170. * {
  171. * "channel_id": 2,
  172. * "channel_name": "渠道二",
  173. * "amount": "330.00",
  174. * "tallage": "11",
  175. * "status": "待审核",
  176. * "remark": null,
  177. * "check_user_id": null,
  178. * "check_user_name": null,
  179. * "created_time": "2017-12-01 16:58:55",
  180. * "updated_time": "2017-12-01 16:58:59"
  181. * }
  182. * ],
  183. * "meta": {
  184. * "total": 2,
  185. * "per_page": 15,
  186. * "current_page": 1,
  187. * "last_page": 1,
  188. * "next_page_url": "",
  189. * "prev_page_url": ""
  190. * }
  191. * }
  192. * }
  193. */
  194. function get_list(Request $request)
  195. {
  196. $distribution_channel_id = $request->has('distribution_channel_id') ? $request->input('distribution_channel_id') : '';
  197. $distribution_channel_name = $request->has('distribution_channel_name') ? $request->input('distribution_channel_name') : '';
  198. $start_time = $request->has('start_time') && !empty($request->input('start_time')) ? date('Ymd', strtotime($request->input('start_time'))) : '';
  199. $end_time = $request->has('end_time') && !empty($request->input('end_time')) ? date('Ymd', strtotime($request->input('end_time'))) : '';
  200. $end_time = self::getMaxDay($end_time);
  201. $statusIn = $request->has('status') ? $request->input('status') : '';
  202. $result = WithdrawCashService::getList($distribution_channel_id, $distribution_channel_name, $start_time, $end_time, $statusIn);
  203. return response()->pagination(new WithdrawCashTransformer(), $result);
  204. }
  205. /**
  206. * @apiVersion 1.0.0
  207. * @apiDescription 财务对账
  208. * @api {get} WithdrawCash/financialCounting 财务对账
  209. * @apiGroup Finance
  210. * @apiName WithdrawCash/financialCounting
  211. * @apiParam {Number} [distribution_channel_id] 渠道id.(可不传,获取所有渠道)
  212. * @apiParam {String} [distribution_channel_name] 渠道名称.(可不传,获取所有渠道)
  213. * @apiParam {String} [account_name] 账户名称
  214. * @apiParam {String} [search_name] 搜索名称
  215. * @apiParam {String} [start_time] 开始时间(可不传)
  216. * @apiParam {String} [end_time] 结束时间(可不传)
  217. * @apiParam {Number} [is_frozen] 0:正常状态; -1:冻结状态.
  218. * @apiParam {Number} [status] 状态 查看接口 api/getWithdrawCashStatus (可不传,获取所有状态)
  219. * @apiParam {Number} [is_company] 0:对私, 1:对公司.(可不传,获取所有渠道)
  220. * @apiSuccess {Number} id 提现ID.
  221. * @apiSuccess {Number} channel_id 渠道ID.
  222. * @apiSuccess {String} channel_name 渠道名称.
  223. * @apiSuccess {Number} amount 提现金额.
  224. * @apiSuccess {Number} pay_amount 打款金额.
  225. * @apiSuccess {String} status 打款状态
  226. * @apiSuccess {String} remark 备注
  227. * @apiSuccess {String} check_user_name 审核人名称
  228. * @apiSuccess {Number} check_user_id 审核人ID
  229. * @apiSuccess {String} account_name 银行卡户主名称
  230. * @apiSuccess {String} identity_card 银行卡户主身份证
  231. * @apiSuccess {String} card_number 银行卡账号
  232. * @apiSuccess {String} account_bank 银行支行
  233. * @apiSuccess {String} bank 银行名称
  234. * @apiSuccess {String} province 银行地址
  235. * @apiSuccess {String} created_time 提现时间.
  236. * @apiSuccess {String} updated_time 审核时间
  237. * @apiSuccess {Number} tallage 税
  238. * @apiSuccess {Number} is_frozen 0:正常状态; -1:冻结状态.
  239. * @apiSuccess {String} fc_remark 冻结备注.
  240. * @apiSuccessExample {json} Success-Response:
  241. *
  242. * {
  243. * "code": 0,
  244. * "msg": "",
  245. * "data": {
  246. * "list": [
  247. * {
  248. * "id": 14,
  249. * "channel_id": 2,
  250. * "channel_name": "渠道二",
  251. * "amount": "330.00",
  252. * "pay_amount": "220.00",
  253. * "status": "已打款",
  254. * "remark": "的发生的饭",
  255. * "check_user_name": "波哥的锅",
  256. * "check_user_id": 2,
  257. * "account_name": "宋晓",
  258. * "identity_card": "33038119930901821X",
  259. * "card_number": "6222520177654916",
  260. * "account_bank": "钱江支行",
  261. * "bank": "杭州银行",
  262. * "province": "北京市",
  263. * "created_time": "2017-11-30 16:24:25",
  264. * "updated_time": "2017-11-30 16:24:27",
  265. * "tallage": "110",
  266. * "is_frozen": 0,
  267. * "fc_remark": ""
  268. * }
  269. * ],
  270. * "meta": {
  271. * "total": 2,
  272. * "per_page": 15,
  273. * "current_page": 1,
  274. * "last_page": 1,
  275. * "next_page_url": "",
  276. * "prev_page_url": ""
  277. * }
  278. * }
  279. * }
  280. */
  281. function financial_counting(Request $request)
  282. {
  283. $distribution_channel_id = $request->has('distribution_channel_id') ? $request->input('distribution_channel_id') : '';
  284. $distribution_channel_name = $request->has('distribution_channel_name') ? $request->input('distribution_channel_name') : '';
  285. $start_time = $request->has('start_time') && !empty($request->input('start_time')) ? date('Ymd', strtotime($request->input('start_time'))) : '';
  286. $end_time = $request->has('end_time') && !empty($request->input('end_time')) ? date('Ymd', strtotime($request->input('end_time'))) : '';
  287. $end_time = self::getMaxDay($end_time);
  288. $isFrozen = $request->has('is_frozen') ? $request->input('is_frozen') : '';
  289. $account_name = $request->has('account_name') ? $request->input('account_name') : '';
  290. $search_name = $request->has('search_name') ? $request->input('search_name') : '';
  291. $status = $request->has('status') ? $request->input('status') : '';
  292. $is_company = $request->has('is_company') ? $request->input('is_company') : '';
  293. $params = [
  294. 'channel_id' => $distribution_channel_id,
  295. 'channel_name' => $distribution_channel_name,
  296. 'start_date' => $start_time,
  297. 'end_date' => $end_time,
  298. 'is_frozen' => $isFrozen,
  299. 'account_name' => $account_name,
  300. 'search_name' => $search_name,
  301. 'is_company' => $is_company,
  302. ];
  303. $result = WithdrawCashService::getFinancialCounting($params, $status);
  304. return response()->pagination(new WithdrawCashFinancialTransformer(), $result);
  305. }
  306. /**
  307. * @apiVersion 1.0.0
  308. * @apiDescription 财务对账导出
  309. * @api {get} WithdrawCash/financialCountingExport 财务对账导出
  310. * @apiGroup Finance
  311. * @apiName WithdrawCash/financialCountingExport
  312. * @apiParam {String} [account_name] 账户名称
  313. * @apiParam {String} [search_name] 搜索名称
  314. * @apiParam {String} [start_time] 开始时间(可不传)
  315. * @apiParam {String} [end_time] 结束时间(可不传)
  316. * @apiParam {Number} [is_frozen] 0:正常状态; -1:冻结状态.
  317. * @apiParam {Number} [status] 状态 查看接口 api/getWithdrawCashStatus (可不传,获取所有状态)
  318. * @apiParam {Number} [is_company] 0:对私, 1:对公司.(可不传,获取所有渠道)
  319. */
  320. function financial_counting_export(Request $request)
  321. {
  322. $distribution_channel_id = $request->has('distribution_channel_id') ? $request->input('distribution_channel_id') : '';
  323. $distribution_channel_name = $request->has('distribution_channel_name') ? $request->input('distribution_channel_name') : '';
  324. $start_time = $request->has('start_time') && !empty($request->input('start_time')) ? date('Ymd', strtotime($request->input('start_time'))) : '';
  325. $end_time = $request->has('end_time') && !empty($request->input('end_time')) ? date('Ymd', strtotime($request->input('end_time'))) : '';
  326. $end_time = self::getMaxDay($end_time);
  327. $isFrozen = $request->has('is_frozen') ? $request->input('is_frozen') : '';
  328. $account_name = $request->has('account_name') ? $request->input('account_name') : '';
  329. $search_name = $request->has('search_name') ? $request->input('search_name') : '';
  330. $status = $request->has('status') ? $request->input('status') : '';
  331. $is_company = $request->has('is_company') ? $request->input('is_company') : '';
  332. $params = [
  333. 'channel_id' => $distribution_channel_id,
  334. 'channel_name' => $distribution_channel_name,
  335. 'start_date' => $start_time,
  336. 'end_date' => $end_time,
  337. 'is_frozen' => $isFrozen,
  338. 'account_name' => $account_name,
  339. 'search_name' => $search_name,
  340. 'is_company' => $is_company,
  341. ];
  342. $result = WithdrawCashService::getFinancialCounting($params, $status, true);
  343. header("Content-type:application/vnd.ms-excel");
  344. header("Content-Disposition:attachment;filename=" . "财务对账" . date("YmdHis") . ".csv");
  345. echo iconv("UTF-8", "GBK", "\"操作日期\",\"渠道ID\",\"渠道名称\",\"私/公\",\"姓名\",\"打款金额(元)\",\"打款状态\",\"银行卡\",\"交易银行\",\"开户支行\"\r\n");
  346. if ($result) {
  347. foreach ($result as $item) {
  348. echo("\"" . iconv("UTF-8", "GBK", date('Y-m-d H:i:s', strtotime($item->updated_at))) . "\",");
  349. echo("\"" . ($item->channel_id) . "\",");
  350. echo("\"" . iconv("UTF-8", "GBK", $item->channel_name) . "\",");
  351. echo("\"" . iconv("UTF-8", "GBK", $item->is_company) . "\",");
  352. echo("\"" . mb_convert_encoding($item->account_name, "GBK") . "\",");
  353. echo("\"" . ($item->amount - $item->tallage) . "\",");
  354. echo("\"" . iconv("UTF-8", "GBK", $item->wc_status) . "\",");
  355. echo("\"" . iconv("UTF-8", "GBK", "`" . ($item->card_number)) . "\",");
  356. echo("\"" . iconv("UTF-8", "GBK", $item->bank) . "\",");
  357. echo("\"" . iconv("UTF-8", "GBK", $item->account_bank) . "\"\r\n");
  358. }
  359. }
  360. exit();
  361. }
  362. /**
  363. * @apiVersion 1.0.0
  364. * @apiDescription 财务审核
  365. * @api {get} WithdrawCash/financialAudit 财务审核
  366. * @apiGroup Finance
  367. * @apiName WithdrawCash/financialAudit
  368. * @apiParam {Number} [distribution_channel_id] 渠道id.(可不传,获取所有渠道)
  369. * @apiParam {String} [distribution_channel_name] 渠道名称.(可不传,获取所有渠道)
  370. * @apiParam {String} [account_name] 账户名称
  371. * @apiParam {String} [search_name] 搜索名称
  372. * @apiParam {String} [start_time] 开始时间(可不传)
  373. * @apiParam {String} [end_time] 结束时间(可不传)
  374. * @apiParam {Number} [is_frozen] 0:正常状态; -1:冻结状态.
  375. * @apiParam {Number} [status] 状态 查看接口 api/getWithdrawCashStatus (可不传,获取所有状态)
  376. * @apiParam {Number} [is_company] 0:对私, 1:对公司.(可不传,获取所有渠道)
  377. * @apiSuccess {Number} id 提现ID.
  378. * @apiSuccess {Number} channel_id 渠道ID.
  379. * @apiSuccess {String} channel_name 渠道名称.
  380. * @apiSuccess {Number} amount 提现金额.
  381. * @apiSuccess {Number} pay_amount 打款金额.
  382. * @apiSuccess {String} status 打款状态
  383. * @apiSuccess {String} remark 备注
  384. * @apiSuccess {String} check_user_name 审核人名称
  385. * @apiSuccess {Number} check_user_id 审核人ID
  386. * @apiSuccess {String} account_name 银行卡户主名称
  387. * @apiSuccess {String} identity_card 银行卡户主身份证
  388. * @apiSuccess {String} card_number 银行卡账号
  389. * @apiSuccess {String} account_bank 银行支行
  390. * @apiSuccess {String} bank 银行名称
  391. * @apiSuccess {String} province 银行地址
  392. * @apiSuccess {String} created_time 提现时间.
  393. * @apiSuccess {String} updated_time 审核时间
  394. * @apiSuccess {Number} tallage 税
  395. * @apiSuccess {Number} is_frozen 0:正常状态; -1:冻结状态.
  396. * @apiSuccess {String} fc_remark 冻结备注.
  397. * @apiSuccessExample {json} Success-Response:
  398. *
  399. * {
  400. * "code": 0,
  401. * "msg": "",
  402. * "data": {
  403. * "list": [
  404. * {
  405. * "id": 14,
  406. * "channel_id": 2,
  407. * "channel_name": "渠道二",
  408. * "amount": "330.00",
  409. * "pay_amount": "220.00",
  410. * "status": "已打款",
  411. * "remark": "的发生的饭",
  412. * "check_user_name": "波哥的锅",
  413. * "check_user_id": 2,
  414. * "account_name": "宋晓",
  415. * "identity_card": "33038119930901821X",
  416. * "card_number": "6222520177654916",
  417. * "account_bank": "钱江支行",
  418. * "bank": "杭州银行",
  419. * "province": "北京市",
  420. * "created_time": "2017-11-30 16:24:25",
  421. * "updated_time": "2017-11-30 16:24:27",
  422. * "tallage": "110",
  423. * "is_frozen": 0,
  424. * "fc_remark": ""
  425. * }
  426. * ],
  427. * "meta": {
  428. * "total": 2,
  429. * "per_page": 15,
  430. * "current_page": 1,
  431. * "last_page": 1,
  432. * "next_page_url": "",
  433. * "prev_page_url": ""
  434. * }
  435. * }
  436. * }
  437. */
  438. function financial_audit(Request $request)
  439. {
  440. $distribution_channel_id = $request->has('distribution_channel_id') ? $request->input('distribution_channel_id') : '';
  441. $distribution_channel_name = $request->has('distribution_channel_name') ? $request->input('distribution_channel_name') : '';
  442. $start_time = $request->has('start_time') && !empty($request->input('start_time')) ? date('Ymd', strtotime($request->input('start_time'))) : '';
  443. $end_time = $request->has('end_time') && !empty($request->input('end_time')) ? date('Ymd', strtotime($request->input('end_time'))) : '';
  444. $end_time = self::getMaxDay($end_time);
  445. $isFrozen = $request->has('is_frozen') ? $request->input('is_frozen') : '';
  446. $account_name = $request->has('account_name') ? $request->input('account_name') : '';
  447. $search_name = $request->has('search_name') ? $request->input('search_name') : '';
  448. $status = $request->has('status') ? $request->input('status') : '';
  449. $is_company = $request->has('is_company') ? $request->input('is_company') : '';
  450. $params = [
  451. 'channel_id' => $distribution_channel_id,
  452. 'channel_name' => $distribution_channel_name,
  453. 'start_date' => $start_time,
  454. 'end_date' => $end_time,
  455. 'is_frozen' => $isFrozen,
  456. 'account_name' => $account_name,
  457. 'search_name' => $search_name,
  458. 'is_company' => $is_company,
  459. ];
  460. $result = WithdrawCashService::getFinancialAudit($params, $status);
  461. return response()->pagination(new WithdrawCashFinancialTransformer(), $result);
  462. }
  463. /**
  464. * @apiVersion 1.0.0
  465. * @apiDescription 财务审核导出
  466. * @api {get} WithdrawCash/financialAuditExport 财务审核导出
  467. * @apiGroup Finance
  468. * @apiName WithdrawCash/financialAuditExport
  469. * @apiParam {Number} [distribution_channel_id] 渠道id.(可不传,获取所有渠道)
  470. * @apiParam {String} [distribution_channel_name] 渠道名称.(可不传,获取所有渠道)
  471. * @apiParam {String} [account_name] 账户名称
  472. * @apiParam {String} [search_name] 搜索名称
  473. * @apiParam {String} [start_time] 开始时间(可不传)
  474. * @apiParam {String} [end_time] 结束时间(可不传)
  475. * @apiParam {Number} [is_frozen] 0:正常状态; -1:冻结状态.
  476. * @apiParam {Number} [status] 状态 查看接口 api/getWithdrawCashStatus (可不传,获取所有状态)
  477. * @apiParam {Number} [is_company] 0:对私, 1:对公司.(可不传,获取所有渠道)
  478. */
  479. function financial_audit_export(Request $request)
  480. {
  481. $distribution_channel_id = $request->has('distribution_channel_id') ? $request->input('distribution_channel_id') : '';
  482. $distribution_channel_name = $request->has('distribution_channel_name') ? $request->input('distribution_channel_name') : '';
  483. $start_time = $request->has('start_time') && !empty($request->input('start_time')) ? date('Ymd', strtotime($request->input('start_time'))) : '';
  484. $end_time = $request->has('end_time') && !empty($request->input('end_time')) ? date('Ymd', strtotime($request->input('end_time'))) : '';
  485. $end_time = self::getMaxDay($end_time);
  486. $isFrozen = $request->has('is_frozen') ? $request->input('is_frozen') : '';
  487. $account_name = $request->has('account_name') ? $request->input('account_name') : '';
  488. $search_name = $request->has('search_name') ? $request->input('search_name') : '';
  489. $status = $request->has('status') ? $request->input('status') : '';
  490. $is_company = $request->has('is_company') ? $request->input('is_company') : '';
  491. $params = [
  492. 'channel_id' => $distribution_channel_id,
  493. 'channel_name' => $distribution_channel_name,
  494. 'start_date' => $start_time,
  495. 'end_date' => $end_time,
  496. 'is_frozen' => $isFrozen,
  497. 'account_name' => $account_name,
  498. 'search_name' => $search_name,
  499. 'is_company' => $is_company,
  500. ];
  501. $result = WithdrawCashService::getFinancialAudit($params, $status, true);
  502. //mb_convert_encoding()
  503. header("Content-type:application/vnd.ms-excel");
  504. header("Content-Disposition:attachment;filename=" . "财务审核" . date("YmdHis") . ".csv");
  505. echo iconv("UTF-8", "GBK", "\"创建日期\",\"操作日期\",\"渠道ID\",\"渠道名称\",\"私/公\",\"姓名\",\"打款金额(元)\",\"手续费\",\"备注\",\"打款状态\",\"银行卡\",\"交易银行\",\"开户支行\"\r\n");
  506. if ($result) {
  507. foreach ($result as $item) {
  508. echo("\"" . iconv("UTF-8", "GBK", date('Y-m-d H:i:s', strtotime($item->created_at))) . "\",");
  509. echo("\"" . iconv("UTF-8", "GBK", date('Y-m-d H:i:s', strtotime($item->updated_at))) . "\",");
  510. echo("\"" . $item->channel_id . "\",");
  511. echo("\"" . iconv("UTF-8", "GBK", trim($item->channel_name)) . "\",");
  512. echo("\"" . iconv("UTF-8", "GBK", trim($item->is_company)) . "\",");
  513. echo("\"" . mb_convert_encoding(trim($item->account_name), "GBK") . "\",");
  514. echo("\"" . ($item->amount - $item->tallage) . "\",");
  515. echo("\"" . ($item->tallage) . "\",");
  516. echo("\"" . mb_convert_encoding(trim($item->remark), "GBK") . "\",");
  517. echo("\"" . mb_convert_encoding(trim($item->wc_status), "GBK") . "\",");
  518. echo("\"" . "`" . ($item->card_number) . "\",");
  519. echo("\"" . mb_convert_encoding(trim($item->bank), "GBK") . "\",");
  520. echo("\"" . mb_convert_encoding(trim($item->account_bank), "GBK") . "\"\r\n");
  521. }
  522. }
  523. exit();
  524. }
  525. /**
  526. * @apiVersion 1.0.0
  527. * @apiDescription 对账统计数据
  528. * @api {get} WithdrawCash/dataStatistics 对账统计数据
  529. * @apiGroup Finance
  530. * @apiName WithdrawCash/dataStatistics
  531. * @apiSuccess {Number} yesterday_amount_audit_success 昨日已审核金额
  532. * @apiSuccess {Number} all_amount_audit_success 所有已审核金额
  533. * @apiSuccess {Number} yesterday_amount_apply 昨日申请提现金额
  534. * @apiSuccess {Number} all_amount_apply 所有申请提现金额
  535. * @apiSuccess {Number} yesterday_amount_audit_fail 昨日审核不通过
  536. * @apiSuccess {Number} all_amount_audit_fail 所有审核不通过
  537. * @apiSuccess {Number} yesterday_amount_wait 昨日待打款金额
  538. * @apiSuccess {Number} all_amount_wait 所有待打款金额
  539. * @apiSuccess {Number} yesterday_amount_apply_success 昨日成功提现金额
  540. * @apiSuccess {Number} all_amount_apply_success 所有成功提现金额
  541. * @apiSuccess {Number} yesterday_amount_apply_person_success 昨日对私成功提现金额
  542. * @apiSuccess {Number} all_amount_apply_person_success 所有对私成功提现金额
  543. * @apiSuccess {Number} yesterday_amount_apply_company_success 昨日对公成功提现金额
  544. * @apiSuccess {Number} all_amount_apply_company_success 所有对公成功提现金额
  545. * @apiSuccess {Number} yesterday_apply_num 昨日累积提现笔数
  546. * @apiSuccess {Number} all_apply_num 所有累积提现笔数
  547. * @apiSuccess {Number} yesterday_tallage_count 昨日累积提现手续费
  548. * @apiSuccess {Number} all_stallage_count 所有累积提现手续费
  549. * @apiSuccess {Number} yesterday_payment_count 昨日累积打款金额
  550. * @apiSuccess {Number} all_payment_count 所有累积打款金额
  551. * @apiSuccess {Number} all_amount_apply_success_count 所有累积已提现金额
  552. * @apiSuccess {Number} all_amount_apply_count 所有累积可提现金额
  553. * @apiSuccessExample {json} Success-Response:
  554. *
  555. * {
  556. * "code": 0,
  557. * "msg": "",
  558. * "data": {
  559. * "yesterday_amount_audit_success": "660.00",
  560. * "all_amount_audit_success": "660.00",
  561. * "yesterday_amount_apply": "660.00",
  562. * "all_amount_apply": "660.00",
  563. * "yesterday_amount_audit_fail": "440.00",
  564. * "all_amount_audit_fail": "440.00",
  565. * "yesterday_amount_wait": "440.00",
  566. * "all_amount_wait": "440.00",
  567. * "yesterday_amount_apply_success": "220.00",
  568. * "all_amount_apply_success": "220.00",
  569. * "yesterday_apply_num": 3,
  570. * "all_apply_num": 3,
  571. * "yesterday_tallage_count": 3,
  572. * "all_stallage_count": 3,
  573. * "yesterday_payment_count":200,
  574. * "all_payment_count":200,
  575. * "all_amount_apply_success_count": 3,
  576. * "all_amount_apply_count": 3,
  577. * }
  578. * }
  579. */
  580. function data_statistics(Request $request)
  581. {
  582. $dataWithdrawCash = FinanceService::getDataStatisticsWithdrawCash();
  583. //昨日已审核金额
  584. $yesterday_amount_audit_success = $dataWithdrawCash['yesterday_amount_audit_success'];
  585. //所有已审核金额
  586. $all_amount_audit_success = $dataWithdrawCash['all_amount_audit_success'];
  587. //昨日申请提现金额
  588. $yesterday_amount_apply = $dataWithdrawCash['yesterday_amount_apply'];
  589. //所有申请提现金额
  590. $all_amount_apply = $dataWithdrawCash['all_amount_apply'];
  591. //昨日审核不通过
  592. $yesterday_amount_audit_fail = $dataWithdrawCash['yesterday_amount_audit_fail'];
  593. //所有审核不通过
  594. $all_amount_audit_fail = $dataWithdrawCash['all_amount_audit_fail'];
  595. //昨日待打款
  596. $yesterday_amount_wait = $dataWithdrawCash['yesterday_amount_wait'];
  597. //所有待打款
  598. $all_amount_wait = $dataWithdrawCash['all_amount_wait'];
  599. //所有待笔数
  600. $all_amount_wait_num = $dataWithdrawCash['all_amount_wait_num'];
  601. //昨日对私成功提现金额
  602. $yesterday_amount_apply_person_success = $dataWithdrawCash['yesterday_amount_apply_person_success'];
  603. //所有对私成功提现金额
  604. $all_amount_apply_person_success = $dataWithdrawCash['all_amount_apply_person_success'];
  605. //昨日对公成功提现金额
  606. $yesterday_amount_apply_company_success = $dataWithdrawCash['yesterday_amount_apply_company_success'];
  607. //所有对公成功提现金额
  608. $all_amount_apply_company_success = $dataWithdrawCash['all_amount_apply_company_success'];
  609. //昨日成功提现金额
  610. $yesterday_amount_apply_success = $dataWithdrawCash['yesterday_amount_apply_success'];
  611. //所有成功提现金额
  612. $all_amount_apply_success = $dataWithdrawCash['all_amount_apply_success'];
  613. //昨日累积提现笔数
  614. $yesterday_apply_num = $dataWithdrawCash['yesterday_apply_num'];
  615. //所有累积提现笔数
  616. $all_apply_num = $dataWithdrawCash['all_apply_num'];
  617. //昨日累积提现手续费
  618. $yesterday_tallage_count = $dataWithdrawCash['yesterday_tallage_count'];
  619. //所有累积提现手续费
  620. $all_stallage_count = $dataWithdrawCash['all_stallage_count'];
  621. $dataPayment = FinanceService::getDataStatisticsPayment();
  622. //昨日累积打款金额
  623. $yesterday_payment_count = $dataPayment['yesterday_payment_count'];
  624. //所有累积打款金额
  625. $all_payment_count = $dataPayment['all_payment_count'];
  626. $dataFinancialStat = FinanceService::getDataStatisticsFinancialStat();
  627. //所有累积已提现金额
  628. $all_amount_apply_success_count = $dataFinancialStat['all_amount_apply_success_count'];
  629. //所有累积可提现金额
  630. $all_amount_apply_count = $dataFinancialStat['all_amount_apply_count'];
  631. return response()->success(
  632. compact(
  633. 'yesterday_amount_audit_success',
  634. 'all_amount_audit_success',
  635. 'yesterday_amount_apply',
  636. 'all_amount_apply',
  637. 'yesterday_amount_audit_fail',
  638. 'all_amount_audit_fail',
  639. 'yesterday_amount_wait',
  640. 'all_amount_wait',
  641. 'all_amount_wait_num',
  642. 'yesterday_amount_apply_success',
  643. 'all_amount_apply_success',
  644. 'yesterday_amount_apply_person_success',
  645. 'all_amount_apply_person_success',
  646. 'yesterday_amount_apply_company_success',
  647. 'all_amount_apply_company_success',
  648. 'yesterday_apply_num',
  649. 'all_apply_num',
  650. 'yesterday_tallage_count',
  651. 'all_stallage_count',
  652. 'yesterday_payment_count',
  653. 'all_payment_count',
  654. 'all_amount_apply_success_count',
  655. 'all_amount_apply_count'
  656. ));
  657. }
  658. public function updateWithdrawType(Request $request)
  659. {
  660. $id = $request->input('id', '');
  661. $param = $request->input('param', '');
  662. $param_value = $request->input('param_value', '');
  663. if (empty($id)) {
  664. return response()->error('PARAM_EMPTY');
  665. }
  666. $withdrawCash = WithdrawCashService::getWithdrawCash($id);
  667. if (!$withdrawCash) {
  668. return response()->error('PARAM_ERROR');
  669. }
  670. if ($param == 'is_company') {
  671. $withdrawCash->is_company = $param_value;
  672. $withdrawCash->save();
  673. }
  674. //WithdrawCashService::updateWithdrawCashType($id,);
  675. return response()->success();
  676. }
  677. /**
  678. * 更新打款状态
  679. * id 条目id
  680. * status 状态(10:待打款)
  681. * @param Request $request
  682. * @return mixed
  683. */
  684. function updatePaymentStatus(Request $request)
  685. {
  686. $id = $request->input('id', '');
  687. if (empty($id)) {
  688. return response()->error('PARAM_EMPTY');
  689. }
  690. $withdrawCash = WithdrawCashService::getWithdrawCash($id);
  691. if (!$withdrawCash) {
  692. return response()->error('PARAM_ERROR');
  693. }
  694. $status = WithdrawCashService::getWithdrawCashStatusStr(10);
  695. $withdrawCash->status = $status;
  696. $withdrawCash->save();
  697. //WithdrawCashService::updateWithdrawCashType($id,);
  698. return response()->success();
  699. }
  700. }