forked from XiaoMo/ChatGPT-Next-Web
Merge pull request #2268 from imabutahersiddik/main
Added support for Bangla language.
This commit is contained in:
commit
795b43f174
335
app/locales/bn.ts
Normal file
335
app/locales/bn.ts
Normal file
@ -0,0 +1,335 @@
|
|||||||
|
import { SubmitKey } from "../store/config";
|
||||||
|
import { LocaleType } from "./index";
|
||||||
|
|
||||||
|
const bn: LocaleType = {
|
||||||
|
WIP: "শীঘ্রই আসছে...",
|
||||||
|
Error: {
|
||||||
|
Unauthorized:
|
||||||
|
"অননুমোদিত অ্যাক্সেস, অনুগ্রহ করে [অথোরাইজশন](/#/auth) পৃষ্ঠায় অ্যাক্সেস কোড ইনপুট করুন।",
|
||||||
|
},
|
||||||
|
Auth: {
|
||||||
|
Title: "একটি অ্যাক্সেস কোড প্রয়োজন",
|
||||||
|
Tips: "নীচে অ্যাক্সেস কোড ইনপুট করুন",
|
||||||
|
Input: "অ্যাক্সেস কোড",
|
||||||
|
Confirm: "নিশ্চিত করুন",
|
||||||
|
Later: "পরে",
|
||||||
|
},
|
||||||
|
ChatItem: {
|
||||||
|
ChatItemCount: (count: number) => `${count} টি বার্তা`,
|
||||||
|
},
|
||||||
|
Chat: {
|
||||||
|
SubTitle: (count: number) => `${count} টি বার্তা`,
|
||||||
|
Actions: {
|
||||||
|
ChatList: "চ্যাট তালিকায় যান",
|
||||||
|
CompressedHistory: "সংক্ষিপ্ত ইতিহাস মেমোরি প্রম্পট",
|
||||||
|
Export: "সমস্ত বার্তা মার্কডাউন হিসাবে রপ্তানি করুন",
|
||||||
|
Copy: "কপি",
|
||||||
|
Stop: "বন্ধ করুন",
|
||||||
|
Retry: "পুনরায় চেষ্টা করুন",
|
||||||
|
Pin: "পিন করুন",
|
||||||
|
PinToastContent: "পিন করা হয়েছে ২টি বার্তা প্রম্পটে",
|
||||||
|
PinToastAction: "দেখুন",
|
||||||
|
Delete: "মুছে ফেলুন",
|
||||||
|
Edit: "সম্পাদন করুন",
|
||||||
|
},
|
||||||
|
Commands: {
|
||||||
|
new: "নতুন চ্যাট শুরু করুন",
|
||||||
|
newm: "মাস্ক সহ নতুন চ্যাট শুরু করুন",
|
||||||
|
next: "পরবর্তী চ্যাট",
|
||||||
|
prev: "পূর্ববর্তী চ্যাট",
|
||||||
|
clear: "সংশ্লিষ্টতাবদ্ধকরণ পরিষ্কার করুন",
|
||||||
|
del: "চ্যাট মুছুন",
|
||||||
|
},
|
||||||
|
InputActions: {
|
||||||
|
Stop: "বন্ধ করুন",
|
||||||
|
ToBottom: "সর্বশেষতম দিকে",
|
||||||
|
Theme: {
|
||||||
|
auto: "অটো",
|
||||||
|
light: "হালকা থিম",
|
||||||
|
dark: "ডার্ক থিম",
|
||||||
|
},
|
||||||
|
Prompt: "প্রম্পটগুলিতে",
|
||||||
|
Masks: "মাস্কগুলি",
|
||||||
|
Clear: "সংশ্লিষ্টতাবদ্ধকরণ পরিষ্কার করুন",
|
||||||
|
Settings: "সেটিংস",
|
||||||
|
},
|
||||||
|
Rename: "চ্যাট পুনঃনামকরণ করুন",
|
||||||
|
Typing: "টাইপিং...",
|
||||||
|
Input: (submitKey: string) => {
|
||||||
|
var inputHints = `${submitKey} to send`;
|
||||||
|
if (submitKey === String(SubmitKey.Enter)) {
|
||||||
|
inputHints += ", Shift + Enter to wrap";
|
||||||
|
}
|
||||||
|
return inputHints + ", / to search prompts, : to use commands";
|
||||||
|
},
|
||||||
|
Send: "প্রেরণ করুন",
|
||||||
|
Config: {
|
||||||
|
Reset: "ডিফল্টে রিসেট করুন",
|
||||||
|
SaveAs: "মাস্ক হিসাবে সংরক্ষণ করুন",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Export: {
|
||||||
|
Title: "বার্তা রপ্তানিকরণ",
|
||||||
|
Copy: "সমস্তটি কপি করুন",
|
||||||
|
Download: "ডাউনলোড করুন",
|
||||||
|
MessageFromYou: "আপনার বার্তা",
|
||||||
|
MessageFromChatGPT: "চ্যাটজিপিটির বার্তা",
|
||||||
|
Share: "শেয়ার করুন শেয়ারজিপিটি তে",
|
||||||
|
Format: {
|
||||||
|
Title: "রপ্তানি ফরম্যাট",
|
||||||
|
SubTitle: "মার্কডাউন বা পিএনজি চিত্র",
|
||||||
|
},
|
||||||
|
IncludeContext: {
|
||||||
|
Title: "মাস্ক অন্তর্ভুক্ত করুন",
|
||||||
|
SubTitle: "মাস্কগুলি সংরক্ষণ করবেন না কি",
|
||||||
|
},
|
||||||
|
Steps: {
|
||||||
|
Select: "নির্বাচন করুন",
|
||||||
|
Preview: "প্রিভিউ করুন",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Select: {
|
||||||
|
Search: "অনুসন্ধান করুন",
|
||||||
|
All: "সমস্তটি নির্বাচন করুন",
|
||||||
|
Latest: "সর্বশেষতমটি নির্বাচন করুন",
|
||||||
|
Clear: "পরিষ্কার করুন",
|
||||||
|
},
|
||||||
|
Memory: {
|
||||||
|
Title: "মেমোরি প্রম্পট",
|
||||||
|
EmptyContent: "এখনও কিছুই নেই।",
|
||||||
|
Send: "মেমোরি প্রেরণ করুন",
|
||||||
|
Copy: "মেমোরি কপি করুন",
|
||||||
|
Reset: "পুনরায় নিশ্চিত করুন",
|
||||||
|
ResetConfirm:
|
||||||
|
"রিসেট করলে বর্তমান চ্যাট ইতিহাস এবং ঐতিহাসিক মেমোরি মুছে যাবে। পুনরায় নির্দিষ্ট করতে চান তা নিশ্চিত করতে চান?",
|
||||||
|
},
|
||||||
|
Home: {
|
||||||
|
NewChat: "নতুন চ্যাট",
|
||||||
|
DeleteChat: "নির্বাচিত সংলাপটি মুছতে নিশ্চিত করুন?",
|
||||||
|
DeleteToast: "চ্যাটটি মুছেছেন",
|
||||||
|
Revert: "পুনরায়",
|
||||||
|
},
|
||||||
|
Settings: {
|
||||||
|
Title: "সেটিংস",
|
||||||
|
SubTitle: "সমস্ত সেটিংস",
|
||||||
|
Danger: {
|
||||||
|
Reset: {
|
||||||
|
Title: "সমস্ত সেটিংস পুনঃনির্দেশ দিন",
|
||||||
|
SubTitle: "সকল সেটিংস ডিফল্টে পুনঃনির্দেশ দিতে",
|
||||||
|
Action: "পুনঃনির্দেশ দিন",
|
||||||
|
Confirm: "সমস্ত সেটিংস ডিফল্টে পুনঃনির্দেশ করতে নিশ্চিত করতে?",
|
||||||
|
},
|
||||||
|
Clear: {
|
||||||
|
Title: "সমস্ত তথ্য মুছুন",
|
||||||
|
SubTitle: "সমস্ত বার্তা এবং সেটিংস মুছুন",
|
||||||
|
Action: "মুছুন",
|
||||||
|
Confirm: "সমস্ত বার্তা এবং সেটিংস মুছে ফেলতে নিশ্চিত করতে?",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Lang: {
|
||||||
|
Name: "বাংলা", // ATTENTION: if you wanna add a new translation, please do not translate this value, leave it as `Language`
|
||||||
|
All: "সমস্ত ভাষা",
|
||||||
|
},
|
||||||
|
Avatar: "অবতার",
|
||||||
|
FontSize: {
|
||||||
|
Title: "ফন্ট সাইজ",
|
||||||
|
SubTitle: "চ্যাট সামগ্রীর ফন্ট সাইজ সংশোধন করুন",
|
||||||
|
},
|
||||||
|
|
||||||
|
InputTemplate: {
|
||||||
|
Title: "ইনপুট টেমপ্লেট",
|
||||||
|
SubTitle: "নতুনতম বার্তা এই টেমপ্লেটে পূরণ হবে",
|
||||||
|
},
|
||||||
|
|
||||||
|
Update: {
|
||||||
|
Version: (x: string) => `Version: ${x}`,
|
||||||
|
IsLatest: "Latest version",
|
||||||
|
CheckUpdate: "Check Update",
|
||||||
|
IsChecking: "Checking update...",
|
||||||
|
FoundUpdate: (x: string) => `Found new version: ${x}`,
|
||||||
|
GoToUpdate: "Update",
|
||||||
|
},
|
||||||
|
SendKey: "প্রেরণ চাবি",
|
||||||
|
Theme: "থিম",
|
||||||
|
TightBorder: "সঙ্গতি সীমা",
|
||||||
|
SendPreviewBubble: {
|
||||||
|
Title: "প্রিভিউ বুলবুল প্রেরণ করুন",
|
||||||
|
SubTitle: "বুলবুলে মার্কডাউন প্রিভিউ করুন",
|
||||||
|
},
|
||||||
|
Mask: {
|
||||||
|
Splash: {
|
||||||
|
Title: "মাস্ক স্প্ল্যাশ স্ক্রিন",
|
||||||
|
SubTitle: "নতুন চ্যাট শুরু করার আগে মাস্ক স্প্ল্যাশ স্ক্রিন প্রদর্শন করুন",
|
||||||
|
},
|
||||||
|
Builtin: {
|
||||||
|
Title: "মূলত মাস্ক গোপন করুন",
|
||||||
|
SubTitle: "মাস্ক তালিকা থেকে মূলত মাস্কগুলি লুকান",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Prompt: {
|
||||||
|
Disable: {
|
||||||
|
Title: "অটো-সম্পূর্ণতা নিষ্ক্রিয় করুন",
|
||||||
|
SubTitle: "অটো-সম্পূর্ণতা চালু করতে / ইনপুট করুন",
|
||||||
|
},
|
||||||
|
List: "প্রম্পট তালিকা",
|
||||||
|
ListCount: (builtin: number, custom: number) =>
|
||||||
|
`${builtin} built-in, ${custom} user-defined`,
|
||||||
|
Edit: "সম্পাদন করুন",
|
||||||
|
Modal: {
|
||||||
|
Title: "প্রম্পট তালিকা",
|
||||||
|
Add: "একটি যোগ করুন",
|
||||||
|
Search: "সন্ধান প্রম্পট",
|
||||||
|
},
|
||||||
|
EditModal: {
|
||||||
|
Title: "সম্পাদন করুন প্রম্পট",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
HistoryCount: {
|
||||||
|
Title: "সংযুক্ত বার্তা সংখ্যা",
|
||||||
|
SubTitle: "প্রতি অনুরোধে প্রেরণ করা গেলে প্রেরণ করা হবে",
|
||||||
|
},
|
||||||
|
CompressThreshold: {
|
||||||
|
Title: "ইতিহাস সঙ্কুচিত করার সীমা",
|
||||||
|
SubTitle:
|
||||||
|
"নকুল বার্তা দৈর্ঘ্য সীমা অতিক্রান্ত হলে ঐ বার্তাটি সঙ্কুচিত হবে",
|
||||||
|
},
|
||||||
|
Token: {
|
||||||
|
Title: "অ্যাপি কী",
|
||||||
|
SubTitle: "অ্যাক্সেস কোড সীমা উপেক্ষা করতে আপনার কীটি ব্যবহার করুন",
|
||||||
|
Placeholder: "OpenAI API কী",
|
||||||
|
},
|
||||||
|
Usage: {
|
||||||
|
Title: "একাউন্ট ব্যালেন্স",
|
||||||
|
SubTitle(used: any, total: any) {
|
||||||
|
return `এই মাসে ব্যবহৃত $${used}, সাবস্ক্রিপশন $${total}`;
|
||||||
|
},
|
||||||
|
IsChecking: "চেক করা হচ্ছে...",
|
||||||
|
Check: "চেক",
|
||||||
|
NoAccess: "ব্যালেন্স চেক করতে অ্যাপি কী ইনপুট করুন",
|
||||||
|
},
|
||||||
|
AccessCode: {
|
||||||
|
Title: "অ্যাক্সেস কোড",
|
||||||
|
SubTitle: "অ্যাক্সেস নিয়ন্ত্রণ সক্রিয়",
|
||||||
|
Placeholder: "অ্যাক্সেস কোড প্রয়োজন",
|
||||||
|
},
|
||||||
|
Endpoint: {
|
||||||
|
Title: "ইনটারপয়েন্ট",
|
||||||
|
SubTitle: "কাস্টম এন্ডপয়েন্টটি হতে হবে http(s):// দিয়ে শুরু হতে হবে",
|
||||||
|
},
|
||||||
|
Model: "মডেল",
|
||||||
|
Temperature: {
|
||||||
|
Title: "তাপমাত্রা",
|
||||||
|
SubTitle: "আরতি মান বেশি করলে বেশি এলোমেলো আউটপুট হবে",
|
||||||
|
},
|
||||||
|
TopP: {
|
||||||
|
Title: "শীর্ষ পি",
|
||||||
|
SubTitle: "তাপমাত্রা সঙ্গে এই মান পরিবর্তন করবেন না",
|
||||||
|
},
|
||||||
|
MaxTokens: {
|
||||||
|
Title: "সর্বাধিক টোকেন",
|
||||||
|
SubTitle: "ইনপুট টোকেন এবং উৎপাদিত টোকেনের সর্বাধিক দৈর্ঘ্য",
|
||||||
|
},
|
||||||
|
PresencePenalty: {
|
||||||
|
Title: "উপস্থিতির জরিমানা",
|
||||||
|
SubTitle: "আরতি মান বেশি করলে নতুন বিষয়গুলি সম্ভাব্যতা বাড়াতে পারে",
|
||||||
|
},
|
||||||
|
FrequencyPenalty: {
|
||||||
|
Title: "ফ্রিকুয়েন্সি জরিমানা",
|
||||||
|
SubTitle:
|
||||||
|
"আরতি মান বাড়ালে একই লাইন পুনরায় ব্যাবহার করার সম্ভাবনা হ্রাস পায়",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Store: {
|
||||||
|
DefaultTopic: "নতুন সংলাপ",
|
||||||
|
BotHello: "হ্যালো! আজকে আপনাকে কিভাবে সাহায্য করতে পারি?",
|
||||||
|
Error: "কিছু নিয়ে ভুল হয়েছে, পরে আবার চেষ্টা করুন।",
|
||||||
|
Prompt: {
|
||||||
|
History: (content: string) =>
|
||||||
|
"এটি চ্যাট ইতিহাসের সংক্ষিপ্ত সংকলনের মতো: " + content,
|
||||||
|
Topic:
|
||||||
|
"আমাদের সংলাপটির চার থেকে পাঁচ শব্দের একটি শিরোনাম তৈরি করুন যা আমাদের আলাপের সংক্ষিপ্তসার হিসাবে যোগ হবে না, যেমন অভিবৃত্তি, বিন্যাস, উদ্ধৃতি, পূর্বচালক চিহ্ন, পূর্বরোবক্তির যেকোনো চিহ্ন বা অতিরিক্ত পাঠ। মেয়াদশেষ উদ্ধৃতি চেষ্টা করুন।",
|
||||||
|
Summarize:
|
||||||
|
"২০০ শব্দের লম্বা হয়ে মুহূর্তে আলোচনা সংক্ষেপের রপ্তানি করুন, যেটি ভবিষ্যতের প্রম্পট হিসাবে ব্যবহার করবেন।",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Copy: {
|
||||||
|
Success: "ক্লিপবোর্ডে কপি করা হয়েছে",
|
||||||
|
Failed: "কপি ব্যর্থ, অনুমতি প্রদান করার জন্য অনুমতি প্রদান করুন",
|
||||||
|
},
|
||||||
|
Context: {
|
||||||
|
Toast: (x: any) => `With ${x} contextual prompts`,
|
||||||
|
Edit: "বর্তমান চ্যাট সেটিংস",
|
||||||
|
Add: "একটি প্রম্পট যোগ করুন",
|
||||||
|
Clear: "সঙ্গতি পরিস্কার করুন",
|
||||||
|
Revert: "পূর্ববর্তী অবস্থানে ফিরে যান",
|
||||||
|
},
|
||||||
|
Plugin: {
|
||||||
|
Name: "প্লাগইন",
|
||||||
|
},
|
||||||
|
Mask: {
|
||||||
|
Name: "মাস্ক",
|
||||||
|
Page: {
|
||||||
|
Title: "প্রম্পট টেমপ্লেট",
|
||||||
|
SubTitle: (count: number) => `${count} টি প্রম্পট টেমপ্লেট`,
|
||||||
|
Search: "টেমপ্লেট অনুসন্ধান করুন",
|
||||||
|
Create: "তৈরি করুন",
|
||||||
|
},
|
||||||
|
Item: {
|
||||||
|
Info: (count: number) => `${count} প্রম্পট`,
|
||||||
|
Chat: "চ্যাট",
|
||||||
|
View: "দেখুন",
|
||||||
|
Edit: "সম্পাদন করুন",
|
||||||
|
Delete: "মুছে ফেলুন",
|
||||||
|
DeleteConfirm: "মুছে ফেলতে নিশ্চিত করুন?",
|
||||||
|
},
|
||||||
|
EditModal: {
|
||||||
|
Title: (readonly: boolean) =>
|
||||||
|
`প্রম্পট টেমপ্লেট সম্পাদন করুন ${readonly ? "(readonly)" : ""}`,
|
||||||
|
Download: "ডাউনলোড করুন",
|
||||||
|
Clone: "ক্লোন করুন",
|
||||||
|
},
|
||||||
|
Config: {
|
||||||
|
Avatar: "বট অবতার",
|
||||||
|
Name: "বটের নাম",
|
||||||
|
Sync: {
|
||||||
|
Title: "গ্লোবাল কনফিগ ব্যবহার করুন",
|
||||||
|
SubTitle: "এই চ্যাটে গ্লোবাল কনফিগ ব্যবহার করুন",
|
||||||
|
Confirm: "গ্লোবাল কনফিগ দ্বারা কাস্টম কনফিগ ওভাররাইড করতে নিশ্চিত করতে?",
|
||||||
|
},
|
||||||
|
HideContext: {
|
||||||
|
Title: "সংশ্লিষ্টতা প্রম্পটগুলি লুকান",
|
||||||
|
SubTitle: "চ্যাটে সংশ্লিষ্টতা প্রম্পটগুলি দেখাবেন না",
|
||||||
|
},
|
||||||
|
Share: {
|
||||||
|
Title: "এই মাস্কটি শেয়ার করুন",
|
||||||
|
SubTitle: "এই মাস্কের একটি লিঙ্ক তৈরি করুন",
|
||||||
|
Action: "লিঙ্ক কপি করুন",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
NewChat: {
|
||||||
|
Return: "ফিরে যান",
|
||||||
|
Skip: "শুরু করুন",
|
||||||
|
Title: "মাস্ক নির্বাচন করুন",
|
||||||
|
SubTitle: "মাস্কের পিছনে আত্মার সঙ্গে চ্যাট করুন",
|
||||||
|
More: "আরো খুঁজুন",
|
||||||
|
NotShow: "এখনও দেখাবেন না",
|
||||||
|
ConfirmNoShow: "নিষ্ক্রিয় করতে নিশ্চিত করুন? পরে আপনি এটি সেটিংসে সক্ষম করতে পারবেন।",
|
||||||
|
},
|
||||||
|
|
||||||
|
UI: {
|
||||||
|
Confirm: "নিশ্চিত করুন",
|
||||||
|
Cancel: "বাতিল করুন",
|
||||||
|
Close: "বন্ধ করুন",
|
||||||
|
Create: "তৈরি করুন",
|
||||||
|
Edit: "সম্পাদন করুন",
|
||||||
|
},
|
||||||
|
Exporter: {
|
||||||
|
Model: "মডেল",
|
||||||
|
Messages: "বার্তা",
|
||||||
|
Topic: "টপিক",
|
||||||
|
Time: "সময়",
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
export default bn;
|
@ -13,6 +13,7 @@ import no from "./no";
|
|||||||
import cs from "./cs";
|
import cs from "./cs";
|
||||||
import ko from "./ko";
|
import ko from "./ko";
|
||||||
import ar from "./ar";
|
import ar from "./ar";
|
||||||
|
import bn from "./bn";
|
||||||
import { merge } from "../utils/merge";
|
import { merge } from "../utils/merge";
|
||||||
|
|
||||||
import type { LocaleType } from "./cn";
|
import type { LocaleType } from "./cn";
|
||||||
@ -34,6 +35,7 @@ const ALL_LANGS = {
|
|||||||
cs,
|
cs,
|
||||||
no,
|
no,
|
||||||
ar,
|
ar,
|
||||||
|
bn,
|
||||||
};
|
};
|
||||||
|
|
||||||
export type Lang = keyof typeof ALL_LANGS;
|
export type Lang = keyof typeof ALL_LANGS;
|
||||||
@ -56,6 +58,7 @@ export const ALL_LANG_OPTIONS: Record<Lang, string> = {
|
|||||||
cs: "Čeština",
|
cs: "Čeština",
|
||||||
no: "Nynorsk",
|
no: "Nynorsk",
|
||||||
ar: "العربية",
|
ar: "العربية",
|
||||||
|
bn: "বাংলা",
|
||||||
};
|
};
|
||||||
|
|
||||||
const LANG_KEY = "lang";
|
const LANG_KEY = "lang";
|
||||||
|
Loading…
x
Reference in New Issue
Block a user