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>
This commit is contained in:
@@ -17,8 +17,8 @@ class BudgetTest extends TestCase
|
||||
protected function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
$this->artisan('db:seed', ['--class' => 'RoleSeeder']);
|
||||
$this->artisan('db:seed', ['--class' => 'ChartOfAccountSeeder']);
|
||||
$this->artisan('db:seed', ['--class' => 'FinancialWorkflowPermissionsSeeder', '--force' => true]);
|
||||
$this->artisan('db:seed', ['--class' => 'ChartOfAccountSeeder', '--force' => true]);
|
||||
}
|
||||
|
||||
public function test_budget_belongs_to_created_by_user(): void
|
||||
|
||||
@@ -19,7 +19,7 @@ class IssueTest extends TestCase
|
||||
protected function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
$this->artisan('db:seed', ['--class' => 'RoleSeeder']);
|
||||
$this->artisan('db:seed', ['--class' => 'FinancialWorkflowPermissionsSeeder', '--force' => true]);
|
||||
}
|
||||
|
||||
public function test_issue_number_auto_generation(): void
|
||||
@@ -254,19 +254,19 @@ class IssueTest extends TestCase
|
||||
public function test_status_label_returns_correct_text(): void
|
||||
{
|
||||
$issue = Issue::factory()->create(['status' => Issue::STATUS_NEW]);
|
||||
$this->assertEquals('New', $issue->status_label);
|
||||
$this->assertEquals(__('New'), $issue->status_label);
|
||||
|
||||
$issue->status = Issue::STATUS_CLOSED;
|
||||
$this->assertEquals('Closed', $issue->status_label);
|
||||
$this->assertEquals(__('Closed'), $issue->status_label);
|
||||
}
|
||||
|
||||
public function test_priority_label_returns_correct_text(): void
|
||||
{
|
||||
$issue = Issue::factory()->create(['priority' => Issue::PRIORITY_LOW]);
|
||||
$this->assertEquals('Low', $issue->priority_label);
|
||||
$this->assertEquals(__('Low'), $issue->priority_label);
|
||||
|
||||
$issue->priority = Issue::PRIORITY_URGENT;
|
||||
$this->assertEquals('Urgent', $issue->priority_label);
|
||||
$this->assertEquals(__('Urgent'), $issue->priority_label);
|
||||
}
|
||||
|
||||
public function test_badge_color_methods_work(): void
|
||||
@@ -320,9 +320,9 @@ class IssueTest extends TestCase
|
||||
public function test_issue_type_label_returns_correct_text(): void
|
||||
{
|
||||
$issue = Issue::factory()->create(['issue_type' => Issue::TYPE_WORK_ITEM]);
|
||||
$this->assertEquals('Work Item', $issue->issue_type_label);
|
||||
$this->assertEquals(__('Work Item'), $issue->issue_type_label);
|
||||
|
||||
$issue->issue_type = Issue::TYPE_MEMBER_REQUEST;
|
||||
$this->assertEquals('Member Request', $issue->issue_type_label);
|
||||
$this->assertEquals(__('Member Request'), $issue->issue_type_label);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user