api message paginate

main
panliang 2024-04-29 20:35:34 +08:00
parent c03698fc0b
commit 543c127bc7
5 changed files with 35 additions and 8 deletions

View File

@ -50,9 +50,11 @@ class StoreService extends BaseService
]);
}
// 绑定店长
// 修改店长的所属门店
Employee::where('id', $data['master_id'])->update(['store_id' => $model->id]);
$this->currentModel = $model;
return true;
}
@ -71,6 +73,11 @@ class StoreService extends BaseService
$model->update($data);
// 修改店长的所属门店
if (isset($data['master_id'])) {
Employee::where('id', $data['master_id'])->update(['store_id' => $model->id]);
}
$afterProfitRatio = $model->profit_ratio;
if (bccomp($beforeProfitRatio, $afterProfitRatio, 2) !== 0) {
@ -88,7 +95,9 @@ class StoreService extends BaseService
]);
}
return $model->update($data);
$this->currentModel = $model;
return true;
}
public function resloveData($data, $model = null)

View File

@ -14,6 +14,7 @@ class Kernel extends ConsoleKernel
{
$schedule->command(Commands\TaskUpdateCommand::class)->hourly()->runInBackground();
$schedule->command(Commands\TaskLedgerGenerateCommand::class)->dailyAt('01:00')->runInBackground();
$schedule->command(Commands\EmployeeSign::class)->dailyAt('02:00')->runInBackground();
// $schedule->call(fn() => logger('schedule running'))->everyMinute();
}

View File

@ -11,6 +11,7 @@ use App\Admin\Services\EmployeeSignService;
use App\Enums\{SignTime, SignType, SignStatus};
use Carbon\Carbon;
use Slowlyo\OwlAdmin\Services\AdminSettingService;
use Illuminate\Validation\Rule;
/**
* 考勤打卡
@ -52,17 +53,19 @@ class SignController extends Controller
// 根据定位的距离判断, 是否外勤
$maxDistance = AdminSettingService::make()->arrayGet('sign', 'distance');
$type = SignType::Outside;
$distance = '';
$distance = null;
$description = '当前位置不在考勤范围内,请选择外勤打卡';
if ($request->filled(['lon', 'lat']) && $store && $maxDistance) {
$distance = $service->haversineDistance($request->input('lat'), $request->input('lon'), $store->lat, $store->lon);
if ($distance <= $maxDistance) {
$description = '已进入考勤范围' . $store->title;
$description = '已进入考勤范围: ' . $store->title;
$type = SignType::Normal;
} else {
$enable = false;
}
}
return compact('enable', 'time', 'type', 'description', 'distance');
return compact('enable', 'time', 'type', 'description', 'distance', 'maxDistance');
}
public function store(Request $request, EmployeeSignService $service)
@ -73,6 +76,12 @@ class SignController extends Controller
]);
$user = $this->guard()->user();
$time = SignTime::from($request->input('time'));
$type = SignType::from($request->input('type'));
// 没有定位坐标, 必须是外勤打卡
if (!$request->filled('position') && $type == SignType::Normal) {
}
try {
DB::beginTransaction();
if (!$service->signDay($user, $time, now(), $request->only(['remarks', 'position', 'type']))) {

View File

@ -24,14 +24,22 @@ class MessageController extends Controller
'readingLogs' => fn ($query) => $query->where('employee_id', $user->id),
])
->latest('id')
->simplePaginate($request->query('per_page', 20));
->paginate($request->query('per_page', 20));
return collect($paginator->items())->map(function (Message $message) {
$list = collect($paginator->items())->map(function (Message $message) {
return array_merge(
MessageResource::make($message)->resolve(),
['is_read' => $message->reading_logs_count],
);
});
// 分页
return [
'data' => $list,
'meta' => [
'total' => $paginator->total()
]
];
}
public function show($id, Request $request): MessageResource

View File

@ -36,7 +36,7 @@ class ReimbursementController extends Controller
$validated = $request->validate(
rules: [
'reimbursement_type_id' => ['bail', 'required', Rule::exists(Keyword::class, 'key')],
'expense' => ['bail', 'required', 'min:0', 'decimal:0,2'],
'expense' => ['bail', 'required', 'min:0', 'max:99999999', 'decimal:0,2'],
'reason' => ['bail', 'required', 'max:255'],
'photos' => ['bail', 'required', 'array'],
],