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>
114 lines
7.7 KiB
PHP
114 lines
7.7 KiB
PHP
<x-app-layout>
|
|
<x-slot name="header">
|
|
<h2 class="text-xl font-semibold leading-tight text-gray-800 dark:text-gray-200">
|
|
系統設定 - 通知設定
|
|
</h2>
|
|
</x-slot>
|
|
|
|
<div class="py-12">
|
|
<div class="mx-auto max-w-7xl sm:px-6 lg:px-8">
|
|
<div class="grid grid-cols-1 gap-6 lg:grid-cols-4">
|
|
<!-- Sidebar -->
|
|
<div class="lg:col-span-1">
|
|
@include('admin.settings._sidebar')
|
|
</div>
|
|
|
|
<!-- Main Content -->
|
|
<div class="lg:col-span-3">
|
|
@if (session('status'))
|
|
<div class="mb-6 rounded-md bg-green-50 dark:bg-green-900/50 p-4">
|
|
<p class="text-sm font-medium text-green-800 dark:text-green-200">{{ session('status') }}</p>
|
|
</div>
|
|
@endif
|
|
|
|
<div class="bg-white dark:bg-gray-800 shadow sm:rounded-lg">
|
|
<div class="px-6 py-5 border-b border-gray-200 dark:border-gray-700">
|
|
<h3 class="text-lg font-medium text-gray-900 dark:text-gray-100">通知設定</h3>
|
|
<p class="mt-1 text-sm text-gray-600 dark:text-gray-400">配置系統通知和電子郵件提醒</p>
|
|
</div>
|
|
|
|
<form action="{{ route('admin.settings.notifications.update') }}" method="POST" class="px-6 py-6 space-y-6">
|
|
@csrf
|
|
|
|
<!-- Enable Notifications -->
|
|
<div class="flex items-start">
|
|
<div class="flex items-center h-5">
|
|
<input type="checkbox" name="enabled" id="enabled"
|
|
{{ $settings['enabled'] ? 'checked' : '' }}
|
|
class="w-4 h-4 text-indigo-600 dark:text-indigo-500 border-gray-300 dark:border-gray-700 rounded focus:ring-indigo-500 dark:focus:ring-indigo-600 dark:bg-gray-900">
|
|
</div>
|
|
<div class="ml-3 text-sm">
|
|
<label for="enabled" class="font-medium text-gray-700 dark:text-gray-300">啟用系統通知</label>
|
|
<p class="text-gray-500 dark:text-gray-400">啟用所有系統通知功能</p>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Expiration Alerts -->
|
|
<div class="flex items-start">
|
|
<div class="flex items-center h-5">
|
|
<input type="checkbox" name="expiration_alerts_enabled" id="expiration_alerts_enabled"
|
|
{{ $settings['expiration_alerts_enabled'] ? 'checked' : '' }}
|
|
class="w-4 h-4 text-indigo-600 dark:text-indigo-500 border-gray-300 dark:border-gray-700 rounded focus:ring-indigo-500 dark:focus:ring-indigo-600 dark:bg-gray-900">
|
|
</div>
|
|
<div class="ml-3 text-sm">
|
|
<label for="expiration_alerts_enabled" class="font-medium text-gray-700 dark:text-gray-300">文件到期提醒</label>
|
|
<p class="text-gray-500 dark:text-gray-400">當文件即將到期時發送電子郵件提醒</p>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Expiration Recipients -->
|
|
<div>
|
|
<label for="expiration_recipients" class="block text-sm font-medium text-gray-700 dark:text-gray-300">
|
|
到期通知收件人
|
|
</label>
|
|
<input type="text" name="expiration_recipients" id="expiration_recipients"
|
|
value="{{ old('expiration_recipients', implode(', ', $settings['expiration_recipients'])) }}"
|
|
class="mt-1 block w-full rounded-md border-gray-300 dark:border-gray-700 shadow-sm focus:border-indigo-500 dark:focus:border-indigo-600 focus:ring-indigo-500 dark:focus:ring-indigo-600 sm:text-sm dark:bg-gray-900 dark:text-gray-300"
|
|
placeholder="admin@example.com, manager@example.com">
|
|
<p class="mt-1 text-sm text-gray-500 dark:text-gray-400">接收到期通知的電子郵件地址,以逗號分隔</p>
|
|
@error('expiration_recipients')
|
|
<p class="mt-1 text-sm text-red-600 dark:text-red-400">{{ $message }}</p>
|
|
@enderror
|
|
</div>
|
|
|
|
<!-- Archive Notifications -->
|
|
<div class="flex items-start">
|
|
<div class="flex items-center h-5">
|
|
<input type="checkbox" name="archive_notifications_enabled" id="archive_notifications_enabled"
|
|
{{ $settings['archive_notifications_enabled'] ? 'checked' : '' }}
|
|
class="w-4 h-4 text-indigo-600 dark:text-indigo-500 border-gray-300 dark:border-gray-700 rounded focus:ring-indigo-500 dark:focus:ring-indigo-600 dark:bg-gray-900">
|
|
</div>
|
|
<div class="ml-3 text-sm">
|
|
<label for="archive_notifications_enabled" class="font-medium text-gray-700 dark:text-gray-300">文件封存通知</label>
|
|
<p class="text-gray-500 dark:text-gray-400">當文件被封存時發送通知</p>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- New Document Alerts -->
|
|
<div class="flex items-start">
|
|
<div class="flex items-center h-5">
|
|
<input type="checkbox" name="new_document_alerts_enabled" id="new_document_alerts_enabled"
|
|
{{ $settings['new_document_alerts_enabled'] ? 'checked' : '' }}
|
|
class="w-4 h-4 text-indigo-600 dark:text-indigo-500 border-gray-300 dark:border-gray-700 rounded focus:ring-indigo-500 dark:focus:ring-indigo-600 dark:bg-gray-900">
|
|
</div>
|
|
<div class="ml-3 text-sm">
|
|
<label for="new_document_alerts_enabled" class="font-medium text-gray-700 dark:text-gray-300">新文件通知</label>
|
|
<p class="text-gray-500 dark:text-gray-400">當有新文件上傳時發送通知給相關人員</p>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Submit Button -->
|
|
<div class="flex items-center justify-end pt-4 border-t border-gray-200 dark:border-gray-700">
|
|
<button type="submit"
|
|
class="inline-flex justify-center rounded-md border border-transparent bg-indigo-600 dark:bg-indigo-500 py-2 px-4 text-sm font-medium text-white shadow-sm hover:bg-indigo-700 dark:hover:bg-indigo-600 focus:outline-none focus:ring-2 focus:ring-indigo-500 dark:focus:ring-indigo-600 focus:ring-offset-2 dark:focus:ring-offset-gray-800">
|
|
儲存變更
|
|
</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</x-app-layout>
|