CostProfitListForm.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. <?php
  2. /**
  3. * 重庆赤晓店信息科技有限公司
  4. * https://www.chixiaodian.com
  5. * Copyright (c) 2023 赤店商城 All rights reserved.
  6. */
  7. namespace app\modules\admin\models;
  8. use app\models\Goods;
  9. use app\models\Level;
  10. use app\models\LevelOrder;
  11. use app\models\Md;
  12. use app\models\MdProfit;
  13. use app\models\Order;
  14. use app\models\OrderDetail;
  15. use app\models\OrderTransit;
  16. use app\models\SaasUser;
  17. use app\models\ShareDetail;
  18. use app\models\SharingReceiver;
  19. use app\models\User;
  20. use app\models\UserShareMoney;
  21. use Spatie\SimpleExcel\SimpleExcelWriter;
  22. use yii\base\Model;
  23. class CostProfitListForm extends Model
  24. {
  25. public $store_id;
  26. public $user_id;
  27. public $order_no; //订单号
  28. public $user_name; //用户名称
  29. public $mobile; //手机号
  30. public $day; //查询时间 1 7 30
  31. public $order_start_time; //订单开始时间
  32. public $order_end_time; //订单结束时间
  33. public $type;
  34. public $md_id;
  35. public function rules()
  36. {
  37. return [
  38. [['order_no'], 'trim'],
  39. [['store_id', 'user_id', 'type', 'md_id'], 'integer'],
  40. [['order_no', 'user_name', 'order_start_time', 'order_end_time', 'mobile', 'day'], 'string'],
  41. ];
  42. }
  43. /*
  44. * 财务列表
  45. */
  46. public function search()
  47. {
  48. try {
  49. $user_id = $this->user_id;
  50. $store_id = $this->store_id;
  51. $order_no = $this->order_no;
  52. $user_name = $this->user_name;
  53. $mobile = $this->mobile;
  54. $day = (int)$this->day;
  55. $order_start_time = $this->order_start_time;
  56. $order_end_time = $this->order_end_time;
  57. $start_time = 0;
  58. $end_time = time();
  59. $type = $this->type;
  60. $md_id = $this->md_id;
  61. $query = Order::find()->alias('o')->where([
  62. 'o.store_id' => $store_id, 'o.is_delete' => 0,
  63. 'o.trade_status' => [Order::ORDER_FLOW_NO_SEND, Order::ORDER_FLOW_SEND, Order::ORDER_FLOW_CONFIRM]
  64. ])->andWhere(['or', ['o.is_pay' => 1], ['o.pay_type' => \app\models\Order::PAY_TYPE_COD]])
  65. ->leftJoin(['u' => User::tableName()], 'o.user_id = u.id')
  66. ->leftJoin(['su' => SaasUser::tableName()], 'su.mobile = u.binding');
  67. if ($order_no) {
  68. $query->andWhere(['LIKE', 'o.order_no', $order_no]);
  69. }
  70. if ($user_id) {
  71. $query->andWhere(['o.user_id' => $user_id]);
  72. }
  73. if ($user_name) {
  74. $query->andWhere(['LIKE', 'su.name', $user_name]);
  75. }
  76. if ($mobile) {
  77. $query->andWhere(['OR', ['LIKE', 'su.mobile', $mobile], ['LIKE', 'o.mobile', $mobile]]);
  78. }
  79. if (intval($type)) {
  80. $query->andWhere(['AND', ['o.is_offline' => 1], ['>', 'md_id', 0]]);
  81. if ($md_id) {
  82. $query->andWhere(['o.md_id' => $md_id]);
  83. }
  84. }
  85. if ($day) {
  86. switch ($day) {
  87. case 2:
  88. $start_time = strtotime(date('Y-m-d', strtotime('-1 week')));
  89. break;
  90. case 3:
  91. $start_time = strtotime(date('Y-m-d', strtotime('-1 month')));
  92. break;
  93. case 4:
  94. $start_time = strtotime(date('Y-m-d', strtotime('-1 year')));
  95. break;
  96. default:
  97. $start_time = strtotime(date('Y-m-d'));
  98. break;
  99. }
  100. }
  101. if ($order_start_time && $order_end_time) {
  102. $order_start_time = strtotime($order_start_time);
  103. $order_end_time = strtotime($order_end_time);
  104. if ($order_start_time > $start_time) {
  105. $start_time = $order_start_time;
  106. }
  107. if ($order_end_time < $end_time) {
  108. $end_time = $order_end_time;
  109. }
  110. }
  111. $query->select('o.id, o.order_no, su.name user_name, su.mobile user_mobile, su.avatar, o.name,
  112. o.mobile, o.pay_price total_price, o.created_at, o.rand_discount, o.integral, o.balance, o.md_id');
  113. $query->groupBy('o.id');
  114. $total_query = clone $query;
  115. if (intval($type)) {
  116. $today_total_order = $total_query->asArray()->all();
  117. } else {
  118. $today_total_order = $total_query->andWhere(['AND', ['>=', 'o.created_at', strtotime(date('Y-m-d'))], ['<=', 'o.created_at', time()]])
  119. ->asArray()->all();
  120. }
  121. //今日累计
  122. $today_data = [
  123. 'total_price' => 0,
  124. 'num' => 0,
  125. 'profit' => 0
  126. ];
  127. if ($today_total_order) {
  128. $total_price_arr = array_column($today_total_order, 'total_price');
  129. $today_data['total_price'] = sprintf("%.2f", array_sum($total_price_arr));
  130. $today_data['num'] = count($today_total_order);
  131. $this->commonData($today_total_order);
  132. $total_profit_arr = array_column($today_total_order, 'profit');
  133. $today_data['profit'] = sprintf("%.2f", array_sum($total_profit_arr));
  134. }
  135. if ($start_time && $end_time) {
  136. $query->andWhere(['AND', ['>=', 'o.created_at', $start_time], ['<=', 'o.created_at', $end_time]]);
  137. }
  138. $query->orderBy('o.created_at desc');
  139. $list = pagination_make($query);
  140. $this->commonData($list['list']);
  141. return [
  142. 'code' => 0,
  143. 'msg' => 'success',
  144. 'data' => [
  145. 'data' => $list['list'],
  146. 'today_data' => $today_data,
  147. 'pageNo' => $list['pageNo'],
  148. 'totalCount' => $list['totalCount'],
  149. ],
  150. ];
  151. } catch (\Exception $e) {
  152. return [
  153. 'code' => 1,
  154. 'msg' => $e->getMessage()
  155. ];
  156. }
  157. }
  158. public function commonData(&$list)
  159. {
  160. foreach ($list as &$item) {
  161. $goods_list = OrderDetail::find()->alias('od')->where(['od.order_id' => $item['id']])
  162. ->leftJoin(['g' => Goods::tableName()], 'od.goods_id = g.id')
  163. ->select('od.id, od.attr, g.use_attr ,g.price, g.attr goods_attr, od.total_price, od.num, od.cost_price')->asArray()->all();
  164. $profit = 0;
  165. foreach ($goods_list as $goods_item) {
  166. $total_cost = $goods_item['cost_price'] * $goods_item['num'];
  167. $profit += ($goods_item['total_price'] - $total_cost);
  168. }
  169. //减去立减
  170. $profit -= $item['rand_discount'];
  171. // 减去余额抵扣
  172. $profit -= $item['balance'];
  173. $item['goods_balance'] = $item['balance'] ?? 0;
  174. //减去积分抵扣
  175. $integral = json_decode($item['integral'], true);
  176. $profit -= $integral['forehead'];
  177. $item['created_at'] = date('Y-m-d H:i:s', $item['created_at']);
  178. $item['profit'] = sprintf("%.2f", $profit);
  179. $item['goods_num'] = count($goods_list);
  180. $md = Md::findOne($item['md_id']);
  181. $item['md_name'] = $md->name ?: '';
  182. }
  183. }
  184. }