Add phone login support and member import functionality
Features: - Support login via phone number or email (LoginRequest) - Add members:import-roster command for Excel roster import - Merge survey emails with roster data Code Quality (Phase 1-4): - Add database locking for balance calculation - Add self-approval checks for finance workflow - Create service layer (FinanceDocumentApprovalService, PaymentVerificationService) - Add HasAccountingEntries and HasApprovalWorkflow traits - Create FormRequest classes for validation - Add status-badge component - Define authorization gates in AuthServiceProvider - Add accounting config file Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -2,6 +2,8 @@
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Http\Requests\StoreMemberRequest;
|
||||
use App\Http\Requests\UpdateMemberRequest;
|
||||
use App\Models\Member;
|
||||
use App\Support\AuditLogger;
|
||||
use Spatie\Permission\Models\Role;
|
||||
@@ -88,22 +90,9 @@ class AdminMemberController extends Controller
|
||||
return view('admin.members.create');
|
||||
}
|
||||
|
||||
public function store(Request $request)
|
||||
public function store(StoreMemberRequest $request)
|
||||
{
|
||||
$validated = $request->validate([
|
||||
'full_name' => ['required', 'string', 'max:255'],
|
||||
'email' => ['required', 'email', 'max:255', 'unique:users,email'],
|
||||
'national_id' => ['nullable', 'string', 'max:50'],
|
||||
'phone' => ['nullable', 'string', 'max:50'],
|
||||
'address_line_1' => ['nullable', 'string', 'max:255'],
|
||||
'address_line_2' => ['nullable', 'string', 'max:255'],
|
||||
'city' => ['nullable', 'string', 'max:120'],
|
||||
'postal_code' => ['nullable', 'string', 'max:20'],
|
||||
'emergency_contact_name' => ['nullable', 'string', 'max:255'],
|
||||
'emergency_contact_phone' => ['nullable', 'string', 'max:50'],
|
||||
'membership_started_at' => ['nullable', 'date'],
|
||||
'membership_expires_at' => ['nullable', 'date', 'after_or_equal:membership_started_at'],
|
||||
]);
|
||||
$validated = $request->validated();
|
||||
|
||||
// Create user account
|
||||
$user = \App\Models\User::create([
|
||||
@@ -137,23 +126,9 @@ class AdminMemberController extends Controller
|
||||
]);
|
||||
}
|
||||
|
||||
public function update(Request $request, Member $member)
|
||||
public function update(UpdateMemberRequest $request, Member $member)
|
||||
{
|
||||
$validated = $request->validate([
|
||||
'full_name' => ['required', 'string', 'max:255'],
|
||||
'email' => ['required', 'email', 'max:255'],
|
||||
'national_id' => ['nullable', 'string', 'max:50'],
|
||||
'phone' => ['nullable', 'string', 'max:50'],
|
||||
'address_line_1' => ['nullable', 'string', 'max:255'],
|
||||
'address_line_2' => ['nullable', 'string', 'max:255'],
|
||||
'city' => ['nullable', 'string', 'max:120'],
|
||||
'postal_code' => ['nullable', 'string', 'max:20'],
|
||||
'emergency_contact_name' => ['nullable', 'string', 'max:255'],
|
||||
'emergency_contact_phone' => ['nullable', 'string', 'max:50'],
|
||||
'membership_started_at' => ['nullable', 'date'],
|
||||
'membership_expires_at' => ['nullable', 'date', 'after_or_equal:membership_started_at'],
|
||||
]);
|
||||
|
||||
$validated = $request->validated();
|
||||
$member->update($validated);
|
||||
AuditLogger::log('member.updated', $member, $validated);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user