Features: - Implement two fee types: entrance fee and annual fee (both NT$1,000) - Add 50% discount for disability certificate holders - Add disability certificate upload in member profile - Integrate disability verification into cashier approval workflow - Add membership fee settings in system admin Document permissions: - Fix hard-coded role logic in Document model - Use permission-based authorization instead of role checks Additional features: - Add announcements, general ledger, and trial balance modules - Add income management and accounting entries - Add comprehensive test suite with factories - Update UI translations to Traditional Chinese 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
80 lines
2.3 KiB
PHP
80 lines
2.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Models\IssueLabel;
|
|
use App\Support\AuditLogger;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Auth;
|
|
|
|
class IssueLabelController extends Controller
|
|
{
|
|
public function index()
|
|
{
|
|
$labels = IssueLabel::withCount('issues')->orderBy('name')->get();
|
|
return view('admin.issue-labels.index', compact('labels'));
|
|
}
|
|
|
|
public function create()
|
|
{
|
|
return view('admin.issue-labels.create');
|
|
}
|
|
|
|
public function store(Request $request)
|
|
{
|
|
$validated = $request->validate([
|
|
'name' => ['required', 'string', 'max:255', 'unique:issue_labels,name'],
|
|
'color' => ['required', 'string', 'regex:/^#[0-9A-Fa-f]{6}$/'],
|
|
'description' => ['nullable', 'string', 'max:500'],
|
|
]);
|
|
|
|
$label = IssueLabel::create($validated);
|
|
|
|
AuditLogger::log('issue_label.created', $label, [
|
|
'name' => $label->name,
|
|
]);
|
|
|
|
return redirect()->route('admin.issue-labels.index')
|
|
->with('status', __('Label created successfully.'));
|
|
}
|
|
|
|
public function edit(IssueLabel $issueLabel)
|
|
{
|
|
return view('admin.issue-labels.edit', compact('issueLabel'));
|
|
}
|
|
|
|
public function update(Request $request, IssueLabel $issueLabel)
|
|
{
|
|
$validated = $request->validate([
|
|
'name' => ['required', 'string', 'max:255', 'unique:issue_labels,name,' . $issueLabel->id],
|
|
'color' => ['required', 'string', 'regex:/^#[0-9A-Fa-f]{6}$/'],
|
|
'description' => ['nullable', 'string', 'max:500'],
|
|
]);
|
|
|
|
$issueLabel->update($validated);
|
|
|
|
AuditLogger::log('issue_label.updated', $issueLabel, [
|
|
'name' => $issueLabel->name,
|
|
]);
|
|
|
|
return redirect()->route('admin.issue-labels.index')
|
|
->with('status', __('Label updated successfully.'));
|
|
}
|
|
|
|
public function destroy(IssueLabel $issueLabel)
|
|
{
|
|
if (!Auth::user()->hasRole('admin')) {
|
|
abort(403, 'Only administrators can delete labels.');
|
|
}
|
|
|
|
AuditLogger::log('issue_label.deleted', $issueLabel, [
|
|
'name' => $issueLabel->name,
|
|
]);
|
|
|
|
$issueLabel->delete();
|
|
|
|
return redirect()->route('admin.issue-labels.index')
|
|
->with('status', __('Label deleted successfully.'));
|
|
}
|
|
}
|