调整除自动计算费用问题以外的问题
parent
cd8bd7ddc2
commit
13576efcf9
|
|
@ -28,13 +28,13 @@ class ConstFlowController extends AdminController
|
|||
$this->baseFilter()->body([
|
||||
amisMake()->TextControl('name', '名称')->size('md'),
|
||||
amisMake()->TextControl('card_no', '身份证')->size('md'),
|
||||
amisMake()->TextControl('sn', '单据编号')->size('md'),
|
||||
amisMake()->TextControl('idsn', '单据编号')->size('md'),
|
||||
amis('button')->label(__('admin.reset'))->actionType('clear-and-submit'),
|
||||
amis('submit')->label(__('admin.search'))->level('primary'),
|
||||
])->actions([])
|
||||
)
|
||||
->columns([
|
||||
amisMake()->TableColumn('sn', '单据编号')->copyable(true),
|
||||
amisMake()->TableColumn('idsn', '单据编号')->copyable(true),
|
||||
amisMake()->TableColumn('oldman.name', '客人'),
|
||||
amisMake()->TableColumn('const_type', '缴费类型')->type('mapping')->map(ConstFlow::typeMapLabel())->className('text-primary'),
|
||||
amisMake()->TableColumn('money', '金额'),
|
||||
|
|
|
|||
|
|
@ -337,7 +337,7 @@ class OldmenController extends AdminController
|
|||
->whereIn('const_type', [ConstFlow::TYPE_IN, ConstFlow::TYPE_CONTINUE])
|
||||
->where('state', 0)
|
||||
->whereBetween('start_at', [$oldMan->live_in_at, $oldMan->avliable_at])//开始时间在用户这段时间内的清单
|
||||
->get();
|
||||
->orderBy('created_at', 'desc')->limit(3)->get();//调整为最近3条
|
||||
$tableList = [];
|
||||
foreach($flowList as $flow){
|
||||
$_feeInfo = $_bonusInfo = $_addInfo = $_delInfo = '';
|
||||
|
|
|
|||
|
|
@ -17,6 +17,11 @@ class ConstFlowFilter extends ModelFilter
|
|||
return $this->where('sn', $sn);
|
||||
}
|
||||
|
||||
public function idsn($idsn){
|
||||
$id = 0+$idsn;
|
||||
return $this->where('id', $id);
|
||||
}
|
||||
|
||||
/**
|
||||
* 名称
|
||||
*/
|
||||
|
|
|
|||
|
|
@ -26,7 +26,7 @@ class PrintController extends Controller
|
|||
$flow->load(['oldman', 'adminuser']);
|
||||
$name = $flow->oldman->name;
|
||||
$time = $flow->created_at->format('Y-m-d H:i:s');
|
||||
$sn = $flow->sn;
|
||||
$idsn = $flow->idsn;
|
||||
$ukeys = explode(',', $request->input('ukeys', ''));
|
||||
$i = 0;
|
||||
foreach($rows as $item){
|
||||
|
|
@ -61,7 +61,7 @@ class PrintController extends Controller
|
|||
$timeZone = substr($flow->start_at, 0, 10).'至'.substr($flow->end_at, 0, 10);
|
||||
}
|
||||
|
||||
return view('print-const', compact('name', 'time', 'sn', 'list', 'total', 'bigTotal', 'timeZone', 'adminName'));
|
||||
return view('print-const', compact('name', 'time', 'idsn', 'list', 'total', 'bigTotal', 'timeZone', 'adminName'));
|
||||
}
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -6,6 +6,7 @@ use Illuminate\Database\Eloquent\Model;
|
|||
use EloquentFilter\Filterable;
|
||||
use Slowlyo\OwlAdmin\Models\AdminUser;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Database\Eloquent\Casts\Attribute;
|
||||
|
||||
class ConstFlow extends Model
|
||||
{
|
||||
|
|
@ -34,6 +35,8 @@ class ConstFlow extends Model
|
|||
];
|
||||
}
|
||||
|
||||
protected $appends = ['idsn'];
|
||||
|
||||
protected $casts = [
|
||||
'extends' => 'array',
|
||||
];
|
||||
|
|
@ -53,6 +56,13 @@ class ConstFlow extends Model
|
|||
});
|
||||
}
|
||||
|
||||
public function idsn():Attribute
|
||||
{
|
||||
return Attribute::make(
|
||||
get: fn($value) => str_pad($this->id, 6, '0',STR_PAD_LEFT),
|
||||
);
|
||||
}
|
||||
|
||||
public function oldman(){
|
||||
return $this->belongsTo(Oldmen::class, 'oldman_id');
|
||||
}
|
||||
|
|
|
|||
|
|
@ -22,6 +22,7 @@ class Oldmen extends Model
|
|||
|
||||
protected $casts = [
|
||||
'birthday' => 'datetime:Y-m-d',
|
||||
'bonds' => 'array',
|
||||
];
|
||||
|
||||
protected $appends = ['age'];
|
||||
|
|
|
|||
|
|
@ -23,17 +23,18 @@ class LiveExitService extends OldmenService
|
|||
if($oldMan->live_in != Oldmen::STATUS_LIVE){
|
||||
return $this->setError('客人状态异常,请刷新后重试!');
|
||||
}
|
||||
|
||||
$flowList = ConstFlow::where('oldman_id', $oldMan->id)
|
||||
->whereIn('const_type', [ConstFlow::TYPE_IN, ConstFlow::TYPE_CONTINUE])
|
||||
->where('state', 0)
|
||||
->whereBetween('start_at', [$oldMan->live_in_at, $oldMan->avliable_at])//开始时间在用户这段时间内的清单
|
||||
->get();
|
||||
|
||||
$flowMoney = 0;
|
||||
foreach($flowList as $flow){
|
||||
$flowMoney = bcsub($flowMoney, $flow->money, 2);
|
||||
}
|
||||
|
||||
//取消计算历史费用
|
||||
// $flowList = ConstFlow::where('oldman_id', $oldMan->id)
|
||||
// ->whereIn('const_type', [ConstFlow::TYPE_IN, ConstFlow::TYPE_CONTINUE])
|
||||
// ->where('state', 0)
|
||||
// ->whereBetween('start_at', [$oldMan->live_in_at, $oldMan->avliable_at])//开始时间在用户这段时间内的清单
|
||||
// ->get();
|
||||
|
||||
// foreach($flowList as $flow){
|
||||
// $flowMoney = bcsub($flowMoney, $flow->money, 2);
|
||||
// }
|
||||
|
||||
$flow = new ConstFlow();
|
||||
$flow->oldman_id = $oldMan->id;
|
||||
|
|
@ -63,7 +64,7 @@ class LiveExitService extends OldmenService
|
|||
'need_pay' => Oldmen::PAY_NORMAL,
|
||||
'live_in_at' => null,
|
||||
'avliable_at' => null,
|
||||
'bonds' => 0,//保证金归零
|
||||
'bonds' => [],//保证金归零
|
||||
]);
|
||||
DB::commit();
|
||||
}catch(Throwable $th){
|
||||
|
|
|
|||
|
|
@ -110,29 +110,30 @@ class OldmenService extends BaseService
|
|||
|
||||
switch($type){
|
||||
case ConstFlow::TYPE_EXIT:
|
||||
if($oldMan){
|
||||
if(isset($extends['live_in_at']) && $extends['avliable_at']){
|
||||
$startAt = $extends['live_in_at'];
|
||||
$endAt = $extends['avliable_at'];
|
||||
}else{
|
||||
$startAt = $oldMan->live_in_at;
|
||||
$endAt = $oldMan->avliable_at;
|
||||
}
|
||||
//取消缴费记录计算
|
||||
// if($oldMan){
|
||||
// if(isset($extends['live_in_at']) && $extends['avliable_at']){
|
||||
// $startAt = $extends['live_in_at'];
|
||||
// $endAt = $extends['avliable_at'];
|
||||
// }else{
|
||||
// $startAt = $oldMan->live_in_at;
|
||||
// $endAt = $oldMan->avliable_at;
|
||||
// }
|
||||
|
||||
$flowList = ConstFlow::where('oldman_id', $oldMan->id)
|
||||
->whereIn('const_type', [ConstFlow::TYPE_IN, ConstFlow::TYPE_CONTINUE])
|
||||
->where('state', 0)
|
||||
->whereBetween('start_at', [$startAt, $endAt])//开始时间在用户这段时间内的清单
|
||||
->get();
|
||||
foreach($flowList as $flow){
|
||||
$rows[] = [
|
||||
'ukey' => 'history_'.$flow->id,
|
||||
'name' => '缴费记录',
|
||||
'fee_name' => ConstFlow::typeMap()[$flow->const_type].'【'.$flow->created_at->format('m-d H:i:s').'】',
|
||||
'fee_value' => 0-$flow->money,
|
||||
];
|
||||
}
|
||||
}
|
||||
// $flowList = ConstFlow::where('oldman_id', $oldMan->id)
|
||||
// ->whereIn('const_type', [ConstFlow::TYPE_IN, ConstFlow::TYPE_CONTINUE])
|
||||
// ->where('state', 0)
|
||||
// ->whereBetween('start_at', [$startAt, $endAt])//开始时间在用户这段时间内的清单
|
||||
// ->get();
|
||||
// foreach($flowList as $flow){
|
||||
// $rows[] = [
|
||||
// 'ukey' => 'history_'.$flow->id,
|
||||
// 'name' => '缴费记录',
|
||||
// 'fee_name' => ConstFlow::typeMap()[$flow->const_type].'【'.$flow->created_at->format('m-d H:i:s').'】',
|
||||
// 'fee_value' => 0-$flow->money,
|
||||
// ];
|
||||
// }
|
||||
// }
|
||||
|
||||
$addFee = Arr::get($extends, 'add_extends', []);
|
||||
if(!$addFee){
|
||||
|
|
|
|||
File diff suppressed because it is too large
Load Diff
|
|
@ -55,7 +55,7 @@
|
|||
<p class="tag" style="font-size:20px;">
|
||||
<span class="left">客户姓名 :{{$name}}</span>
|
||||
<span class="middle">日期 :{{$time}}</span>
|
||||
<span class="right">单据编号 :{{$sn}}</span>
|
||||
<span class="right">单据编号 :{{$idsn}}</span>
|
||||
</p>
|
||||
<table class="print-table">
|
||||
<tr>
|
||||
|
|
|
|||
Loading…
Reference in New Issue