## 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>
167 lines
6.5 KiB
JSON
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"
|
|
}
|
|
}
|