Files
PROJECT-CONTORL/frontend/public/locales/en/settings.json
beabigegg 3bdc6ff1c9 feat: implement 8 OpenSpec proposals for security, reliability, and UX improvements
## Security Enhancements (P0)
- Add input validation with max_length and numeric range constraints
- Implement WebSocket token authentication via first message
- Add path traversal prevention in file storage service

## Permission Enhancements (P0)
- Add project member management for cross-department access
- Implement is_department_manager flag for workload visibility

## Cycle Detection (P0)
- Add DFS-based cycle detection for task dependencies
- Add formula field circular reference detection
- Display user-friendly cycle path visualization

## Concurrency & Reliability (P1)
- Implement optimistic locking with version field (409 Conflict on mismatch)
- Add trigger retry mechanism with exponential backoff (1s, 2s, 4s)
- Implement cascade restore for soft-deleted tasks

## Rate Limiting (P1)
- Add tiered rate limits: standard (60/min), sensitive (20/min), heavy (5/min)
- Apply rate limits to tasks, reports, attachments, and comments

## Frontend Improvements (P1)
- Add responsive sidebar with hamburger menu for mobile
- Improve touch-friendly UI with proper tap target sizes
- Complete i18n translations for all components

## Backend Reliability (P2)
- Configure database connection pool (size=10, overflow=20)
- Add Redis fallback mechanism with message queue
- Add blocker check before task deletion

## API Enhancements (P3)
- Add standardized response wrapper utility
- Add /health/ready and /health/live endpoints
- Implement project templates with status/field copying

## Tests Added
- test_input_validation.py - Schema and path traversal tests
- test_concurrency_reliability.py - Optimistic locking and retry tests
- test_backend_reliability.py - Connection pool and Redis tests
- test_api_enhancements.py - Health check and template tests

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-10 22:13:43 +08:00

167 lines
6.5 KiB
JSON

