412 lines
18 KiB
PHP
412 lines
18 KiB
PHP
<?php
|
|
|
|
namespace App\Admin\Controllers;
|
|
|
|
use App\Models\Keyword;
|
|
use Slowlyo\OwlAdmin\Models\AdminSetting;
|
|
use Slowlyo\OwlAdmin\Renderers\Page;
|
|
use Slowlyo\OwlAdmin\Renderers\Form;
|
|
use Slowlyo\OwlAdmin\Renderers\TableColumn;
|
|
use Slowlyo\OwlAdmin\Renderers\TextControl;
|
|
use Slowlyo\OwlAdmin\Controllers\AdminController;
|
|
use App\Services\Admin\OldmenService;
|
|
use Illuminate\Http\Request;
|
|
use App\Admin\Components;
|
|
use App\Models\ConstFlow;
|
|
use App\Models\Oldmen;
|
|
use Carbon\Carbon;
|
|
|
|
/**
|
|
* @property OldmenService $service
|
|
*/
|
|
class OldmenController extends AdminController
|
|
{
|
|
protected string $serviceName = OldmenService::class;
|
|
|
|
protected string $pageTitle = '客人管理';
|
|
|
|
public function options(){
|
|
$list = $this->service->listQuery()->select(['id as value', 'name as label'])->get();
|
|
|
|
return $this->response()->success($list);
|
|
}
|
|
|
|
public function list(): Page
|
|
{
|
|
$crud = $this->baseCRUD()
|
|
->filterTogglable(false)
|
|
->headerToolbar([
|
|
$this->createButton(true, 'lg'),
|
|
...$this->baseHeaderToolBar(),
|
|
])
|
|
->filter(
|
|
$this->baseFilter()->body([
|
|
amisMake()->TextControl('name', '名称')->size('md'),
|
|
amisMake()->TextControl('card_no', '身份证')->size('md'),
|
|
amisMake()->TextControl('floor_name', '楼栋')->size('md'),
|
|
amisMake()->SelectControl('nurse_lv', '护理等级')->options(Keyword::getByParentKey('nurse_lv')->pluck('name', 'value'))->checkAll(true)->multiple(true)->size('md'),
|
|
amis('button')->label(__('admin.reset'))->actionType('clear-and-submit'),
|
|
amis('submit')->label(__('admin.search'))->level('primary'),
|
|
])->actions([])
|
|
)
|
|
->columns([
|
|
// TableColumn::make()->name('id')->label('ID')->sortable(),
|
|
TableColumn::make()->name('name')->label('姓名'),
|
|
TableColumn::make()->name('age')->label('年龄')->sortable(),
|
|
TableColumn::make()->name('card_no')->label('身份证')->copyable(true),
|
|
TableColumn::make()->name('floor_name')->label('楼栋'),
|
|
TableColumn::make()->name('nurse_lv')->type('mapping')->map(Keyword::getByParentKey('nurse_lv')->pluck('name', 'value'))->label('护理等级')->className('text-primary')->sortable(),
|
|
TableColumn::make()->name('client_name')->label('委托人'),
|
|
TableColumn::make()->name('client_phone')->label('委托人-手机号')->copyable(true),
|
|
//状态:未入住、已办理,未入住、已入住
|
|
TableColumn::make()->name('created_at')->label(__('admin.created_at'))->type('datetime')->sortable(true),
|
|
amisMake()->Operation()->label(__('admin.actions'))->buttons([
|
|
$this->rowEditButton(true, 'lg'),
|
|
$this->rowDeleteButton()
|
|
]),
|
|
]);
|
|
|
|
return $this->baseList($crud);
|
|
}
|
|
|
|
public function form(): Form
|
|
{
|
|
return $this->baseForm()->body([
|
|
amisMake()->FieldSetControl()->title('居住人信息')->collapsable(true)->body([
|
|
amisMake()->GroupControl()->body([
|
|
amisMake()->TextControl('name', '姓名')->required(true),
|
|
amisMake()->RadiosControl('sex', '性别')->options([
|
|
1=>'男',2=>'女'
|
|
])->required(true),
|
|
]),
|
|
amisMake()->GroupControl()->body([
|
|
amisMake()->TextControl('card_no', '身份证号码')->required(true),
|
|
amisMake()->DateControl('birthday', '出生日期')->format('YYYY-MM-DD')->required(true),
|
|
]),
|
|
amisMake()->InputCityControl('card_city_code', '地区选择')->placeholder('请选择城市地区')->searchable('true')->required(true),
|
|
amisMake()->GroupControl()->body([
|
|
amisMake()->TextControl('card_address', '详细地址')->required(true),
|
|
]),
|
|
|
|
amisMake()->GroupControl()->body([
|
|
amisMake()->TextControl('floor_name', '楼栋'),
|
|
amisMake()->TextControl('agreement_no', '协议号码'),
|
|
]),
|
|
amisMake()->RadiosControl('nurse_lv', '护理等级')->options(Keyword::getByParentKey('nurse_lv')->pluck('name', 'value'))->required(true)->disabledOn('data.live_in > 0'),
|
|
]),
|
|
amisMake()->FieldSetControl()->className('mt-10')->title('委托人信息')->collapsable(true)->body([
|
|
amisMake()->GroupControl()->body([
|
|
amisMake()->TextControl('client_name', '姓名')->required(true),
|
|
amisMake()->TextControl('client_phone', '手机号')->required(true),
|
|
]),
|
|
amisMake()->InputCityControl('client_city_code', '地区选择')->placeholder('请选择城市地区')->searchable('true')->required(true),
|
|
amisMake()->GroupControl()->body([
|
|
amisMake()->TextControl('client_address', '详细地址')->required(true),
|
|
]),
|
|
]),
|
|
]);
|
|
}
|
|
|
|
public function detail(): Form
|
|
{
|
|
return $this->baseDetail()->body([
|
|
TextControl::make()->static()->name('id')->label('ID'),
|
|
TextControl::make()->static()->name('created_at')->label(__('admin.created_at')),
|
|
TextControl::make()->static()->name('updated_at')->label(__('admin.updated_at'))
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 获取编辑页面
|
|
*
|
|
* @param $id
|
|
*
|
|
* @return JsonResponse|JsonResource
|
|
* @throws ContainerExceptionInterface
|
|
* @throws NotFoundExceptionInterface
|
|
*/
|
|
public function edit($id)
|
|
{
|
|
$this->isEdit = true;
|
|
|
|
if ($this->actionOfGetData()) {
|
|
$data = null;
|
|
if($id){
|
|
$data = $this->service->getEditData($id);
|
|
//处理下
|
|
if($data->avliable_at){
|
|
//续住时的开始时间
|
|
$data->offsetSet('start_at', Carbon::parse($data->avliable_at)->addSecond()->format('Y-m-d'));
|
|
}
|
|
}
|
|
return $this->response()->success($data);
|
|
}
|
|
|
|
$form = amisMake()
|
|
->Card()
|
|
->className('base-form')
|
|
->header(['title' => __('admin.edit')])
|
|
->toolbar([$this->backButton()])
|
|
->body(
|
|
$this->form(true)->api($this->getUpdatePath())->initApi($this->getEditGetDataPath())
|
|
);
|
|
|
|
$page = $this->basePage()->body($form);
|
|
|
|
return $this->response()->success($page);
|
|
}
|
|
|
|
/**
|
|
* 生成结算费用清单
|
|
*/
|
|
public function liveFeelist(Request $request)
|
|
{
|
|
$rows = $addFee = $delFee = [];
|
|
foreach($request->input() as $key => $value){
|
|
if($key == 'add_extends'){
|
|
if(is_array($value)){
|
|
$addFee = $value;
|
|
}
|
|
}elseif($key == 'del_extends'){
|
|
if(is_array($value)){
|
|
$delFee = $value;
|
|
}
|
|
}else{
|
|
if(is_array($value)){
|
|
foreach($value as $item =>$vv){
|
|
$_fee = Keyword::where('key', $item)->first();
|
|
$rows[] = [
|
|
'name' => $_fee->parent->name,
|
|
'fee_name' => $_fee->name,
|
|
'fee_value' => $vv,
|
|
];
|
|
}
|
|
}else{
|
|
$_fee = Keyword::where('key', $key)->first();
|
|
$rows[] = [
|
|
'name' => $_fee->parent->name,
|
|
'fee_name' => $_fee->name,
|
|
'fee_value' => $value,
|
|
];
|
|
}
|
|
}
|
|
}
|
|
foreach($addFee as $item){
|
|
if(isset($item['name']) && isset($item['fee'])){
|
|
$rows[] = [
|
|
'name' => '收费项',
|
|
'fee_name' => $item['name'],
|
|
'fee_value' => $item['fee'],
|
|
];
|
|
}
|
|
}
|
|
foreach($delFee as $item){
|
|
if(isset($item['name']) && isset($item['fee'])){
|
|
$rows[] = [
|
|
'name' => '抵扣项',
|
|
'fee_name' => $item['name'],
|
|
'fee_value' => 0-$item['fee'],
|
|
];
|
|
}
|
|
}
|
|
return $this->response()->success([
|
|
'rows'=> $rows,
|
|
]);
|
|
}
|
|
|
|
public function exitFeelist(Request $request)
|
|
{
|
|
$rows = $addFee = $delFee = [];
|
|
$oldMan = Oldmen::find($request->input('oldman_id', 0));
|
|
if($oldMan){
|
|
$flowList = ConstFlow::where('oldman_id', $oldMan->id)
|
|
->whereIn('const_type', [ConstFlow::TYPE_IN, ConstFlow::TYPE_CONTINUE])
|
|
->whereBetween('start_at', [$oldMan->live_in_at, $oldMan->avliable_at])//开始时间在用户这段时间内的清单
|
|
->get();
|
|
foreach($flowList as $flow){
|
|
$rows[] = [
|
|
'name' => '缴费记录',
|
|
'fee_name' => ConstFlow::typeMap()[$flow->const_type].'【'.$flow->created_at->format('m-d H:i:s').'】',
|
|
'fee_value' => $flow->money,
|
|
];
|
|
}
|
|
}
|
|
|
|
$addFee = $request->input('add_extends') ?? [];
|
|
$delFee = $request->input('del_extends') ?? [];
|
|
foreach($addFee as $item){
|
|
if(isset($item['name']) && isset($item['fee'])){
|
|
$rows[] = [
|
|
'name' => '抵扣项',
|
|
'fee_name' => $item['name'],
|
|
'fee_value' => $item['fee'],
|
|
];
|
|
}
|
|
}
|
|
foreach($delFee as $item){
|
|
if(isset($item['name']) && isset($item['fee'])){
|
|
$rows[] = [
|
|
'name' => '收费项',
|
|
'fee_name' => $item['name'],
|
|
'fee_value' => 0-$item['fee'],
|
|
];
|
|
}
|
|
}
|
|
return $this->response()->success([
|
|
'rows'=> $rows,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 费用表单
|
|
*
|
|
*/
|
|
public function liveSchemaForm(Request $request)
|
|
{
|
|
$type = $request->input('type', 'live_fee');
|
|
$dateRange = $request->input('live_in_date', null);
|
|
//处理续住时间传递
|
|
$startDay = $dateRange ? explode(',', $dateRange)[0].' 00:00:00' : $request->input('start_at', null);
|
|
$endDay = $dateRange ? explode(',', $dateRange)[1].' 23:59:59' : $request->input('end_at', null);
|
|
|
|
if($startDay && $endDay){
|
|
$diffYears = Carbon::parse($startDay)->diffInYears($endDay);
|
|
$diffMonths = Carbon::parse($startDay)->addYears($diffYears)->diffInMonths($endDay);
|
|
$diffAbMonths = Carbon::parse($startDay)->diffInMonths($endDay);
|
|
$diffDays = Carbon::parse($startDay)->addYears($diffYears)->addMonths($diffMonths)->diffInDays($endDay);
|
|
$diffAbDays = Carbon::parse($startDay)->diffInDays($endDay);
|
|
}
|
|
|
|
$lv = $request->input('nurse_lv', 1);
|
|
$feeKey = Keyword::getByParentKey($type);
|
|
$feeKeyHelp = AdminSetting::whereIn('key', $feeKey?->pluck('key')->toArray())->pluck('values','key')->toArray();
|
|
foreach(Keyword::getByParentKey($type) as $fee)
|
|
{
|
|
$_feeValue = 0;
|
|
if(isset($feeKeyHelp[$fee->key])){
|
|
$_feeValues = [];
|
|
if($feeKeyHelp[$fee->key]['has_time'] == 2 && !empty($dateRange)){
|
|
array_map(function($item) use(&$_feeValues){
|
|
$_feeValues[$item['lv']][$item['time_type']] = $item['fee'];
|
|
}, $feeKeyHelp[$fee->key]['values']);
|
|
|
|
if(isset($_feeValues[$lv]['day'])){
|
|
//判断是否有设置年份
|
|
if(isset($_feeValues[$lv]['year'])){
|
|
$_feeValue += bcmul($diffYears, $_feeValues[$lv]['year'], 2);
|
|
if(isset($_feeValues[$lv]['month'])){
|
|
$_feeValue += bcmul($diffMonths, $_feeValues[$lv]['month'], 2);
|
|
$_feeValue += bcmul($diffDays, $_feeValues[$lv]['day'], 2);
|
|
}else{
|
|
$_feeValue += bcmul($diffAbDays, $_feeValues[$lv]['day'], 2);
|
|
}
|
|
}else{
|
|
if(isset($_feeValues[$lv]['month'])){
|
|
$_feeValue += bcmul($diffAbMonths, $_feeValues[$lv]['month'], 2);
|
|
}else{
|
|
$_feeValue += bcmul($diffAbDays, $_feeValues[$lv]['day'], 2);
|
|
}
|
|
}
|
|
}
|
|
}else{
|
|
$_feeValues = collect($feeKeyHelp[$fee->key]['values'] ?? [])->keyBy('lv')->toArray();
|
|
$_feeValue = $_feeValues[$lv]['fee'] ?? 0;
|
|
}
|
|
}
|
|
$feeArr[] = Components::make()->decimalControl($type.'['.$fee->key.']', $fee->name)->description(amis('tpl')->tpl('根据当前护理等级,建议费用为:'.$_feeValue));
|
|
}
|
|
|
|
return $this->response()->success($feeArr);
|
|
}
|
|
|
|
/**
|
|
* 已缴费明细清单
|
|
*/
|
|
public function liveConstFlow(Request $request)
|
|
{
|
|
$page = [];
|
|
$oldMan = Oldmen::find($request->input('oldman_id', 0));
|
|
if($oldMan){
|
|
$flowList = ConstFlow::where('oldman_id', $oldMan->id)
|
|
->whereIn('const_type', [ConstFlow::TYPE_IN, ConstFlow::TYPE_CONTINUE])
|
|
->whereBetween('start_at', [$oldMan->live_in_at, $oldMan->avliable_at])//开始时间在用户这段时间内的清单
|
|
->get();
|
|
$tableList = [];
|
|
foreach($flowList as $flow){
|
|
$_feeInfo = $_bonusInfo = $_addInfo = $_delInfo = '';
|
|
|
|
foreach($flow->extends as $_feeKey => $_feeArr){
|
|
$_money = 0;
|
|
switch($_feeKey){
|
|
case 'live_fee':
|
|
case 'continue_fee':
|
|
foreach($_feeArr as $k => $v){
|
|
$_fee = Keyword::where('key', $k)->first();
|
|
$_feeInfo.= '【'.$_fee->name.'】'.$v.'元,';
|
|
$_money = bcadd($_money, $v, 2);
|
|
}
|
|
$_feeInfo = mb_substr($_feeInfo, 0, -1);
|
|
$_feeInfo = $_money.'元:'.$_feeInfo;
|
|
break;
|
|
case 'bonds_fee':
|
|
foreach($_feeArr as $k => $v){
|
|
$_fee = Keyword::where('key', $k)->first();
|
|
$_bonusInfo.= '【'.$_fee->name.'】'.$v.'元,';
|
|
$_money = bcadd($_money, $v, 2);
|
|
}
|
|
$_bonusInfo = mb_substr($_bonusInfo, 0, -1);
|
|
$_bonusInfo = $_money.'元:'.$_bonusInfo;
|
|
break;
|
|
case 'add_fee':
|
|
foreach($_feeArr as $k => $_fee){
|
|
$_addInfo.= '【'.$_fee["name"].'】'.$_fee["fee"].'元,';
|
|
$_money = bcadd($_money, $_fee["fee"], 2);
|
|
}
|
|
$_addInfo = mb_substr($_addInfo, 0, -1);
|
|
$_addInfo = $_money.'元:'.$_addInfo;
|
|
break;
|
|
case 'del_fee':
|
|
foreach($_feeArr as $k => $_fee){
|
|
$_delInfo.= '【'.$_fee["name"].'】-'.$_fee["fee"].'元,';
|
|
$_money = bcsub($_money, $_fee["fee"], 2);
|
|
}
|
|
$_delInfo = mb_substr($_delInfo, 0, -1);
|
|
$_delInfo = $_money.'元:'.$_delInfo;
|
|
break;
|
|
}
|
|
}
|
|
|
|
$tableList[] = [
|
|
'type' => ConstFlow::typeMap()[$flow->const_type],//类别
|
|
'money'=> $flow->money,//金额(含保证金)
|
|
'date_range' => Carbon::parse($flow->start_at)->format('Y-m-d').' 至 '.Carbon::parse($flow->end_at)->format('Y-m-d'),//时间区间
|
|
'flow_at'=>$flow->created_at->format('Y-m-d H:i:s'),//办理时间
|
|
'fee_info'=>$_feeInfo,//费用明细,
|
|
'bonus_info'=>$_bonusInfo,
|
|
'add_info'=>$_addInfo,//收费项
|
|
'del_info'=>$_delInfo,//抵扣项
|
|
];
|
|
}
|
|
$page = amisMake()->table()
|
|
->className('m-b-none')->columnsTogglable(false)
|
|
->data([
|
|
'rows' => $tableList
|
|
])
|
|
->source('${rows}')
|
|
->footable([
|
|
'expand'=>'first'
|
|
])->columns([
|
|
amisMake()->TableColumn()->name('type')->label('缴费类型'),
|
|
amisMake()->TableColumn()->name('money')->label('缴费金额'),
|
|
amisMake()->TableColumn()->name('flow_at')->label('办理时间'),
|
|
amisMake()->TableColumn()->name('date_range')->label('有效时间')->breakpoint("*"),
|
|
amisMake()->TableColumn()->name('fee_info')->label('费用明细')->breakpoint("*"),
|
|
amisMake()->TableColumn()->name('bonus_info')->label('保证金')->breakpoint("*"),
|
|
amisMake()->TableColumn()->name('add_info')->label('附加-收费项')->breakpoint("*"),
|
|
amisMake()->TableColumn()->name('del_info')->label('附加-抵扣项')->breakpoint("*"),
|
|
]);
|
|
}
|
|
return $this->response()->success($page);
|
|
}
|
|
}
|