From ae5b1a4b02f059dfc3269cd6a085a9a27e47a5cd Mon Sep 17 00:00:00 2001 From: Reece Browne <74901996+reecebrowne@users.noreply.github.com> Date: Tue, 25 Nov 2025 15:15:44 +0000 Subject: [PATCH] consolidate english language to use gb (#5002) # Description of Changes --- ## Checklist ### General - [ ] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [ ] I have read the [Stirling-PDF Developer Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/DeveloperGuide.md) (if applicable) - [ ] I have read the [How to add new languages to Stirling-PDF](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/HowToAddNewLanguage.md) (if applicable) - [ ] I have performed a self-review of my own code - [ ] My changes generate no new warnings ### Documentation - [ ] I have updated relevant docs on [Stirling-PDF's doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) (if functionality has heavily changed) - [ ] I have read the section [Add New Translation Tags](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/HowToAddNewLanguage.md#add-new-translation-tags) (for new translation tags only) ### Translations (if applicable) - [ ] I ran [`scripts/counter_translation.py`](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/docs/counter_translation.md) ### UI Changes (if applicable) - [ ] Screenshots or videos demonstrating the UI changes are attached (e.g., as comments or direct attachments in the PR) ### Testing (if applicable) - [ ] I have tested my changes locally. Refer to the [Testing Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/DeveloperGuide.md#6-testing) for more details. --- .../public/locales/en-US/translation.json | 5360 ----------------- frontend/src/core/i18n.ts | 13 +- frontend/src/core/utils/languageMapping.ts | 2 +- 3 files changed, 8 insertions(+), 5367 deletions(-) delete mode 100644 frontend/public/locales/en-US/translation.json diff --git a/frontend/public/locales/en-US/translation.json b/frontend/public/locales/en-US/translation.json deleted file mode 100644 index 6a1d7255c..000000000 --- a/frontend/public/locales/en-US/translation.json +++ /dev/null @@ -1,5360 +0,0 @@ -{ - "toolPanel": { - "modePrompt": { - "title": "Choose how you browse tools", - "description": "Preview both layouts and decide how you want to explore Stirling PDF tools.", - "sidebarTitle": "Sidebar mode", - "sidebarDescription": "Keep tools alongside your workspace for quick switching.", - "recommended": "Recommended", - "chooseSidebar": "Use sidebar mode", - "fullscreenTitle": "Fullscreen mode - (legacy)", - "fullscreenDescription": "Browse every tool in a catalog that covers the workspace until you pick one.", - "chooseFullscreen": "Use fullscreen mode", - "dismiss": "Maybe later" - }, - "fullscreen": { - "showDetails": "Show Details", - "comingSoon": "Coming soon:", - "favorite": "Add to favorites", - "favorites": "Favorites", - "heading": "All tools (fullscreen view)", - "noResults": "Try adjusting your search or toggle descriptions to find what you need.", - "recommended": "Recommended", - "unfavorite": "Remove from favorites" - }, - "placeholder": "Choose a tool to get started", - "toggle": { - "fullscreen": "Switch to fullscreen mode", - "sidebar": "Switch to sidebar mode" - } - }, - "unsavedChanges": "You have unsaved changes to your PDF.", - "areYouSure": "Are you sure you want to leave?", - "unsavedChangesTitle": "Unsaved Changes", - "keepWorking": "Keep Working", - "discardChanges": "Discard & Leave", - "applyAndContinue": "Save & Leave", - "exportAndContinue": "Export & Continue", - "zipWarning": { - "title": "Large ZIP File", - "message": "This ZIP contains {{count}} files. Extract anyway?", - "cancel": "Cancel", - "confirm": "Extract" - }, - "language": { - "direction": "ltr" - }, - "cancel": "Cancel", - "addPageNumbers": { - "fontSize": "Font Size", - "fontName": "Font Name", - "title": "Add Page Numbers", - "header": "Add Page Numbers", - "selectText": { - "1": "Select PDF file:", - "2": "Margin Size", - "3": "Position Selection", - "4": "Starting Number", - "5": "Pages to Number", - "6": "Custom Text Format" - }, - "customTextDesc": "Custom Text", - "numberPagesDesc": "e.g., 1,3,5-8 or leave blank for all pages", - "customNumberDesc": "e.g., \"Page {n}\" or leave blank for just numbers", - "submit": "Add Page Numbers", - "configuration": "Configuration", - "customize": "Customize Appearance", - "pagesAndStarting": "Pages & Starting Number", - "positionAndPages": "Position & Pages", - "error": { - "failed": "Add page numbers operation failed" - }, - "results": { - "title": "Page Number Results" - }, - "preview": "Position Selection", - "previewDisclaimer": "Preview is approximate. Final output may vary due to PDF font metrics." - }, - "pageSelectionPrompt": "Custom Page Selection (Enter a comma-separated list of page numbers 1,5,6 or Functions like 2n+1)", - "startingNumberTooltip": "The first number to display. Subsequent pages will increment from this number.", - "marginTooltip": "Distance between the page number and the edge of the page.", - "fontSizeTooltip": "Size of the page number text in points. Larger numbers create bigger text.", - "fontTypeTooltip": "Font family for the page numbers. Choose based on your document style.", - "customTextTooltip": "Optional custom format for page numbers. Use {n} as placeholder for the number. Example: \"Page {n}\" will show \"Page 1\", \"Page 2\", etc.", - "pdfPrompt": "Select PDF(s)", - "multiPdfPrompt": "Select PDFs (2+)", - "multiPdfDropPrompt": "Select (or drag & drop) all PDFs you require", - "imgPrompt": "Select Image(s)", - "genericSubmit": "Submit", - "uploadLimit": "Maximum file size:", - "uploadLimitExceededSingular": "is too large. Maximum allowed size is", - "uploadLimitExceededPlural": "are too large. Maximum allowed size is", - "processTimeWarning": "Warning: This process can take up to a minute depending on file-size", - "pageOrderPrompt": "Custom Page Order (Enter a comma-separated list of page numbers or Functions like 2n+1) :", - "goToPage": "Go", - "true": "True", - "false": "False", - "unknown": "Unknown", - "app": { - "description": "The Free Adobe Acrobat alternative (10M+ Downloads)" - }, - "save": "Save", - "saveToBrowser": "Save to Browser", - "download": "Download", - "pin": "Pin File (keep active after tool run)", - "unpin": "Unpin File (replace after tool run)", - "undoOperationTooltip": "Click to undo the last operation and restore the original files", - "undo": "Undo", - "back": "Back", - "nothingToUndo": "Nothing to undo", - "moreOptions": "More Options", - "editYourNewFiles": "Edit your new file(s)", - "close": "Close", - "openInViewer": "Open in Viewer", - "confirmClose": "Confirm Close", - "confirmCloseMessage": "Are you sure you want to close this file?", - "confirmCloseCancel": "Cancel", - "confirmCloseConfirm": "Close File", - "fileSelected": "Selected: {{filename}}", - "chooseFile": "Choose File", - "filesSelected": "{{count}} files selected", - "files": { - "title": "Files", - "upload": "Upload", - "uploadFiles": "Upload Files", - "addFiles": "Add files", - "selectFromWorkbench": "Select files from the workbench or ", - "selectMultipleFromWorkbench": "Select at least {{count}} files from the workbench or ", - "created": "Created", - "size": "File Size" - }, - "noFavourites": "No favorites added", - "downloadComplete": "Download Complete", - "bored": "Bored Waiting?", - "alphabet": "Alphabet", - "downloadPdf": "Download PDF", - "text": "Text", - "font": "Font", - "selectFillter": "-- Select --", - "pageNum": "Page Number", - "sizes": { - "small": "Small", - "medium": "Medium", - "large": "Large", - "x-large": "X-Large" - }, - "error": { - "pdfPassword": "The PDF Document is passworded and either the password was not provided or was incorrect", - "encryptedPdfMustRemovePassword": "This PDF is encrypted or password-protected. Please unlock it before converting to PDF/A.", - "incorrectPasswordProvided": "The PDF password is incorrect or not provided.", - "_value": "Error", - "dismissAllErrors": "Dismiss All Errors", - "sorry": "Sorry for the issue!", - "needHelp": "Need help / Found an issue?", - "contactTip": "If you're still having trouble, don't hesitate to reach out to us for help. You can submit a ticket on our GitHub page or contact us through Discord:", - "404": { - "head": "404 - Page Not Found | Oops, we tripped in the code!", - "1": "We can't seem to find the page you're looking for.", - "2": "Something went wrong" - }, - "github": "Submit a ticket on GitHub", - "showStack": "Show Stack Trace", - "copyStack": "Copy Stack Trace", - "githubSubmit": "GitHub - Submit a ticket", - "discordSubmit": "Discord - Submit Support post" - }, - "warning": { - "tooltipTitle": "Warning" - }, - "edit": "Edit", - "delete": "Delete", - "username": "Username", - "password": "Password", - "welcome": "Welcome", - "property": "Property", - "black": "Black", - "white": "White", - "red": "Red", - "green": "Green", - "blue": "Blue", - "custom": "Custom...", - "comingSoon": "Coming soon", - "WorkInProgess": "Work in progress, May not work or be buggy, Please report any problems!", - "poweredBy": "Powered by", - "yes": "Yes", - "no": "No", - "changedCredsMessage": "Credentials changed!", - "notAuthenticatedMessage": "User not authenticated.", - "userNotFoundMessage": "User not found.", - "incorrectPasswordMessage": "Current password is incorrect.", - "usernameExistsMessage": "New Username already exists.", - "invalidUsernameMessage": "Invalid username, username can only contain letters, numbers and the following special characters @._+- or must be a valid email address.", - "invalidPasswordMessage": "The password must not be empty and must not have spaces at the beginning or end.", - "confirmPasswordErrorMessage": "New Password and Confirm New Password must match.", - "deleteCurrentUserMessage": "Cannot delete currently logged in user.", - "deleteUsernameExistsMessage": "The username does not exist and cannot be deleted.", - "downgradeCurrentUserMessage": "Cannot downgrade current user's role", - "disabledCurrentUserMessage": "The current user cannot be disabled", - "downgradeCurrentUserLongMessage": "Cannot downgrade current user's role. Hence, current user will not be shown.", - "userAlreadyExistsOAuthMessage": "The user already exists as an OAuth2 user.", - "userAlreadyExistsWebMessage": "The user already exists as an web user.", - "oops": "Oops!", - "help": "Help", - "goHomepage": "Go to Homepage", - "joinDiscord": "Join our Discord server", - "seeDockerHub": "See Docker Hub", - "visitGithub": "Visit Github Repository", - "donate": "Donate", - "color": "Color", - "sponsor": "Sponsor", - "info": "Info", - "pro": "Pro", - "page": "Page", - "pages": "Pages", - "loading": "Loading...", - "review": "Review", - "addToDoc": "Add to Document", - "reset": "Reset", - "apply": "Apply", - "noFileSelected": "No file selected. Please upload one.", - "legal": { - "privacy": "Privacy Policy", - "iAgreeToThe": "I agree to all of the", - "terms": "Terms and Conditions", - "accessibility": "Accessibility", - "cookie": "Cookie Policy", - "impressum": "Impressum", - "showCookieBanner": "Cookie Preferences" - }, - "pipeline": { - "header": "Pipeline Menu (Beta)", - "uploadButton": "Upload Custom", - "configureButton": "Configure", - "defaultOption": "Custom", - "submitButton": "Submit", - "help": "Pipeline Help", - "scanHelp": "Folder Scanning Help", - "deletePrompt": "Are you sure you want to delete pipeline", - "tags": "automate,sequence,scripted,batch-process", - "title": "Pipeline" - }, - "pipelineOptions": { - "header": "Pipeline Configuration", - "pipelineNameLabel": "Pipeline Name", - "saveSettings": "Save Operation Settings", - "pipelineNamePrompt": "Enter pipeline name here", - "selectOperation": "Select Operation", - "addOperationButton": "Add operation", - "pipelineHeader": "Pipeline:", - "saveButton": "Download", - "validateButton": "Validate" - }, - "enterpriseEdition": { - "button": "Upgrade to Pro", - "warning": "This feature is only available to Pro users.", - "yamlAdvert": "Stirling PDF Pro supports YAML configuration files and other SSO features.", - "ssoAdvert": "Looking for more user management features? Check out Stirling PDF Pro" - }, - "analytics": { - "title": "Do you want make Stirling PDF better?", - "paragraph1": "Stirling PDF has opt in analytics to help us improve the product. We do not track any personal information or file contents.", - "paragraph2": "Please consider enabling analytics to help Stirling-PDF grow and to allow us to understand our users better.", - "learnMore": "Learn more", - "enable": "Enable analytics", - "disable": "Disable analytics", - "settings": "You can change the settings for analytics in the config/settings.yml file" - }, - "navbar": { - "favorite": "Favorites", - "recent": "New and recently updated", - "darkmode": "Dark Mode", - "language": "Languages", - "settings": "Settings", - "allTools": "Tools", - "multiTool": "Multi Tool", - "search": "Search", - "sections": { - "organize": "Organize", - "convertTo": "Convert to PDF", - "convertFrom": "Convert from PDF", - "security": "Sign & Security", - "advance": "Advanced", - "edit": "View & Edit", - "popular": "Popular" - } - }, - "settings": { - "title": "Settings", - "update": "Update available", - "updateAvailable": "{0} is the current installed version. A new version ({1}) is available.", - "appVersion": "App Version:", - "downloadOption": { - "title": "Choose download option (For single file non zip downloads):", - "1": "Open in same window", - "2": "Open in new window", - "3": "Download file" - }, - "zipThreshold": "Zip files when the number of downloaded files exceeds", - "signOut": "Sign Out", - "accountSettings": "Account Settings", - "bored": { - "help": "Enables easter egg game" - }, - "cacheInputs": { - "name": "Save form inputs", - "help": "Enable to store previously used inputs for future runs" - }, - "general": { - "title": "General", - "description": "Configure general application preferences.", - "account": "Account", - "accountDescription": "Manage your account settings", - "user": "User", - "signedInAs": "Signed in as", - "logout": "Log out", - "enableFeatures": { - "title": "For System Administrators", - "intro": "Enable user authentication, team management, and workspace features for your organization.", - "action": "Configure", - "and": "and", - "benefit": "Enables user roles, team collaboration, admin controls, and enterprise features.", - "learnMore": "Learn more in documentation", - "dismiss": "Dismiss" - }, - "autoUnzip": "Auto-unzip API responses", - "autoUnzipDescription": "Automatically extract files from ZIP responses", - "autoUnzipTooltip": "Automatically extract ZIP files returned from API operations. Disable to keep ZIP files intact. This does not affect automation workflows.", - "autoUnzipFileLimit": "Auto-unzip file limit", - "autoUnzipFileLimitDescription": "Maximum number of files to extract from ZIP", - "autoUnzipFileLimitTooltip": "Only unzip if the ZIP contains this many files or fewer. Set higher to extract larger ZIPs.", - "defaultToolPickerMode": "Default tool picker mode", - "defaultToolPickerModeDescription": "Choose whether the tool picker opens in fullscreen or sidebar by default", - "mode": { - "fullscreen": "Fullscreen", - "sidebar": "Sidebar" - } - }, - "hotkeys": { - "title": "Keyboard Shortcuts", - "description": "Hover a tool to see its shortcut or customize it below. Click \"Change shortcut\" and press a new key combination. Press Esc to cancel.", - "errorModifier": { - "mac": "Include ⌘ (Command), ⌥ (Option), or another modifier in your shortcut.", - "windows": "Include Ctrl, Alt, or another modifier in your shortcut." - }, - "errorConflict": "Shortcut already used by {{tool}}.", - "none": "Not assigned", - "customBadge": "Custom", - "defaultLabel": "Default: {{shortcut}}", - "capturing": "Press keys… (Esc to cancel)", - "change": "Change shortcut", - "reset": "Reset", - "shortcut": "Shortcut", - "noShortcut": "No shortcut set", - "searchPlaceholder": "Search tools..." - } - }, - "changeCreds": { - "title": "Change Credentials", - "header": "Update Your Account Details", - "changePassword": "You are using default login credentials. Please enter a new password", - "newUsername": "New Username", - "oldPassword": "Current Password", - "newPassword": "New Password", - "confirmNewPassword": "Confirm New Password", - "submit": "Submit Changes" - }, - "account": { - "title": "Account Settings", - "accountSettings": "Account Settings", - "adminSettings": "Admin Settings - View and Add Users", - "userControlSettings": "User Control Settings", - "changeUsername": "Change Username", - "newUsername": "New Username", - "password": "Confirmation Password", - "oldPassword": "Old password", - "newPassword": "New Password", - "changePassword": "Change Password", - "confirmNewPassword": "Confirm New Password", - "signOut": "Sign Out", - "yourApiKey": "Your API Key", - "syncTitle": "Sync browser settings with Account", - "settingsCompare": "Settings Comparison:", - "property": "Property", - "webBrowserSettings": "Web Browser Setting", - "syncToBrowser": "Sync Account -> Browser", - "syncToAccount": "Sync Account <- Browser" - }, - "adminUserSettings": { - "title": "User Control Settings", - "header": "Admin User Control Settings", - "admin": "Admin", - "user": "User", - "addUser": "Add New User", - "deleteUser": "Delete User", - "confirmDeleteUser": "Should the user be deleted?", - "confirmChangeUserStatus": "Should the user be disabled/enabled?", - "usernameInfo": "Username can only contain letters, numbers and the following special characters @._+- or must be a valid email address.", - "roles": "Roles", - "role": "Role", - "actions": "Actions", - "apiUser": "Limited API User", - "extraApiUser": "Additional Limited API User", - "webOnlyUser": "Web Only User", - "demoUser": "Demo User (No custom settings)", - "internalApiUser": "Internal API User", - "forceChange": "Force user to change password on login", - "submit": "Save User", - "changeUserRole": "Change User's Role", - "authenticated": "Authenticated", - "editOwnProfil": "Edit own profile", - "enabledUser": "enabled user", - "disabledUser": "disabled user", - "activeUsers": "Active Users:", - "disabledUsers": "Disabled Users:", - "totalUsers": "Total Users:", - "lastRequest": "Last Request", - "usage": "View Usage" - }, - "endpointStatistics": { - "title": "Endpoint Statistics", - "header": "Endpoint Statistics", - "top10": "Top 10", - "top20": "Top 20", - "all": "All", - "refresh": "Refresh", - "dataTypeLabel": "Data Type:", - "dataTypeAll": "All", - "dataTypeApi": "API", - "dataTypeUi": "UI", - "totalEndpoints": "Total Endpoints", - "totalVisits": "Total Visits", - "showing": "Showing", - "selectedVisits": "Selected Visits", - "endpoint": "Endpoint", - "visits": "Visits", - "percentage": "Percentage", - "loading": "Loading...", - "failedToLoad": "Failed to load endpoint data. Please try refreshing.", - "home": "Home", - "login": "Login", - "top": "Top", - "numberOfVisits": "Number of Visits", - "visitsTooltip": "Visits: {0} ({1}% of total)", - "retry": "Retry" - }, - "database": { - "title": "Database Import/Export", - "header": "Database Import/Export", - "fileName": "File Name", - "creationDate": "Creation Date", - "fileSize": "File Size", - "deleteBackupFile": "Delete Backup File", - "importBackupFile": "Import Backup File", - "createBackupFile": "Create Backup File", - "downloadBackupFile": "Download Backup File", - "info_1": "When importing data, it is crucial to ensure the correct structure. If you are unsure of what you are doing, seek advice and support from a professional. An error in the structure can cause application malfunctions, up to and including the complete inability to run the application.", - "info_2": "The file name does not matter when uploading. It will be renamed afterward to follow the format backup_user_yyyyMMddHHmm.sql, ensuring a consistent naming convention.", - "submit": "Import Backup", - "importIntoDatabaseSuccessed": "Import into database successed", - "backupCreated": "Database backup successful", - "fileNotFound": "File not found", - "fileNullOrEmpty": "File must not be null or empty", - "failedImportFile": "Failed to import file", - "notSupported": "This function is not available for your database connection." - }, - "session": { - "expired": "Your session has expired. Please refresh the page and try again.", - "refreshPage": "Refresh Page" - }, - "home": { - "desc": "Your locally hosted one-stop-shop for all your PDF needs.", - "searchBar": "Search for features...", - "viewPdf": { - "title": "View/Edit PDF", - "desc": "View, annotate, draw, add text or images" - }, - "setFavorites": "Set Favorites", - "hideFavorites": "Hide Favorites", - "showFavorites": "Show Favorites", - "legacyHomepage": "Old homepage", - "newHomePage": "Try our new homepage!", - "alphabetical": "Alphabetical", - "globalPopularity": "Global Popularity", - "sortBy": "Sort by:", - "mobile": { - "brandAlt": "Stirling PDF logo", - "openFiles": "Open files", - "swipeHint": "Swipe left or right to switch views", - "tools": "Tools", - "toolsSlide": "Tool selection panel", - "viewSwitcher": "Switch workspace view", - "workbenchSlide": "Workspace panel", - "workspace": "Workspace" - }, - "multiTool": { - "tags": "multiple,tools", - "title": "PDF Multi Tool", - "desc": "Merge, Rotate, Rearrange, Split, and Remove pages" - }, - "merge": { - "tags": "combine,join,unite", - "title": "Merge", - "desc": "Easily merge multiple PDFs into one." - }, - "split": { - "tags": "divide,separate,break", - "title": "Split", - "desc": "Split PDFs into multiple documents" - }, - "rotate": { - "tags": "turn,flip,orient", - "title": "Rotate", - "desc": "Easily rotate your PDFs." - }, - "convert": { - "tags": "transform,change", - "title": "Convert", - "desc": "Convert files between different formats" - }, - "pdfOrganiser": { - "tags": "organize,rearrange,reorder", - "title": "Organize", - "desc": "Remove/Rearrange pages in any order" - }, - "addImage": { - "tags": "insert,embed,place", - "title": "Add image", - "desc": "Adds a image onto a set location on the PDF" - }, - "addAttachments": { - "tags": "embed,attach,include", - "title": "Add Attachments", - "desc": "Add or remove embedded files (attachments) to/from a PDF" - }, - "watermark": { - "tags": "stamp,mark,overlay", - "title": "Add Watermark", - "desc": "Add a custom watermark to your PDF document." - }, - "removePassword": { - "tags": "unlock", - "title": "Remove Password", - "desc": "Remove password protection from your PDF document." - }, - "compress": { - "tags": "shrink,reduce,optimize", - "title": "Compress", - "desc": "Compress PDFs to reduce their file size." - }, - "unlockPDFForms": { - "tags": "unlock,enable,edit", - "title": "Unlock PDF Forms", - "desc": "Remove read-only property of form fields in a PDF document." - }, - "changeMetadata": { - "tags": "edit,modify,update", - "title": "Change Metadata", - "desc": "Change/Remove/Add metadata from a PDF document" - }, - "ocr": { - "tags": "extract,scan", - "title": "OCR / Cleanup scans", - "desc": "Cleanup scans and detects text from images within a PDF and re-adds it as text." - }, - "extractImages": { - "tags": "pull,save,export", - "title": "Extract Images", - "desc": "Extracts all images from a PDF and saves them to zip" - }, - "scannerImageSplit": { - "tags": "detect,split,photos", - "title": "Detect & Split Scanned Photos", - "desc": "Detect and split scanned photos into separate pages" - }, - "sign": { - "tags": "signature,autograph", - "title": "Sign", - "desc": "Adds signature to PDF by drawing, text or image" - }, - "flatten": { - "tags": "simplify,remove,interactive", - "title": "Flatten", - "desc": "Remove all interactive elements and forms from a PDF" - }, - "certSign": { - "tags": "authenticate,PEM,P12,official,encrypt,sign,certificate,PKCS12,JKS,server,manual,auto", - "title": "Sign with Certificate", - "desc": "Signs a PDF with a Certificate/Key (PEM/P12)" - }, - "repair": { - "tags": "fix,restore", - "title": "Repair", - "desc": "Tries to repair a corrupt/broken PDF" - }, - "removeBlanks": { - "tags": "delete,clean,empty", - "title": "Remove Blank pages", - "desc": "Detects and removes blank pages from a document" - }, - "removeAnnotations": { - "tags": "delete,clean,strip", - "title": "Remove Annotations", - "desc": "Removes all comments/annotations from a PDF" - }, - "compare": { - "tags": "difference", - "title": "Compare", - "desc": "Compares and shows the differences between 2 PDF Documents" - }, - "removeCertSign": { - "tags": "remove,delete,unlock", - "title": "Remove Certificate Sign", - "desc": "Remove certificate signature from PDF" - }, - "pageLayout": { - "tags": "layout,arrange,combine", - "title": "Multi-Page Layout", - "desc": "Merge multiple pages of a PDF document into a single page" - }, - "bookletImposition": { - "tags": "booklet,print,binding", - "title": "Booklet Imposition", - "desc": "Create booklets with proper page ordering and multi-page layout for printing and binding" - }, - "scalePages": { - "tags": "resize,adjust,scale", - "title": "Adjust page size/scale", - "desc": "Change the size/scale of a page and/or its contents." - }, - "addPageNumbers": { - "tags": "number,pagination,count", - "title": "Add Page Numbers", - "desc": "Add Page numbers throughout a document in a set location" - }, - "autoRename": { - "tags": "auto-detect,header-based,organize,relabel", - "title": "Auto Rename PDF File", - "desc": "Auto renames a PDF file based on its detected header" - }, - "adjustContrast": { - "tags": "contrast,brightness,saturation", - "title": "Adjust Colors/Contrast", - "desc": "Adjust Colors/Contrast, Saturation and Brightness of a PDF" - }, - "crop": { - "tags": "trim,cut,resize", - "title": "Crop PDF", - "desc": "Crop a PDF to reduce its size (maintains text!)" - }, - "autoSplitPDF": { - "tags": "auto,split,QR", - "title": "Auto Split Pages", - "desc": "Auto Split Scanned PDF with physical scanned page splitter QR Code" - }, - "sanitize": { - "tags": "clean,purge,remove", - "title": "Sanitize", - "desc": "Remove potentially harmful elements from PDF files" - }, - "getPdfInfo": { - "tags": "info,metadata,details", - "title": "Get ALL Info on PDF", - "desc": "Grabs any and all information possible on PDFs" - }, - "pdfToSinglePage": { - "tags": "combine,merge,single", - "title": "PDF to Single Large Page", - "desc": "Merges all PDF pages into one large single page" - }, - "showJS": { - "tags": "javascript,code,script", - "title": "Show Javascript", - "desc": "Searches and displays any JS injected into a PDF" - }, - "redact": { - "tags": "censor,blackout,hide", - "title": "Redact", - "desc": "Redacts (blacks out) a PDF based on selected text, drawn shapes and/or selected page(s)" - }, - "splitBySections": { - "tags": "split,sections,divide", - "title": "Split PDF by Sections", - "desc": "Divide each page of a PDF into smaller horizontal and vertical sections" - }, - "addStamp": { - "tags": "stamp,mark,seal", - "title": "Add Stamp to PDF", - "desc": "Add text or add image stamps at set locations" - }, - "removeImage": { - "tags": "remove,delete,clean", - "title": "Remove image", - "desc": "Remove image from PDF to reduce file size" - }, - "splitByChapters": { - "tags": "split,chapters,structure", - "title": "Split PDF by Chapters", - "desc": "Split a PDF into multiple files based on its chapter structure." - }, - "validateSignature": { - "tags": "validate,verify,certificate", - "title": "Validate PDF Signature", - "desc": "Verify digital signatures and certificates in PDF documents" - }, - "swagger": { - "tags": "API,documentation,test", - "title": "API Documentation", - "desc": "View API documentation and test endpoints" - }, - "scannerEffect": { - "tags": "scan,simulate,create", - "title": "Scanner Effect", - "desc": "Create a PDF that looks like it was scanned" - }, - "editTableOfContents": { - "tags": "bookmarks,contents,edit", - "title": "Edit Table of Contents", - "desc": "Add or edit bookmarks and table of contents in PDF documents" - }, - "manageCertificates": { - "tags": "certificates,import,export", - "title": "Manage Certificates", - "desc": "Import, export, or delete digital certificate files used for signing PDFs." - }, - "read": { - "tags": "view,open,display", - "title": "Read", - "desc": "View and annotate PDFs. Highlight text, draw, or insert comments for review and collaboration." - }, - "reorganizePages": { - "tags": "rearrange,reorder,organize", - "title": "Reorganize Pages", - "desc": "Rearrange, duplicate, or delete PDF pages with visual drag-and-drop control." - }, - "extractPages": { - "tags": "pull,select,copy", - "title": "Extract Pages", - "desc": "Extract specific pages from a PDF document" - }, - "removePages": { - "tags": "delete,extract,exclude", - "title": "Remove Pages", - "desc": "Remove specific pages from a PDF document" - }, - "autoSizeSplitPDF": { - "tags": "auto,split,size", - "title": "Auto Split by Size/Count", - "desc": "Automatically split PDFs by file size or page count" - }, - "replaceColor": { - "title": "Replace & Invert Color", - "desc": "Replace or invert colors in PDF documents" - }, - "devApi": { - "tags": "API,development,documentation", - "title": "API", - "desc": "Link to API documentation" - }, - "devFolderScanning": { - "tags": "automation,folder,scanning", - "title": "Automated Folder Scanning", - "desc": "Link to automated folder scanning guide" - }, - "devSsoGuide": { - "title": "SSO Guide", - "desc": "Link to SSO guide" - }, - "devAirgapped": { - "title": "Air-gapped Setup", - "desc": "Link to air-gapped setup guide" - }, - "addPassword": { - "title": "Add Password", - "desc": "Add password protection and restrictions to PDF files" - }, - "changePermissions": { - "title": "Change Permissions", - "desc": "Change document restrictions and permissions" - }, - "automate": { - "tags": "workflow,sequence,automation", - "title": "Automate", - "desc": "Build multi-step workflows by chaining together PDF actions. Ideal for recurring tasks." - }, - "overlay-pdfs": { - "desc": "Overlay one PDF on top of another", - "title": "Overlay PDFs" - } - }, - "landing": { - "addFiles": "Add Files", - "uploadFromComputer": "Upload from computer" - }, - "viewPdf": { - "tags": "view,read,annotate,text,image,highlight,edit", - "title": "View/Edit PDF", - "header": "View PDF" - }, - "multiTool": { - "tags": "Multi Tool,Multi operation,UI,click drag,front end,client side,interactive,intractable,move,delete,migrate,divide", - "title": "PDF Multi Tool", - "header": "PDF Multi Tool", - "uploadPrompts": "File Name", - "selectAll": "Select All", - "deselectAll": "Deselect All", - "selectPages": "Page Select", - "selectedPages": "Selected Pages", - "page": "Page", - "deleteSelected": "Delete Selected", - "downloadAll": "Export", - "downloadSelected": "Export Selected", - "insertPageBreak": "Insert Page Break", - "addFile": "Add File", - "rotateLeft": "Rotate Left", - "rotateRight": "Rotate Right", - "split": "Split", - "moveLeft": "Move Left", - "moveRight": "Move Right", - "delete": "Delete", - "dragDropMessage": "Page(s) Selected", - "undo": "Undo (CTRL + Z)", - "redo": "Redo (CTRL + Y)" - }, - "merge": { - "tags": "merge,Page operations,Back end,server side", - "title": "Merge", - "removeDigitalSignature": { - "label": "Remove digital signature in the merged file?", - "tooltip": { - "title": "Remove Digital Signature", - "description": "Digital signatures will be invalidated when merging files. Check this to remove them from the final merged PDF." - } - }, - "generateTableOfContents": { - "label": "Generate table of contents in the merged file?", - "tooltip": { - "title": "Generate Table of Contents", - "description": "Automatically creates a clickable table of contents in the merged PDF based on the original file names and page numbers." - } - }, - "submit": "Merge", - "sortBy": { - "description": "Files will be merged in the order they're selected. Drag to reorder or sort below.", - "label": "Sort By", - "filename": "File Name", - "dateModified": "Date Modified", - "ascending": "Ascending", - "descending": "Descending", - "sort": "Sort" - }, - "error": { - "failed": "An error occurred while merging the PDFs." - } - }, - "split": { - "title": "Split PDF", - "header": "Split PDF", - "desc": { - "1": "The numbers you select are the page number you wish to do a split on", - "2": "As such selecting 1,3,7-9 would split a 10 page document into 6 separate PDFS with:", - "3": "Document #1: Page 1", - "4": "Document #2: Page 2 and 3", - "5": "Document #3: Page 4, 5, 6 and 7", - "6": "Document #4: Page 8", - "7": "Document #5: Page 9", - "8": "Document #6: Page 10" - }, - "splitPages": "Enter pages to split on:", - "submit": "Split", - "steps": { - "chooseMethod": "Choose Method", - "settings": "Settings" - }, - "settings": { - "selectMethodFirst": "Please select a split method first" - }, - "error": { - "failed": "An error occurred while splitting the PDF." - }, - "method": { - "label": "Choose split method", - "placeholder": "Select how to split the PDF" - }, - "methods": { - "prefix": { - "splitAt": "Split at", - "splitBy": "Split by" - }, - "byPages": { - "name": "Page Numbers", - "desc": "Extract specific pages (1,3,5-10)", - "tooltip": "Enter page numbers separated by commas or ranges with hyphens" - }, - "bySections": { - "name": "Sections", - "desc": "Divide pages into grid sections", - "tooltip": "Split each page into horizontal and vertical sections" - }, - "bySize": { - "name": "File Size", - "desc": "Limit maximum file size", - "tooltip": "Specify maximum file size (e.g. 10MB, 500KB)" - }, - "byPageCount": { - "name": "Page Count", - "desc": "Fixed pages per file", - "tooltip": "Enter the number of pages for each split file" - }, - "byDocCount": { - "name": "Document Count", - "desc": "Create specific number of files", - "tooltip": "Enter how many files you want to create" - }, - "byChapters": { - "name": "Chapters", - "desc": "Split at bookmark boundaries", - "tooltip": "Uses PDF bookmarks to determine split points" - }, - "byPageDivider": { - "name": "Page Divider", - "desc": "Auto-split with divider sheets", - "tooltip": "Use QR code divider sheets between documents when scanning" - } - }, - "value": { - "fileSize": { - "label": "File Size", - "placeholder": "e.g. 10MB, 500KB" - }, - "pageCount": { - "label": "Pages per File", - "placeholder": "e.g. 5, 10" - }, - "docCount": { - "label": "Number of Files", - "placeholder": "e.g. 3, 5" - } - }, - "tooltip": { - "header": { - "title": "Split Methods Overview" - }, - "byPages": { - "title": "Split at Page Numbers", - "text": "Split your PDF at specific page numbers. Using 'n' splits after page n. Using 'n-m' splits before page n and after page m.", - "bullet1": "Single split points: 3,7 (splits after pages 3 and 7)", - "bullet2": "Range split points: 3-8 (splits before page 3 and after page 8)", - "bullet3": "Mixed: 2,5-10,15 (splits after page 2, before page 5, after page 10, and after page 15)" - }, - "bySections": { - "title": "Split by Grid Sections", - "text": "Divide each page into a grid of sections. Useful for splitting documents with multiple columns or extracting specific areas.", - "bullet1": "Horizontal: Number of rows to create", - "bullet2": "Vertical: Number of columns to create", - "bullet3": "Merge: Combine all sections into one PDF" - }, - "bySize": { - "title": "Split by File Size", - "text": "Create multiple PDFs that don't exceed a specified file size. Ideal for file size limitations or email attachments.", - "bullet1": "Use MB for larger files (e.g., 10MB)", - "bullet2": "Use KB for smaller files (e.g., 500KB)", - "bullet3": "System will split at page boundaries" - }, - "byCount": { - "title": "Split by Count", - "text": "Create multiple PDFs with a specific number of pages or documents each.", - "bullet1": "Page Count: Fixed number of pages per file", - "bullet2": "Document Count: Fixed number of output files", - "bullet3": "Useful for batch processing workflows" - }, - "byChapters": { - "title": "Split by Chapters", - "text": "Use PDF bookmarks to automatically split at chapter boundaries. Requires PDFs with bookmark structure.", - "bullet1": "Bookmark Level: Which level to split on (1=top level)", - "bullet2": "Include Metadata: Preserve document properties", - "bullet3": "Allow Duplicates: Handle repeated bookmark names" - }, - "byDocCount": { - "bullet1": "Enter the number of output files you want", - "bullet2": "Pages are distributed as evenly as possible", - "bullet3": "Useful when you need a specific number of files", - "text": "Create a specific number of output files by evenly distributing pages across them.", - "title": "Split by Document Count" - }, - "byPageCount": { - "bullet1": "Enter the number of pages per output file", - "bullet2": "Last file may have fewer pages if not evenly divisible", - "bullet3": "Useful for batch processing workflows", - "text": "Create multiple PDFs with a specific number of pages each. Perfect for creating uniform document chunks.", - "title": "Split by Page Count" - }, - "byPageDivider": { - "bullet1": "Print divider sheets from the download link", - "bullet2": "Insert divider sheets between your documents", - "bullet3": "Scan all documents together as one PDF", - "bullet4": "Upload - divider pages are automatically detected and removed", - "bullet5": "Enable Duplex Mode if scanning both sides of divider sheets", - "text": "Automatically split scanned documents using physical divider sheets with QR codes. Perfect for processing multiple documents scanned together.", - "title": "Split by Page Divider" - } - }, - "methodSelection": { - "tooltip": { - "bullet1": "Click on a method card to select it", - "bullet2": "Hover over each card to see a quick description", - "bullet3": "The settings step will appear after you select a method", - "bullet4": "You can change methods at any time before processing", - "header": { - "text": "Choose how you want to split your PDF document. Each method is optimized for different use cases and document types.", - "title": "Split Method Selection" - }, - "title": "Choose Your Split Method" - } - }, - "selectMethod": "Select a split method", - "resultsTitle": "Split Results" - }, - "rotate": { - "title": "Rotate PDF", - "submit": "Apply Rotation", - "selectRotation": "Select Rotation Angle (Clockwise)", - "error": { - "failed": "An error occurred while rotating the PDF." - }, - "preview": { - "title": "Rotation Preview" - }, - "rotateLeft": "Rotate Anticlockwise", - "rotateRight": "Rotate Clockwise", - "tooltip": { - "header": { - "title": "Rotate Settings Overview" - }, - "description": { - "text": "Rotate your PDF pages clockwise or anticlockwise in 90-degree increments. All pages in the PDF will be rotated. The preview shows how your document will look after rotation." - }, - "controls": { - "title": "Controls", - "text": "Use the rotation buttons to adjust orientation. Left button rotates anticlockwise, right button rotates clockwise. Each click rotates by 90 degrees." - } - } - }, - "convert": { - "title": "Convert", - "desc": "Convert files between different formats", - "files": "Files", - "selectFilesPlaceholder": "Select files in the main view to get started", - "settings": "Settings", - "conversionCompleted": "Conversion completed", - "results": "Results", - "defaultFilename": "converted_file", - "conversionResults": "Conversion Results", - "convertFrom": "Convert from", - "convertTo": "Convert to", - "sourceFormatPlaceholder": "Source format", - "targetFormatPlaceholder": "Target format", - "selectSourceFormatFirst": "Select a source format first", - "outputOptions": "Output Options", - "pdfOptions": "PDF Options", - "imageOptions": "Image Options", - "colorType": "Color Type", - "color": "Color", - "greyscale": "Grayscale", - "blackwhite": "Black & White", - "dpi": "DPI", - "output": "Output", - "single": "Single", - "multiple": "Multiple", - "fitOption": "Fit Option", - "maintainAspectRatio": "Maintain Aspect Ratio", - "fitDocumentToPage": "Fit Document to Page", - "fillPage": "Fill Page", - "autoRotate": "Auto Rotate", - "autoRotateDescription": "Automatically rotate images to better fit the PDF page", - "combineImages": "Combine Images", - "combineImagesDescription": "Combine all images into one PDF, or create separate PDFs for each image", - "webOptions": "Web to PDF Options", - "zoomLevel": "Zoom Level", - "emailOptions": "Email to PDF Options", - "includeAttachments": "Include email attachments", - "maxAttachmentSize": "Maximum attachment size (MB)", - "includeAllRecipients": "Include CC and BCC recipients in header", - "downloadHtml": "Download HTML intermediate file instead of PDF", - "pdfaOptions": "PDF/A Options", - "outputFormat": "Output Format", - "pdfaNote": "PDF/A-1b is more compatible, PDF/A-2b supports more features.", - "pdfaDigitalSignatureWarning": "The PDF contains a digital signature. This will be removed in the next step.", - "fileFormat": "File Format", - "wordDoc": "Word Document", - "wordDocExt": "Word Document (.docx)", - "odtExt": "OpenDocument Text (.odt)", - "pptExt": "PowerPoint (.pptx)", - "odpExt": "OpenDocument Presentation (.odp)", - "txtExt": "Plain Text (.txt)", - "rtfExt": "Rich Text Format (.rtf)", - "selectedFiles": "Selected files", - "noFileSelected": "No file selected. Use the file panel to add files.", - "convertFiles": "Convert Files", - "converting": "Converting...", - "downloadConverted": "Download Converted File", - "errorNoFiles": "Please select at least one file to convert.", - "errorNoFormat": "Please select both source and target formats.", - "errorNotSupported": "Conversion from {{from}} to {{to}} is not supported.", - "images": "Images", - "officeDocs": "Office Documents (Word, Excel, PowerPoint)", - "imagesExt": "Images (JPG, PNG, etc.)", - "markdown": "Markdown", - "textRtf": "Text/RTF", - "grayscale": "Grayscale", - "errorConversion": "An error occurred while converting the file.", - "cbzOptions": "CBZ to PDF Options", - "optimizeForEbook": "Optimize PDF for ebook readers (uses Ghostscript)", - "cbzOutputOptions": "PDF to CBZ Options", - "cbzDpi": "DPI for image rendering" - }, - "imageToPdf": { - "tags": "conversion,img,jpg,picture,photo" - }, - "pdfToImage": { - "tags": "conversion,img,jpg,picture,photo", - "title": "PDF to Image", - "header": "PDF to Image", - "selectText": "Image Format", - "singleOrMultiple": "Page to Image result type", - "single": "Single Big Image Combing all pages", - "multi": "Multiple Images, one image per page", - "colorType": "Color type", - "color": "Color", - "grey": "Grayscale", - "blackwhite": "Black and White (May lose data!)", - "submit": "Convert", - "info": "Python is not installed. Required for WebP conversion.", - "placeholder": "(e.g. 1,2,8 or 4,7,12-16 or 2n-1)" - }, - "pdfOrganiser": { - "tags": "duplex,even,odd,sort,move", - "title": "Page Organizer", - "header": "PDF Page Organizer", - "submit": "Rearrange Pages", - "mode": { - "_value": "Organization mode", - "1": "Custom Page Order", - "2": "Reverse Order", - "3": "Duplex Sort", - "4": "Booklet Sort", - "5": "Side Stitch Booklet Sort", - "6": "Odd-Even Split", - "7": "Remove First", - "8": "Remove Last", - "9": "Remove First and Last", - "10": "Odd-Even Merge", - "11": "Duplicate all pages", - "desc": { - "BOOKLET_SORT": "Arrange pages for booklet printing (last, first, second, second last, …).", - "CUSTOM": "Use a custom sequence of page numbers or expressions to define a new order.", - "DUPLEX_SORT": "Interleave fronts then backs as if a duplex scanner scanned all fronts, then all backs (1, n, 2, n-1, …).", - "DUPLICATE": "Duplicate each page according to the custom order count (e.g., 4 duplicates each page 4×).", - "ODD_EVEN_MERGE": "Merge two PDFs by alternating pages: odd from the first, even from the second.", - "ODD_EVEN_SPLIT": "Split the document into two outputs: all odd pages and all even pages.", - "REMOVE_FIRST": "Remove the first page from the document.", - "REMOVE_FIRST_AND_LAST": "Remove both the first and last pages from the document.", - "REMOVE_LAST": "Remove the last page from the document.", - "REVERSE_ORDER": "Flip the document so the last page becomes first and so on.", - "SIDE_STITCH_BOOKLET_SORT": "Arrange pages for side‑stitch booklet printing (optimized for binding on the side)." - } - }, - "desc": { - "CUSTOM": "Use a custom sequence of page numbers or expressions to define a new order.", - "REVERSE_ORDER": "Flip the document so the last page becomes first and so on.", - "DUPLEX_SORT": "Interleave fronts then backs as if a duplex scanner scanned all fronts, then all backs (1, n, 2, n-1, …).", - "BOOKLET_SORT": "Arrange pages for booklet printing (last, first, second, second last, …).", - "SIDE_STITCH_BOOKLET_SORT": "Arrange pages for side‑stitch booklet printing (optimized for binding on the side).", - "ODD_EVEN_SPLIT": "Split the document into two outputs: all odd pages and all even pages.", - "ODD_EVEN_MERGE": "Merge two PDFs by alternating pages: odd from the first, even from the second.", - "DUPLICATE": "Duplicate each page according to the custom order count (e.g., 4 duplicates each page 4×).", - "REMOVE_FIRST": "Remove the first page from the document.", - "REMOVE_LAST": "Remove the last page from the document.", - "REMOVE_FIRST_AND_LAST": "Remove both the first and last pages from the document." - }, - "placeholder": "(e.g. 1,3,2 or 4-8,2,10-12 or 2n-1)" - }, - "addImage": { - "tags": "img,jpg,picture,photo", - "title": "Add Image", - "header": "Add image to PDF", - "everyPage": "Every Page?", - "upload": "Add image", - "submit": "Add image" - }, - "attachments": { - "tags": "attachments,add,remove,embed,file", - "title": "Add Attachments", - "header": "Add Attachments", - "add": "Add Attachment", - "remove": "Remove Attachment", - "embed": "Embed Attachment", - "submit": "Add Attachments" - }, - "watermark": { - "title": "Add Watermark", - "desc": "Add text or image watermarks to PDF files", - "completed": "Watermark added", - "submit": "Add Watermark", - "filenamePrefix": "watermarked", - "error": { - "failed": "An error occurred while adding watermark to the PDF." - }, - "watermarkType": { - "text": "Text", - "image": "Image" - }, - "settings": { - "type": "Watermark Type", - "text": { - "label": "Watermark Text", - "placeholder": "Enter watermark text" - }, - "image": { - "label": "Watermark Image", - "choose": "Choose Image", - "selected": "Selected: {{filename}}" - }, - "fontSize": "Font Size", - "size": "Size", - "alphabet": "Font/Language", - "color": "Watermark Color", - "rotation": "Rotation (degrees)", - "opacity": "Opacity (%)", - "spacing": { - "horizontal": "Horizontal Spacing", - "vertical": "Vertical Spacing", - "height": "Height Spacing", - "width": "Width Spacing" - }, - "convertToImage": "Flatten PDF pages to images" - }, - "alphabet": { - "roman": "Roman/Latin", - "arabic": "Arabic", - "japanese": "Japanese", - "korean": "Korean", - "chinese": "Chinese", - "thai": "Thai" - }, - "steps": { - "type": "Watermark Type", - "wording": "Wording", - "textStyle": "Style", - "formatting": "Formatting", - "file": "Watermark File" - }, - "results": { - "title": "Watermark Results" - }, - "tooltip": { - "language": { - "title": "Language Support", - "text": "Choose the appropriate language setting to ensure proper font rendering for your text." - }, - "appearance": { - "title": "Appearance Settings", - "text": "Control how your watermark looks and blends with the document.", - "bullet1": "Rotation: -360° to 360° for angled watermarks", - "bullet2": "Opacity: 0-100% for transparency control", - "bullet3": "Lower opacity creates subtle watermarks" - }, - "spacing": { - "title": "Spacing Control", - "text": "Adjust the spacing between repeated watermarks across the page.", - "bullet1": "Width spacing: Horizontal distance between watermarks", - "bullet2": "Height spacing: Vertical distance between watermarks", - "bullet3": "Higher values create more spread out patterns" - }, - "type": { - "header": { - "title": "Watermark Type Selection" - }, - "description": { - "title": "Choose Your Watermark", - "text": "Select between text or image watermarks based on your needs." - }, - "text": { - "title": "Text Watermarks", - "text": "Perfect for adding copyright notices, company names, or confidentiality labels. Supports multiple languages and custom colors.", - "bullet1": "Customizable fonts and languages", - "bullet2": "Adjustable colors and transparency", - "bullet3": "Ideal for legal or branding text" - }, - "image": { - "title": "Image Watermarks", - "text": "Use logos, stamps, or any image as a watermark. Great for branding and visual identification.", - "bullet1": "Upload any image format", - "bullet2": "Maintains image quality", - "bullet3": "Perfect for logos and stamps" - } - }, - "wording": { - "header": { - "title": "Text Content" - }, - "text": { - "title": "Watermark Text", - "text": "Enter the text that will appear as your watermark across the document.", - "bullet1": "Keep it concise for better readability", - "bullet2": "Common examples: 'CONFIDENTIAL', 'DRAFT', company name", - "bullet3": "Emoji characters are not supported and will be filtered out" - } - }, - "textStyle": { - "header": { - "title": "Text Style" - }, - "color": { - "title": "Color Selection", - "text": "Choose a color that provides good contrast with your document content.", - "bullet1": "Light gray (#d3d3d3) for subtle watermarks", - "bullet2": "Black or dark colors for high contrast", - "bullet3": "Custom colors for branding purposes" - }, - "language": { - "title": "Language Support", - "text": "Choose the appropriate language setting to ensure proper font rendering." - } - }, - "file": { - "header": { - "title": "Image Upload" - }, - "upload": { - "title": "Image Selection", - "text": "Upload an image file to use as your watermark.", - "bullet1": "Supports common formats: PNG, JPG, GIF, BMP", - "bullet2": "PNG with transparency works best", - "bullet3": "Higher resolution images maintain quality better" - }, - "recommendations": { - "title": "Best Practices", - "text": "Tips for optimal image watermark results.", - "bullet1": "Use logos or stamps with transparent backgrounds", - "bullet2": "Simple designs work better than complex images", - "bullet3": "Consider the final document size when choosing resolution" - } - }, - "formatting": { - "header": { - "title": "Formatting & Layout" - }, - "size": { - "title": "Size Control", - "text": "Adjust the size of your watermark (text or image).", - "bullet1": "Larger sizes create more prominent watermarks" - }, - "appearance": { - "title": "Appearance Settings", - "text": "Control how your watermark looks and blends with the document.", - "bullet1": "Rotation: -360° to 360° for angled watermarks", - "bullet2": "Opacity: 0-100% for transparency control", - "bullet3": "Lower opacity creates subtle watermarks" - }, - "spacing": { - "title": "Spacing Control", - "text": "Adjust the spacing between repeated watermarks across the page.", - "bullet1": "Horizontal spacing: Distance between watermarks left to right", - "bullet2": "Vertical spacing: Distance between watermarks top to bottom", - "bullet3": "Higher values create more spread out patterns" - }, - "security": { - "title": "Security Option", - "text": "Convert the final PDF to an image-based format for enhanced security.", - "bullet1": "Prevents text selection and copying", - "bullet2": "Makes watermarks harder to remove", - "bullet3": "Results in larger file sizes", - "bullet4": "Best for sensitive or copyrighted content" - } - } - }, - "type": { - "1": "Text", - "2": "Image" - } - }, - "permissions": { - "tags": "read,write,edit,print", - "title": "Change Permissions", - "header": "Change Permissions", - "warning": "Warning to have these permissions be unchangeable it is recommended to set them with a password via the add-password page", - "selectText": { - "1": "Select PDF to change permissions", - "2": "Permissions to set", - "3": "Prevent assembly of document", - "4": "Prevent content extraction", - "5": "Prevent extraction for accessibility", - "6": "Prevent filling in form", - "7": "Prevent modification", - "8": "Prevent annotation modification", - "9": "Prevent printing", - "10": "Prevent printing different formats" - }, - "submit": "Change" - }, - "editTableOfContents": { - "settings": { - "title": "Bookmarks & outline", - "replaceExisting": "Replace existing bookmarks (uncheck to append)", - "replaceExistingHint": "When disabled, the new outline is appended after the current bookmarks." - }, - "actions": { - "source": "Load bookmarks", - "selectedFile": "Loaded from {{file}}", - "noFile": "Select a PDF to extract existing bookmarks.", - "loadFromPdf": "Load from selected PDF", - "importJson": "Import JSON", - "importClipboard": "Paste JSON from clipboard", - "export": "Export bookmarks", - "exportJson": "Download JSON", - "exportClipboard": "Copy JSON to clipboard", - "clipboardUnavailable": "Clipboard access is not available in this browser." - }, - "info": { - "line1": "Each bookmark needs a descriptive title and the page it should open.", - "line2": "Use child bookmarks to build a hierarchy for chapters, sections, or subsections.", - "line3": "Import bookmarks from the selected PDF or from a JSON file to save time." - }, - "editor": { - "heading": "Bookmark editor", - "description": "Add, nest, and reorder bookmarks to craft your PDF outline.", - "addTopLevel": "Add top-level bookmark", - "empty": { - "title": "No bookmarks yet", - "description": "Import existing bookmarks or start by adding your first entry.", - "action": "Add first bookmark" - }, - "defaultTitle": "New bookmark", - "defaultChildTitle": "Child bookmark", - "defaultSiblingTitle": "New bookmark", - "untitled": "Untitled bookmark", - "childBadge": "Child", - "pagePreview": "Page {{page}}", - "field": { - "title": "Bookmark title", - "page": "Target page number" - }, - "actions": { - "toggle": "Toggle children", - "addChild": "Add child bookmark", - "addSibling": "Add sibling bookmark", - "remove": "Remove bookmark" - }, - "confirmRemove": "Remove this bookmark and all of its children?" - }, - "messages": { - "loadedTitle": "Bookmarks extracted", - "loadedBody": "Existing bookmarks from the PDF were loaded into the editor.", - "noBookmarks": "No bookmarks were found in the selected PDF.", - "loadFailed": "Unable to extract bookmarks from the selected PDF.", - "imported": "Bookmarks imported", - "importedBody": "Your JSON outline replaced the current editor contents.", - "importedClipboard": "Clipboard data replaced the current bookmark list.", - "invalidJson": "Invalid JSON structure", - "invalidJsonBody": "Please provide a valid bookmark JSON file and try again.", - "exported": "JSON download ready", - "copied": "Copied to clipboard", - "copiedBody": "Bookmark JSON copied successfully.", - "copyFailed": "Copy failed" - }, - "submit": "Apply table of contents", - "results": { - "title": "Updated PDF with bookmarks" - } - }, - "removePages": { - "tags": "Remove pages,delete pages", - "title": "Remove Pages", - "pageNumbers": { - "label": "Pages to Remove", - "placeholder": "e.g., 1,3,5-8,10", - "error": "Invalid page number format. Use numbers, ranges (1-5), or mathematical expressions (2n+1)" - }, - "filenamePrefix": "pages_removed", - "files": { - "placeholder": "Select a PDF file in the main view to get started" - }, - "settings": { - "title": "Settings" - }, - "tooltip": { - "header": { - "title": "Remove Pages Settings" - }, - "pageNumbers": { - "title": "Page Selection", - "text": "Specify which pages to remove from your PDF. You can select individual pages, ranges, or use mathematical expressions.", - "bullet1": "Individual pages: 1,3,5 (removes pages 1, 3, and 5)", - "bullet2": "Page ranges: 1-5,10-15 (removes pages 1-5 and 10-15)", - "bullet3": "Mathematical: 2n+1 (removes odd pages)", - "bullet4": "Open ranges: 5- (removes from page 5 to end)" - }, - "examples": { - "title": "Common Examples", - "text": "Here are some common page selection patterns:", - "bullet1": "Remove first page: 1", - "bullet2": "Remove last 3 pages: -3", - "bullet3": "Remove every other page: 2n", - "bullet4": "Remove specific scattered pages: 1,5,10,15" - }, - "safety": { - "title": "Safety Tips", - "text": "Important considerations when removing pages:", - "bullet1": "Always preview your selection before processing", - "bullet2": "Keep a backup of your original file", - "bullet3": "Page numbers start from 1, not 0", - "bullet4": "Invalid page numbers will be ignored" - } - }, - "error": { - "failed": "An error occurred while removing pages." - }, - "results": { - "title": "Page Removal Results" - }, - "submit": "Remove Pages" - }, - "extractPages": { - "title": "Extract Pages", - "pageNumbers": { - "label": "Pages to Extract", - "placeholder": "e.g., 1,3,5-8 or odd & 1-10" - }, - "settings": { - "title": "Settings" - }, - "tooltip": { - "description": "Extracts the selected pages into a new PDF, preserving order." - }, - "error": { - "failed": "Failed to extract pages" - }, - "results": { - "title": "Pages Extracted" - }, - "submit": "Extract Pages" - }, - "pageSelection": { - "tooltip": { - "header": { - "title": "Page Selection Guide" - }, - "basic": { - "title": "Basic Usage", - "text": "Select specific pages from your PDF document using simple syntax.", - "bullet1": "Individual pages: 1,3,5", - "bullet2": "Page ranges: 3-6 or 10-15", - "bullet3": "All pages: all" - }, - "advanced": { - "title": "Advanced Features" - }, - "tips": { - "title": "Tips", - "text": "Keep these guidelines in mind:", - "bullet1": "Page numbers start from 1 (not 0)", - "bullet2": "Spaces are automatically removed", - "bullet3": "Invalid expressions are ignored" - }, - "syntax": { - "title": "Syntax Basics", - "text": "Use numbers, ranges, keywords, and progressions (n starts at 0). Parentheses are supported.", - "bullets": { - "numbers": "Numbers/ranges: 5, 10-20", - "keywords": "Keywords: odd, even", - "progressions": "Progressions: 3n, 4n+1" - } - }, - "operators": { - "title": "Operators", - "text": "AND has higher precedence than comma. NOT applies within the document range.", - "and": "AND: & or \"and\" — require both conditions (e.g., 1-50 & even)", - "comma": "Comma: , or | — combine selections (e.g., 1-10, 20)", - "not": "NOT: ! or \"not\" — exclude pages (e.g., 3n & not 30)" - }, - "examples": { - "title": "Examples" - }, - "complex": { - "bullet1": "1,3-5,8,2n → pages 1, 3–5, 8, plus evens", - "bullet2": "10-,2n-1 → from page 10 to end + odd pages", - "description": "Mix different types.", - "title": "Complex Combinations" - }, - "description": "Choose which pages to use for the operation. Supports single pages, ranges, formulas, and the all keyword.", - "individual": { - "bullet1": "1,3,5 → selects pages 1, 3, 5", - "bullet2": "2,7,12 → selects pages 2, 7, 12", - "description": "Enter numbers separated by commas.", - "title": "Individual Pages" - }, - "mathematical": { - "bullet1": "2n → all even pages (2, 4, 6…)", - "bullet2": "2n-1 → all odd pages (1, 3, 5…)", - "bullet3": "3n → every 3rd page (3, 6, 9…)", - "bullet4": "4n-1 → pages 3, 7, 11, 15…", - "description": "Use n in formulas for patterns.", - "title": "Mathematical Functions" - }, - "ranges": { - "bullet1": "3-6 → selects pages 3–6", - "bullet2": "10-15 → selects pages 10–15", - "bullet3": "5- → selects pages 5 to end", - "description": "Use - for consecutive pages.", - "title": "Page Ranges" - }, - "special": { - "bullet1": "all → selects all pages", - "title": "Special Keywords" - } - } - }, - "bulkSelection": { - "syntaxError": "There is a syntax issue. See Page Selection tips for help.", - "header": { - "title": "Page Selection Guide" - }, - "syntax": { - "title": "Syntax Basics", - "text": "Use numbers, ranges, keywords, and progressions (n starts at 0). Parentheses are supported.", - "bullets": { - "numbers": "Numbers/ranges: 5, 10-20", - "keywords": "Keywords: odd, even", - "progressions": "Progressions: 3n, 4n+1" - } - }, - "operators": { - "title": "Operators", - "text": "AND has higher precedence than comma. NOT applies within the document range.", - "and": "AND: & or \"and\" — require both conditions (e.g., 1-50 & even)", - "comma": "Comma: , or | — combine selections (e.g., 1-10, 20)", - "not": "NOT: ! or \"not\" — exclude pages (e.g., 3n & not 30)" - }, - "examples": { - "title": "Examples", - "first50": "First 50", - "last50": "Last 50", - "every3rd": "Every 3rd", - "oddWithinExcluding": "Odd within 1-20 excluding 5-7", - "combineSets": "Combine sets" - }, - "firstNPages": { - "title": "First N Pages", - "placeholder": "Number of pages" - }, - "lastNPages": { - "title": "Last N Pages", - "placeholder": "Number of pages" - }, - "everyNthPage": { - "title": "Every Nth Page", - "placeholder": "Step size" - }, - "range": { - "title": "Range", - "fromPlaceholder": "From", - "toPlaceholder": "To" - }, - "keywords": { - "title": "Keywords" - }, - "advanced": { - "title": "Advanced" - } - }, - "compressPdfs": { - "tags": "squish,small,tiny" - }, - "unlockPDFForms": { - "tags": "remove,delete,form,field,readonly", - "title": "Remove Read-Only from Form Fields", - "header": "Unlock PDF Forms", - "submit": "Unlock Forms", - "description": "This tool will remove read-only restrictions from PDF form fields, making them editable and fillable.", - "filenamePrefix": "unlocked_forms", - "files": { - "placeholder": "Select a PDF file in the main view to get started" - }, - "error": { - "failed": "An error occurred while unlocking PDF forms." - }, - "results": { - "title": "Unlocked Forms Results" - } - }, - "changeMetadata": { - "header": "Change Metadata", - "submit": "Change", - "filenamePrefix": "metadata", - "settings": { - "title": "Metadata Settings" - }, - "standardFields": { - "title": "Standard Fields" - }, - "deleteAll": { - "label": "Remove Existing Metadata", - "checkbox": "Delete all metadata" - }, - "title": { - "label": "Title", - "placeholder": "Document title" - }, - "author": { - "label": "Author", - "placeholder": "Document author" - }, - "subject": { - "label": "Subject", - "placeholder": "Document subject" - }, - "keywords": { - "label": "Keywords", - "placeholder": "Document keywords" - }, - "creator": { - "label": "Creator", - "placeholder": "Document creator" - }, - "producer": { - "label": "Producer", - "placeholder": "Document producer" - }, - "dates": { - "title": "Date Fields" - }, - "creationDate": { - "label": "Creation Date", - "placeholder": "Creation date" - }, - "modificationDate": { - "label": "Modification Date", - "placeholder": "Modification date" - }, - "trapped": { - "label": "Trapped Status", - "unknown": "Unknown", - "true": "True", - "false": "False" - }, - "advanced": { - "title": "Advanced Options" - }, - "customFields": { - "title": "Custom Metadata", - "description": "Add custom metadata fields to the document", - "add": "Add Field", - "key": "Key", - "keyPlaceholder": "Custom key", - "value": "Value", - "valuePlaceholder": "Custom value", - "remove": "Remove" - }, - "results": { - "title": "Updated PDFs" - }, - "error": { - "failed": "An error occurred while changing the PDF metadata." - }, - "tooltip": { - "header": { - "title": "PDF Metadata Overview" - }, - "standardFields": { - "title": "Standard Fields", - "text": "Common PDF metadata fields that describe the document.", - "bullet1": "Title: Document name or heading", - "bullet2": "Author: Person who created the document", - "bullet3": "Subject: Brief description of content", - "bullet4": "Keywords: Search terms for the document", - "bullet5": "Creator/Producer: Software used to create the PDF" - }, - "dates": { - "title": "Date Fields", - "text": "When the document was created and modified.", - "bullet1": "Creation Date: When original document was made", - "bullet2": "Modification Date: When last changed" - }, - "options": { - "title": "Additional Options", - "text": "Custom fields and privacy controls.", - "bullet1": "Custom Metadata: Add your own key-value pairs", - "bullet2": "Trapped Status: High-quality printing setting", - "bullet3": "Delete All: Remove all metadata for privacy" - }, - "deleteAll": { - "title": "Remove Existing Metadata", - "text": "Complete metadata deletion to ensure privacy." - }, - "customFields": { - "title": "Custom Metadata", - "text": "Add your own custom key-value metadata pairs.", - "bullet1": "Add any custom fields relevant to your document", - "bullet2": "Examples: Department, Project, Version, Status", - "bullet3": "Both key and value are required for each entry" - }, - "advanced": { - "title": "Advanced Options", - "trapped": { - "title": "Trapped Status", - "description": "Indicates if document is prepared for high-quality printing.", - "bullet1": "True: Document has been trapped for printing", - "bullet2": "False: Document has not been trapped", - "bullet3": "Unknown: Trapped status is not specified" - } - } - } - }, - "fileToPDF": { - "tags": "transformation,format,document,picture,slide,text,conversion,office,docs,word,excel,powerpoint", - "title": "File to PDF", - "header": "Convert any file to PDF", - "credit": "This service uses LibreOffice and Unoconv for file conversion.", - "supportedFileTypesInfo": "Supported File types", - "supportedFileTypes": "Supported file types should include the below however for a full updated list of supported formats, please refer to the LibreOffice documentation", - "submit": "Convert to PDF" - }, - "ocr": { - "tags": "recognition,text,image,scan,read,identify,detection,editable", - "title": "OCR / Scan Cleanup", - "desc": "Cleanup scans and detects text from images within a PDF and re-adds it as text.", - "header": "Cleanup Scans / OCR (Optical Character Recognition)", - "selectText": { - "1": "Select languages that are to be detected within the PDF (Ones listed are the ones currently detected):", - "2": "Produce text file containing OCR text alongside the OCR'ed PDF", - "3": "Correct pages were scanned at a skewed angle by rotating them back into place", - "4": "Clean page so its less likely that OCR will find text in background noise. (No output change)", - "5": "Clean page so its less likely that OCR will find text in background noise, maintains cleanup in output.", - "6": "Ignores pages that have interactive text on them, only OCRs pages that are images", - "7": "Force OCR, will OCR Every page removing all original text elements", - "8": "Normal (Will error if PDF contains text)", - "9": "Additional Settings", - "10": "OCR Mode", - "11": "Remove images after OCR (Removes ALL images, only useful if part of conversion step)", - "12": "Render Type (Advanced)" - }, - "help": "Please read this documentation on how to use this for other languages and/or use not in docker", - "credit": "This service uses qpdf and Tesseract for OCR.", - "submit": "Process PDF with OCR", - "operation": { - "submit": "Process OCR and Review" - }, - "results": { - "title": "OCR Results" - }, - "languagePicker": { - "additionalLanguages": "Looking for additional languages?", - "viewSetupGuide": "View setup guide →" - }, - "settings": { - "title": "Settings", - "ocrMode": { - "label": "OCR Mode", - "auto": "Auto (skip text layers)", - "force": "Force (re-OCR all, replace text)", - "strict": "Strict (abort if text found)" - }, - "languages": { - "label": "Languages", - "placeholder": "Select languages" - }, - "compatibilityMode": { - "label": "Compatibility Mode" - }, - "advancedOptions": { - "label": "Processing Options", - "sidecar": "Create a text file", - "deskew": "Deskew pages", - "clean": "Clean input file", - "cleanFinal": "Clean final output" - } - }, - "tooltip": { - "header": { - "title": "OCR Settings Overview" - }, - "mode": { - "title": "OCR Mode", - "text": "Optical Character Recognition (OCR) helps you turn scanned or screenshotted pages into text you can search, copy, or highlight.", - "bullet1": "Auto skips pages that already contain text layers.", - "bullet2": "Force re-OCRs every page and replaces all the text.", - "bullet3": "Strict halts if any selectable text is found." - }, - "languages": { - "title": "Languages", - "text": "Improve OCR accuracy by specifying the expected languages. Choose one or more languages to guide detection." - }, - "output": { - "title": "Output", - "text": "Decide how you want the text output formatted:", - "bullet1": "Searchable PDF embeds text behind the original image.", - "bullet2": "HOCR XML returns a structured machine-readable file.", - "bullet3": "Plain-text sidecar creates a separate .txt file with raw content." - }, - "advanced": { - "header": { - "title": "Advanced OCR Processing" - }, - "compatibility": { - "title": "Compatibility Mode", - "text": "Uses OCR 'sandwich PDF' mode: results in larger files, but more reliable with certain languages and older PDF software. By default we use hOCR for smaller, modern PDFs." - }, - "sidecar": { - "title": "Create Text File", - "text": "Generates a separate .txt file alongside the PDF containing all extracted text content for easy access and processing." - }, - "deskew": { - "title": "Deskew Pages", - "text": "Automatically corrects skewed or tilted pages to improve OCR accuracy. Useful for scanned documents that weren't perfectly aligned." - }, - "clean": { - "title": "Clean Input File", - "text": "Preprocesses the input by removing noise, enhancing contrast, and optimizing the image for better OCR recognition before processing." - }, - "cleanFinal": { - "title": "Clean Final Output", - "text": "Post-processes the final PDF by removing OCR artifacts and optimizing the text layer for better readability and smaller file size." - } - } - }, - "error": { - "failed": "OCR operation failed" - } - }, - "extractImages": { - "tags": "picture,photo,save,archive,zip,capture,grab", - "title": "Extract Images", - "header": "Extract Images", - "selectText": "Select image format to convert extracted images to", - "allowDuplicates": "Save duplicate images", - "submit": "Extract", - "settings": { - "title": "Settings" - }, - "error": { - "failed": "An error occurred while extracting images from the PDF." - } - }, - "pdfToPDFA": { - "tags": "archive,long-term,standard,conversion,storage,preservation", - "title": "PDF To PDF/A", - "header": "PDF To PDF/A", - "credit": "This service uses libreoffice for PDF/A conversion", - "submit": "Convert", - "tip": "Currently does not work for multiple inputs at once", - "outputFormat": "Output format", - "pdfWithDigitalSignature": "The PDF contains a digital signature. This will be removed in the next step." - }, - "PDFToWord": { - "tags": "doc,docx,odt,word,transformation,format,conversion,office,microsoft,docfile", - "title": "PDF to Word", - "header": "PDF to Word", - "selectText": { - "1": "Output file format" - }, - "credit": "This service uses LibreOffice for file conversion.", - "submit": "Convert" - }, - "PDFToPresentation": { - "tags": "slides,show,office,microsoft", - "title": "PDF to Presentation", - "header": "PDF to Presentation", - "selectText": { - "1": "Output file format" - }, - "credit": "This service uses LibreOffice for file conversion.", - "submit": "Convert" - }, - "PDFToText": { - "tags": "richformat,richtextformat,rich text format", - "title": "PDF to RTF (Text)", - "header": "PDF to RTF (Text)", - "selectText": { - "1": "Output file format" - }, - "credit": "This service uses LibreOffice for file conversion.", - "submit": "Convert" - }, - "PDFToHTML": { - "tags": "web content,browser friendly", - "title": "PDF to HTML", - "header": "PDF to HTML", - "credit": "This service uses pdftohtml for file conversion.", - "submit": "Convert" - }, - "PDFToXML": { - "tags": "data-extraction,structured-content,interop,transformation,convert", - "title": "PDF to XML", - "header": "PDF to XML", - "credit": "This service uses LibreOffice for file conversion.", - "submit": "Convert" - }, - "ScannerImageSplit": { - "tags": "separate,auto-detect,scans,multi-photo,organize", - "selectText": { - "1": "Angle Threshold:", - "2": "Tilt (in degrees) needed before we auto-straighten a photo.", - "3": "Tolerance:", - "4": "How closely a color must match the page background to count as background. Higher = looser, lower = stricter.", - "5": "Minimum Area:", - "6": "Smallest photo size (in pixels²) we'll keep to avoid tiny fragments.", - "7": "Minimum Contour Area:", - "8": "Smallest edge/shape we consider when finding photos (filters dust and specks).", - "9": "Border Size:", - "10": "Extra padding (in pixels) around each saved photo so edges aren't cut." - }, - "info": "Python is not installed. It is required to run." - }, - "scannerImageSplit": { - "title": "Extracted Images", - "submit": "Extract Image Scans", - "error": { - "failed": "An error occurred while extracting image scans." - }, - "tooltip": { - "title": "Photo Splitter", - "whatThisDoes": "What this does", - "whatThisDoesDesc": "Automatically finds and extracts each photo from a scanned page or composite image—no manual cropping.", - "whenToUse": "When to use", - "useCase1": "Scan whole album pages in one go", - "useCase2": "Split flatbed batches into separate files", - "useCase3": "Break collages into individual photos", - "useCase4": "Pull photos from documents", - "quickFixes": "Quick fixes", - "problem1": "Photos not detected → increase Tolerance to 30-50", - "problem2": "Too many false detections → increase Minimum Area to 15,000-20,000", - "problem3": "Crops are too tight → increase Border Size to 5-10", - "problem4": "Tilted photos not straightened → lower Angle Threshold to ~5°", - "problem5": "Dust/noise boxes → increase Minimum Contour Area to 1000-2000", - "setupTips": "Setup tips", - "tip1": "Use a plain, light background", - "tip2": "Leave a small gap (≈1 cm) between photos", - "tip3": "Scan at 300-600 DPI", - "tip4": "Clean the scanner glass", - "headsUp": "Heads-up", - "headsUpDesc": "Overlapping photos or backgrounds very close in color to the photos can reduce accuracy-try a lighter or darker background and leave more space." - } - }, - "sign": { - "title": "Sign", - "header": "Sign PDFs", - "upload": "Upload Image", - "draw": { - "title": "Draw your signature", - "clear": "Clear" - }, - "text": { - "name": "Signer Name", - "placeholder": "Enter your full name" - }, - "clear": "Clear", - "add": "Add", - "saved": "Saved Signatures", - "save": "Save Signature", - "applySignatures": "Apply Signatures", - "personalSigs": "Personal Signatures", - "sharedSigs": "Shared Signatures", - "noSavedSigs": "No saved signatures found", - "addToAll": "Add to all pages", - "delete": "Delete", - "first": "First page", - "last": "Last page", - "next": "Next page", - "previous": "Previous page", - "maintainRatio": "Toggle maintain aspect ratio", - "undo": "Undo", - "redo": "Redo", - "submit": "Sign Document", - "steps": { - "configure": "Configure Signature" - }, - "type": { - "title": "Signature Type", - "draw": "Draw", - "canvas": "Canvas", - "image": "Image", - "text": "Text" - }, - "image": { - "label": "Upload signature image", - "placeholder": "Select image file", - "hint": "Upload a PNG or JPG image of your signature" - }, - "instructions": { - "title": "How to add signature", - "canvas": "After drawing your signature in the canvas, close the modal then click anywhere on the PDF to place it.", - "image": "After uploading your signature image above, click anywhere on the PDF to place it.", - "text": "After entering your name above, click anywhere on the PDF to place your signature." - }, - "mode": { - "move": "Move Signature", - "place": "Place Signature" - }, - "updateAndPlace": "Update and Place", - "activate": "Activate Signature Placement", - "deactivate": "Stop Placing Signatures", - "results": { - "title": "Signature Results" - }, - "error": { - "failed": "An error occurred while signing the PDF." - } - }, - "flatten": { - "title": "Flatten", - "header": "Flatten PDF", - "flattenOnlyForms": "Flatten only forms", - "submit": "Flatten", - "filenamePrefix": "flattened", - "files": { - "placeholder": "Select a PDF file in the main view to get started" - }, - "steps": { - "settings": "Settings" - }, - "options": { - "stepTitle": "Flatten Options", - "title": "Flatten Options", - "flattenOnlyForms": { - "label": "Flatten only forms", - "desc": "Only flatten form fields, leaving other interactive elements intact" - }, - "note": "Flattening removes interactive elements from the PDF, making them non-editable." - }, - "results": { - "title": "Flatten Results" - }, - "error": { - "failed": "An error occurred while flattening the PDF." - }, - "tooltip": { - "header": { - "title": "About Flattening PDFs" - }, - "description": { - "title": "What does flattening do?", - "text": "Flattening makes your PDF non-editable by turning fillable forms and buttons into regular text and images. The PDF will look exactly the same, but no one can change or fill in the forms anymore. Perfect for sharing completed forms, creating final documents for records, or ensuring the PDF looks the same everywhere.", - "bullet1": "Text boxes become regular text (can't be edited)", - "bullet2": "Checkboxes and buttons become pictures", - "bullet3": "Great for final versions you don't want changed", - "bullet4": "Ensures consistent appearance across all devices" - }, - "formsOnly": { - "title": "What does 'Flatten only forms' mean?", - "text": "This option only removes the ability to fill in forms, but keeps other features working like clicking links, viewing bookmarks, and reading comments.", - "bullet1": "Forms become non-editable", - "bullet2": "Links still work when clicked", - "bullet3": "Comments and notes remain visible", - "bullet4": "Bookmarks still help you navigate" - } - } - }, - "repair": { - "tags": "fix,restore,correction,recover", - "title": "Repair", - "header": "Repair PDFs", - "submit": "Repair", - "description": "This tool will attempt to repair corrupted or damaged PDF files. No additional settings are required.", - "filenamePrefix": "repaired", - "files": { - "placeholder": "Select a PDF file in the main view to get started" - }, - "error": { - "failed": "An error occurred while repairing the PDF." - }, - "results": { - "title": "Repair Results" - } - }, - "removeBlanks": { - "title": "Remove Blanks", - "header": "Remove Blank Pages", - "settings": { - "title": "Settings" - }, - "threshold": { - "label": "Pixel Whiteness Threshold" - }, - "whitePercent": { - "label": "White Percentage Threshold", - "unit": "%" - }, - "includeBlankPages": { - "label": "Include detected blank pages" - }, - "tooltip": { - "header": { - "title": "Remove Blank Pages Settings" - }, - "threshold": { - "title": "Pixel Whiteness Threshold", - "text": "Controls how white a pixel must be to be considered 'white'. This helps determine what counts as a blank area on the page.", - "bullet1": "0 = Pure black (most restrictive)", - "bullet2": "128 = Medium gray", - "bullet3": "255 = Pure white (least restrictive)" - }, - "whitePercent": { - "title": "White Percentage Threshold", - "text": "Sets the minimum percentage of white pixels required for a page to be considered blank and removed.", - "bullet1": "Lower values (e.g., 80%) = More pages removed", - "bullet2": "Higher values (e.g., 95%) = Only very blank pages removed", - "bullet3": "Use higher values for documents with light backgrounds" - }, - "includeBlankPages": { - "title": "Include Detected Blank Pages", - "text": "When enabled, creates a separate PDF containing all the blank pages that were detected and removed from the original document.", - "bullet1": "Useful for reviewing what was removed", - "bullet2": "Helps verify the detection accuracy", - "bullet3": "Can be disabled to reduce output file size" - } - }, - "submit": "Remove blank pages", - "error": { - "failed": "Failed to remove blank pages" - }, - "results": { - "title": "Removed Blank Pages" - } - }, - "removeAnnotations": { - "tags": "comments,highlight,notes,markup,remove", - "title": "Remove Annotations", - "header": "Remove Annotations", - "submit": "Remove", - "settings": { - "title": "Settings" - }, - "info": { - "title": "About Remove Annotations", - "description": "This tool will remove all annotations (comments, highlights, notes, etc.) from your PDF documents." - }, - "error": { - "failed": "An error occurred while removing annotations from the PDF." - } - }, - "compare": { - "tags": "differentiate,contrast,changes,analysis", - "title": "Compare", - "header": "Compare PDFs", - "clearSelected": "Clear selected", - "clear": { - "confirmTitle": "Clear selected PDFs?", - "confirmBody": "This will close the current comparison and take you back to Active Files.", - "confirm": "Clear and return" - }, - "review": { - "title": "Comparison Result", - "actionsHint": "Review the comparison, switch document roles, or export the summary.", - "switchOrder": "Switch order", - "exportSummary": "Export summary" - }, - "base": { - "label": "Original document", - "placeholder": "Select the original PDF" - }, - "comparison": { - "label": "Edited document", - "placeholder": "Select the edited PDF" - }, - "addFilesHint": "Add PDFs in the Files step to enable selection.", - "noFiles": "No PDFs available yet", - "pages": "Pages", - "selection": { - "originalEditedTitle": "Select Original and Edited PDFs" - }, - "original": { - "label": "Original PDF" - }, - "edited": { - "label": "Edited PDF" - }, - "swap": { - "confirmTitle": "Re-run comparison?", - "confirmBody": "This will rerun the tool. Are you sure you want to swap the order of Original and Edited?", - "confirm": "Swap and Re-run" - }, - "cta": "Compare", - "loading": "Comparing...", - "summary": { - "baseHeading": "Original document", - "comparisonHeading": "Edited document", - "pageLabel": "Page" - }, - "rendering": { - "pageNotReadyTitle": "Page not rendered yet", - "pageNotReadyBody": "Some pages are still rendering. Navigation will snap once they are ready.", - "rendering": "rendering", - "inProgress": "At least one of these PDFs are very large, scrolling won't be smooth until the rendering is complete", - "pagesRendered": "pages rendered", - "complete": "Page rendering complete" - }, - "dropdown": { - "deletionsLabel": "Deletions", - "additionsLabel": "Additions", - "deletions": "Deletions ({{count}})", - "additions": "Additions ({{count}})", - "searchPlaceholder": "Search changes...", - "noResults": "No changes found" - }, - "actions": { - "stackVertically": "Stack vertically", - "placeSideBySide": "Place side by side", - "zoomOut": "Zoom out", - "zoomIn": "Zoom in", - "resetView": "Reset view", - "unlinkScrollPan": "Unlink scroll and pan", - "linkScrollPan": "Link scroll and pan", - "unlinkScroll": "Unlink scroll", - "linkScroll": "Link scroll" - }, - "toasts": { - "unlinkedTitle": "Independent scroll & pan enabled", - "unlinkedBody": "Tip: Arrow Up/Down scroll both panes; panning only moves the active pane." - }, - "error": { - "selectRequired": "Select a original and edited document.", - "filesMissing": "Unable to locate the selected files. Please re-select them.", - "generic": "Unable to compare these files." - }, - "status": { - "extracting": "Extracting text...", - "processing": "Analyzing differences...", - "complete": "Comparison ready" - }, - "longJob": { - "title": "Large comparison in progress", - "body": "These PDFs together exceed 2,000 pages. Processing can take several minutes." - }, - "slowOperation": { - "title": "Still working…", - "body": "This comparison is taking longer than usual. You can let it continue or cancel it.", - "cancel": "Cancel comparison" - }, - "newLine": "new-line", - "complex": { - "message": "One or both of the provided documents are large files, accuracy of comparison may be reduced" - }, - "large": { - "file": { - "message": "One or Both of the provided documents are too large to process" - } - }, - "no": { - "text": { - "message": "One or both of the selected PDFs have no text content. Please choose PDFs with text for comparison." - } - }, - "too": { - "dissimilar": { - "message": "These documents appear highly dissimilar. Comparison was stopped to save time." - } - }, - "earlyDissimilarity": { - "title": "These PDFs look highly different", - "body": "We're seeing very few similarities so far. You can stop the comparison if these aren't related documents.", - "stopButton": "Stop comparison" - } - }, - "certSign": { - "tags": "authenticate,PEM,P12,official,encrypt,sign,certificate,PKCS12,JKS,server,manual,auto", - "title": "Certificate Signing", - "filenamePrefix": "signed", - "signMode": { - "stepTitle": "Sign Mode", - "tooltip": { - "header": { - "title": "About PDF Signatures" - }, - "overview": { - "title": "How signatures work", - "text": "Both modes seal the document (any edits are flagged as tampering) and record who/when/how for auditing. Viewer trust depends on the certificate chain." - }, - "manual": { - "title": "Manual - Bring your certificate", - "text": "Use your own certificate files for brand-aligned identity. Can display Trusted when your CA/chain is recognized.", - "use": "Use for: customer-facing, legal, compliance." - }, - "auto": { - "title": "Auto - Zero-setup, instant system seal", - "text": "Signs with a server self-signed certificate. Same tamper-evident seal and audit trail; typically shows Unverified in viewers.", - "use": "Use when: you need speed and consistent internal identity across reviews and records." - }, - "rule": { - "title": "Rule of thumb", - "text": "Need recipient Trusted status? Manual. Need a fast, tamper-evident seal and audit trail with no setup? Auto." - } - } - }, - "certTypeStep": { - "stepTitle": "Certificate Format" - }, - "certFiles": { - "stepTitle": "Certificate Files" - }, - "appearance": { - "stepTitle": "Signature Appearance", - "tooltip": { - "header": { - "title": "About Signature Appearance" - }, - "invisible": { - "title": "Invisible Signatures", - "text": "The signature is added to the PDF for security but won't be visible when viewing the document. Perfect for legal requirements without changing the document's appearance.", - "bullet1": "Provides security without visual changes", - "bullet2": "Meets legal requirements for digital signing", - "bullet3": "Doesn't affect document layout or design" - }, - "visible": { - "title": "Visible Signatures", - "text": "Shows a signature block on the PDF with your name, date, and optional details. Useful when you want readers to clearly see the document is signed.", - "bullet1": "Shows signer name and date on the document", - "bullet2": "Can include reason and location for signing", - "bullet3": "Choose which page to place the signature", - "bullet4": "Optional logo can be included" - } - }, - "invisible": "Invisible", - "options": { - "title": "Signature Details" - }, - "visible": "Visible" - }, - "sign": { - "submit": "Sign PDF", - "results": "Signed PDF" - }, - "error": { - "failed": "An error occurred while processing signatures." - }, - "tooltip": { - "header": { - "title": "About Managing Signatures" - }, - "overview": { - "title": "What can this tool do?", - "text": "This tool lets you check if your PDFs are digitally signed and add new digital signatures. Digital signatures prove who created or approved a document and show if it has been changed since signing.", - "bullet1": "Check existing signatures and their validity", - "bullet2": "View detailed information about signers and certificates", - "bullet3": "Add new digital signatures to secure your documents", - "bullet4": "Multiple files supported with easy navigation" - }, - "validation": { - "title": "Checking Signatures", - "text": "When you check signatures, the tool tells you if they're valid, who signed the document, when it was signed, and whether the document has been changed since signing.", - "bullet1": "Shows if signatures are valid or invalid", - "bullet2": "Displays signer information and signing date", - "bullet3": "Checks if the document was modified after signing", - "bullet4": "Can use custom certificates for verification" - }, - "signing": { - "title": "Adding Signatures", - "text": "To sign a PDF, you need a digital certificate (like PEM, PKCS12, or JKS). You can choose to make the signature visible on the document or keep it invisible for security only.", - "bullet1": "Supports PEM, PKCS12, JKS, and server certificate formats", - "bullet2": "Option to show or hide signature on the PDF", - "bullet3": "Add reason, location, and signer name", - "bullet4": "Choose which page to place visible signatures", - "bullet5": "Use server certificate for simple 'Sign with Stirling-PDF' option" - } - }, - "certType": { - "tooltip": { - "header": { - "title": "About Certificate Types" - }, - "what": { - "title": "What's a certificate?", - "text": "It's a secure ID for your signature that proves you signed. Unless you're required to sign via certificate, we recommend using another secure method like Type, Draw, or Upload." - }, - "which": { - "title": "Which option should I use?", - "text": "Choose the format that matches your certificate file:", - "bullet1": "PKCS#12 (.p12 / .pfx) – one combined file (most common)", - "bullet2": "PFX (.pfx) – Microsoft's version of PKCS12", - "bullet3": "PEM – separate private-key and certificate .pem files", - "bullet4": "JKS – Java .jks keystore for dev / CI-CD workflows" - }, - "convert": { - "title": "Key not listed?", - "text": "Convert your file to a Java keystore (.jks) with keytool, then pick JKS." - } - } - }, - "chooseCertificate": "Choose Certificate File", - "chooseJksFile": "Choose JKS File", - "chooseP12File": "Choose PKCS12 File", - "choosePfxFile": "Choose PFX File", - "choosePrivateKey": "Choose Private Key File", - "location": "Location", - "logoTitle": "Logo", - "name": "Name", - "noLogo": "No Logo", - "pageNumber": "Page Number", - "password": "Certificate Password", - "passwordOptional": "Leave empty if no password", - "reason": "Reason", - "serverCertMessage": "Using server certificate - no files or password required", - "showLogo": "Show Logo" - }, - "removeCertSign": { - "tags": "authenticate,PEM,P12,official,decrypt", - "title": "Remove Certificate Signature", - "header": "Remove the digital certificate from the PDF", - "selectPDF": "Select a PDF file:", - "submit": "Remove Signature", - "description": "This tool will remove digital certificate signatures from your PDF document.", - "filenamePrefix": "unsigned", - "files": { - "placeholder": "Select a PDF file in the main view to get started" - }, - "error": { - "failed": "An error occurred while removing certificate signatures." - }, - "results": { - "title": "Certificate Removal Results" - } - }, - "pageLayout": { - "tags": "merge,composite,single-view,organize", - "title": "Multi Page Layout", - "header": "Multi Page Layout", - "pagesPerSheet": "Pages per sheet:", - "addBorder": "Add Borders", - "submit": "Submit", - "desc": { - "2": "Place 2 pages side-by-side on a single sheet.", - "3": "Place 3 pages on a single sheet in a single row.", - "4": "Place 4 pages on a single sheet (2 × 2 grid).", - "9": "Place 9 pages on a single sheet (3 × 3 grid).", - "16": "Place 16 pages on a single sheet (4 × 4 grid)." - }, - "error": { - "failed": "An error occurred while creating the multi-page layout." - } - }, - "bookletImposition": { - "tags": "booklet,imposition,printing,binding,folding,signature", - "title": "Booklet Imposition", - "header": "Booklet Imposition", - "submit": "Create Booklet", - "spineLocation": { - "label": "Spine Location", - "left": "Left (Standard)", - "right": "Right (RTL)" - }, - "doubleSided": { - "label": "Double-sided printing", - "tooltip": "Creates both front and back sides for proper booklet printing" - }, - "manualDuplex": { - "title": "Manual Duplex Mode", - "instructions": "For printers without automatic duplex. You'll need to run this twice:" - }, - "duplexPass": { - "label": "Print Pass", - "first": "1st Pass", - "second": "2nd Pass", - "firstInstructions": "Prints front sides → stack face-down → run again with 2nd Pass", - "secondInstructions": "Load printed stack face-down → prints back sides" - }, - "rtlBinding": { - "label": "Right-to-left binding", - "tooltip": "For Arabic, Hebrew, or other right-to-left languages" - }, - "addBorder": { - "label": "Add borders around pages", - "tooltip": "Adds borders around each page section to help with cutting and alignment" - }, - "addGutter": { - "label": "Add gutter margin", - "tooltip": "Adds inner margin space for binding" - }, - "gutterSize": { - "label": "Gutter size (points)" - }, - "flipOnShortEdge": { - "label": "Flip on short edge (automatic duplex only)", - "tooltip": "Enable for short-edge duplex printing (automatic duplex only - ignored in manual mode)", - "manualNote": "Not needed in manual mode - you flip the stack yourself" - }, - "advanced": { - "toggle": "Advanced Options" - }, - "paperSizeNote": "Paper size is automatically derived from your first page.", - "tooltip": { - "header": { - "title": "Booklet Creation Guide" - }, - "description": { - "title": "What is Booklet Imposition?", - "text": "Creates professional booklets by arranging pages in the correct printing order. Your PDF pages are placed 2-up on landscape sheets so when folded and bound, they read in proper sequence like a real book." - }, - "example": { - "title": "Example: 8-Page Booklet", - "text": "Your 8-page document becomes 2 sheets:", - "bullet1": "Sheet 1 Front: Pages 8, 1 | Back: Pages 2, 7", - "bullet2": "Sheet 2 Front: Pages 6, 3 | Back: Pages 4, 5", - "bullet3": "When folded & stacked: Reads 1→2→3→4→5→6→7→8" - }, - "printing": { - "title": "How to Print & Assemble", - "text": "Follow these steps for perfect booklets:", - "bullet1": "Print double-sided with 'Flip on long edge'", - "bullet2": "Stack sheets in order, fold in half", - "bullet3": "Staple or bind along the folded spine", - "bullet4": "For short-edge printers: Enable 'Flip on short edge' option" - }, - "manualDuplex": { - "title": "Manual Duplex (Single-sided Printers)", - "text": "For printers without automatic duplex:", - "bullet1": "Turn OFF 'Double-sided printing'", - "bullet2": "Select '1st Pass' → Print → Stack face-down", - "bullet3": "Select '2nd Pass' → Load stack → Print backs", - "bullet4": "Fold and assemble as normal" - }, - "advanced": { - "title": "Advanced Options", - "text": "Fine-tune your booklet:", - "bullet1": "Right-to-Left Binding: For Arabic, Hebrew, or RTL languages", - "bullet2": "Borders: Shows cut lines for trimming", - "bullet3": "Gutter Margin: Adds space for binding/stapling", - "bullet4": "Short-edge Flip: Only for automatic duplex printers" - } - }, - "error": { - "failed": "An error occurred while creating the booklet imposition." - } - }, - "scalePages": { - "title": "Adjust page-scale", - "header": "Adjust page-scale", - "pageSize": "Size of a page of the document.", - "keepPageSize": "Original Size", - "scaleFactor": "Zoom level (crop) of a page.", - "submit": "Submit" - }, - "adjustPageScale": { - "tags": "resize,modify,dimension,adapt", - "title": "Adjust Page Scale", - "header": "Adjust Page Scale", - "scaleFactor": { - "label": "Scale Factor" - }, - "pageSize": { - "label": "Target Page Size", - "keep": "Keep Original Size", - "letter": "Letter", - "legal": "Legal" - }, - "submit": "Adjust Page Scale", - "error": { - "failed": "An error occurred while adjusting the page scale." - }, - "tooltip": { - "header": { - "title": "Page Scale Settings Overview" - }, - "description": { - "title": "Description", - "text": "Adjust the size of PDF content and change the page dimensions." - }, - "scaleFactor": { - "title": "Scale Factor", - "text": "Controls how large or small the content appears on the page. Content is scaled and centered - if scaled content is larger than the page size, it may be cropped.", - "bullet1": "1.0 = Original size", - "bullet2": "0.5 = Half size (50% smaller)", - "bullet3": "2.0 = Double size (200% larger, may crop)" - }, - "pageSize": { - "title": "Target Page Size", - "text": "Sets the dimensions of the output PDF pages. 'Keep Original Size' maintains current dimensions, while other options resize to standard paper sizes." - } - } - }, - "add-page-numbers": { - "tags": "paginate,label,organize,index" - }, - "auto-rename": { - "tags": "auto-detect,header-based,organize,relabel", - "title": "Auto Rename", - "header": "Auto Rename PDF", - "description": "Automatically finds the title from your PDF content and uses it as the filename.", - "submit": "Auto Rename", - "files": { - "placeholder": "Select a PDF file in the main view to get started" - }, - "error": { - "failed": "An error occurred while auto-renaming the PDF." - }, - "results": { - "title": "Auto-Rename Results" - }, - "tooltip": { - "header": { - "title": "How Auto-Rename Works" - }, - "howItWorks": { - "title": "Smart Renaming", - "text": "Automatically finds the title from your PDF content and uses it as the filename.", - "bullet1": "Looks for text that appears to be a title or heading", - "bullet2": "Creates a clean, valid filename from the detected title", - "bullet3": "Keeps the original name if no suitable title is found" - } - } - }, - "adjust-contrast": { - "tags": "color-correction,tune,modify,enhance,color-correction" - }, - "crop": { - "title": "Crop", - "header": "Crop PDF", - "submit": "Apply Crop", - "noFileSelected": "Select a PDF file to begin cropping", - "preview": { - "title": "Crop Area Selection" - }, - "reset": "Reset to full PDF", - "coordinates": { - "title": "Position and Size", - "x": { - "label": "X Position", - "desc": "Left edge (points)" - }, - "y": { - "label": "Y Position", - "desc": "Bottom edge (points)" - }, - "width": { - "label": "Width", - "desc": "Crop width (points)" - }, - "height": { - "label": "Height", - "desc": "Crop height (points)" - } - }, - "error": { - "invalidArea": "Crop area extends beyond PDF boundaries", - "failed": "Failed to crop PDF" - }, - "steps": { - "selectArea": "Select Crop Area" - }, - "tooltip": { - "title": "How to Crop PDFs", - "description": "Select the area to crop from your PDF by dragging and resizing the blue overlay on the thumbnail.", - "drag": "Drag the overlay to move the crop area", - "resize": "Drag the corner and edge handles to resize", - "precision": "Use coordinate inputs for precise positioning" - }, - "results": { - "title": "Crop Results" - }, - "automation": { - "info": "Enter crop coordinates in PDF points. Origin (0,0) is at bottom-left. These values will be applied to all PDFs processed in this automation.", - "reference": "Reference: A4 page is 595.28 × 841.89 points (210mm × 297mm). 1 inch = 72 points." - } - }, - "autoSplitPDF": { - "tags": "QR-based,separate,scan-segment,organize", - "title": "Auto Split PDF", - "header": "Auto Split PDF", - "description": "Print, Insert, Scan, upload, and let us auto-separate your documents. No manual work sorting needed.", - "selectText": { - "1": "Print out some divider sheets from below (Black and white is fine).", - "2": "Scan all your documents at once by inserting the divider sheet between them.", - "3": "Upload the single large scanned PDF file and let Stirling PDF handle the rest.", - "4": "Divider pages are automatically detected and removed, guaranteeing a neat final document." - }, - "formPrompt": "Submit PDF containing Stirling-PDF Page dividers:", - "duplexMode": "Duplex Mode (Front and back scanning)", - "dividerDownload2": "Download 'Auto Splitter Divider (with instructions).pdf'", - "submit": "Submit" - }, - "sanitizePdf": { - "tags": "clean,secure,safe,remove-threats" - }, - "URLToPDF": { - "tags": "web-capture,save-page,web-to-doc,archive", - "title": "URL To PDF", - "header": "URL To PDF", - "submit": "Convert", - "credit": "Uses WeasyPrint" - }, - "HTMLToPDF": { - "tags": "markup,web-content,transformation,convert", - "title": "HTML To PDF", - "header": "HTML To PDF", - "help": "Accepts HTML files and ZIPs containing html/css/images etc required", - "submit": "Convert", - "credit": "Uses WeasyPrint", - "zoom": "Zoom level for displaying the website.", - "pageWidth": "Width of the page in centimeters. (Blank to default)", - "pageHeight": "Height of the page in centimeters. (Blank to default)", - "marginTop": "Top margin of the page in millimeters. (Blank to default)", - "marginBottom": "Bottom margin of the page in millimeters. (Blank to default)", - "marginLeft": "Left margin of the page in millimeters. (Blank to default)", - "marginRight": "Right margin of the page in millimeters. (Blank to default)", - "printBackground": "Render the background of websites.", - "defaultHeader": "Enable Default Header (Name and page number)", - "cssMediaType": "Change the CSS media type of the page.", - "none": "None", - "print": "Print", - "screen": "Screen" - }, - "MarkdownToPDF": { - "tags": "markup,web-content,transformation,convert,md", - "title": "Markdown To PDF", - "header": "Markdown To PDF", - "submit": "Convert", - "help": "Work in progress", - "credit": "Uses WeasyPrint" - }, - "PDFToMarkdown": { - "tags": "markup,web-content,transformation,convert,md", - "title": "PDF To Markdown", - "header": "PDF To Markdown", - "submit": "Convert" - }, - "getPdfInfo": { - "tags": "infomation,data,stats,statistics", - "title": "Get Info on PDF", - "header": "Get Info on PDF", - "submit": "Get Info", - "downloadJson": "Download JSON" - }, - "extractPage": { - "tags": "extract" - }, - "PdfToSinglePage": { - "tags": "single page" - }, - "showJS": { - "tags": "JS", - "title": "Show Javascript", - "header": "Show Javascript", - "downloadJS": "Download Javascript", - "submit": "Show", - "results": "Result", - "processing": "Extracting JavaScript...", - "done": "JavaScript extracted", - "singleFileWarning": "This tool only supports one file at a time. Please select a single file.", - "view": { - "title": "Extracted JavaScript" - } - }, - "redact": { - "tags": "Redact,Hide,black out,black,marker,hidden,auto redact,manual redact", - "title": "Redact", - "submit": "Redact", - "error": { - "failed": "An error occurred while redacting the PDF." - }, - "modeSelector": { - "title": "Redaction Method", - "mode": "Mode", - "automatic": "Automatic", - "automaticDesc": "Redact text based on search terms", - "manual": "Manual", - "manualDesc": "Click and drag to redact specific areas", - "manualComingSoon": "Manual redaction coming soon" - }, - "auto": { - "header": "Auto Redact", - "settings": { - "title": "Redaction Settings", - "advancedTitle": "Advanced" - }, - "colorLabel": "Box Color", - "wordsToRedact": { - "title": "Words to Redact", - "placeholder": "Enter a word", - "add": "Add", - "examples": "Examples: Confidential, Top-Secret" - }, - "useRegexLabel": "Use Regex", - "wholeWordSearchLabel": "Whole Word Search", - "customPaddingLabel": "Custom Extra Padding", - "convertPDFToImageLabel": "Convert PDF to PDF-Image" - }, - "tooltip": { - "mode": { - "header": { - "title": "Redaction Method" - }, - "automatic": { - "title": "Automatic Redaction", - "text": "Automatically finds and redacts specified text throughout the document. Perfect for removing consistent sensitive information like names, addresses, or confidential markers." - }, - "manual": { - "title": "Manual Redaction", - "text": "Click and drag to manually select specific areas to redact. Gives you precise control over what gets redacted. (Coming soon)" - } - }, - "words": { - "header": { - "title": "Words to Redact" - }, - "description": { - "title": "Text Matching", - "text": "Enter words or phrases to find and redact in your document. Each word will be searched for separately." - }, - "bullet1": "Add one word at a time", - "bullet2": "Press Enter or click 'Add Another' to add", - "bullet3": "Click × to remove words", - "examples": { - "title": "Common Examples", - "text": "Typical words to redact include: bank details, email addresses, or specific names." - } - }, - "advanced": { - "header": { - "title": "Advanced Redaction Settings" - }, - "color": { - "title": "Box Color & Padding", - "text": "Customize the appearance of redaction boxes. Black is standard, but you can choose any color. Padding adds extra space around the found text." - }, - "regex": { - "title": "Use Regex", - "text": "Enable regular expressions for advanced pattern matching. Useful for finding phone numbers, emails, or complex patterns.", - "bullet1": "Example: \\d{4}-\\d{2}-\\d{2} to match any dates in YYYY-MM-DD format", - "bullet2": "Use with caution - test thoroughly" - }, - "wholeWord": { - "title": "Whole Word Search", - "text": "Only match complete words, not partial matches. 'John' won't match 'Johnson' when enabled." - }, - "convert": { - "title": "Convert to PDF-Image", - "text": "Converts the PDF to an image-based PDF after redaction. This ensures text behind redaction boxes is completely removed and unrecoverable." - } - } - }, - "manual": { - "header": "Manual Redaction", - "textBasedRedaction": "Text-based Redaction", - "pageBasedRedaction": "Page-based Redaction", - "convertPDFToImageLabel": "Convert PDF to PDF-Image (Used to remove text behind the box)", - "pageRedactionNumbers": { - "title": "Pages", - "placeholder": "(e.g. 1,2,8 or 4,7,12-16 or 2n-1)" - }, - "redactionColor": { - "title": "Redaction Color" - }, - "export": "Export", - "upload": "Upload", - "boxRedaction": "Box draw redaction", - "zoom": "Zoom", - "zoomIn": "Zoom in", - "zoomOut": "Zoom out", - "nextPage": "Next Page", - "previousPage": "Previous Page", - "toggleSidebar": "Toggle Sidebar", - "showThumbnails": "Show Thumbnails", - "showDocumentOutline": "Show Document Outline (double-click to expand/collapse all items)", - "showAttachments": "Show Attachments", - "showLayers": "Show Layers (double-click to reset all layers to the default state)", - "colourPicker": "Color Picker", - "findCurrentOutlineItem": "Find current outline item", - "applyChanges": "Apply Changes" - } - }, - "tableExtraxt": { - "tags": "CSV,Table Extraction,extract,convert" - }, - "autoSizeSplitPDF": { - "tags": "pdf,split,document,organization" - }, - "overlay-pdfs": { - "tags": "Overlay", - "header": "Overlay PDF Files", - "title": "Overlay PDFs", - "desc": "Overlay one PDF on top of another", - "baseFile": { - "label": "Select Base PDF File" - }, - "overlayFiles": { - "label": "Select Overlay PDF Files", - "placeholder": "Choose PDF(s)...", - "addMore": "Add more PDFs..." - }, - "mode": { - "label": "Select Overlay Mode", - "sequential": "Sequential Overlay", - "interleaved": "Interleaved Overlay", - "fixedRepeat": "Fixed Repeat Overlay" - }, - "counts": { - "label": "Overlay Counts (for Fixed Repeat Mode)", - "placeholder": "Enter comma-separated counts (e.g., 2,3,1)", - "item": "Count for file", - "noFiles": "Add overlay files to configure counts" - }, - "position": { - "label": "Select Overlay Position", - "foreground": "Foreground", - "background": "Background" - }, - "submit": "Submit", - "settings": { - "title": "Settings" - }, - "results": { - "title": "Overlay Results" - }, - "tooltip": { - "header": { - "title": "Overlay PDFs Overview" - }, - "description": { - "title": "Description", - "text": "Combine a base PDF with one or more overlay PDFs. Overlays can be applied page-by-page in different modes and placed in the foreground or background." - }, - "mode": { - "title": "Overlay Mode", - "text": "Choose how to distribute overlay pages across the base PDF pages.", - "sequential": "Sequential Overlay: Use pages from the first overlay PDF until it ends, then move to the next.", - "interleaved": "Interleaved Overlay: Take one page from each overlay in turn.", - "fixedRepeat": "Fixed Repeat Overlay: Take a set number of pages from each overlay before moving to the next. Use Counts to set the numbers." - }, - "position": { - "title": "Overlay Position", - "text": "Foreground places the overlay on top of the page. Background places it behind." - }, - "overlayFiles": { - "title": "Overlay Files", - "text": "Select one or more PDFs to overlay on the base. The order of these files affects how pages are applied in Sequential and Fixed Repeat modes." - }, - "counts": { - "title": "Counts (Fixed Repeat only)", - "text": "Provide a positive number for each overlay file showing how many pages to take before moving to the next. Required when mode is Fixed Repeat." - } - }, - "error": { - "failed": "An error occurred while overlaying PDFs." - } - }, - "split-by-sections": { - "tags": "Section Split, Divide, Customize,Customize", - "title": "Split PDF by Sections", - "header": "Split PDF into Sections", - "horizontal": { - "label": "Horizontal Divisions", - "placeholder": "Enter number of horizontal divisions" - }, - "vertical": { - "label": "Vertical Divisions", - "placeholder": "Enter number of vertical divisions" - }, - "submit": "Split PDF", - "merge": "Merge Into One PDF" - }, - "AddStampRequest": { - "tags": "Stamp, Add image, center image, Watermark, PDF, Embed, Customize,Customize", - "header": "Stamp PDF", - "title": "Stamp PDF", - "stampSetup": "Stamp Setup", - "stampType": "Stamp Type", - "stampText": "Stamp Text", - "stampImage": "Stamp Image", - "alphabet": "Alphabet", - "fontSize": "Font/Image Size", - "rotation": "Rotation", - "opacity": "Opacity", - "position": "Position", - "overrideX": "Override X Coordinate", - "overrideY": "Override Y Coordinate", - "customMargin": "Custom Margin", - "customColor": "Custom Text Color", - "submit": "Submit", - "noStampSelected": "No stamp selected. Return to Step 1.", - "customPosition": "Drag the stamp to the desired location in the preview window.", - "error": { - "failed": "An error occurred while adding stamp to the PDF." - }, - "imageSize": "Image Size", - "margin": "Margin", - "positionAndFormatting": "Position & Formatting", - "quickPosition": "Select a position on the page to place the stamp.", - "results": { - "title": "Stamp Results" - } - }, - "removeImagePdf": { - "tags": "Remove Image,Page operations,Back end,server side" - }, - "splitPdfByChapters": { - "tags": "split,chapters,bookmarks,organize" - }, - "validateSignature": { - "tags": "signature,verify,validate,pdf,certificate,digital signature,Validate Signature,Validate certificate", - "title": "Validate PDF Signatures", - "header": "Validate Digital Signatures", - "selectPDF": "Select signed PDF file", - "submit": "Validate Signatures", - "results": "Validation Results", - "status": { - "_value": "Status", - "valid": "Valid", - "invalid": "Invalid", - "complete": "Validation complete" - }, - "signer": "Signer", - "date": "Date", - "reason": "Reason", - "location": "Location", - "noSignatures": "No digital signatures found in this document", - "chain": { - "invalid": "Certificate chain validation failed - cannot verify signer's identity" - }, - "trust": { - "invalid": "Certificate not in trust store - source cannot be verified" - }, - "cert": { - "expired": "Certificate has expired", - "revoked": "Certificate has been revoked", - "info": "Certificate Details", - "issuer": "Issuer", - "subject": "Subject", - "serialNumber": "Serial Number", - "validFrom": "Valid From", - "validUntil": "Valid Until", - "algorithm": "Algorithm", - "keySize": "Key Size", - "version": "Version", - "keyUsage": "Key Usage", - "selfSigned": "Self-Signed", - "bits": "bits", - "details": "Certificate Details" - }, - "signature": { - "info": "Signature Information", - "_value": "Signature", - "mathValid": "Signature is mathematically valid BUT:" - }, - "selectCustomCert": "Custom Certificate File X.509 (Optional)", - "downloadCsv": "Download CSV", - "downloadJson": "Download JSON", - "downloadPdf": "Download PDF Report", - "downloadType": { - "csv": "CSV", - "json": "JSON", - "pdf": "PDF" - }, - "error": { - "allFailed": "Unable to validate the selected files.", - "partial": "Some files could not be validated.", - "reportGeneration": "Could not generate the PDF report. JSON and CSV are available.", - "unexpected": "Unexpected error during validation." - }, - "finalizing": "Preparing downloads...", - "issue": { - "certExpired": "Certificate expired", - "certRevocationUnknown": "Certificate revocation status unknown", - "certRevoked": "Certificate revoked", - "chainInvalid": "Certificate chain invalid", - "signatureInvalid": "Signature cryptographic check failed", - "trustInvalid": "Certificate not trusted" - }, - "noResults": "Run the validation to generate a report.", - "noSignaturesShort": "No signatures", - "processing": "Validating signatures...", - "report": { - "continued": "Continued", - "downloads": "Downloads", - "entryLabel": "Signature Summary", - "fields": { - "created": "Created", - "fileSize": "File Size", - "signatureCount": "Total Signatures", - "signatureDate": "Signature Date" - }, - "filesEvaluated": "{{count}} files evaluated", - "footer": "Validated via Stirling PDF", - "generatedAt": "Generated", - "noPdf": "PDF report will be available after a successful validation.", - "page": "Page", - "shortTitle": "Signature Summary", - "signatureCountLabel": "{{count}} signatures", - "signaturesFound": "{{count}} signatures detected", - "signaturesValid": "{{count}} fully valid", - "title": "Signature Validation Report" - }, - "settings": { - "certHint": "Upload a trusted X.509 certificate to validate against a custom trust source.", - "title": "Validation Settings" - }, - "signatureDate": "Signature Date", - "totalSignatures": "Total Signatures" - }, - "replaceColor": { - "tags": "Replace Color,Page operations,Back end,server side", - "labels": { - "settings": "Settings", - "colourOperation": "Color operation" - }, - "options": { - "highContrast": "High contrast", - "invertAll": "Invert all colors", - "custom": "Custom", - "cmyk": "Convert to CMYK" - }, - "tooltip": { - "header": { - "title": "Replace & Invert Color Settings Overview" - }, - "description": { - "title": "Description", - "text": "Transform PDF colors to improve readability and accessibility. Choose from high contrast presets, invert all colors, or create custom color schemes." - }, - "highContrast": { - "title": "High Contrast", - "text": "Apply predefined high contrast color combinations designed for better readability and accessibility compliance.", - "bullet1": "White text on black background - Classic dark mode", - "bullet2": "Black text on white background - Standard high contrast", - "bullet3": "Yellow text on black background - High visibility option", - "bullet4": "Green text on black background - Alternative high contrast" - }, - "invertAll": { - "title": "Invert All Colors", - "text": "Completely invert all colors in the PDF, creating a negative-like effect. Useful for creating dark mode versions of documents or reducing eye strain in low-light conditions." - }, - "custom": { - "title": "Custom Colors", - "text": "Define your own text and background colors using the color pickers. Perfect for creating branded documents or specific accessibility requirements.", - "bullet1": "Text color - Choose the color for text elements", - "bullet2": "Background color - Set the background color for the document" - }, - "cmyk": { - "title": "Convert to CMYK", - "text": "Convert the PDF from RGB color space to CMYK color space, optimized for professional printing. This process converts colors to the Cyan, Magenta, Yellow, Black model used by printers." - } - }, - "error": { - "failed": "An error occurred while processing the color replacement." - } - }, - "login": { - "title": "Sign in", - "header": "Sign in", - "signin": "Sign in", - "signInWith": "Sign in with", - "signInAnonymously": "Sign Up as a Guest", - "rememberme": "Remember me", - "invalid": "Invalid username or password.", - "locked": "Your account has been locked.", - "sessionExpired": "Your session has expired. Please sign in again.", - "signinTitle": "Please sign in", - "ssoSignIn": "Login via Single Sign-on", - "oAuth2AutoCreateDisabled": "OAUTH2 Auto-Create User Disabled", - "oAuth2AdminBlockedUser": "Registration or logging in of non-registered users is currently blocked. Please contact the administrator.", - "oauth2RequestNotFound": "Authorization request not found", - "oauth2InvalidUserInfoResponse": "Invalid User Info Response", - "oauth2invalidRequest": "Invalid Request", - "oauth2AccessDenied": "Access Denied", - "oauth2InvalidTokenResponse": "Invalid Token Response", - "oauth2InvalidIdToken": "Invalid Id Token", - "relyingPartyRegistrationNotFound": "No relying party registration found", - "userIsDisabled": "User is deactivated, login is currently blocked with this username. Please contact the administrator.", - "alreadyLoggedIn": "You are already logged in to", - "alreadyLoggedIn2": "devices. Please log out of the devices and try again.", - "toManySessions": "You have too many active sessions", - "logoutMessage": "You have been logged out.", - "youAreLoggedIn": "You are logged in!", - "email": "Email", - "password": "Password", - "enterEmail": "Enter your email", - "enterPassword": "Enter your password", - "loggingIn": "Logging In...", - "username": "Username", - "enterUsername": "Enter username", - "useEmailInstead": "Login with email", - "forgotPassword": "Forgot your password?", - "logIn": "Log In", - "signingIn": "Signing in...", - "login": "Login", - "or": "Or", - "useMagicLink": "Use magic link instead", - "enterEmailForMagicLink": "Enter your email for magic link", - "sending": "Sending…", - "sendMagicLink": "Send Magic Link", - "cancel": "Cancel", - "dontHaveAccount": "Don't have an account? Sign up", - "home": "Home", - "debug": "Debug", - "signOut": "Sign Out", - "pleaseEnterBoth": "Please enter both email and password", - "pleaseEnterEmail": "Please enter your email address", - "magicLinkSent": "Magic link sent to {{email}}! Check your email and click the link to sign in.", - "passwordResetSent": "Password reset link sent to {{email}}! Check your email and follow the instructions.", - "failedToSignIn": "Failed to sign in with {{provider}}: {{message}}", - "unexpectedError": "Unexpected error: {{message}}", - "accountCreatedSuccess": "Account created successfully! You can now sign in.", - "passwordChangedSuccess": "Password changed successfully! Please sign in with your new password.", - "credentialsUpdated": "Your credentials have been updated. Please sign in again." - }, - "signup": { - "title": "Create an account", - "subtitle": "Join Stirling PDF to get started", - "name": "Name", - "email": "Email", - "password": "Password", - "confirmPassword": "Confirm password", - "enterName": "Enter your name", - "enterEmail": "Enter your email", - "enterPassword": "Enter your password", - "confirmPasswordPlaceholder": "Confirm password", - "or": "or", - "creatingAccount": "Creating Account...", - "signUp": "Sign Up", - "alreadyHaveAccount": "Already have an account? Sign in", - "pleaseFillAllFields": "Please fill in all fields", - "passwordsDoNotMatch": "Passwords do not match", - "passwordTooShort": "Password must be at least 6 characters long", - "invalidEmail": "Please enter a valid email address", - "checkEmailConfirmation": "Check your email for a confirmation link to complete your registration.", - "accountCreatedSuccessfully": "Account created successfully! You can now sign in.", - "unexpectedError": "Unexpected error: {{message}}", - "useEmailInstead": "Use Email Instead", - "nameRequired": "Name is required", - "emailRequired": "Email is required", - "passwordRequired": "Password is required", - "confirmPasswordRequired": "Please confirm your password" - }, - "pdfToSinglePage": { - "title": "PDF To Single Page", - "header": "PDF To Single Page", - "submit": "Convert To Single Page", - "description": "This tool will merge all pages of your PDF into one large single page. The width will remain the same as the original pages, but the height will be the sum of all page heights.", - "filenamePrefix": "single_page", - "files": { - "placeholder": "Select a PDF file in the main view to get started" - }, - "error": { - "failed": "An error occurred while converting to single page." - }, - "results": { - "title": "Single Page Results" - } - }, - "pageExtracter": { - "title": "Extract Pages", - "header": "Extract Pages", - "submit": "Extract", - "placeholder": "(e.g. 1,2,8 or 4,7,12-16 or 2n-1)" - }, - "sanitizePDF": { - "title": "Sanitize PDF", - "header": "Sanitize a PDF file", - "selectText": { - "1": "Remove JavaScript actions", - "2": "Remove embedded files", - "3": "Remove XMP metadata", - "4": "Remove links", - "5": "Remove fonts", - "6": "Remove Document Info Metadata" - }, - "submit": "Sanitize PDF" - }, - "adjustContrast": { - "title": "Adjust Colors/Contrast", - "header": "Adjust Colors/Contrast", - "basic": "Basic Adjustments", - "contrast": "Contrast:", - "brightness": "Brightness:", - "saturation": "Saturation:", - "download": "Download", - "adjustColors": "Adjust Colors", - "blue": "Blue", - "confirm": "Confirm", - "error": { - "failed": "Failed to adjust colors/contrast" - }, - "green": "Green", - "noPreview": "Select a PDF to preview", - "red": "Red", - "results": { - "title": "Adjusted PDF" - } - }, - "compress": { - "title": "Compress", - "desc": "Compress PDFs to reduce their file size.", - "header": "Compress PDF", - "method": { - "title": "Compression Method", - "quality": "Quality", - "filesize": "File Size" - }, - "credit": "This service uses qpdf for PDF Compress/Optimization.", - "grayscale": { - "label": "Apply Grayscale for Compression" - }, - "tooltip": { - "header": { - "title": "Compress Settings Overview" - }, - "description": { - "title": "Description", - "text": "Compression is an easy way to reduce your file size. Pick File Size to enter a target size and have us adjust quality for you. Pick Quality to set compression strength manually." - }, - "qualityAdjustment": { - "title": "Quality Adjustment", - "text": "Drag the slider to adjust the compression strength. Lower values (1-3) preserve quality but result in larger files. Higher values (7-9) shrink the file more but reduce image clarity.", - "bullet1": "Lower values preserve quality", - "bullet2": "Higher values reduce file size" - }, - "grayscale": { - "title": "Grayscale", - "text": "Select this option to convert all images to black and white, which can significantly reduce file size especially for scanned PDFs or image-heavy documents." - } - }, - "error": { - "failed": "An error occurred while compressing the PDF." - }, - "selectText": { - "1": { - "_value": "Compression Settings", - "1": "1-3 PDF compression,
4-6 lite image compression,
7-9 intense image compression Will dramatically reduce image quality" - }, - "2": "Optimization level:", - "4": "Auto mode - Auto adjusts quality to get PDF to exact size", - "5": "Expected PDF Size (e.g. 25MB, 10.8MB, 25KB)" - }, - "submit": "Compress" - }, - "decrypt": { - "passwordPrompt": "This file is password-protected. Please enter the password:", - "cancelled": "Operation cancelled for PDF: {0}", - "noPassword": "No password provided for encrypted PDF: {0}", - "invalidPassword": "Please try again with the correct password.", - "invalidPasswordHeader": "Incorrect password or unsupported encryption for PDF: {0}", - "unexpectedError": "There was an error processing the file. Please try again.", - "serverError": "Server error while decrypting: {0}", - "success": "File decrypted successfully." - }, - "multiTool-advert": { - "message": "This feature is also available in our multi-tool page. Check it out for enhanced page-by-page UI and additional features!" - }, - "pageRemover": { - "title": "Page Remover", - "header": "PDF Page remover", - "pagesToDelete": "Pages to delete (Enter a comma-separated list of page numbers) :", - "submit": "Delete Pages", - "placeholder": "(e.g. 1,2,6 or 1-10,15-30)" - }, - "imageToPDF": { - "title": "Image to PDF", - "header": "Image to PDF", - "submit": "Convert", - "selectLabel": "Image Fit Options", - "fillPage": "Fill Page", - "fitDocumentToImage": "Fit Page to Image", - "maintainAspectRatio": "Maintain Aspect Ratios", - "selectText": { - "2": "Auto rotate PDF", - "3": "Multi file logic (Only enabled if working with multiple images)", - "4": "Merge into single PDF", - "5": "Convert to separate PDFs" - } - }, - "PDFToCSV": { - "title": "PDF to CSV", - "header": "PDF to CSV", - "prompt": "Choose page to extract table", - "submit": "Extract" - }, - "split-by-size-or-count": { - "title": "Split PDF by Size or Count", - "header": "Split PDF by Size or Count", - "type": { - "label": "Select Split Type", - "size": "By Size", - "pageCount": "By Page Count", - "docCount": "By Document Count" - }, - "value": { - "label": "Enter Value", - "placeholder": "Enter size (e.g., 2MB or 3KB) or count (e.g., 5)" - }, - "submit": "Submit" - }, - "printFile": { - "title": "Print File", - "header": "Print File to Printer", - "selectText": { - "1": "Select File to Print", - "2": "Enter Printer Name" - }, - "submit": "Print" - }, - "licenses": { - "nav": "Licenses", - "title": "3rd Party Licenses", - "header": "3rd Party Licenses", - "module": "Module", - "version": "Version", - "license": "License" - }, - "survey": { - "nav": "Survey", - "title": "Stirling-PDF Survey", - "description": "Stirling-PDF has no tracking so we want to hear from our users to improve Stirling-PDF!", - "changes": "Stirling-PDF has changed since the last survey! To find out more please check our blog post here:", - "changes2": "With these changes we are getting paid business support and funding", - "please": "Please consider taking our survey to have input on the future of Stirling-PDF!", - "disabled": "(Survey popup will be disabled in following updates but available at foot of page)", - "button": "Take Survey", - "dontShowAgain": "Don't show again", - "meeting": { - "1": "If you're using Stirling PDF at work, we'd love to speak to you. We're offering technical support sessions in exchange for a 15 minute user discovery session.", - "2": "This is a chance to:", - "3": "Get help with deployment, integrations, or troubleshooting", - "4": "Provide direct feedback on performance, edge cases, and feature gaps", - "5": "Help us refine Stirling PDF for real-world enterprise use", - "6": "If you're interested, you can book time with our team directly. (English speaking only)", - "7": "Looking forward to digging into your use cases and making Stirling PDF even better!", - "notInterested": "Not a business and/or interested in a meeting?", - "button": "Book meeting" - } - }, - "removeImage": { - "title": "Remove image", - "header": "Remove image", - "removeImage": "Remove image", - "submit": "Remove image", - "error": { - "failed": "Failed to remove images from the PDF." - }, - "results": { - "title": "Remove Images Results" - } - }, - "splitByChapters": { - "title": "Split PDF by Chapters", - "header": "Split PDF by Chapters", - "bookmarkLevel": "Bookmark Level", - "includeMetadata": "Include Metadata", - "allowDuplicates": "Allow Duplicates", - "desc": { - "1": "This tool splits a PDF file into multiple PDFs based on its chapter structure.", - "2": "Bookmark Level: Choose the level of bookmarks to use for splitting (0 for top-level, 1 for second-level, etc.).", - "3": "Include Metadata: If checked, the original PDF's metadata will be included in each split PDF.", - "4": "Allow Duplicates: If checked, allows multiple bookmarks on the same page to create separate PDFs." - }, - "submit": "Split PDF" - }, - "fileChooser": { - "click": "Click", - "or": "or", - "dragAndDrop": "Drag & Drop", - "dragAndDropPDF": "Drag & Drop PDF file", - "dragAndDropImage": "Drag & Drop Image file", - "hoveredDragAndDrop": "Drag & Drop file(s) here", - "extractPDF": "Extracting..." - }, - "releases": { - "footer": "Releases", - "title": "Release Notes", - "header": "Release Notes", - "current": { - "version": "Current Release" - }, - "note": "Release notes are only available in English" - }, - "swagger": { - "title": "API Documentation", - "header": "API Documentation", - "desc": "View and test the Stirling PDF API endpoints", - "tags": "api,documentation,swagger,endpoints,development" - }, - "cookieBanner": { - "popUp": { - "title": "How we use Cookies", - "description": { - "1": "We use cookies and other technologies to make Stirling PDF work better for you—helping us improve our tools and keep building features you'll love.", - "2": "If you'd rather not, clicking 'No Thanks' will only enable the essential cookies needed to keep things running smoothly." - }, - "acceptAllBtn": "Okay", - "acceptNecessaryBtn": "No Thanks", - "showPreferencesBtn": "Manage preferences" - }, - "preferencesModal": { - "title": "Consent Preferences Center", - "acceptAllBtn": "Accept all", - "acceptNecessaryBtn": "Reject all", - "savePreferencesBtn": "Save preferences", - "closeIconLabel": "Close modal", - "serviceCounterLabel": "Service|Services", - "subtitle": "Cookie Usage", - "description": { - "1": "Stirling PDF uses cookies and similar technologies to enhance your experience and understand how our tools are used. This helps us improve performance, develop the features you care about, and provide ongoing support to our users.", - "2": "Stirling PDF cannot—and will never—track or access the content of the documents you use.", - "3": "Your privacy and trust are at the core of what we do." - }, - "necessary": { - "title": { - "1": "Strictly Necessary Cookies", - "2": "Always Enabled" - }, - "description": "These cookies are essential for the website to function properly. They enable core features like setting your privacy preferences, logging in, and filling out forms—which is why they can't be turned off." - }, - "analytics": { - "title": "Analytics", - "description": "These cookies help us understand how our tools are being used, so we can focus on building the features our community values most. Rest assured—Stirling PDF cannot and will never track the content of the documents you work with." - } - }, - "services": { - "posthog": "PostHog Analytics", - "scarf": "Scarf Pixel" - } - }, - "removeMetadata": { - "submit": "Remove Metadata" - }, - "sidebar": { - "toggle": "Toggle Sidebar" - }, - "theme": { - "toggle": "Toggle Theme" - }, - "view": { - "viewer": "Viewer", - "pageEditor": "Page Editor", - "fileManager": "File Manager" - }, - "pageEditor": { - "title": "Page Editor", - "save": "Save Changes", - "noPdfLoaded": "No PDF loaded. Please upload a PDF to edit.", - "rotatedLeft": "Rotated left:", - "rotatedRight": "Rotated right:", - "deleted": "Deleted:", - "movedLeft": "Moved left:", - "movedRight": "Moved right:", - "splitAt": "Split at:", - "insertedPageBreak": "Inserted page break at:", - "addFileNotImplemented": "Add file not implemented in demo", - "closePdf": "Close PDF", - "reset": "Reset Changes", - "zoomIn": "Zoom In", - "zoomOut": "Zoom Out", - "fitToWidth": "Fit to Width", - "actualSize": "Actual Size" - }, - "viewer": { - "firstPage": "First Page", - "lastPage": "Last Page", - "previousPage": "Previous Page", - "nextPage": "Next Page", - "zoomIn": "Zoom In", - "zoomOut": "Zoom Out", - "singlePageView": "Single Page View", - "dualPageView": "Dual Page View" - }, - "rightRail": { - "closeSelected": "Close Selected Files", - "selectAll": "Select All", - "deselectAll": "Deselect All", - "selectByNumber": "Select by Page Numbers", - "deleteSelected": "Delete Selected Pages", - "closePdf": "Close PDF", - "exportAll": "Export PDF", - "downloadSelected": "Download Selected Files", - "downloadAll": "Download All", - "toggleTheme": "Toggle Theme", - "language": "Language", - "search": "Search PDF", - "panMode": "Pan Mode", - "rotateLeft": "Rotate Left", - "rotateRight": "Rotate Right", - "toggleSidebar": "Toggle Sidebar", - "exportSelected": "Export Selected Pages", - "toggleAnnotations": "Toggle Annotations Visibility", - "annotationMode": "Toggle Annotation Mode", - "draw": "Draw", - "save": "Save", - "saveChanges": "Save Changes" - }, - "search": { - "title": "Search PDF", - "placeholder": "Enter search term...", - "noResults": "No results found", - "searching": "Searching..." - }, - "guestBanner": { - "title": "You're using Stirling PDF as a guest!", - "message": "Create a free account to save your work, access more features, and support the project.", - "dismiss": "Dismiss banner", - "signUp": "Sign Up Free" - }, - "toolPicker": { - "searchPlaceholder": "Search tools...", - "noToolsFound": "No tools found", - "allTools": "ALL TOOLS", - "quickAccess": "QUICK ACCESS", - "categories": { - "standardTools": "Standard Tools", - "advancedTools": "Advanced Tools", - "recommendedTools": "Recommended Tools" - }, - "subcategories": { - "signing": "Signing", - "documentSecurity": "Document Security", - "verification": "Verification", - "documentReview": "Document Review", - "pageFormatting": "Page Formatting", - "extraction": "Extraction", - "removal": "Removal", - "automation": "Automation", - "general": "General", - "advancedFormatting": "Advanced Formatting", - "developerTools": "Developer Tools" - } - }, - "quickAccess": { - "read": "Read", - "sign": "Sign", - "automate": "Automate", - "files": "Files", - "activity": "Activity", - "help": "Help", - "account": "Account", - "config": "Config", - "settings": "Settings", - "adminSettings": "Admin Settings", - "allTools": "Tools", - "reader": "Reader", - "helpMenu": { - "toolsTour": "Tools Tour", - "toolsTourDesc": "Learn what the tools can do", - "adminTour": "Admin Tour", - "adminTourDesc": "Explore admin settings & features" - } - }, - "admin": { - "error": "Error", - "success": "Success", - "expand": "Expand", - "close": "Close", - "status": { - "active": "Active", - "inactive": "Inactive" - }, - "settings": { - "title": "Admin Settings", - "workspace": "Workspace", - "fetchError": "Failed to load settings", - "saveError": "Failed to save settings", - "saved": "Settings saved successfully", - "saveSuccess": "Settings saved successfully", - "save": "Save Changes", - "restartRequired": "Restart Required", - "loginRequired": "Login mode must be enabled to modify admin settings", - "loginDisabled": { - "title": "Login Mode Required", - "message": "Login mode must be enabled to modify admin settings. Please set SECURITY_ENABLELOGIN=true in your environment or security.enableLogin: true in settings.yml, then restart the server.", - "readOnly": "The settings below show example values for reference. Enable login mode to view and edit actual configuration." - }, - "restart": { - "title": "Restart Required", - "message": "Settings have been saved successfully. A server restart is required for the changes to take effect.", - "question": "Would you like to restart the server now or later?", - "now": "Restart Now", - "later": "Restart Later" - }, - "restarting": "Restarting Server", - "restartingMessage": "The server is restarting. Please wait a moment...", - "restartError": "Failed to restart server. Please restart manually.", - "general": { - "title": "System Settings", - "description": "Configure system-wide application settings including branding and default behavior.", - "ui": "User Interface", - "system": "System", - "appName": { - "label": "Application Name", - "description": "The name displayed in the browser tab and home page" - }, - "appNameNavbar": { - "label": "Navbar Brand", - "description": "The name displayed in the navigation bar" - }, - "homeDescription": { - "label": "Home Description", - "description": "The description text shown on the home page" - }, - "defaultLocale": { - "label": "Default Locale", - "description": "The default language for new users (e.g., en_US, es_ES)" - }, - "fileUploadLimit": { - "label": "File Upload Limit", - "description": "Maximum file upload size (e.g., 100MB, 1GB)" - }, - "showUpdate": { - "label": "Show Update Notifications", - "description": "Display notifications when a new version is available" - }, - "showUpdateOnlyAdmin": { - "label": "Show Updates to Admins Only", - "description": "Restrict update notifications to admin users only" - }, - "customHTMLFiles": { - "label": "Custom HTML Files", - "description": "Allow serving custom HTML files from the customFiles directory" - }, - "languages": { - "label": "Available Languages", - "description": "Languages that users can select from (leave empty to enable all languages)" - }, - "customMetadata": { - "label": "Custom Metadata", - "autoUpdate": { - "label": "Auto Update Metadata", - "description": "Automatically update PDF metadata on all processed documents" - }, - "author": { - "label": "Default Author", - "description": "Default author for PDF metadata (e.g., username)" - }, - "creator": { - "label": "Default Creator", - "description": "Default creator for PDF metadata" - }, - "producer": { - "label": "Default Producer", - "description": "Default producer for PDF metadata" - } - }, - "logoStyle": { - "label": "Logo Style", - "description": "Choose between the modern minimalist logo or the classic S icon", - "classic": "Classic", - "modern": "Modern" - }, - "customPaths": { - "label": "Custom Paths", - "description": "Configure custom file system paths for pipeline processing and external tools", - "pipeline": { - "label": "Pipeline Directories", - "watchedFoldersDir": { - "label": "Watched Folders Directory", - "description": "Directory where pipeline monitors for incoming PDFs (leave empty for default: /pipeline/watchedFolders)" - }, - "finishedFoldersDir": { - "label": "Finished Folders Directory", - "description": "Directory where processed PDFs are outputted (leave empty for default: /pipeline/finishedFolders)" - } - }, - "operations": { - "label": "External Tool Paths", - "weasyprint": { - "label": "WeasyPrint Executable", - "description": "Path to WeasyPrint executable for HTML to PDF conversion (leave empty for default: /opt/venv/bin/weasyprint)" - }, - "unoconvert": { - "label": "Unoconvert Executable", - "description": "Path to LibreOffice unoconvert for document conversions (leave empty for default: /opt/venv/bin/unoconvert)" - } - } - } - }, - "security": { - "title": "Security", - "description": "Configure authentication, login behavior, and security policies.", - "ssoNotice": { - "title": "Looking for SSO/SAML settings?", - "message": "OAuth2 and SAML2 authentication providers have been moved to the Connections menu for easier management." - }, - "authentication": "Authentication", - "enableLogin": { - "label": "Enable Login", - "description": "Require users to log in before accessing the application" - }, - "loginMethod": { - "label": "Login Method", - "description": "The authentication method to use for user login", - "all": "All Methods", - "normal": "Username/Password Only", - "oauth2": "OAuth2 Only", - "saml2": "SAML2 Only" - }, - "loginAttemptCount": { - "label": "Login Attempt Limit", - "description": "Maximum number of failed login attempts before account lockout" - }, - "loginResetTimeMinutes": { - "label": "Login Reset Time (minutes)", - "description": "Time before failed login attempts are reset" - }, - "csrfDisabled": { - "label": "Disable CSRF Protection", - "description": "Disable Cross-Site Request Forgery protection (not recommended)" - }, - "initialLogin": { - "label": "Initial Login", - "username": { - "label": "Initial Username", - "description": "The username for the initial admin account" - }, - "password": { - "label": "Initial Password", - "description": "The password for the initial admin account" - } - }, - "jwt": { - "label": "JWT Configuration", - "secureCookie": { - "label": "Secure Cookie", - "description": "Require HTTPS for JWT cookies (recommended for production)" - }, - "keyRetentionDays": { - "label": "Key Retention Days", - "description": "Number of days to retain old JWT keys for verification" - }, - "persistence": { - "label": "Enable Key Persistence", - "description": "Store JWT keys persistently to survive server restarts" - }, - "enableKeyRotation": { - "label": "Enable Key Rotation", - "description": "Automatically rotate JWT signing keys periodically" - }, - "enableKeyCleanup": { - "label": "Enable Key Cleanup", - "description": "Automatically remove expired JWT keys" - } - }, - "audit": { - "label": "Audit Logging", - "enabled": { - "label": "Enable Audit Logging", - "description": "Track user actions and system events for compliance and security monitoring" - }, - "level": { - "label": "Audit Level", - "description": "0=OFF, 1=BASIC, 2=STANDARD, 3=VERBOSE" - }, - "retentionDays": { - "label": "Audit Retention (days)", - "description": "Number of days to retain audit logs" - } - }, - "htmlUrlSecurity": { - "label": "HTML URL Security", - "description": "Configure URL access restrictions for HTML processing to prevent SSRF attacks", - "enabled": { - "label": "Enable URL Security", - "description": "Enable URL security restrictions for HTML to PDF conversions" - }, - "level": { - "label": "Security Level", - "description": "MAX: whitelist only, MEDIUM: block internal networks, OFF: no restrictions", - "max": "Maximum (Whitelist Only)", - "medium": "Medium (Block Internal)", - "off": "Off (No Restrictions)" - }, - "advanced": "Advanced Settings", - "allowedDomains": { - "label": "Allowed Domains (Whitelist)", - "description": "One domain per line (e.g., cdn.example.com). Only these domains allowed when level is MAX" - }, - "blockedDomains": { - "label": "Blocked Domains (Blacklist)", - "description": "One domain per line (e.g., malicious.com). Additional domains to block" - }, - "internalTlds": { - "label": "Internal TLDs", - "description": "One TLD per line (e.g., .local, .internal). Block domains with these TLD patterns" - }, - "networkBlocking": "Network Blocking", - "blockPrivateNetworks": { - "label": "Block Private Networks", - "description": "Block RFC 1918 private networks (10.x.x.x, 192.168.x.x, 172.16-31.x.x)" - }, - "blockLocalhost": { - "label": "Block Localhost", - "description": "Block localhost and loopback addresses (127.x.x.x, ::1)" - }, - "blockLinkLocal": { - "label": "Block Link-Local Addresses", - "description": "Block link-local addresses (169.254.x.x, fe80::/10)" - }, - "blockCloudMetadata": { - "label": "Block Cloud Metadata Endpoints", - "description": "Block cloud provider metadata endpoints (169.254.169.254)" - } - } - }, - "connections": { - "title": "Connections", - "description": "Configure external authentication providers like OAuth2 and SAML.", - "linkedServices": "Linked Services", - "unlinkedServices": "Unlinked Services", - "connect": "Connect", - "disconnect": "Disconnect", - "disconnected": "Provider disconnected successfully", - "disconnectError": "Failed to disconnect provider", - "ssoAutoLogin": { - "label": "SSO Auto Login", - "enable": "Enable SSO Auto Login", - "description": "Automatically redirect to SSO login when authentication is required" - }, - "oauth2": { - "label": "OAuth2", - "enabled": { - "label": "Enable OAuth2", - "description": "Allow users to authenticate using OAuth2 providers" - }, - "provider": { - "label": "Provider", - "description": "The OAuth2 provider to use for authentication" - }, - "issuer": { - "label": "Issuer URL", - "description": "The OAuth2 provider issuer URL" - }, - "clientId": { - "label": "Client ID", - "description": "The OAuth2 client ID from your provider" - }, - "clientSecret": { - "label": "Client Secret", - "description": "The OAuth2 client secret from your provider" - }, - "useAsUsername": { - "label": "Use as Username", - "description": "The OAuth2 claim to use as the username (e.g., email, sub)" - }, - "autoCreateUser": { - "label": "Auto Create Users", - "description": "Automatically create user accounts on first OAuth2 login" - }, - "blockRegistration": { - "label": "Block Registration", - "description": "Prevent new user registration via OAuth2" - }, - "scopes": { - "label": "OAuth2 Scopes", - "description": "Comma-separated list of OAuth2 scopes to request (e.g., openid, profile, email)" - } - }, - "saml2": { - "label": "SAML2", - "enabled": { - "label": "Enable SAML2", - "description": "Allow users to authenticate using SAML2 providers" - }, - "provider": { - "label": "Provider", - "description": "The SAML2 provider name" - }, - "registrationId": { - "label": "Registration ID", - "description": "The SAML2 registration identifier" - }, - "autoCreateUser": { - "label": "Auto Create Users", - "description": "Automatically create user accounts on first SAML2 login" - }, - "blockRegistration": { - "label": "Block Registration", - "description": "Prevent new user registration via SAML2" - } - } - }, - "database": { - "title": "Database", - "description": "Configure custom database connection settings for enterprise deployments.", - "configuration": "Database Configuration", - "enableCustom": { - "label": "Enable Custom Database", - "description": "Use your own custom database configuration instead of the default embedded database" - }, - "customUrl": { - "label": "Custom Database URL", - "description": "Full JDBC connection string (e.g., jdbc:postgresql://localhost:5432/postgres). If provided, individual connection settings below are not used." - }, - "type": { - "label": "Database Type", - "description": "Type of database (not used if custom URL is provided)" - }, - "hostName": { - "label": "Host Name", - "description": "Database server hostname (not used if custom URL is provided)" - }, - "port": { - "label": "Port", - "description": "Database server port (not used if custom URL is provided)" - }, - "name": { - "label": "Database Name", - "description": "Name of the database (not used if custom URL is provided)" - }, - "username": { - "label": "Username", - "description": "Database authentication username" - }, - "password": { - "label": "Password", - "description": "Database authentication password" - } - }, - "privacy": { - "title": "Privacy", - "description": "Configure privacy and data collection settings.", - "analytics": "Analytics & Tracking", - "enableAnalytics": { - "label": "Enable Analytics", - "description": "Collect anonymous usage analytics to help improve the application" - }, - "metricsEnabled": { - "label": "Enable Metrics", - "description": "Enable collection of performance and usage metrics. Provides API endpoint for admins to access metrics data" - }, - "searchEngine": "Search Engine Visibility", - "googleVisibility": { - "label": "Google Visibility", - "description": "Allow search engines to index this application" - } - }, - "advanced": { - "title": "Advanced", - "description": "Configure advanced features and experimental functionality.", - "features": "Feature Flags", - "processing": "Processing", - "endpoints": { - "label": "Endpoints", - "manage": "Manage API Endpoints", - "description": "Endpoint management is configured via YAML. See documentation for details on enabling/disabling specific endpoints." - }, - "enableAlphaFunctionality": { - "label": "Enable Alpha Features", - "description": "Enable experimental and alpha-stage features (may be unstable)" - }, - "enableUrlToPDF": { - "label": "Enable URL to PDF", - "description": "Allow conversion of web pages to PDF documents" - }, - "maxDPI": { - "label": "Maximum DPI", - "description": "Maximum DPI for image processing (0 = unlimited)" - }, - "tessdataDir": { - "label": "Tessdata Directory", - "description": "Path to the tessdata directory for OCR language files" - }, - "disableSanitize": { - "label": "Disable HTML Sanitization", - "description": "WARNING: Security risk - disabling HTML sanitization can lead to XSS vulnerabilities" - }, - "tempFileManagement": { - "label": "Temp File Management", - "description": "Configure temporary file storage and cleanup behavior", - "baseTmpDir": { - "label": "Base Temp Directory", - "description": "Base directory for temporary files (leave empty for default: java.io.tmpdir/stirling-pdf)" - }, - "libreofficeDir": { - "label": "LibreOffice Temp Directory", - "description": "Directory for LibreOffice temp files (leave empty for default: baseTmpDir/libreoffice)" - }, - "systemTempDir": { - "label": "System Temp Directory", - "description": "System temp directory to clean (only used if cleanupSystemTemp is enabled)" - }, - "prefix": { - "label": "Temp File Prefix", - "description": "Prefix for temp file names" - }, - "maxAgeHours": { - "label": "Max Age (hours)", - "description": "Maximum age in hours before temp files are cleaned up" - }, - "cleanupIntervalMinutes": { - "label": "Cleanup Interval (minutes)", - "description": "How often to run cleanup (in minutes)" - }, - "startupCleanup": { - "label": "Startup Cleanup", - "description": "Clean up old temp files on application startup" - }, - "cleanupSystemTemp": { - "label": "Cleanup System Temp", - "description": "Whether to clean broader system temp directory (use with caution)" - } - }, - "processExecutor": { - "label": "Process Executor Limits", - "description": "Configure session limits and timeouts for each process executor", - "sessionLimit": { - "label": "Session Limit", - "description": "Maximum concurrent instances" - }, - "timeout": { - "label": "Timeout (minutes)", - "description": "Maximum execution time" - }, - "libreOffice": "LibreOffice", - "pdfToHtml": "PDF to HTML", - "qpdf": "QPDF", - "tesseract": "Tesseract OCR", - "pythonOpenCv": "Python OpenCV", - "weasyPrint": "WeasyPrint", - "installApp": "Install App", - "calibre": "Calibre", - "ghostscript": "Ghostscript", - "ocrMyPdf": "OCRmyPDF" - } - }, - "mail": { - "title": "Mail Server", - "description": "Configure SMTP settings for sending email notifications.", - "smtp": "SMTP Configuration", - "enabled": { - "label": "Enable Mail", - "description": "Enable email notifications and SMTP functionality" - }, - "host": { - "label": "SMTP Host", - "description": "The hostname or IP address of your SMTP server" - }, - "port": { - "label": "SMTP Port", - "description": "The port number for SMTP connection (typically 25, 465, or 587)" - }, - "username": { - "label": "SMTP Username", - "description": "Username for SMTP authentication" - }, - "password": { - "label": "SMTP Password", - "description": "Password for SMTP authentication" - }, - "from": { - "label": "From Address", - "description": "The email address to use as the sender" - }, - "enableInvites": { - "label": "Enable Email Invites", - "description": "Allow admins to invite users via email with auto-generated passwords" - }, - "frontendUrl": { - "label": "Frontend URL", - "description": "Base URL for frontend (e.g. https://pdf.example.com). Used for generating invite links in emails. Leave empty to use backend URL." - } - }, - "legal": { - "title": "Legal Documents", - "description": "Configure links to legal documents and policies.", - "disclaimer": { - "title": "Legal Responsibility Warning", - "message": "By customizing these legal documents, you assume full responsibility for ensuring compliance with all applicable laws and regulations, including but not limited to GDPR and other EU data protection requirements. Only modify these settings if: (1) you are operating a personal/private instance, (2) you are outside EU jurisdiction and understand your local legal obligations, or (3) you have obtained proper legal counsel and accept sole responsibility for all user data and legal compliance. Stirling-PDF and its developers assume no liability for your legal obligations." - }, - "termsAndConditions": { - "label": "Terms and Conditions", - "description": "URL or filename to terms and conditions" - }, - "privacyPolicy": { - "label": "Privacy Policy", - "description": "URL or filename to privacy policy" - }, - "accessibilityStatement": { - "label": "Accessibility Statement", - "description": "URL or filename to accessibility statement" - }, - "cookiePolicy": { - "label": "Cookie Policy", - "description": "URL or filename to cookie policy" - }, - "impressum": { - "label": "Impressum", - "description": "URL or filename to impressum (required in some jurisdictions)" - } - }, - "premium": { - "title": "Premium & Enterprise", - "description": "Configure your premium or enterprise license key.", - "license": "License Configuration", - "key": { - "label": "License Key", - "description": "Enter your premium or enterprise license key" - }, - "enabled": { - "label": "Enable Premium Features", - "description": "Enable license key checks for pro/enterprise features" - }, - "movedFeatures": { - "title": "Premium Features Distributed", - "message": "Premium and Enterprise features are now organized in their respective sections:" - } - }, - "features": { - "title": "Features", - "description": "Configure optional features and functionality.", - "serverCertificate": { - "label": "Server Certificate", - "description": "Configure server-side certificate generation for \"Sign with Stirling-PDF\" functionality", - "enabled": { - "label": "Enable Server Certificate", - "description": "Enable server-side certificate for \"Sign with Stirling-PDF\" option" - }, - "organizationName": { - "label": "Organization Name", - "description": "Organization name for generated certificates" - }, - "validity": { - "label": "Certificate Validity (days)", - "description": "Number of days the certificate will be valid" - }, - "regenerateOnStartup": { - "label": "Regenerate on Startup", - "description": "Generate new certificate on each application startup" - } - } - }, - "endpoints": { - "title": "API Endpoints", - "description": "Control which API endpoints and endpoint groups are available.", - "management": "Endpoint Management", - "toRemove": { - "label": "Disabled Endpoints", - "description": "Select individual endpoints to disable" - }, - "groupsToRemove": { - "label": "Disabled Endpoint Groups", - "description": "Select endpoint groups to disable" - }, - "note": "Note: Disabling endpoints restricts API access but does not remove UI components. Restart required for changes to take effect." - } - } - }, - "fileUpload": { - "selectFile": "Select a file", - "selectFiles": "Select files", - "selectPdfToView": "Select a PDF to view", - "selectPdfToEdit": "Select a PDF to edit", - "chooseFromStorage": "Choose a file from storage or upload a new PDF", - "chooseFromStorageMultiple": "Choose files from storage or upload new PDFs", - "loadFromStorage": "Load from Storage", - "filesAvailable": "files available", - "loading": "Loading...", - "or": "or", - "dropFileHere": "Drop file here or click to upload", - "dropFilesHere": "Drop files here or click the upload button", - "pdfFilesOnly": "PDF files only", - "supportedFileTypes": "Supported file types", - "upload": "Upload", - "uploadFile": "Upload File", - "uploadFiles": "Upload Files", - "noFilesInStorage": "No files available in storage. Upload some files first.", - "selectFromStorage": "Select from Storage", - "backToTools": "Back to Tools", - "addFiles": "Add Files" - }, - "fileEditor": { - "addFiles": "Add Files" - }, - "fileManager": { - "title": "Upload PDF Files", - "subtitle": "Add files to your storage for easy access across tools", - "filesSelected": "files selected", - "clearSelection": "Clear Selection", - "openInFileEditor": "Open in File Editor", - "uploadError": "Failed to upload some files.", - "failedToOpen": "Failed to open file. It may have been removed from storage.", - "failedToLoad": "Failed to load file to active set.", - "storageCleared": "Browser cleared storage. Files have been removed. Please re-upload.", - "clearAll": "Clear All", - "reloadFiles": "Reload Files", - "dragDrop": "Drag & Drop files here", - "clickToUpload": "Click to upload files", - "selectedFiles": "Selected Files", - "storage": "Storage", - "filesStored": "files stored", - "storageError": "Storage error occurred", - "storageLow": "Storage is running low. Consider removing old files.", - "supportMessage": "Powered by browser database storage for unlimited capacity", - "noFileSelected": "No files selected", - "showHistory": "Show History", - "hideHistory": "Hide History", - "fileHistory": "File History", - "loadingHistory": "Loading History...", - "lastModified": "Last Modified", - "toolChain": "Tools Applied", - "restore": "Restore", - "unzip": "Unzip", - "searchFiles": "Search files...", - "recent": "Recent", - "localFiles": "Local Files", - "googleDrive": "Google Drive", - "googleDriveShort": "Drive", - "myFiles": "My Files", - "noRecentFiles": "No recent files found", - "googleDriveNotAvailable": "Google Drive integration not available", - "openFiles": "Open Files", - "openFile": "Open File", - "details": "File Details", - "fileName": "Name", - "fileFormat": "Format", - "fileSize": "Size", - "fileVersion": "Version", - "totalSelected": "Total Selected", - "dropFilesHere": "Drop files here", - "selectAll": "Select All", - "deselectAll": "Deselect All", - "deleteSelected": "Delete Selected", - "downloadSelected": "Download Selected", - "selectedCount": "{{count}} selected", - "download": "Download", - "delete": "Delete", - "unsupported": "Unsupported", - "addToUpload": "Add to Upload", - "deleteAll": "Delete All", - "loadingFiles": "Loading files...", - "noFiles": "No files available", - "noFilesFound": "No files found matching your search", - "openInPageEditor": "Open in Page Editor", - "showAll": "Show All", - "sortByDate": "Sort by Date", - "sortByName": "Sort by Name", - "sortBySize": "Sort by Size" - }, - "storage": { - "temporaryNotice": "Files are stored temporarily in your browser and may be cleared automatically", - "storageLimit": "Storage limit", - "storageUsed": "Temporary Storage used", - "storageFull": "Storage is nearly full. Consider removing some files.", - "fileTooLarge": "File too large. Maximum size per file is", - "storageQuotaExceeded": "Storage quota exceeded. Please remove some files before uploading more.", - "approximateSize": "Approximate size" - }, - "sanitize": { - "title": "Sanitize", - "desc": "Remove potentially harmful elements from PDF files.", - "submit": "Sanitize PDF", - "completed": "Sanitization completed successfully", - "error": { - "generic": "Sanitization failed", - "failed": "An error occurred while sanitizing the PDF." - }, - "filenamePrefix": "sanitized", - "sanitizationResults": "Sanitization Results", - "steps": { - "files": "Files", - "settings": "Settings", - "results": "Results" - }, - "files": { - "placeholder": "Select a PDF file in the main view to get started" - }, - "options": { - "title": "Sanitization Options", - "note": "Select the elements you want to remove from the PDF. At least one option must be selected.", - "removeJavaScript": { - "label": "Remove JavaScript", - "desc": "Remove JavaScript actions and scripts from the PDF" - }, - "removeEmbeddedFiles": { - "label": "Remove Embedded Files", - "desc": "Remove any files embedded within the PDF" - }, - "removeXMPMetadata": { - "label": "Remove XMP Metadata", - "desc": "Remove XMP metadata from the PDF" - }, - "removeMetadata": { - "label": "Remove Document Metadata", - "desc": "Remove document information metadata (title, author, etc.)" - }, - "removeLinks": { - "label": "Remove Links", - "desc": "Remove external links and launch actions from the PDF" - }, - "removeFonts": { - "label": "Remove Fonts", - "desc": "Remove embedded fonts from the PDF" - } - } - }, - "addPassword": { - "title": "Add Password", - "desc": "Encrypt your PDF document with a password.", - "completed": "Password protection applied", - "submit": "Encrypt", - "filenamePrefix": "encrypted", - "error": { - "failed": "An error occurred while encrypting the PDF." - }, - "passwords": { - "stepTitle": "Passwords & Encryption", - "completed": "Passwords configured", - "user": { - "label": "User Password", - "placeholder": "Enter user password" - }, - "owner": { - "label": "Owner Password", - "placeholder": "Enter owner password" - } - }, - "encryption": { - "keyLength": { - "label": "Encryption Key Length", - "40bit": "40-bit (Low)", - "128bit": "128-bit (Standard)", - "256bit": "256-bit (High)" - } - }, - "results": { - "title": "Encrypted PDFs" - }, - "tooltip": { - "header": { - "title": "Password Protection Overview" - }, - "passwords": { - "title": "Password Types", - "text": "User passwords restrict opening the document, while owner passwords control what can be done with the document once opened. You can set both or just one.", - "bullet1": "User Password: Required to open the PDF", - "bullet2": "Owner Password: Controls document permissions (not supported by all PDF viewers)" - }, - "encryption": { - "title": "Encryption Levels", - "text": "Higher encryption levels provide better security but may not be supported by older PDF viewers.", - "bullet1": "40-bit: Basic security, compatible with older viewers", - "bullet2": "128-bit: Standard security, widely supported", - "bullet3": "256-bit: Maximum security, requires modern viewers" - }, - "permissions": { - "title": "Change Permissions", - "text": "These permissions control what users can do with the PDF. Most effective when combined with an owner password." - } - } - }, - "changePermissions": { - "title": "Change Permissions", - "desc": "Change document restrictions and permissions.", - "completed": "Permissions changed", - "submit": "Change Permissions", - "error": { - "failed": "An error occurred while changing PDF permissions." - }, - "permissions": { - "preventAssembly": { - "label": "Prevent assembly of document" - }, - "preventExtractContent": { - "label": "Prevent content extraction" - }, - "preventExtractForAccessibility": { - "label": "Prevent extraction for accessibility" - }, - "preventFillInForm": { - "label": "Prevent filling in form" - }, - "preventModify": { - "label": "Prevent modification" - }, - "preventModifyAnnotations": { - "label": "Prevent annotation modification" - }, - "preventPrinting": { - "label": "Prevent printing" - }, - "preventPrintingFaithful": { - "label": "Prevent printing different formats" - } - }, - "results": { - "title": "Modified PDFs" - }, - "tooltip": { - "header": { - "title": "Change Permissions" - }, - "description": { - "text": "Changes document permissions, allowing/disallowing access to different features in PDF readers." - }, - "warning": { - "text": "To make these permissions unchangeable, use the Add Password tool to set an owner password." - } - } - }, - "removePassword": { - "title": "Remove Password", - "desc": "Remove password protection from your PDF document.", - "tags": "secure,Decrypt,security,unpassword,delete password", - "password": { - "stepTitle": "Remove Password", - "label": "Current Password", - "placeholder": "Enter current password", - "completed": "Password configured" - }, - "filenamePrefix": "decrypted", - "error": { - "failed": "An error occurred while removing the password from the PDF." - }, - "tooltip": { - "description": "Removing password protection requires the password that was used to encrypt the PDF. This will decrypt the document, making it accessible without a password." - }, - "submit": "Remove Password", - "results": { - "title": "Decrypted PDFs" - } - }, - "automate": { - "title": "Automate", - "desc": "Build multi-step workflows by chaining together PDF actions. Ideal for recurring tasks.", - "invalidStep": "Invalid step", - "files": { - "placeholder": "Select files to process with this automation" - }, - "selection": { - "title": "Automation Selection", - "saved": { - "title": "Saved" - }, - "createNew": { - "title": "Create New Automation" - }, - "suggested": { - "title": "Suggested" - } - }, - "creation": { - "createTitle": "Create Automation", - "editTitle": "Edit Automation", - "intro": "Automations run tools sequentially. To get started, add tools in the order you want them to run.", - "name": { - "label": "Automation Name", - "placeholder": "My Automation" - }, - "description": { - "label": "Description (optional)", - "placeholder": "Describe what this automation does..." - }, - "tools": { - "selectTool": "Select a tool...", - "selected": "Selected Tools", - "remove": "Remove tool", - "configure": "Configure tool", - "notConfigured": "! Not Configured", - "addTool": "Add Tool", - "add": "Add a tool..." - }, - "save": "Save Automation", - "unsavedChanges": { - "title": "Unsaved Changes", - "message": "You have unsaved changes. Are you sure you want to go back? All changes will be lost.", - "cancel": "Cancel", - "confirm": "Go Back" - }, - "icon": { - "label": "Icon" - } - }, - "run": { - "title": "Run Automation" - }, - "sequence": { - "unnamed": "Unnamed Automation", - "steps": "{{count}} steps", - "running": "Running Automation...", - "run": "Run Automation", - "finish": "Finish" - }, - "reviewTitle": "Automation Results", - "config": { - "loading": "Loading tool configuration...", - "noSettings": "This tool does not have configurable settings.", - "title": "Configure {{toolName}}", - "description": "Configure the settings for this tool. These settings will be applied when the automation runs.", - "cancel": "Cancel", - "save": "Save Configuration" - }, - "copyToSaved": "Copy to Saved" - }, - "automation": { - "suggested": { - "securePdfIngestion": "Secure PDF Ingestion", - "securePdfIngestionDesc": "Comprehensive PDF processing workflow that sanitizes documents, applies OCR with cleanup, converts to PDF/A format for long-term archival, and optimizes file size.", - "emailPreparation": "Email Preparation", - "emailPreparationDesc": "Optimizes PDFs for email distribution by compressing files, splitting large documents into 20MB chunks for email compatibility, and removing metadata for privacy.", - "secureWorkflow": "Security Workflow", - "secureWorkflowDesc": "Secures PDF documents by removing potentially malicious content like JavaScript and embedded files, then adds password protection to prevent unauthorized access. Password is set to 'password' by default.", - "processImages": "Process Images", - "processImagesDesc": "Converts multiple image files into a single PDF document, then applies OCR technology to extract searchable text from the images." - } - }, - "common": { - "previous": "Previous", - "next": "Next", - "collapse": "Collapse", - "expand": "Expand", - "collapsed": "collapsed", - "lines": "lines", - "copy": "Copy", - "copied": "Copied!", - "refresh": "Refresh", - "retry": "Retry", - "remaining": "remaining", - "used": "used", - "available": "available", - "cancel": "Cancel", - "preview": "Preview" - }, - "config": { - "overview": { - "title": "Application Configuration", - "description": "Current application settings and configuration details." - }, - "account": { - "overview": { - "title": "Account Settings", - "manageAccountPreferences": "Manage your account preferences", - "guestDescription": "You are signed in as a guest. Consider upgrading your account above." - }, - "upgrade": { - "title": "Upgrade Guest Account", - "description": "Link your account to preserve your history and access more features!", - "socialLogin": "Upgrade with Social Account", - "linkWith": "Link with", - "emailPassword": "or enter your email & password", - "email": "Email", - "emailPlaceholder": "Enter your email", - "password": "Password (optional)", - "passwordPlaceholder": "Set a password", - "passwordNote": "Leave empty to use email verification only", - "upgradeButton": "Upgrade Account" - } - }, - "apiKeys": { - "intro": "Use your API key to programmatically access Stirling PDF's processing capabilities.", - "docsTitle": "API Documentation", - "docsDescription": "Learn more about integrating with Stirling PDF:", - "docsLink": "API Documentation", - "schemaLink": "API Schema Reference", - "usage": "Include this key in the X-API-KEY header with all API requests.", - "description": "Your API key for accessing Stirling's suite of PDF tools. Copy it to your project or refresh to generate a new one.", - "publicKeyAriaLabel": "Public API key", - "copyKeyAriaLabel": "Copy API key", - "refreshAriaLabel": "Refresh API key", - "includedCredits": "Included credits", - "purchasedCredits": "Purchased credits", - "totalCredits": "Total Credits", - "chartAriaLabel": "Credits usage: included {{includedUsed}} of {{includedTotal}}, purchased {{purchasedUsed}} of {{purchasedTotal}}", - "nextReset": "Next Reset", - "lastApiUse": "Last API Use", - "overlayMessage": "Generate a key to see credits and available credits", - "label": "API Key", - "guestInfo": "Guest users do not receive API keys. Create an account to get an API key you can use in your applications.", - "goToAccount": "Go to Account", - "refreshModal": { - "title": "Refresh API Keys", - "warning": "⚠️ Warning: This action will generate new API keys and make your previous keys invalid.", - "impact": "Any applications or services currently using these keys will stop working until you update them with the new keys.", - "confirmPrompt": "Are you sure you want to continue?", - "confirmCta": "Refresh Keys" - }, - "generateError": "We couldn't generate your API key." - } - }, - "AddAttachmentsRequest": { - "attachments": "Select Attachments", - "info": "Select files to attach to your PDF. These files will be embedded and accessible through the PDF's attachment panel.", - "selectFiles": "Select Files to Attach", - "placeholder": "Choose files...", - "addMoreFiles": "Add more files...", - "selectedFiles": "Selected Files", - "submit": "Add Attachments", - "results": { - "title": "Attachment Results" - }, - "error": { - "failed": "Add attachments operation failed" - } - }, - "termsAndConditions": "Terms & Conditions", - "logOut": "Log out", - "addAttachments": { - "error": { - "failed": "An error occurred while adding attachments to the PDF." - } - }, - "autoRename": { - "description": "This tool will automatically rename PDF files based on their content. It analyzes the document to find the most suitable title from the text." - }, - "customPosition": "Custom Position", - "details": "Details", - "downloadUnavailable": "Download unavailable for this item", - "invalidUndoData": "Cannot undo: invalid operation data", - "margin": { - "large": "Large", - "medium": "Medium", - "small": "Small", - "xLarge": "Extra Large" - }, - "noFilesToUndo": "Cannot undo: no files were processed in the last operation", - "noOperationToUndo": "No operation to undo", - "noValidFiles": "No valid files to process", - "operationCancelled": "Operation cancelled", - "pageEdit": { - "deselectAll": "Select None", - "selectAll": "Select All" - }, - "quickPosition": "Quick Position", - "reorganizePages": { - "error": { - "failed": "Failed to reorganize pages" - }, - "results": { - "title": "Pages Reorganized" - }, - "settings": { - "title": "Settings" - }, - "submit": "Reorganize Pages" - }, - "replace-color": { - "options": { - "fill": "Fill color", - "gradient": "Gradient" - }, - "previewOverlayOpacity": "Preview overlay opacity", - "previewOverlayTransparency": "Preview overlay transparency", - "previewOverlayVisibility": "Show preview overlay", - "selectText": { - "1": "Replace or invert color options", - "2": "Default (preset high contrast colors)", - "3": "Custom (choose your own colors)", - "4": "Full invert (invert all colors)", - "5": "High contrast color options", - "6": "White text on black background", - "7": "Black text on white background", - "8": "Yellow text on black background", - "9": "Green text on black background", - "10": "Choose text Color", - "11": "Choose background Color", - "12": "Choose start color", - "13": "Choose end color" - }, - "submit": "Replace", - "title": "Replace-Invert-Color" - }, - "size": "Size", - "submit": "Submit", - "success": "Success", - "tools": { - "noSearchResults": "No tools found", - "noTools": "No tools available" - }, - "undoDataMismatch": "Cannot undo: operation data is corrupted", - "undoFailed": "Failed to undo operation", - "undoQuotaError": "Cannot undo: insufficient storage space", - "undoStorageError": "Undo completed but some files could not be saved to storage", - "undoSuccess": "Operation undone successfully", - "unsupported": "Unsupported", - "onboarding": { - "welcomeModal": { - "title": "Welcome to Stirling PDF!", - "description": "Would you like to take a quick 1-minute tour to learn the key features and how to get started?", - "helpHint": "You can always access this tour later from the Help button in the bottom left.", - "startTour": "Start Tour", - "maybeLater": "Maybe Later", - "dontShowAgain": "Don't Show Again" - }, - "allTools": "This is the Tools panel, where you can browse and select from all available PDF tools.", - "selectCropTool": "Let's select the Crop tool to demonstrate how to use one of the tools.", - "toolInterface": "This is the Crop tool interface. As you can see, there's not much there because we haven't added any PDF files to work with yet.", - "filesButton": "The Files button on the Quick Access bar allows you to upload PDFs to use the tools on.", - "fileSources": "You can upload new files or access recent files from here. For the tour, we'll just use a sample file.", - "workbench": "This is the Workbench - the main area where you view and edit your PDFs.", - "viewSwitcher": "Use these controls to select how you want to view your PDFs.", - "viewer": "The Viewer lets you read and annotate your PDFs.", - "pageEditor": "The Page Editor allows you to do various operations on the pages within your PDFs, such as reordering, rotating and deleting.", - "activeFiles": "The Active Files view shows all of the PDFs you have loaded into the tool, and allows you to select which ones to process.", - "fileCheckbox": "Clicking one of the files selects it for processing. You can select multiple files for batch operations.", - "selectControls": "The Right Rail contains buttons to quickly select/deselect all of your active PDFs, along with buttons to change the app's theme or language.", - "cropSettings": "Now that we've selected the file we want crop, we can configure the Crop tool to choose the area that we want to crop the PDF to.", - "runButton": "Once the tool has been configured, this button allows you to run the tool on all the selected PDFs.", - "results": "After the tool has finished running, the Review step will show a preview of the results in this panel, and allow you to undo the operation or download the file. ", - "fileReplacement": "The modified file will replace the original file in the Workbench automatically, allowing you to easily run it through more tools.", - "pinButton": "You can use the Pin button if you'd rather your files stay active after running tools on them.", - "wrapUp": "You're all set! You've learnt about the main areas of the app and how to use them. Click the Help button whenever you like to see this tour again.", - "previous": "Previous", - "next": "Next", - "finish": "Finish", - "startTour": "Start Tour", - "startTourDescription": "Take a guided tour of Stirling PDF's key features" - }, - "adminOnboarding": { - "welcome": "Welcome to the Admin Tour! Let's explore the powerful enterprise features and settings available to system administrators.", - "configButton": "Click the Config button to access all system settings and administrative controls.", - "settingsOverview": "This is the Settings Panel. Admin settings are organized by category for easy navigation.", - "teamsAndUsers": "Manage Teams and individual users here. You can invite new users via email, shareable links, or create custom accounts for them yourself.", - "systemCustomization": "We have extensive ways to customize the UI: System Settings let you change the app name and languages, Features allows server certificate management, and Endpoints lets you enable or disable specific tools for your users.", - "databaseSection": "For advanced production environments, we have settings to allow external database hookups so you can integrate with your existing infrastructure.", - "connectionsSection": "The Connections section supports various login methods including custom SSO and SAML providers like Google and GitHub, plus email integrations for notifications and communications.", - "adminTools": "Finally, we have advanced administration tools like Auditing to track system activity and Usage Analytics to monitor how your users interact with the platform.", - "wrapUp": "That's the admin tour! You've seen the enterprise features that make Stirling PDF a powerful, customizable solution for organizations. Access this tour anytime from the Help menu." - }, - "workspace": { - "title": "Workspace", - "people": { - "title": "People", - "description": "Manage workspace members and their permissions", - "loading": "Loading people...", - "searchMembers": "Search members...", - "addMembers": "Add Members", - "inviteMembers": { - "label": "Invite Members", - "subtitle": "Type or paste in emails below, separated by commas. Your workspace will be billed by members." - }, - "user": "User", - "role": "Role", - "team": "Team", - "status": "Status", - "actions": "Actions", - "noMembersFound": "No members found", - "active": "Active", - "disabled": "Disabled", - "activeSession": "Active session", - "member": "Member", - "admin": "Admin", - "roleDescriptions": { - "admin": "Can manage settings and invite members, with full administrative access.", - "member": "Can view and edit shared files, but cannot manage workspace settings or members.", - "user": "User" - }, - "editRole": "Edit Role", - "enable": "Enable", - "disable": "Disable", - "deleteUser": "Delete User", - "deleteUserSuccess": "User deleted successfully", - "deleteUserError": "Failed to delete user", - "confirmDelete": "Are you sure you want to delete this user? This action cannot be undone.", - "addMember": { - "title": "Add Member", - "username": "Username (Email)", - "usernamePlaceholder": "user@example.com", - "password": "Password", - "passwordPlaceholder": "Enter password", - "role": "Role", - "team": "Team (Optional)", - "teamPlaceholder": "Select a team", - "forcePasswordChange": "Force password change on first login", - "cancel": "Cancel", - "submit": "Add Member", - "usernameRequired": "Username and password are required", - "passwordTooShort": "Password must be at least 6 characters", - "success": "User created successfully", - "error": "Failed to create user" - }, - "editMember": { - "title": "Edit Member", - "editing": "Editing:", - "role": "Role", - "team": "Team (Optional)", - "teamPlaceholder": "Select a team", - "cancel": "Cancel", - "submit": "Update Member", - "success": "User updated successfully", - "error": "Failed to update user" - }, - "toggleEnabled": { - "success": "User status updated successfully", - "error": "Failed to update user status" - }, - "delete": { - "success": "User deleted successfully", - "error": "Failed to delete user" - }, - "emailInvite": { - "tab": "Email Invite", - "description": "Type or paste in emails below, separated by commas. Users will receive login credentials via email.", - "emails": "Email Addresses", - "emailsPlaceholder": "user1@example.com, user2@example.com", - "emailsRequired": "At least one email address is required", - "submit": "Send Invites", - "success": "user(s) invited successfully", - "partialSuccess": "Some invites failed", - "allFailed": "Failed to invite users", - "error": "Failed to send invites" - }, - "directInvite": { - "tab": "Direct Create" - }, - "inviteLinkTab": { - "tab": "Invite Link" - }, - "inviteLink": { - "description": "Generate a secure link that allows the user to set their own password", - "email": "Email Address", - "emailPlaceholder": "user@example.com (optional)", - "emailDescription": "Optional - leave blank for a general invite link that can be used by anyone", - "emailRequired": "Email address is required", - "emailOptional": "Optional - leave blank for a general invite link", - "emailRequiredForSend": "Email address is required to send email notification", - "expiryHours": "Expiry Hours", - "expiryDescription": "How many hours until the link expires", - "sendEmail": "Send invite link via email", - "sendEmailDescription": "If enabled, the invite link will be sent to the specified email address", - "smtpRequired": "SMTP not configured", - "generate": "Generate Link", - "generated": "Invite Link Generated", - "copied": "Link copied to clipboard", - "success": "Invite link generated successfully", - "successWithEmail": "Invite link generated and sent via email", - "emailSent": "Invite link generated and sent via email", - "emailFailed": "Invite link generated, but email failed", - "emailFailedDetails": "Error: {0}. Please share the invite link manually.", - "error": "Failed to generate invite link", - "submit": "Generate Invite Link" - }, - "inviteMode": { - "username": "Username", - "email": "Email", - "link": "Link", - "emailDisabled": "Email invites require SMTP configuration and mail.enableInvites=true in settings" - }, - "license": { - "users": "users", - "availableSlots": "Available Slots", - "grandfathered": "Grandfathered", - "grandfatheredShort": "{{count}} grandfathered", - "fromLicense": "from license", - "slotsAvailable": "{{count}} user slot(s) available", - "noSlotsAvailable": "No slots available", - "currentUsage": "Currently using {{current}} of {{max}} user licenses" - } - }, - "teams": { - "title": "Teams", - "description": "Manage teams and organize workspace members", - "loading": "Loading teams...", - "loadingDetails": "Loading team details...", - "createNewTeam": "Create New Team", - "teamName": "Team Name", - "totalMembers": "Total Members", - "actions": "Actions", - "noTeamsFound": "No teams found", - "noMembers": "No members in this team", - "system": "System", - "addMember": "Add Member", - "viewTeam": "View Team", - "removeMember": "Remove from team", - "cannotRemoveFromSystemTeam": "Cannot remove from system team", - "renameTeamLabel": "Rename Team", - "deleteTeamLabel": "Delete Team", - "cannotDeleteInternal": "Cannot delete the Internal team", - "confirmDelete": "Are you sure you want to delete this team? This team must be empty to delete.", - "confirmRemove": "Remove user from this team?", - "cannotRenameInternal": "Cannot rename the Internal team", - "cannotAddToInternal": "Cannot add members to the Internal team", - "teamNotFound": "Team not found", - "backToTeams": "Back to Teams", - "memberCount": "{{count}} members", - "removeMemberSuccess": "User removed from team", - "removeMemberError": "Failed to remove user from team", - "createTeam": { - "title": "Create New Team", - "teamName": "Team Name", - "teamNamePlaceholder": "Enter team name", - "cancel": "Cancel", - "submit": "Create Team", - "nameRequired": "Team name is required", - "success": "Team created successfully", - "error": "Failed to create team" - }, - "renameTeam": { - "title": "Rename Team", - "renaming": "Renaming:", - "newTeamName": "New Team Name", - "newTeamNamePlaceholder": "Enter new team name", - "cancel": "Cancel", - "submit": "Rename Team", - "nameRequired": "Team name is required", - "success": "Team renamed successfully", - "error": "Failed to rename team" - }, - "deleteTeam": { - "success": "Team deleted successfully", - "error": "Failed to delete team. Make sure the team is empty.", - "teamMustBeEmpty": "Team must be empty before deletion" - }, - "addMemberToTeam": { - "title": "Add Member to Team", - "addingTo": "Adding to", - "selectUser": "Select User", - "selectUserPlaceholder": "Choose a user", - "selectUserRequired": "Please select a user", - "currentlyIn": "currently in", - "willBeMoved": "Note: This user will be moved from their current team to this team.", - "cancel": "Cancel", - "submit": "Add Member", - "userRequired": "Please select a user", - "success": "Member added to team successfully", - "error": "Failed to add member to team" - }, - "changeTeam": { - "label": "Change Team", - "title": "Change Team", - "changing": "Moving", - "selectTeam": "Select Team", - "selectTeamPlaceholder": "Choose a team", - "selectTeamRequired": "Please select a team", - "success": "Team changed successfully", - "error": "Failed to change team", - "submit": "Change Team" - } - } - }, - "plan": { - "currency": "Currency", - "popular": "Popular", - "current": "Current Plan", - "upgrade": "Upgrade", - "contact": "Contact Us", - "customPricing": "Custom", - "showComparison": "Compare All Features", - "hideComparison": "Hide Feature Comparison", - "featureComparison": "Feature Comparison", - "activePlan": { - "title": "Active Plan", - "subtitle": "Your current subscription details" - }, - "availablePlans": { - "title": "Available Plans", - "subtitle": "Choose the plan that fits your needs" - }, - "static": { - "title": "Billing Information", - "message": "Online billing is not currently configured. To upgrade your plan or manage subscriptions, please contact us directly.", - "contactSales": "Contact Sales", - "contactToUpgrade": "Contact us to upgrade or customize your plan", - "maxUsers": "Max Users", - "upTo": "Up to" - }, - "period": { - "month": "month" - }, - "free": { - "name": "Free", - "highlight1": "Limited Tool Usage Per week", - "highlight2": "Access to all tools", - "highlight3": "Community support" - }, - "pro": { - "name": "Pro", - "highlight1": "Unlimited Tool Usage", - "highlight2": "Advanced PDF tools", - "highlight3": "No watermarks" - }, - "enterprise": { - "name": "Enterprise", - "highlight1": "Custom pricing", - "highlight2": "Dedicated support", - "highlight3": "Latest features" - }, - "feature": { - "title": "Feature", - "pdfTools": "Basic PDF Tools", - "fileSize": "File Size Limit", - "automation": "Automate tool workflows", - "api": "API Access", - "priority": "Priority Support", - "customPricing": "Custom Pricing" - } - }, - "subscription": { - "status": { - "active": "Active", - "pastDue": "Past Due", - "canceled": "Canceled", - "incomplete": "Incomplete", - "trialing": "Trial", - "none": "No Subscription" - }, - "renewsOn": "Renews on {{date}}", - "cancelsOn": "Cancels on {{date}}" - }, - "billing": { - "manageBilling": "Manage Billing", - "portal": { - "error": "Failed to open billing portal" - } - }, - "payment": { - "preparing": "Preparing your checkout...", - "upgradeTitle": "Upgrade to {{planName}}", - "success": "Payment Successful!", - "successMessage": "Your subscription has been activated successfully. You will receive a confirmation email shortly.", - "autoClose": "This window will close automatically...", - "error": "Payment Error" - }, - "firstLogin": { - "title": "First Time Login", - "welcomeTitle": "Welcome!", - "welcomeMessage": "For security reasons, you must change your password on your first login.", - "loggedInAs": "Logged in as", - "error": "Error", - "currentPassword": "Current Password", - "enterCurrentPassword": "Enter your current password", - "newPassword": "New Password", - "enterNewPassword": "Enter new password (min 8 characters)", - "confirmPassword": "Confirm New Password", - "reEnterNewPassword": "Re-enter new password", - "changePassword": "Change Password", - "allFieldsRequired": "All fields are required", - "passwordsDoNotMatch": "New passwords do not match", - "passwordTooShort": "Password must be at least 8 characters", - "passwordMustBeDifferent": "New password must be different from current password", - "passwordChangedSuccess": "Password changed successfully! Please log in again.", - "passwordChangeFailed": "Failed to change password. Please check your current password." - }, - "invite": { - "welcome": "Welcome to Stirling PDF", - "invalidToken": "Invalid invitation link", - "validationError": "Failed to validate invitation link", - "passwordRequired": "Password is required", - "passwordTooShort": "Password must be at least 6 characters", - "passwordMismatch": "Passwords do not match", - "acceptError": "Failed to create account", - "validating": "Validating invitation...", - "invalidInvitation": "Invalid Invitation", - "goToLogin": "Go to Login", - "welcomeTitle": "You've been invited!", - "welcomeSubtitle": "Complete your account setup to get started", - "accountFor": "Creating account for", - "linkExpires": "Link expires", - "email": "Email address", - "emailPlaceholder": "Enter your email address", - "emailRequired": "Email address is required", - "invalidEmail": "Invalid email address", - "choosePassword": "Choose a password", - "passwordPlaceholder": "Enter your password", - "confirmPassword": "Confirm password", - "confirmPasswordPlaceholder": "Re-enter your password", - "createAccount": "Create Account", - "creating": "Creating Account...", - "alreadyHaveAccount": "Already have an account?", - "signIn": "Sign in" - }, - "audit": { - "error": { - "title": "Error loading audit system" - }, - "notAvailable": "Audit system not available", - "notAvailableMessage": "The audit system is not configured or not available.", - "disabled": "Audit logging is disabled", - "disabledMessage": "Enable audit logging in your application configuration to track system events.", - "systemStatus": { - "title": "System Status", - "status": "Audit Logging", - "enabled": "Enabled", - "disabled": "Disabled", - "level": "Audit Level", - "retention": "Retention Period", - "days": "days", - "totalEvents": "Total Events" - }, - "tabs": { - "dashboard": "Dashboard", - "events": "Audit Events", - "export": "Export" - }, - "charts": { - "title": "Audit Dashboard", - "error": "Error loading charts", - "day": "Day", - "week": "Week", - "month": "Month", - "byType": "Events by Type", - "byUser": "Events by User", - "overTime": "Events Over Time" - }, - "events": { - "title": "Audit Events", - "filterByType": "Filter by type", - "filterByUser": "Filter by user", - "startDate": "Start date", - "endDate": "End date", - "clearFilters": "Clear", - "error": "Error loading events", - "noEvents": "No events found", - "timestamp": "Timestamp", - "type": "Type", - "user": "User", - "ipAddress": "IP Address", - "actions": "Actions", - "viewDetails": "View Details", - "eventDetails": "Event Details", - "details": "Details" - }, - "export": { - "title": "Export Audit Data", - "description": "Export audit events to CSV or JSON format. Use filters to limit the exported data.", - "format": "Export Format", - "filters": "Filters (Optional)", - "filterByType": "Filter by type", - "filterByUser": "Filter by user", - "startDate": "Start date", - "endDate": "End date", - "clearFilters": "Clear", - "exportButton": "Export Data", - "error": "Failed to export data" - } - }, - "usage": { - "noData": "No data available", - "error": "Error loading usage statistics", - "noDataMessage": "No usage statistics are currently available.", - "controls": { - "top10": "Top 10", - "top20": "Top 20", - "all": "All", - "refresh": "Refresh", - "dataTypeLabel": "Data Type:", - "dataType": { - "all": "All", - "api": "API", - "ui": "UI" - } - }, - "showing": { - "top10": "Top 10", - "top20": "Top 20", - "all": "All" - }, - "stats": { - "totalEndpoints": "Total Endpoints", - "totalVisits": "Total Visits", - "showing": "Showing", - "selectedVisits": "Selected Visits" - }, - "chart": { - "title": "Endpoint Usage Chart" - }, - "table": { - "title": "Detailed Statistics", - "endpoint": "Endpoint", - "visits": "Visits", - "percentage": "Percentage", - "noData": "No data available" - } - }, - "backendHealth": { - "checking": "Checking backend status...", - "online": "Backend Online", - "offline": "Backend Offline", - "starting": "Backend starting up...", - "wait": "Please wait for the backend to finish launching and try again." - } -} \ No newline at end of file diff --git a/frontend/src/core/i18n.ts b/frontend/src/core/i18n.ts index 1d5eccb5e..38ab032eb 100644 --- a/frontend/src/core/i18n.ts +++ b/frontend/src/core/i18n.ts @@ -5,9 +5,7 @@ import Backend from 'i18next-http-backend'; // Define supported languages (based on your existing translations) export const supportedLanguages = { - 'en': 'English', - 'en-GB': 'English (UK)', - 'en-US': 'English (US)', + 'en-GB': 'English', 'ar-AR': 'العربية', 'az-AZ': 'Azərbaycan Dili', 'bg-BG': 'Български', @@ -72,8 +70,7 @@ i18n backend: { loadPath: (lngs: string[], namespaces: string[]) => { - // Map 'en' to 'en-GB' for loading translations - const lng = lngs[0] === 'en' ? 'en-GB' : lngs[0]; + const lng = lngs[0]; const basePath = import.meta.env.BASE_URL || '/'; const cleanBasePath = basePath.endsWith('/') ? basePath.slice(0, -1) : basePath; return `${cleanBasePath}/locales/${lng}/${namespaces[0]}.json`; @@ -83,7 +80,11 @@ i18n detection: { order: ['localStorage', 'navigator', 'htmlTag'], caches: ['localStorage'], - convertDetectedLanguage: (lng: string) => lng === 'en' ? 'en-GB' : lng, + convertDetectedLanguage: (lng: string) => { + // Map en and en-US to en-GB + if (lng === 'en' || lng === 'en-US') return 'en-GB'; + return lng; + }, }, react: { diff --git a/frontend/src/core/utils/languageMapping.ts b/frontend/src/core/utils/languageMapping.ts index 687c63258..811320275 100644 --- a/frontend/src/core/utils/languageMapping.ts +++ b/frontend/src/core/utils/languageMapping.ts @@ -13,7 +13,7 @@ const languageDefinitions: LanguageDefinition[] = [ { ocrCode: 'eng', displayName: 'English', - browserCodes: ['en', 'en-US', 'en-GB', 'en-AU', 'en-CA', 'en-IE', 'en-NZ', 'en-ZA'] + browserCodes: ['en', 'en-GB', 'en-AU', 'en-CA', 'en-IE', 'en-NZ', 'en-ZA'] }, // Spanish