en.ts 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313
  1. export default {
  2. nav: {
  3. feed: 'Feed',
  4. compose: 'New Post',
  5. media: 'Media',
  6. scheduler: 'Scheduler',
  7. analytics: 'Analytics',
  8. settings: 'Settings',
  9. },
  10. analytics: {
  11. title: 'Analytics',
  12. subtitle: 'Publishing activity across all connected platforms',
  13. refresh: 'Refresh',
  14. loading: 'Loading analytics…',
  15. empty: 'No posts yet.',
  16. emptyHint: 'Start publishing to see analytics here.',
  17. totalPosts: 'Total Posts',
  18. last7Days: 'Last 7 Days',
  19. platformsReached: 'Platforms Reached',
  20. successRate: 'Success Rate',
  21. postsPerDay: 'Posts per Day',
  22. postsPerDaySubtitle: 'Last 30 days',
  23. noActivity: 'No activity in the last 30 days.',
  24. platformBreakdown: 'Platform Breakdown',
  25. successfulPosts: 'successful posts',
  26. statusBreakdown: 'Status Breakdown',
  27. published: 'Published',
  28. partial: 'Partial',
  29. failed: 'Failed',
  30. recentPosts: 'Recent Posts',
  31. colContent: 'Content',
  32. colPlatforms: 'Platforms',
  33. colDate: 'Date',
  34. colStatus: 'Status',
  35. statusPublished: 'Published',
  36. statusPartial: 'Partial',
  37. statusFailed: 'Failed',
  38. typeScheduled: 'Scheduled',
  39. typeImmediate: 'Immediate',
  40. noRecentPosts: 'No posts to show.',
  41. loadMore: 'Load more',
  42. noContent: 'Content not available for older posts',
  43. crawlMetrics: 'Crawl Metrics',
  44. crawling: 'Crawling…',
  45. crawlDone: 'Crawled {count} posts',
  46. insightsTitle: 'Advanced Insights',
  47. insightsSubtitle: 'Engagement metrics from connected platforms',
  48. insightsEmpty: 'No engagement data yet.',
  49. insightsEmptyHint: 'Click "Crawl Metrics" to fetch engagement data from your connected platforms.',
  50. bestTimeTitle: 'Best Posting Times',
  51. bestTimeSubtitle: 'Average engagement score by time (UTC)',
  52. byHourTitle: 'By Hour of Day',
  53. byDayTitle: 'By Day of Week',
  54. heatmapTitle: 'Engagement Heatmap',
  55. heatmapSubtitle: 'Day × hour (UTC) — darker = higher avg engagement',
  56. topPostsTitle: 'Top Performing Posts',
  57. noTopPosts: 'No top posts yet.',
  58. platformCompTitle: 'Platform Comparison',
  59. colAvgEngagement: 'Avg Engagement',
  60. colAvgLikes: 'Avg Likes',
  61. colAvgComments: 'Avg Comments',
  62. colAvgShares: 'Avg Shares',
  63. colTracked: 'Posts Tracked',
  64. dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
  65. },
  66. media: {
  67. title: 'Media Library',
  68. fileCount: '{count} files',
  69. upload: 'Upload',
  70. uploading: 'Uploading…',
  71. dropZoneTitle: 'Drop files here or click Upload',
  72. dropZoneHint: 'Supports JPEG, PNG, GIF, WebP, MP4, MOV — up to 100 MB each',
  73. useInPost: 'Use in Post',
  74. copyUrl: 'Copy URL',
  75. copied: 'Copied!',
  76. deleteConfirmTitle: 'Delete this file?',
  77. deleteConfirmHint: 'This cannot be undone. Any posts using this file will lose the media.',
  78. cancel: 'Cancel',
  79. delete: 'Delete',
  80. deleting: 'Deleting…',
  81. },
  82. dashboard: {
  83. platforms: 'Platforms',
  84. tags: 'Tags',
  85. allTags: 'All',
  86. searchPlaceholder: 'Search content or user...',
  87. refresh: 'Refresh',
  88. refreshing: 'Refreshing...',
  89. newPost: '+ New Post',
  90. loading: 'Loading feed...',
  91. empty: 'No content to show.',
  92. emptyHint: 'Check platform connections or refresh the feed.',
  93. },
  94. compose: {
  95. title: 'New Post',
  96. destinationsLabel: 'Post to',
  97. placeholder: "What's on your mind?",
  98. cancel: 'Cancel',
  99. schedule: 'Schedule',
  100. send: 'Post Now →',
  101. sending: 'Posting...',
  102. successMessage: 'Post sent successfully.',
  103. scheduleTitle: 'Schedule post (leave empty to post now)',
  104. timezoneLabel: 'Timezone',
  105. timezoneAutoFrom: 'Auto from account',
  106. preview: 'Preview',
  107. addMedia: 'Photo / Video',
  108. uploadFile: 'Upload a photo or video from your device',
  109. uploading: 'Uploading…',
  110. uploadFailed: 'Upload failed. Please try again.',
  111. pasteUrl: 'or paste a URL',
  112. cancelUrl: 'cancel',
  113. mediaUrlPlaceholder: 'Paste image or video URL, then press Enter…',
  114. mediaLoadError: 'Could not load this URL — check it is publicly accessible.',
  115. igImageRequired: 'Instagram requires an image or video.',
  116. noDestinations: 'No platforms configured.',
  117. goToSettings: 'Go to Settings →',
  118. saveDraft: 'Save Draft',
  119. updateDraft: 'Update Draft',
  120. savingDraft: 'Saving…',
  121. draftSaved: 'Draft saved.',
  122. hashtagSuggestions: 'Suggested hashtags',
  123. hashtagsLoading: 'Suggesting…',
  124. hashtagsRefresh: 'Refresh',
  125. aiButton: 'AI',
  126. aiPanelTitle: 'Generate with AI',
  127. aiTopic: 'Topic',
  128. aiTopicPlaceholder: 'What should this post be about?',
  129. aiGoal: 'Goal',
  130. aiGoals: {
  131. promote: 'Promote',
  132. engage: 'Engage',
  133. inform: 'Inform',
  134. entertain: 'Entertain',
  135. announce: 'Announce',
  136. },
  137. aiTone: 'Tone',
  138. aiToneDefault: 'From profile',
  139. aiGenerate: 'Generate',
  140. aiGenerating: 'Generating…',
  141. aiStop: 'Stop',
  142. aiContextFrom: 'Context: {account}',
  143. aiNoContext: 'No profile — set one in Settings',
  144. aiNotConfigured: 'AI not configured — check Settings → AI Integration',
  145. aiError: 'Generation failed',
  146. captionGenerate: '✨ Generate caption',
  147. captionGenerating: 'Generating caption…',
  148. captionError: 'Caption generation failed',
  149. },
  150. scheduler: {
  151. title: 'Scheduler',
  152. newSchedule: '+ New Post',
  153. noJobs: 'No scheduled posts.',
  154. statuses: {
  155. pending: 'Pending',
  156. completed: 'Completed',
  157. failed: 'Failed',
  158. cancelled: 'Cancelled',
  159. },
  160. cancel: 'Cancel',
  161. scheduledTab: 'Scheduled',
  162. calendarTab: 'Calendar',
  163. draftsTab: 'Drafts',
  164. noDrafts: 'No saved drafts.',
  165. editDraft: 'Edit',
  166. deleteDraft: 'Delete',
  167. goToToday: 'Today',
  168. noJobsDay: 'No posts scheduled for this day.',
  169. weekDaysShort: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
  170. months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
  171. },
  172. settings: {
  173. title: 'Platform Connections',
  174. subtitle: 'Edit the {env} file to connect platforms, then restart the relevant service.',
  175. connected: 'Connected',
  176. notConnected: 'Not connected',
  177. refreshStatus: '↻ Refresh Status',
  178. envHint: 'Configuration required',
  179. profiles: {
  180. sectionTitle: 'Account Profiles',
  181. sectionSubtitle: 'Business context used to personalise AI-generated content.',
  182. edit: 'Edit',
  183. close: 'Close',
  184. save: 'Save Profile',
  185. saving: 'Saving…',
  186. saved: 'Saved!',
  187. noAccounts: 'No connected accounts. Connect platforms above first.',
  188. businessName: 'Business Name',
  189. businessNameHint: 'e.g. Acme Coffee Roasters',
  190. description: 'Description',
  191. descriptionHint: 'What does this account represent? What do you do?',
  192. websiteUrl: 'Website URL',
  193. industry: 'Industry',
  194. industryHint: 'e.g. Food & Beverage, SaaS, Retail',
  195. targetAudience: 'Target Audience',
  196. targetAudienceHint: 'e.g. Coffee enthusiasts aged 25–45',
  197. toneOfVoice: 'Tone of Voice',
  198. toneSelect: 'Select a tone…',
  199. keywords: 'Keywords',
  200. keywordsHint: 'Comma-separated, e.g. organic, specialty, single-origin',
  201. hashtags: 'Preferred Hashtags',
  202. hashtagsHint: 'e.g. #specialtycoffee #coffeelovers',
  203. postingGuidelines: 'Posting Guidelines',
  204. postingGuidelinesHint: 'Any specific rules, e.g. always mention opening hours on Fridays',
  205. timezone: 'Timezone',
  206. timezoneHint: 'Used to schedule posts at the correct local time for this account.',
  207. timezoneAuto: 'Use browser timezone',
  208. },
  209. meta: {
  210. sectionTitle: 'Facebook & Instagram',
  211. sectionSubtitle: 'Both platforms share a single Facebook Developer App. Connect once to manage all your Pages and Instagram accounts.',
  212. appIdLabel: 'App ID',
  213. appSecretLabel: 'App Secret',
  214. appIdPlaceholder: 'Your Facebook App ID',
  215. appSecretPlaceholder: 'Your Facebook App Secret',
  216. saveApp: 'Save App Credentials',
  217. saving: 'Saving...',
  218. appConfigured: 'App credentials saved',
  219. connectButton: 'Connect with Facebook & Instagram',
  220. connecting: 'Redirecting to Facebook...',
  221. reconnect: 'Reconnect',
  222. disconnect: 'Disconnect all',
  223. disconnectConfirm: 'This will disconnect all Facebook Pages and Instagram accounts. Continue?',
  224. discoveryTitle: 'Choose Pages & Accounts to Connect',
  225. discoverySubtitle: 'Select any combination of Facebook Pages and Instagram accounts below.',
  226. pagesHeading: 'Facebook Pages',
  227. igHeading: 'Instagram Accounts',
  228. noPages: 'No Facebook Pages found for this account.',
  229. noIgAccounts: 'No Instagram Business accounts found.',
  230. igLinkedTo: 'Linked to',
  231. confirmSelection: 'Connect Selected',
  232. confirmingSelection: 'Connecting...',
  233. nothingSelected: 'Select at least one Page or Instagram account.',
  234. connectedPages: 'Connected Pages',
  235. connectedAccounts: 'Connected Accounts',
  236. errorTitle: 'OAuth Error',
  237. getAppHelp: 'Get your App ID and Secret from',
  238. devPortal: 'developers.facebook.com',
  239. expiryWarningTitle: 'Instagram token expiring soon',
  240. expiryWarningBody: '{username} expires in {days} day | {username} expires in {days} days',
  241. expiryRefreshToken: 'Refresh Token',
  242. expiryRefreshing: 'Refreshing…',
  243. expiryRefreshDone: 'Token refreshed',
  244. expiryAutoNote: 'Tokens are refreshed automatically when ≤ 7 days remain.',
  245. expiryReconnect: 'Reconnect',
  246. expiryDismiss: 'Dismiss',
  247. },
  248. },
  249. ai: {
  250. sectionTitle: 'AI Integration',
  251. sectionSubtitle: 'Connect a local Ollama instance to generate post content with AI.',
  252. endpointLabel: 'Ollama Endpoint',
  253. endpointPlaceholder: 'http://localhost:11434',
  254. endpointHint: 'Inside Docker the default is http://ollama:11434',
  255. modelLabel: 'Model',
  256. modelPlaceholder: 'Select a model…',
  257. testConnection: 'Test Connection',
  258. testing: 'Testing…',
  259. saveConfig: 'Save',
  260. saving: 'Saving…',
  261. saved: 'Saved!',
  262. noModels: 'No models found — is Ollama running?',
  263. connected: 'Connected',
  264. connectionFailed: 'Connection failed',
  265. modelsAvailable: '{count} model available | {count} models available',
  266. visionModelLabel: 'Vision Model',
  267. visionModelPlaceholder: 'e.g. llava, llama3.2-vision',
  268. visionModelHint: 'Used for image captioning. Pull with: ollama pull llava',
  269. },
  270. feed: {
  271. openOriginal: '↗ Open',
  272. },
  273. platforms: {
  274. twitter: 'Twitter/X',
  275. linkedin: 'LinkedIn',
  276. mastodon: 'Mastodon',
  277. bluesky: 'Bluesky',
  278. instagram: 'Instagram',
  279. facebook: 'Facebook',
  280. reddit: 'Reddit',
  281. youtube: 'YouTube',
  282. },
  283. }