123 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			123 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
| 
								 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								namespace app\shop\logic\finance;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								use app\common\basics\Logic;
							 | 
						||
| 
								 | 
							
								use app\common\enum\ShopEnum;
							 | 
						||
| 
								 | 
							
								use app\common\model\shop\ShopAccountLog;
							 | 
						||
| 
								 | 
							
								use app\common\server\ExportExcelServer;
							 | 
						||
| 
								 | 
							
								use app\common\server\UrlServer;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class ShopLogic extends Logic
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * @Notes: 账户明细
							 | 
						||
| 
								 | 
							
								     * @param $get
							 | 
						||
| 
								 | 
							
								     * @param $shop_id (商家ID)
							 | 
						||
| 
								 | 
							
								     * @return array
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function account($get, $shop_id, $is_export = false)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $where[] = ['shop_id', '=', (int)$shop_id];
							 | 
						||
| 
								 | 
							
								        if (isset($get['search_key']) && $get['search_key']) {
							 | 
						||
| 
								 | 
							
								            switch($get['search_key']){
							 | 
						||
| 
								 | 
							
								                case 'settle':
							 | 
						||
| 
								 | 
							
								                    $where[] = ['SAL.source_type', '=', ShopAccountLog::settlement_add_money];
							 | 
						||
| 
								 | 
							
								                    break;
							 | 
						||
| 
								 | 
							
								                case 'withdrawal':
							 | 
						||
| 
								 | 
							
								                    $where[] = ['SAL.source_type', '=', ShopAccountLog::withdrawal_dec_money];
							 | 
						||
| 
								 | 
							
								                    break;
							 | 
						||
| 
								 | 
							
								                case 'withdrawal_error':
							 | 
						||
| 
								 | 
							
								                    $where[] = ['SAL.source_type', '=', ShopAccountLog::withdrawal_fail_money];
							 | 
						||
| 
								 | 
							
								                    break;
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (!empty($get['start_time']) and $get['start_time']) {
							 | 
						||
| 
								 | 
							
								            $where[] = ['SAL.create_time', '>=', strtotime($get['start_time'])];
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (!empty($get['end_time']) and $get['end_time']) {
							 | 
						||
| 
								 | 
							
								            $where[] = ['SAL.create_time', '<=', strtotime($get['end_time'])];
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (true === $is_export) {
							 | 
						||
| 
								 | 
							
								            return self::export($where);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $model = new ShopAccountLog();
							 | 
						||
| 
								 | 
							
								        $lists = $model->alias('SAL')
							 | 
						||
| 
								 | 
							
								            ->field(['SAL.*', 'S.name,S.logo,S.type'])
							 | 
						||
| 
								 | 
							
								            ->join('shop S', 'S.id = SAL.shop_id')
							 | 
						||
| 
								 | 
							
								            ->where($where)
							 | 
						||
| 
								 | 
							
								            ->order('create_time','desc')
							 | 
						||
| 
								 | 
							
								            ->paginate([
							 | 
						||
| 
								 | 
							
								                'page'      => $get['page'],
							 | 
						||
| 
								 | 
							
								                'list_rows' => $get['limit'],
							 | 
						||
| 
								 | 
							
								                'var_page'  => 'page'
							 | 
						||
| 
								 | 
							
								            ])->toArray();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        foreach ($lists['data'] as &$item) {
							 | 
						||
| 
								 | 
							
								            $item['type'] = ShopEnum::getShopTypeDesc($item['type']);
							 | 
						||
| 
								 | 
							
								            $item['source_type'] = ShopAccountLog::getSourceType($item['source_type']);
							 | 
						||
| 
								 | 
							
								            $symbol = $item['change_type'] === 1 ? '+' : '-';
							 | 
						||
| 
								 | 
							
								            $item['change_amount'] = $symbol.$item['change_amount'];
							 | 
						||
| 
								 | 
							
								            $item['logo'] = UrlServer::getFileUrl($item['logo']);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return ['count'=>$lists['total'], 'lists'=>$lists['data']];
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * @notes 导出
							 | 
						||
| 
								 | 
							
								     * @param $where
							 | 
						||
| 
								 | 
							
								     * @return array|false
							 | 
						||
| 
								 | 
							
								     * @author 段誉
							 | 
						||
| 
								 | 
							
								     * @date 2022/4/24 11:59
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function export($where)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        try {
							 | 
						||
| 
								 | 
							
								            $lists = (new ShopAccountLog())->alias('SAL')
							 | 
						||
| 
								 | 
							
								                ->field(['SAL.*', 'S.name,S.logo,S.type'])
							 | 
						||
| 
								 | 
							
								                ->join('shop S', 'S.id = SAL.shop_id')
							 | 
						||
| 
								 | 
							
								                ->where($where)
							 | 
						||
| 
								 | 
							
								                ->order('create_time','desc')
							 | 
						||
| 
								 | 
							
								                ->select()->toArray();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            foreach ($lists as &$item) {
							 | 
						||
| 
								 | 
							
								                $item['type'] = ShopEnum::getShopTypeDesc($item['type']);
							 | 
						||
| 
								 | 
							
								                $item['source_type'] = ShopAccountLog::getSourceType($item['source_type']);
							 | 
						||
| 
								 | 
							
								                $symbol = $item['change_type'] === 1 ? '+' : '-';
							 | 
						||
| 
								 | 
							
								                $item['change_amount'] = $symbol.$item['change_amount'];
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            $excelFields = [
							 | 
						||
| 
								 | 
							
								                'name' => '商家名称',
							 | 
						||
| 
								 | 
							
								                'type' => '商家类型',
							 | 
						||
| 
								 | 
							
								                'log_sn' => '明细流水号',
							 | 
						||
| 
								 | 
							
								                'source_sn' => '来源单号',
							 | 
						||
| 
								 | 
							
								                'source_type' => '明细类型',
							 | 
						||
| 
								 | 
							
								                'change_amount' => '变动金额',
							 | 
						||
| 
								 | 
							
								                'left_amount' => '剩余金额',
							 | 
						||
| 
								 | 
							
								                'create_time' => '记录时间',
							 | 
						||
| 
								 | 
							
								            ];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            $export = new ExportExcelServer();
							 | 
						||
| 
								 | 
							
								            $export->setFileName('账户明细');
							 | 
						||
| 
								 | 
							
								            $export->setExportNumber(['log_sn', 'source_sn']);
							 | 
						||
| 
								 | 
							
								            $result = $export->createExcel($excelFields, $lists);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            return ['url' => $result];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        } catch (\Exception $e) {
							 | 
						||
| 
								 | 
							
								            self::$error = $e->getMessage();
							 | 
						||
| 
								 | 
							
								            return false;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								}
							 |