{
"title": "Settings",
"projectSettings": "Project Settings",
"backToTasks": "Back to Tasks",
"mySettings": {
"title": "My Settings",
"profile": "Profile",
"email": "Email",
"department": "Department",
"role": "Role",
"workloadSettings": "Workload Settings",
"capacityDescription": "Set your weekly available work hours, used to calculate workload percentage.",
"weeklyCapacity": "Weekly Capacity",
"hoursPerWeek": "hours/week",
"capacityHelp": "Recommended: 40 hours (standard work week). Maximum: 168 hours (total hours in a week).",
"capacitySaved": "Capacity settings saved",
"capacityError": "Failed to save capacity settings",
"capacityInvalid": "Please enter a valid number of hours (0-168)"
},
"tabs": {
"general": "General",
"members": "Members",
"customFields": "Custom Fields",
"notifications": "Notifications",
"integrations": "Integrations",
"danger": "Danger Zone"
},
"general": {
"title": "General Settings",
"projectName": "Project Name",
"description": "Description",
"noDescription": "No description",
"securityLevel": "Security Level",
"status": "Status",
"visibility": "Visibility",
"public": "Public",
"private": "Private",
"helpText": "To edit project details, contact the project owner."
},
"members": {
"title": "Member Management",
"description": "Manage users who can access this project. Project members can view and edit project content.",
"addMember": "Add Member",
"invite": "Invite Member",
"inviteByEmail": "Invite by email",
"emailPlaceholder": "Enter email address",
"selectUser": "Select User",
"searchUserPlaceholder": "Search users...",
"user": "User",
"role": "Role",
"joinedAt": "Joined",
"changeRole": "Change Role",
"remove": "Remove",
"confirmRemove": "Are you sure you want to remove this member?",
"removeConfirmTitle": "Remove Member",
"removeConfirmMessage": "Are you sure you want to remove {{name}} from this project? They will no longer have access.",
"empty": "No members in this project yet.",
"emptyHint": "Click \"Add Member\" to add project members.",
"loadError": "Failed to load member list",
"addError": "Failed to add member",
"removeError": "Failed to remove member",
"roleChangeError": "Failed to change role",
"memberAdded": "Member added successfully",
"adding": "Adding...",
"selectUserRequired": "Please select a user to add",
"alreadyMember": "This user is already a project member",
"roles": {
"member": "Member",
"admin": "Admin"
},
"roleHelp": {
"member": "Members can view and edit tasks in this project.",
"admin": "Admins can manage project settings and members."
}
},
"customFields": {
"title": "Custom Fields",
"add": "Add Field",
"edit": "Edit Field",
"delete": "Delete Field",
"create": "Create Field",
"fieldName": "Field Name",
"fieldNamePlaceholder": "e.g., Story Points, Sprint Number",
"fieldType": "Field Type",
"required": "Required",
"requiredField": "Required field",
"requiredHelp": "Tasks cannot be created or updated without filling in required fields.",
"cannotChangeType": "cannot be changed",
"description": "Custom fields allow you to add additional data to tasks. You can create up to 20 fields per project.",
"loading": "Loading custom fields...",
"loadError": "Failed to load custom fields",
"retry": "Retry",
"empty": "No custom fields defined yet.",
"emptyHint": "Click \"Add Field\" to create your first custom field.",
"deleteConfirmTitle": "Delete Custom Field?",
"deleteConfirmMessage": "This will permanently delete this field and all stored values for all tasks. This action cannot be undone.",
"deleting": "Deleting...",
"deleted": "Custom field deleted successfully",
"deleteError": "Failed to delete field",
"saving": "Saving...",
"saveChanges": "Save Changes",
"saveError": "Failed to save field",
"options": "Options",
"optionPlaceholder": "Option {{index}}",
"addOption": "Add Option",
"optionRequired": "At least one option is required for dropdown fields",
"formula": "Formula Expression",
"formulaPlaceholder": "e.g., {time_spent} / {original_estimate} * 100",
"formulaRequired": "Formula expression is required",
"formulaHelp": {
"intro": "Use curly braces to reference other fields:",
"customField": "Reference a custom number field",
"estimate": "Task time estimate",
"timeSpent": "Logged time",
"operators": "Supported operators: +, -, *, /"
},
"types": {
"text": "Text",
"textDesc": "Single line text input",
"number": "Number",
"numberDesc": "Numeric value",
"date": "Date",
"dateDesc": "Date picker",
"dropdown": "Dropdown",
"dropdownDesc": "Select from predefined options",
"person": "Person",
"personDesc": "User assignment",
"formula": "Formula",
"formulaDesc": "Calculated from other fields"
},
"validation": {
"nameRequired": "Field name is required"
},
"circularError": {
"title": "Circular Reference Detected",
"description": "This formula creates a circular reference, which is not allowed.",
"cyclePath": "Reference Cycle",
"helpText": "To resolve this issue, modify the formula to avoid referencing fields that directly or indirectly reference this field."
}
},
"notifications": {
"title": "Notification Settings",
"email": "Email Notifications",
"inApp": "In-app Notifications",
"taskAssigned": "When a task is assigned to me",
"taskCompleted": "When a task is completed",
"commentAdded": "When a comment is added",
"dueDateApproaching": "When a due date is approaching"
},
"danger": {
"title": "Danger Zone",
"archive": "Archive Project",
"archiveDescription": "Archive this project. The project will become read-only.",
"delete": "Delete Project",
"deleteDescription": "Permanently delete this project and all its data. This action cannot be undone.",
"confirmArchive": "Are you sure you want to archive this project?",
"confirmDelete": "Are you sure you want to delete this project? Type the project name to confirm:",
"typeToConfirm": "Type \"{{name}}\" to confirm"
},
"messages": {
"saved": "Settings saved",
"memberInvited": "Invitation sent",
"memberRemoved": "Member removed",
"roleChanged": "Role changed"
}
}