Fund.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2017 https://www.sapixx.com All rights reserved.
  4. * @license Licensed (http://www.apache.org/licenses/LICENSE-2.0).
  5. * @author pillar<ltmn@qq.com>
  6. * 采购基金
  7. */
  8. namespace app\ais\controller;
  9. use app\ais\model\AisFund;
  10. use app\ais\model\AisFundBill;
  11. use app\ais\model\AisCouponSubsidize;
  12. use app\ais\model\AisCoupon;
  13. use app\ais\model\AisOrder;
  14. use filter\Filter;
  15. class Fund extends Common{
  16. public $mini_program = [];
  17. public function initialize() {
  18. parent::initialize();
  19. $this->assign('pathMaps',[['name'=>'采购基金','url'=>url("fund/index")]]);
  20. }
  21. /**
  22. * 采购基金
  23. * @return void
  24. */
  25. public function index(int $types = 0){
  26. $fund = AisFund::where($this->mini_program)->find();
  27. $counts = [];
  28. if(empty($fund)){
  29. $counts['balance'] = 0;
  30. $counts['subsidize'] = 0;
  31. $counts['subsidize_num'] = 0;
  32. }else{
  33. $counts['balance'] = $fund->balance;
  34. $counts['subsidize'] = $fund->subsidize;
  35. $counts['subsidize_num'] = $fund->subsidize_num;
  36. }
  37. $view['fund'] = $counts;
  38. if($types <= 1){
  39. $view['bill'] = AisFundBill::where($this->mini_program)->where(['types' => $types])->order('id desc')->paginate(10,false,['query'=>['types' => $types]]);
  40. }else{
  41. $view['bill'] = AisCouponSubsidize::with('coupon')->where($this->mini_program)->order('id desc')->paginate(10,false,['query'=>['types' => $types]]);
  42. }
  43. $view['types'] = $types;
  44. return view()->assign($view);
  45. }
  46. /**
  47. * 删除关联
  48. * @return void
  49. */
  50. public function delAisCoupon(int $id){
  51. $result = AisCouponSubsidize::where($this->mini_program)->where(['id' => $id])->delete();
  52. if($result){
  53. return json(['code'=>200,'msg'=>'操作成功']);
  54. }else{
  55. return json(['code'=>403,'msg'=>'删除失败']);
  56. }
  57. }
  58. /**
  59. * 关联优惠券
  60. * @return void
  61. */
  62. public function winCoupon(){
  63. if(request()->isAjax()){
  64. $ids = input('post.ids/s');
  65. if(empty($ids)){
  66. return json(['code'=>0,'msg'=>'请选择要关联的优惠券']);
  67. }
  68. $ida = ids($ids,true);
  69. $data = [];
  70. foreach ($ida as $key => $value) {
  71. $data[$key]['member_miniapp_id'] = $this->member_miniapp_id;
  72. $data[$key]['coupon_id'] = $value;
  73. $data[$key]['how_much'] = 0;
  74. }
  75. $result = AisCouponSubsidize::insertAll($data);
  76. if($result){
  77. return json(['code'=>302,'msg'=>'关联补贴优惠券成功','data' =>[]]);
  78. }else{
  79. return json(['code'=>0,'msg'=>'关联补贴优惠券失败']);
  80. }
  81. }else{
  82. $coupon = AisCouponSubsidize::where($this->mini_program)->field('coupon_id')->select()->toArray();
  83. $coupon_ids = [];
  84. if(!empty($coupon)){
  85. $coupon_ids = array_column($coupon,'coupon_id');
  86. }
  87. $view['lists'] = AisCoupon::where($this->mini_program)->whereNotIn('id',$coupon_ids)->order('id desc')->paginate(10);
  88. return view()->assign($view);
  89. }
  90. }
  91. /**
  92. * 排序
  93. */
  94. public function howmuch(){
  95. if(request()->isAjax()){
  96. $data = [
  97. 'sort' => input('post.sort/f'),
  98. 'id' => input('post.id/d'),
  99. ];
  100. $result = AisCouponSubsidize::where($this->mini_program)->where(['id' =>$data['id']])->update(['how_much' => $data['sort']]);
  101. if($result){
  102. return json(['code'=>200,'msg'=>'操作成功']);
  103. }else{
  104. return json(['code'=>0,'msg'=>'操作失败']);
  105. }
  106. }
  107. }
  108. /**
  109. * 重置分账队列
  110. * @return void
  111. */
  112. public function reset(string $order_no){
  113. $result = AisOrder::where(['state' => 1,'order_no' => Filter::filter_escape(substr($order_no, 0, -2))])->find();
  114. if($result && AisOrder::subsidy($result)){
  115. return enjson(200);
  116. }else{
  117. return enjson(0);
  118. }
  119. }
  120. }