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;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|