feat: Phase 2 - page CRUD, subscriber management, user management
This commit is contained in:
@@ -5,34 +5,58 @@ declare(strict_types=1);
|
||||
namespace App\Http\Controllers\Admin;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Http\Requests\Admin\IndexSubscriberRequest;
|
||||
use App\Models\PreregistrationPage;
|
||||
use Illuminate\View\View;
|
||||
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||
|
||||
class SubscriberController extends Controller
|
||||
{
|
||||
public function index(PreregistrationPage $page): \Illuminate\View\View
|
||||
public function index(IndexSubscriberRequest $request, PreregistrationPage $page): View
|
||||
{
|
||||
return view('admin.subscribers.index', compact('page'));
|
||||
$search = $request->validated('search');
|
||||
$subscribers = $page->subscribers()
|
||||
->search(is_string($search) ? $search : null)
|
||||
->orderByDesc('created_at')
|
||||
->paginate(25)
|
||||
->withQueryString();
|
||||
|
||||
return view('admin.subscribers.index', compact('page', 'subscribers'));
|
||||
}
|
||||
|
||||
public function export(PreregistrationPage $page): \Symfony\Component\HttpFoundation\StreamedResponse
|
||||
public function export(IndexSubscriberRequest $request, PreregistrationPage $page): StreamedResponse
|
||||
{
|
||||
$this->authorize('view', $page);
|
||||
$search = $request->validated('search');
|
||||
$subscribers = $page->subscribers()
|
||||
->search(is_string($search) ? $search : null)
|
||||
->orderBy('created_at')
|
||||
->get();
|
||||
|
||||
$subscribers = $page->subscribers()->orderBy('created_at')->get();
|
||||
$phoneEnabled = $page->phone_enabled;
|
||||
|
||||
return response()->streamDownload(function () use ($subscribers, $page) {
|
||||
return response()->streamDownload(function () use ($subscribers, $phoneEnabled): void {
|
||||
$handle = fopen('php://output', 'w');
|
||||
fputcsv($handle, ['First Name', 'Last Name', 'Email', 'Phone', 'Registered At']);
|
||||
foreach ($subscribers as $sub) {
|
||||
fputcsv($handle, [
|
||||
$sub->first_name,
|
||||
$sub->last_name,
|
||||
$sub->email,
|
||||
$sub->phone,
|
||||
$sub->created_at->toDateTimeString(),
|
||||
]);
|
||||
$headers = ['First Name', 'Last Name', 'Email'];
|
||||
if ($phoneEnabled) {
|
||||
$headers[] = 'Phone';
|
||||
}
|
||||
$headers = array_merge($headers, ['Registered At', 'Synced to Mailwizz', 'Synced At']);
|
||||
fputcsv($handle, $headers);
|
||||
|
||||
foreach ($subscribers as $sub) {
|
||||
$row = [$sub->first_name, $sub->last_name, $sub->email];
|
||||
if ($phoneEnabled) {
|
||||
$row[] = $sub->phone ?? '';
|
||||
}
|
||||
$row[] = $sub->created_at?->toDateTimeString() ?? '';
|
||||
$row[] = $sub->synced_to_mailwizz ? 'Yes' : 'No';
|
||||
$row[] = $sub->synced_at?->toDateTimeString() ?? '';
|
||||
fputcsv($handle, $row);
|
||||
}
|
||||
|
||||
fclose($handle);
|
||||
}, "subscribers-{$page->slug}.csv");
|
||||
}, 'subscribers-'.$page->slug.'.csv', [
|
||||
'Content-Type' => 'text/csv; charset=UTF-8',
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user