Update membership types to match charter Article 7

- Add individual, sponsor, honorary_academic types (per charter)
- Keep legacy types (regular, honorary, lifetime, student) for compatibility
- Update labels to Chinese names
- Fix MembershipPayment import to include verification dates

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
2026-01-25 03:43:08 +08:00
parent 42099759e8
commit e27d3c0f72
4 changed files with 53 additions and 10 deletions

View File

@@ -27,7 +27,7 @@ CREATE INDEX "document_access_logs_document_id_index" on "document_access_logs"
CREATE INDEX "document_access_logs_user_id_index" on "document_access_logs" ("user_id");
CREATE INDEX "document_access_logs_action_index" on "document_access_logs" ("action");
CREATE INDEX "document_access_logs_accessed_at_index" on "document_access_logs" ("accessed_at");
CREATE TABLE IF NOT EXISTS "members" ("id" integer primary key autoincrement not null, "user_id" integer, "full_name" varchar not null, "email" varchar not null, "phone" varchar, "national_id_encrypted" varchar, "national_id_hash" varchar, "membership_started_at" date, "membership_expires_at" date, "created_at" datetime, "updated_at" datetime, "last_expiry_reminder_sent_at" datetime, "address_line_1" varchar, "address_line_2" varchar, "city" varchar, "postal_code" varchar, "emergency_contact_name" varchar, "emergency_contact_phone" varchar, "membership_status" varchar check ("membership_status" in ('pending', 'active', 'expired', 'suspended')) not null default 'pending', "membership_type" varchar check ("membership_type" in ('regular', 'honorary', 'lifetime', 'student')) not null default 'regular', "disability_certificate_path" varchar, "disability_certificate_status" varchar, "disability_verified_by" integer, "disability_verified_at" datetime, "disability_rejection_reason" text, foreign key("user_id") references "users"("id") on delete set null);
CREATE TABLE IF NOT EXISTS "members" ("id" integer primary key autoincrement not null, "user_id" integer, "full_name" varchar not null, "email" varchar not null, "phone" varchar, "national_id_encrypted" varchar, "national_id_hash" varchar, "membership_started_at" date, "membership_expires_at" date, "created_at" datetime, "updated_at" datetime, "last_expiry_reminder_sent_at" datetime, "address_line_1" varchar, "address_line_2" varchar, "city" varchar, "postal_code" varchar, "emergency_contact_name" varchar, "emergency_contact_phone" varchar, "membership_status" varchar check ("membership_status" in ('pending', 'active', 'expired', 'suspended')) not null default 'pending', "membership_type" varchar check ("membership_type" in ('individual', 'sponsor', 'honorary_academic', 'regular', 'honorary', 'lifetime', 'student')) not null default 'individual', "disability_certificate_path" varchar, "disability_certificate_status" varchar, "disability_verified_by" integer, "disability_verified_at" datetime, "disability_rejection_reason" text, foreign key("user_id") references "users"("id") on delete set null);
CREATE INDEX "members_email_index" on "members" ("email");
CREATE INDEX "members_national_id_hash_index" on "members" ("national_id_hash");
CREATE TABLE IF NOT EXISTS "membership_payments" ("id" integer primary key autoincrement not null, "member_id" integer not null, "paid_at" date not null, "amount" numeric not null, "method" varchar, "reference" varchar, "created_at" datetime, "updated_at" datetime, "status" varchar check ("status" in ('pending', 'approved_cashier', 'approved_accountant', 'approved_chair', 'rejected')) not null default 'pending', "payment_method" varchar check ("payment_method" in ('bank_transfer', 'convenience_store', 'cash', 'credit_card')), "receipt_path" varchar, "submitted_by_user_id" integer, "verified_by_cashier_id" integer, "cashier_verified_at" datetime, "verified_by_accountant_id" integer, "accountant_verified_at" datetime, "verified_by_chair_id" integer, "chair_verified_at" datetime, "rejected_by_user_id" integer, "rejected_at" datetime, "rejection_reason" text, "notes" text, "fee_type" varchar not null default 'entrance_fee', "base_amount" numeric, "discount_amount" numeric not null default '0', "final_amount" numeric, "disability_discount" tinyint(1) not null default '0', foreign key("member_id") references "members"("id") on delete cascade);