Files
usher-manage-stack/app/Http/Controllers/IssueLabelController.php
Gbanyan 642b879dd4 Add membership fee system with disability discount and fix document permissions
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>
2025-12-01 09:56:01 +08:00

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.'));
}
}