attendance log

This commit is contained in:
xiaomlove
2023-04-12 01:59:12 +08:00
parent 8e3ace4d83
commit 1ba01b2713
9 changed files with 185 additions and 1 deletions

View File

@@ -0,0 +1,113 @@
<?php
namespace App\Filament\Resources\User;
use App\Filament\OptionsTrait;
use App\Filament\Resources\User\AttendanceLogResource\Pages;
use App\Filament\Resources\User\AttendanceLogResource\RelationManagers;
use App\Models\AttendanceLog;
use Carbon\Carbon;
use Filament\Forms;
use Filament\Resources\Form;
use Filament\Resources\Resource;
use Filament\Resources\Table;
use Filament\Tables;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
class AttendanceLogResource extends Resource
{
use OptionsTrait;
protected static ?string $model = AttendanceLog::class;
protected static ?string $navigationIcon = 'heroicon-o-pencil-alt';
protected static ?string $navigationGroup = 'User';
protected static ?int $navigationSort = 11;
protected static function getNavigationLabel(): string
{
return __('admin.sidebar.attendance_log');
}
public static function getBreadcrumb(): string
{
return self::getNavigationLabel();
}
public static function form(Form $form): Form
{
return $form
->schema([
//
]);
}
public static function table(Table $table): Table
{
return $table
->columns([
Tables\Columns\TextColumn::make('id')->sortable(),
Tables\Columns\TextColumn::make('uid')->formatStateUsing(fn ($state) => username_for_admin($state)),
Tables\Columns\TextColumn::make('date')->label(__('attendance.fields.date'))->sortable(),
Tables\Columns\TextColumn::make('points')->label(__('attendance.fields.points')),
Tables\Columns\IconColumn::make('is_retroactive')
->label(__('attendance.fields.is_retroactive'))
->boolean(true)
,
Tables\Columns\TextColumn::make('created_at')->label(__('label.created_at')),
])
->defaultSort('id', 'desc')
->filters([
Tables\Filters\Filter::make('id')
->form([
Forms\Components\TextInput::make('id')
->placeholder('UID')
,
])->query(function (Builder $query, array $data) {
return $query->when($data['id'], fn (Builder $query, $value) => $query->where("uid", $value));
})
,
Tables\Filters\SelectFilter::make('is_retroactive')
->options(self::getYesNoOptions())
->label(__('attendance.fields.is_retroactive'))
,
Tables\Filters\Filter::make('date')
->form([
Forms\Components\DatePicker::make('date')
->maxDate(now())
->label(__('attendance.fields.date'))
,
])->query(function (Builder $query, array $data) {
return $query->when($data['date'], fn (Builder $query, $value) => $query->where("date", $value));
})
,
Tables\Filters\Filter::make('created_at')
->form([
Forms\Components\DatePicker::make('created_at')
->label(__('label.created_at'))
,
])->query(function (Builder $query, array $data) {
return $query->when($data['created_at'], function (Builder $query, $value) {
$begin = Carbon::parse($value)->startOfDay();
$end = Carbon::parse($value)->endOfDay();
return $query->where("created_at", ">=", $begin)->where('created_at', '<=', $end);
});
})
,
])
->actions([
])
->bulkActions([
]);
}
public static function getPages(): array
{
return [
'index' => Pages\ManageAttendanceLogs::route('/'),
];
}
}

View File

@@ -0,0 +1,20 @@
<?php
namespace App\Filament\Resources\User\AttendanceLogResource\Pages;
use App\Filament\PageListSingle;
use App\Filament\Resources\User\AttendanceLogResource;
use Filament\Pages\Actions;
use Filament\Resources\Pages\ManageRecords;
class ManageAttendanceLogs extends PageListSingle
{
protected static string $resource = AttendanceLogResource::class;
protected function getActions(): array
{
return [
Actions\CreateAction::make(),
];
}
}

View File

@@ -64,6 +64,8 @@ class AttendanceRepository extends BaseRepository
'uid' => $attendance->uid,
'points' => $update['points'],
'date' => $now->format('Y-m-d'),
'created_at' => $now,
'updated_at' => $now,
];
AttendanceLog::query()->insert($attendanceLog);
}

View File

@@ -0,0 +1,33 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::table('agent_allowed_family', function (Blueprint $table) {
$table->string("comment")->nullable(true)->change();
});
Schema::table('agent_deny_family', function (Blueprint $table) {
$table->string("comment")->nullable(true)->change();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
//
}
};

View File

@@ -1,6 +1,6 @@
<?php
defined('VERSION_NUMBER') || define('VERSION_NUMBER', '1.8.0');
defined('RELEASE_DATE') || define('RELEASE_DATE', '2023-04-09');
defined('RELEASE_DATE') || define('RELEASE_DATE', '2023-04-12');
defined('IN_TRACKER') || define('IN_TRACKER', false);
defined('PROJECTNAME') || define("PROJECTNAME","NexusPHP");
defined('NEXUSPHPURL') || define("NEXUSPHPURL","https://nexusphp.org");

View File

@@ -6,4 +6,9 @@ return [
'already_attendance' => 'Already attendance',
'card_not_enough' => 'Attendance card not enough',
'ranking' => "Today's Ranking: <b>:ranking</b> / <b>:counts</b>",
'fields' => [
'date' => 'Date',
'points' => 'Got bonus',
'is_retroactive' => 'Is retroactive',
],
];

View File

@@ -35,6 +35,7 @@ return [
'login_log' => '登录记录',
'bonus_log' => '魔力记录',
'torrent_buy_log' => '种子购买',
'attendance_log' => '签到记录',
],
'resources' => [
'agent_allow' => [

View File

@@ -6,4 +6,9 @@ return [
'already_attendance' => '已经签到',
'card_not_enough' => '补签卡不足',
'ranking' => '今日签到排名:<b>:ranking</b> / <b>:counts</b>',
'fields' => [
'date' => '日期',
'points' => '获得魔力',
'is_retroactive' => '是否补签',
],
];

View File

@@ -6,5 +6,10 @@ return [
'already_attendance' => '已經簽到',
'card_not_enough' => '補簽卡不足',
'ranking' => '今日簽到排名:<b>:ranking</b> / <b>:counts</b>',
'fields' => [
'date' => '日期',
'points' => '獲得魔力',
'is_retroactive' => '是否補簽',
],
];