123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- <?php
- /**
- * Created by PhpStorm.
- * User: tandunzhao
- * Date: 2017/12/7
- * Time: 上午9:50
- */
- namespace App\Modules\Finance\Models;
- use Illuminate\Database\Eloquent\Model;
- /**
- * 清算汇总表
- * Class LiquidatedStat
- * @package App\Modules\Finance\Models
- */
- class LiquidatedStat extends Model
- {
- protected $table = 'liquidated_stats';
- protected $fillable = ['amount', 'account_balance_amount', 'account_balance_amount_day', 'pay_merchant_source'];
- /**
- * 添加更新清算汇总
- * @param $amount 添加正数,减少负数
- * @param $pay_merchant_source
- * @return mixed
- */
- public static function createOrUpdate($pay_merchant_source, $amount) {
- $liquidatedStat = self::where('pay_merchant_source', $pay_merchant_source)->first();
- if($pay_merchant_source == config('common.tonglianpay') || $pay_merchant_source == config('common.officialpay')) {
- //官方,通联,每天自动结算,不用清算数据
- $amount = 0;
- }
- if(empty($liquidatedStat)) {
- $liquidatedStat['amount'] = $amount;
- $liquidatedStat['pay_merchant_source'] = $pay_merchant_source;
- $liquidatedStat = LiquidatedStat::create($liquidatedStat);
- } else {
- $liquidatedStat['amount'] = (float)$liquidatedStat['amount'] + (float)$amount;
- $liquidatedStat->save();
- }
- return $liquidatedStat;
- }
- /**
- * 更新支付渠道余额
- * @param $pay_merchant_source
- * @param $amount
- * @return mixed
- */
- public static function updateAccountBalanceAmount($pay_merchant_source, $amount) {
- $liquidatedStat = self::where('pay_merchant_source', $pay_merchant_source)->first();
- print_r('$liquidatedStat:'.json_encode($liquidatedStat));
- if(!empty($liquidatedStat)) {
- $hh = date('H');
- $liquidatedStat->account_balance_amount_day = (float)$amount;
- $liquidatedStat->account_balance_amount = (float)$amount;
- print_r('account_balance_amount_day:'.$liquidatedStat->account_balance_amount);
- $liquidatedStat->save();
- print_r('pay_source:'.$pay_merchant_source);
- $res = self::where('pay_merchant_source', $pay_merchant_source)->update(['account_balance_amount_day'=>$amount,'account_balance_amount'=>$amount]);
- print_r('---:'.$res);
- }
- return $liquidatedStat;
- }
- /**
- * 更新支付渠道余额当天
- * @param $pay_merchant_source
- * @param $amount
- * @return mixed
- */
- public static function updateAccountBalanceAmountDay($pay_merchant_source, $amount) {
- $liquidatedStat = self::where('pay_merchant_source', $pay_merchant_source)->first();
- if(!empty($liquidatedStat)) {
- $liquidatedStat['account_balance_amount_day'] = $liquidatedStat['account_balance_amount_day'] + (float)$amount;
- $liquidatedStat->save();
- }
- return $liquidatedStat;
- }
- /**
- * 清算汇总列表
- * @return mixed
- */
- public static function getLiquidatedStatList() {
- $search_object = LiquidatedStat::select([
- 'liquidated_stats.id',
- 'liquidated_stats.amount',
- 'liquidated_stats.account_balance_amount',
- 'liquidated_stats.pay_merchant_source'
- ]);
- return $search_object->get();
- }
- /**
- * 根据支付通道获取
- * @param $pay_merchant_source
- * @return mixed
- */
- public static function getLiquidatedStatSingleBySource($pay_merchant_source) {
- $liquidatedStat = self::where('pay_merchant_source', $pay_merchant_source)->first();
- return $liquidatedStat;
- }
- }
|