mirror of
https://github.com/langgenius/dify.git
synced 2025-12-19 17:27:16 -05:00
feat(i18n): add Tunisian Arabic (ar-TN) translation (#29306)
Signed-off-by: yyh <yuanyouhuilyz@gmail.com> Co-authored-by: yyh <yuanyouhuilyz@gmail.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
This commit is contained in:
@@ -20,6 +20,7 @@ language_timezone_mapping = {
|
||||
"sl-SI": "Europe/Ljubljana",
|
||||
"th-TH": "Asia/Bangkok",
|
||||
"id-ID": "Asia/Jakarta",
|
||||
"ar-TN": "Africa/Tunis",
|
||||
}
|
||||
|
||||
languages = list(language_timezone_mapping.keys())
|
||||
|
||||
@@ -185,6 +185,14 @@ export default combine(
|
||||
sonarjs: sonar,
|
||||
},
|
||||
},
|
||||
// allow generated i18n files (like i18n/*/workflow.ts) to exceed max-lines
|
||||
{
|
||||
files: ['i18n/**'],
|
||||
rules: {
|
||||
'sonarjs/max-lines': 'off',
|
||||
'max-lines': 'off',
|
||||
},
|
||||
},
|
||||
// need further research
|
||||
{
|
||||
rules: {
|
||||
|
||||
@@ -70,6 +70,8 @@ export type I18nText = {
|
||||
'uk-UA': string
|
||||
'id-ID': string
|
||||
'tr-TR': string
|
||||
'fa-IR': string
|
||||
'ar-TN': string
|
||||
'YOUR_LANGUAGE_CODE': string
|
||||
}
|
||||
```
|
||||
@@ -157,6 +159,18 @@ export const languages = [
|
||||
example: 'Привет, Dify!',
|
||||
supported: true,
|
||||
},
|
||||
{
|
||||
value: 'fa-IR',
|
||||
name: 'Farsi (Iran)',
|
||||
example: 'سلام, دیفای!',
|
||||
supported: true,
|
||||
},
|
||||
{
|
||||
value: 'ar-TN',
|
||||
name: 'العربية (تونس)',
|
||||
example: 'مرحبا، Dify!',
|
||||
supported: true,
|
||||
},
|
||||
// Add your language here 👇
|
||||
...
|
||||
// Add your language here 👆
|
||||
|
||||
@@ -27,6 +27,7 @@ export type I18nText = {
|
||||
'tr-TR': string
|
||||
'fa-IR': string
|
||||
'sl-SI': string
|
||||
'ar-TN': string
|
||||
}
|
||||
|
||||
export const languages = data.languages
|
||||
@@ -81,6 +82,7 @@ export const NOTICE_I18N = {
|
||||
tr_TR: 'Önemli Duyuru',
|
||||
fa_IR: 'هشدار مهم',
|
||||
sl_SI: 'Pomembno obvestilo',
|
||||
ar_TN: 'إشعار مهم',
|
||||
},
|
||||
desc: {
|
||||
en_US:
|
||||
@@ -117,6 +119,8 @@ export const NOTICE_I18N = {
|
||||
'Naš sistem ne bo na voljo od 19:00 do 24:00 UTC 28. avgusta zaradi nadgradnje. Za vprašanja se obrnite na našo skupino za podporo (support@dify.ai). Cenimo vašo potrpežljivost.',
|
||||
th_TH:
|
||||
'ระบบของเราจะไม่สามารถใช้งานได้ตั้งแต่เวลา 19:00 ถึง 24:00 UTC ในวันที่ 28 สิงหาคม เพื่อทำการอัปเกรด หากมีคำถามใดๆ กรุณาติดต่อทีมสนับสนุนของเรา (support@dify.ai) เราขอขอบคุณในความอดทนของท่าน',
|
||||
ar_TN:
|
||||
'سيكون نظامنا غير متاح من الساعة 19:00 إلى 24:00 بالتوقيت العالمي المنسق في 28 أغسطس لإجراء ترقية. للأسئلة، يرجى الاتصال بفريق الدعم لدينا (support@dify.ai). نحن نقدر صبرك.',
|
||||
},
|
||||
href: '#',
|
||||
}
|
||||
|
||||
@@ -146,6 +146,13 @@
|
||||
"prompt_name": "Indonesian",
|
||||
"example": "Halo, Dify!",
|
||||
"supported": true
|
||||
},
|
||||
{
|
||||
"value": "ar-TN",
|
||||
"name": "العربية (تونس)",
|
||||
"prompt_name": "Tunisian Arabic",
|
||||
"example": "مرحبا، Dify!",
|
||||
"supported": true
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
98
web/i18n/ar-TN/app-annotation.ts
Normal file
98
web/i18n/ar-TN/app-annotation.ts
Normal file
@@ -0,0 +1,98 @@
|
||||
const translation = {
|
||||
title: 'التعليقات التوضيحية',
|
||||
name: 'رد التعليق التوضيحي',
|
||||
editBy: 'تم تعديل الإجابة بواسطة {{author}}',
|
||||
noData: {
|
||||
title: 'لا توجد تعليقات توضيحية',
|
||||
description: 'يمكنك تعديل التعليقات التوضيحية أثناء تصحيح أخطاء التطبيق أو استيراد التعليقات التوضيحية بالجملة هنا للحصول على استجابة عالية الجودة.',
|
||||
},
|
||||
table: {
|
||||
header: {
|
||||
question: 'السؤال',
|
||||
answer: 'الإجابة',
|
||||
createdAt: 'تم الإنشاء في',
|
||||
hits: 'المطابقات',
|
||||
actions: 'الإجراءات',
|
||||
addAnnotation: 'إضافة تعليق توضيحي',
|
||||
bulkImport: 'استيراد بالجملة',
|
||||
bulkExport: 'تصدير بالجملة',
|
||||
clearAll: 'حذف الكل',
|
||||
clearAllConfirm: 'حذف جميع التعليقات التوضيحية؟',
|
||||
},
|
||||
},
|
||||
editModal: {
|
||||
title: 'تعديل رد التعليق التوضيحي',
|
||||
queryName: 'استعلام المستخدم',
|
||||
answerName: 'الراوي',
|
||||
yourAnswer: 'إجابتك',
|
||||
answerPlaceholder: 'اكتب إجابتك هنا',
|
||||
yourQuery: 'استعلامك',
|
||||
queryPlaceholder: 'اكتب استعلامك هنا',
|
||||
removeThisCache: 'حذف هذا التعليق التوضيحي',
|
||||
createdAt: 'تم الإنشاء في',
|
||||
},
|
||||
addModal: {
|
||||
title: 'إضافة رد تعليق توضيحي',
|
||||
queryName: 'السؤال',
|
||||
answerName: 'الإجابة',
|
||||
answerPlaceholder: 'اكتب الإجابة هنا',
|
||||
queryPlaceholder: 'اكتب الاستعلام هنا',
|
||||
createNext: 'إضافة رد توضيحي آخر',
|
||||
},
|
||||
batchModal: {
|
||||
title: 'استيراد بالجملة',
|
||||
csvUploadTitle: 'اسحب وأفلت ملف CSV هنا، أو ',
|
||||
browse: 'تصفح',
|
||||
tip: 'يجب أن يتوافق ملف CSV مع الهيكل التالي:',
|
||||
question: 'السؤال',
|
||||
answer: 'الإجابة',
|
||||
contentTitle: 'محتوى المقطع',
|
||||
content: 'المحتوى',
|
||||
template: 'تحميل القالب من هنا',
|
||||
cancel: 'إلغاء',
|
||||
run: 'تشغيل الدفعة',
|
||||
runError: 'فشل تشغيل الدفعة',
|
||||
processing: 'جاري المعالجة',
|
||||
completed: 'اكتمل الاستيراد',
|
||||
error: 'خطأ في الاستيراد',
|
||||
ok: 'موافق',
|
||||
},
|
||||
list: {
|
||||
delete: {
|
||||
title: 'هل أنت متأكد من الحذف؟',
|
||||
},
|
||||
},
|
||||
batchAction: {
|
||||
selected: 'المحدد',
|
||||
delete: 'حذف',
|
||||
cancel: 'إلغاء',
|
||||
},
|
||||
errorMessage: {
|
||||
answerRequired: 'الإجابة مطلوبة',
|
||||
queryRequired: 'السؤال مطلوب',
|
||||
},
|
||||
viewModal: {
|
||||
annotatedResponse: 'رد التعليق التوضيحي',
|
||||
hitHistory: 'سجل المطابقة',
|
||||
hit: 'مطابقة',
|
||||
hits: 'مطابقات',
|
||||
noHitHistory: 'لا يوجد سجل مطابقة',
|
||||
},
|
||||
hitHistoryTable: {
|
||||
query: 'الاستعلام',
|
||||
match: 'المطابقة',
|
||||
response: 'الاستجابة',
|
||||
source: 'المصدر',
|
||||
score: 'النتيجة',
|
||||
time: 'الوقت',
|
||||
},
|
||||
initSetup: {
|
||||
title: 'الإعداد الأولي لرد التعليق التوضيحي',
|
||||
configTitle: 'إعداد رد التعليق التوضيحي',
|
||||
confirmBtn: 'حفظ وتمكين',
|
||||
configConfirmBtn: 'حفظ',
|
||||
},
|
||||
embeddingModelSwitchTip: 'سيؤدي تبديل نموذج التضمين للنص التوضيحي إلى إعادة التضمين، مما يؤدي إلى تكاليف إضافية.',
|
||||
}
|
||||
|
||||
export default translation
|
||||
85
web/i18n/ar-TN/app-api.ts
Normal file
85
web/i18n/ar-TN/app-api.ts
Normal file
@@ -0,0 +1,85 @@
|
||||
const translation = {
|
||||
apiServer: 'خادم API',
|
||||
apiKey: 'مفتاح API',
|
||||
status: 'الحالة',
|
||||
disabled: 'معطل',
|
||||
ok: 'في الخدمة',
|
||||
copy: 'نسخ',
|
||||
copied: 'تم النسخ',
|
||||
regenerate: 'إعادة إنشاء',
|
||||
play: 'تشغيل',
|
||||
pause: 'إيقاف مؤقت',
|
||||
playing: 'جاري التشغيل',
|
||||
loading: 'جاري التحميل',
|
||||
merMaid: {
|
||||
rerender: 'إعادة الرسم',
|
||||
},
|
||||
never: 'أبدا',
|
||||
apiKeyModal: {
|
||||
apiSecretKey: 'مفتاح API السري',
|
||||
apiSecretKeyTips: 'لمنع إساءة استخدام API، قم بحماية مفتاح API الخاص بك. تجنب استخدامه كنص عادي في كود الواجهة الأمامية. :)',
|
||||
createNewSecretKey: 'إنشاء مفتاح سري جديد',
|
||||
secretKey: 'المفتاح السري',
|
||||
created: 'تم الإنشاء',
|
||||
lastUsed: 'آخر استخدام',
|
||||
generateTips: 'احتفظ بهذا المفتاح في مكان آمن ويمكن الوصول إليه.',
|
||||
},
|
||||
actionMsg: {
|
||||
deleteConfirmTitle: 'حذف هذا المفتاح السري؟',
|
||||
deleteConfirmTips: 'لا يمكن التراجع عن هذا الإجراء.',
|
||||
ok: 'موافق',
|
||||
},
|
||||
completionMode: {
|
||||
title: 'API تطبيق الإكمال',
|
||||
info: 'لتوليد نصوص عالية الجودة، مثل المقالات والملخصات والترجمات، استخدم API رسائل الإكمال مع إدخال المستخدم. يعتمد توليد النص على معلمات النموذج وقوالب المطالبة المعينة في هندسة مطالبات Dify.',
|
||||
createCompletionApi: 'إنشاء رسالة إكمال',
|
||||
createCompletionApiTip: 'إنشاء رسالة إكمال لدعم وضع السؤال والجواب.',
|
||||
inputsTips: '(اختياري) توفير حقول إدخال المستخدم كأزواج مفتاح وقيمة، بما يتوافق مع المتغيرات في هندسة المطالبات. المفتاح هو اسم المتغير، والقيمة هي قيمة المعلمة. إذا كان نوع الحقل هو تحديد، فيجب أن تكون القيمة المرسلة واحدة من الخيارات المحددة مسبقًا.',
|
||||
queryTips: 'محتوى نص إدخال المستخدم.',
|
||||
blocking: 'نوع الحظر، في انتظار اكتمال التنفيذ وإرجاع النتائج. (قد يتم قطع الطلبات إذا كانت العملية طويلة)',
|
||||
streaming: 'عائدات التدفق. تنفيذ عائد التدفق بناءً على SSE (أحداث مرسلة من الخادم).',
|
||||
messageFeedbackApi: 'ملاحظات الرسالة (إعجاب)',
|
||||
messageFeedbackApiTip: 'قيم الرسائل المستلمة نيابة عن المستخدمين النهائيين بإعجاب أو عدم إعجاب. هذه البيانات مرئية في صفحة السجلات والتعليقات التوضيحية وتستخدم لضبط النموذج في المستقبل.',
|
||||
messageIDTip: 'معرف الرسالة',
|
||||
ratingTip: 'إعجاب أو عدم إعجاب، null للإلغاء',
|
||||
parametersApi: 'الحصول على معلومات حول معلمات التطبيق',
|
||||
parametersApiTip: 'استرداد معلمات الإدخال المكونة، بما في ذلك أسماء المتغيرات وأسماء الحقول والأنواع والقيم الافتراضية. تستخدم عادة لعرض هذه الحقول في نموذج أو ملء القيم الافتراضية بعد تحميل العميل.',
|
||||
},
|
||||
chatMode: {
|
||||
title: 'API تطبيق الدردشة',
|
||||
info: 'للتطبيقات المحادثة متعددة الاستخدامات باستخدام تنسيق Q&A، اتصل بـ API رسائل الدردشة لبدء الحوار. حافظ على المحادثات الجارية عن طريق تمرير conversation_id المرتجع. تعتمد معلمات الاستجابة والقوالب على إعدادات Dify Prompt Eng.',
|
||||
createChatApi: 'إنشاء رسالة دردشة',
|
||||
createChatApiTip: 'بناء رسالة محادثة جديدة أو استمرار حوار موجود.',
|
||||
inputsTips: '(اختياري) توفير حقول إدخال المستخدم كأزواج مفتاح وقيمة، بما يتوافق مع المتغيرات في هندسة المطالبات. المفتاح هو اسم المتغير، والقيمة هي قيمة المعلمة. إذا كان نوع الحقل هو تحديد، فيجب أن تكون القيمة المرسلة واحدة من الخيارات المحددة مسبقًا.',
|
||||
queryTips: 'محتوى إدخال/سؤال المستخدم',
|
||||
blocking: 'نوع الحظر، في انتظار اكتمال التنفيذ وإرجاع النتائج. (قد يتم قطع الطلبات إذا كانت العملية طويلة)',
|
||||
streaming: 'عائدات التدفق. تنفيذ عائد التدفق بناءً على SSE (أحداث مرسلة من الخادم).',
|
||||
conversationIdTip: '(اختياري) معرف المحادثة: اتركه فارغًا للمحادثة لأول مرة؛ مرر conversation_id من السياق لمتابعة الحوار.',
|
||||
messageFeedbackApi: 'ملاحظات مستخدم محطة الرسالة، إعجاب',
|
||||
messageFeedbackApiTip: 'قيم الرسائل المستلمة نيابة عن المستخدمين النهائيين بإعجاب أو عدم إعجاب. هذه البيانات مرئية في صفحة السجلات والتعليقات التوضيحية وتستخدم لضبط النموذج في المستقبل.',
|
||||
messageIDTip: 'معرف الرسالة',
|
||||
ratingTip: 'إعجاب أو عدم إعجاب، null للإلغاء',
|
||||
chatMsgHistoryApi: 'الحصول على رسالة سجل الدردشة',
|
||||
chatMsgHistoryApiTip: 'تُرجع الصفحة الأولى أحدث شريط `limit`، وهو بترتيب عكسي.',
|
||||
chatMsgHistoryConversationIdTip: 'معرف المحادثة',
|
||||
chatMsgHistoryFirstId: 'معرف سجل الدردشة الأول في الصفحة الحالية. الافتراضي هو لا شيء.',
|
||||
chatMsgHistoryLimit: 'كم عدد المحادثات التي يتم إرجاعها في طلب واحد',
|
||||
conversationsListApi: 'الحصول على قائمة المحادثات',
|
||||
conversationsListApiTip: 'يحصل على قائمة الجلسات للمستخدم الحالي. بشكل افتراضي، يتم إرجاع آخر 20 جلسة.',
|
||||
conversationsListFirstIdTip: 'معرف السجل الأخير في الصفحة الحالية، الافتراضي لا شيء.',
|
||||
conversationsListLimitTip: 'كم عدد المحادثات التي يتم إرجاعها في طلب واحد',
|
||||
conversationRenamingApi: 'إعادة تسمية المحادثة',
|
||||
conversationRenamingApiTip: 'إعادة تسمية المحادثات؛ يتم عرض الاسم في واجهات العملاء متعددة الجلسات.',
|
||||
conversationRenamingNameTip: 'اسم جديد',
|
||||
parametersApi: 'الحصول على معلومات حول معلمات التطبيق',
|
||||
parametersApiTip: 'استرداد معلمات الإدخال المكونة، بما في ذلك أسماء المتغيرات وأسماء الحقول والأنواع والقيم الافتراضية. تستخدم عادة لعرض هذه الحقول في نموذج أو ملء القيم الافتراضية بعد تحميل العميل.',
|
||||
},
|
||||
develop: {
|
||||
requestBody: 'جسم الطلب (Request Body)',
|
||||
pathParams: 'معلمات المسار (Path Params)',
|
||||
query: 'استعلام (Query)',
|
||||
toc: 'المحتويات',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
571
web/i18n/ar-TN/app-debug.ts
Normal file
571
web/i18n/ar-TN/app-debug.ts
Normal file
@@ -0,0 +1,571 @@
|
||||
const translation = {
|
||||
pageTitle: {
|
||||
line1: 'المطالبة',
|
||||
line2: 'الهندسة',
|
||||
},
|
||||
orchestrate: 'تنسيق',
|
||||
promptMode: {
|
||||
simple: 'التبديل إلى وضع الخبير لتعديل المطالبة بالكامل',
|
||||
advanced: 'وضع الخبير',
|
||||
switchBack: 'التبديل مرة أخرى',
|
||||
advancedWarning: {
|
||||
title: 'لقد انتقلت إلى وضع الخبير، وبمجرد تعديل المطالبة، لا يمكنك العودة إلى الوضع الأساسي.',
|
||||
description: 'في وضع الخبير، يمكنك تعديل المطالبة بالكامل.',
|
||||
learnMore: 'اعرف المزيد',
|
||||
ok: 'موافق',
|
||||
},
|
||||
operation: {
|
||||
addMessage: 'إضافة رسالة',
|
||||
},
|
||||
contextMissing: 'مكون السياق مفقود، قد لا تكون فعالية المطالبة جيدة.',
|
||||
},
|
||||
operation: {
|
||||
applyConfig: 'نشر',
|
||||
resetConfig: 'إعادة تعيين',
|
||||
debugConfig: 'تصحيح',
|
||||
addFeature: 'إضافة ميزة',
|
||||
automatic: 'توليد',
|
||||
stopResponding: 'إيقاف الاستجابة',
|
||||
agree: 'إعجاب',
|
||||
disagree: 'لم يعجبني',
|
||||
cancelAgree: 'إلغاء الإعجاب',
|
||||
cancelDisagree: 'إلغاء عدم الإعجاب',
|
||||
userAction: 'المستخدم ',
|
||||
},
|
||||
notSetAPIKey: {
|
||||
title: 'لم يتم تعيين مفتاح مزود LLM',
|
||||
trailFinished: 'انتهت التجربة',
|
||||
description: 'لم يتم تعيين مفتاح مزود LLM، ويجب تعيينه قبل تصحيح الأخطاء.',
|
||||
settingBtn: 'الذهاب إلى الإعدادات',
|
||||
},
|
||||
trailUseGPT4Info: {
|
||||
title: 'لا يدعم gpt-4 الآن',
|
||||
description: 'لاستخدام gpt-4، يرجى تعيين مفتاح API.',
|
||||
},
|
||||
feature: {
|
||||
groupChat: {
|
||||
title: 'تحسين الدردشة',
|
||||
description: 'أضف إعدادات ما قبل المحادثة للتطبيقات يمكن أن يعزز تجربة المستخدم.',
|
||||
},
|
||||
groupExperience: {
|
||||
title: 'تحسين التجربة',
|
||||
},
|
||||
conversationOpener: {
|
||||
title: 'فاتحة المحادثة',
|
||||
description: 'في تطبيق الدردشة، يتم استخدام الجملة الأولى التي يتحدث بها الذكاء الاصطناعي بنشاط للمستخدم عادةً كترحيب.',
|
||||
},
|
||||
suggestedQuestionsAfterAnswer: {
|
||||
title: 'متابعة',
|
||||
description: 'يمكن أن يعطي إعداد اقتراح الأسئلة التالية للمستخدمين دردشة أفضل.',
|
||||
resDes: '3 اقتراحات للسؤال التالي للمستخدم.',
|
||||
tryToAsk: 'حاول أن تسأل',
|
||||
},
|
||||
moreLikeThis: {
|
||||
title: 'المزيد مثل هذا',
|
||||
description: 'توليد نصوص متعددة في وقت واحد، ثم تحريرها ومتابعة التوليد',
|
||||
generateNumTip: 'عدد مرات التوليد لكل مرة',
|
||||
tip: 'سيؤدي استخدام هذه الميزة إلى تكبد نفقات إضافية للرموز',
|
||||
},
|
||||
speechToText: {
|
||||
title: 'تحويل الكلام إلى نص',
|
||||
description: 'يمكن استخدام الإدخال الصوتي في الدردشة.',
|
||||
resDes: 'تم تمكين الإدخال الصوتي',
|
||||
},
|
||||
textToSpeech: {
|
||||
title: 'تحويل النص إلى كلام',
|
||||
description: 'يمكن تحويل رسائل المحادثة إلى كلام.',
|
||||
resDes: 'تم تمكين تحويل النص إلى صوت',
|
||||
},
|
||||
citation: {
|
||||
title: 'الاقتباسات والسمات',
|
||||
description: 'عرض المستند المصدري والقسم المنسوب للمحتوى المولد.',
|
||||
resDes: 'تم تمكين الاقتباسات والسمات',
|
||||
},
|
||||
annotation: {
|
||||
title: 'رد التعليق التوضيحي',
|
||||
description: 'يمكنك إضافة استجابة عالية الجودة يدويًا إلى ذاكرة التخزين المؤقت للمطابقة ذات الأولوية مع أسئلة المستخدم المماثلة.',
|
||||
resDes: 'تم تمكين استجابة التعليق التوضيحي',
|
||||
scoreThreshold: {
|
||||
title: 'عتبة النتيجة',
|
||||
description: 'يستخدم لتعيين عتبة التشابه لرد التعليق التوضيحي.',
|
||||
easyMatch: 'تطابق سهل',
|
||||
accurateMatch: 'تطابق دقيق',
|
||||
},
|
||||
matchVariable: {
|
||||
title: 'متغير المطابقة',
|
||||
choosePlaceholder: 'اختر متغير المطابقة',
|
||||
},
|
||||
cacheManagement: 'التعليقات التوضيحية',
|
||||
cached: 'تم التعليق',
|
||||
remove: 'إزالة',
|
||||
removeConfirm: 'حذف هذا التعليق التوضيحي؟',
|
||||
add: 'إضافة تعليق توضيحي',
|
||||
edit: 'تعديل التعليق التوضيحي',
|
||||
},
|
||||
dataSet: {
|
||||
title: 'المعرفة',
|
||||
noData: 'يمكنك استيراد المعرفة كسياق',
|
||||
selectTitle: 'حدد المعرفة المرجعية',
|
||||
selected: 'تم تحديد المعرفة',
|
||||
noDataSet: 'لم يتم العثور على معرفة',
|
||||
toCreate: 'الذهاب للإنشاء',
|
||||
notSupportSelectMulti: 'دعم معرفة واحدة فقط حاليًا',
|
||||
queryVariable: {
|
||||
title: 'متغير الاستعلام',
|
||||
tip: 'سيتم استخدام هذا المتغير كمدخل استعلام لاسترجاع السياق، والحصول على معلومات السياق المتعلقة بمدخل هذا المتغير.',
|
||||
choosePlaceholder: 'اختر متغير الاستعلام',
|
||||
noVar: 'لا توجد متغيرات',
|
||||
noVarTip: 'يرجى إنشاء متغير في قسم المتغيرات',
|
||||
unableToQueryDataSet: 'غير قادر على استعلام المعرفة',
|
||||
unableToQueryDataSetTip: 'غير قادر على استعلام المعرفة بنجاح، يرجى اختيار متغير استعلام سياق في قسم السياق.',
|
||||
ok: 'موافق',
|
||||
contextVarNotEmpty: 'لا يمكن أن يكون متغير استعلام السياق فارغًا',
|
||||
deleteContextVarTitle: 'حذف المتغير "{{varName}}"؟',
|
||||
deleteContextVarTip: 'تم تعيين هذا المتغير كمتغير استعلام سياق، وسيؤثر إزالته على الاستخدام العادي للمعرفة. إذا كنت لا تزال بحاجة إلى حذفه، يرجى إعادة تحديده في قسم السياق.',
|
||||
},
|
||||
},
|
||||
tools: {
|
||||
title: 'الأدوات',
|
||||
tips: 'توفر الأدوات طريقة استدعاء API قياسية، مع أخذ مدخلات المستخدم أو المتغيرات كمعلمات طلب للاستعلام عن البيانات الخارجية كسياق.',
|
||||
toolsInUse: '{{count}} أدوات قيد الاستخدام',
|
||||
modal: {
|
||||
title: 'أداة',
|
||||
toolType: {
|
||||
title: 'نوع الأداة',
|
||||
placeholder: 'يرجى اختيار نوع الأداة',
|
||||
},
|
||||
name: {
|
||||
title: 'الاسم',
|
||||
placeholder: 'يرجى إدخال الاسم',
|
||||
},
|
||||
variableName: {
|
||||
title: 'اسم المتغير',
|
||||
placeholder: 'يرجى إدخال اسم المتغير',
|
||||
},
|
||||
},
|
||||
},
|
||||
conversationHistory: {
|
||||
title: 'سجل المحادثة',
|
||||
description: 'تعيين أسماء بادئة لأدوار المحادثة',
|
||||
tip: 'لم يتم تمكين سجل المحادثة، يرجى إضافة <histories> في المطالبة أعلاه.',
|
||||
learnMore: 'اعرف المزيد',
|
||||
editModal: {
|
||||
title: 'تعديل أسماء أدوار المحادثة',
|
||||
userPrefix: 'بادئة المستخدم',
|
||||
assistantPrefix: 'بادئة المساعد',
|
||||
},
|
||||
},
|
||||
toolbox: {
|
||||
title: 'صندوق الأدوات',
|
||||
},
|
||||
moderation: {
|
||||
title: 'تعديل المحتوى',
|
||||
description: 'تأمين إخراج النموذج باستخدام API التعديل أو الحفاظ على قائمة كلمات حساسة.',
|
||||
contentEnableLabel: 'تم تمكين تعديل المحتوى',
|
||||
allEnabled: 'الإدخال والإخراج',
|
||||
inputEnabled: 'الإدخال',
|
||||
outputEnabled: 'الإخراج',
|
||||
modal: {
|
||||
title: 'إعدادات تعديل المحتوى',
|
||||
provider: {
|
||||
title: 'المزود',
|
||||
openai: 'OpenAI Moderation',
|
||||
openaiTip: {
|
||||
prefix: 'تتطلب OpenAI Moderation مفتاح OpenAI API تم تكوينه في ',
|
||||
suffix: '.',
|
||||
},
|
||||
keywords: 'الكلمات الرئيسية',
|
||||
},
|
||||
keywords: {
|
||||
tip: 'واحد لكل سطر، مفصولة بفواصل الأسطر. ما يصل إلى 100 حرف لكل سطر.',
|
||||
placeholder: 'واحد لكل سطر، مفصولة بفواصل الأسطر',
|
||||
line: 'سطر',
|
||||
},
|
||||
content: {
|
||||
input: 'تعديل محتوى الإدخال',
|
||||
output: 'تعديل محتوى الإخراج',
|
||||
preset: 'ردود محددة مسبقًا',
|
||||
placeholder: 'محتوى الردود المحددة مسبقًا هنا',
|
||||
condition: 'تم تمكين تعديل محتوى الإدخال والإخراج واحد على الأقل',
|
||||
fromApi: 'يتم إرجاع الردود المحددة مسبقًا بواسطة API',
|
||||
errorMessage: 'لا يمكن أن تكون الردود المحددة مسبقًا فارغة',
|
||||
supportMarkdown: 'دعم Markdown',
|
||||
},
|
||||
openaiNotConfig: {
|
||||
before: 'تتطلب OpenAI Moderation مفتاح OpenAI API تم تكوينه في',
|
||||
after: '',
|
||||
},
|
||||
},
|
||||
},
|
||||
fileUpload: {
|
||||
title: 'تحميل الملف',
|
||||
description: 'يسمح مربع إدخال الدردشة بتحميل الصور والمستندات والملفات الأخرى.',
|
||||
supportedTypes: 'أنواع الملفات المدعومة',
|
||||
numberLimit: 'الحد الأقصى للتحميلات',
|
||||
modalTitle: 'إعداد تحميل الملف',
|
||||
},
|
||||
imageUpload: {
|
||||
title: 'تحميل الصور',
|
||||
description: 'السماح بتحميل الصور.',
|
||||
supportedTypes: 'أنواع الملفات المدعومة',
|
||||
numberLimit: 'الحد الأقصى للتحميلات',
|
||||
modalTitle: 'إعداد تحميل الصور',
|
||||
},
|
||||
bar: {
|
||||
empty: 'تمكين الميزة لتعزيز تجربة مستخدم تطبيق الويب',
|
||||
enableText: 'تم تمكين الميزات',
|
||||
manage: 'إدارة',
|
||||
},
|
||||
documentUpload: {
|
||||
title: 'مستند',
|
||||
description: 'سيسمح تمكين المستند للنموذج بأخذ المستندات والإجابة على الأسئلة حولها.',
|
||||
},
|
||||
audioUpload: {
|
||||
title: 'صوت',
|
||||
description: 'سيسمح تمكين الصوت للنموذج بمعالجة ملفات الصوت للنسخ والتحليل.',
|
||||
},
|
||||
},
|
||||
codegen: {
|
||||
title: 'مولد الكود',
|
||||
description: 'يستخدم مولد الكود النماذج المكونة لتوليد كود عالي الجودة بناءً على تعليماتك. يرجى تقديم تعليمات واضحة ومفصلة.',
|
||||
instruction: 'تعليمات',
|
||||
instructionPlaceholder: 'أدخل وصفًا تفصيليًا للكود الذي تريد توليده.',
|
||||
noDataLine1: 'صف حالة استخدامك على اليسار،',
|
||||
noDataLine2: 'سيظهر معاينة الكود هنا.',
|
||||
generate: 'توليد',
|
||||
generatedCodeTitle: 'الكود المولد',
|
||||
loading: 'جاري توليد الكود...',
|
||||
apply: 'تطبيق',
|
||||
applyChanges: 'تطبيق التغييرات',
|
||||
resTitle: 'الكود المولد',
|
||||
overwriteConfirmTitle: 'استبدال الكود الموجود؟',
|
||||
overwriteConfirmMessage: 'سيؤدي هذا الإجراء إلى استبدال الكود الموجود. هل تريد المتابعة؟',
|
||||
},
|
||||
generate: {
|
||||
title: 'مولد المطالبة',
|
||||
description: 'يستخدم مولد المطالبة النموذج المكون لتحسين المطالبات للحصول على جودة أعلى وبنية أفضل. يرجى كتابة تعليمات واضحة ومفصلة.',
|
||||
tryIt: 'جربه',
|
||||
instruction: 'تعليمات',
|
||||
instructionPlaceHolderTitle: 'صف كيف ترغب في تحسين هذه المطالبة. على سبيل المثال:',
|
||||
instructionPlaceHolderLine1: 'اجعل الإخراج أكثر إيجازًا، مع الاحتفاظ بالنقاط الأساسية.',
|
||||
instructionPlaceHolderLine2: 'تنسيق الإخراج غير صحيح، يرجى اتباع تنسيق JSON بدقة.',
|
||||
instructionPlaceHolderLine3: 'النبرة قاسية جدًا، يرجى جعلها أكثر ودية.',
|
||||
codeGenInstructionPlaceHolderLine: 'كلما كانت الملاحظات أكثر تفصيلاً، مثل أنواع بيانات الإدخال والإخراج وكذلك كيفية معالجة المتغيرات، كلما كان توليد الكود أكثر دقة.',
|
||||
idealOutput: 'المخرجات المثالية',
|
||||
idealOutputPlaceholder: 'صف تنسيق الاستجابة المثالي، والطول، والنبرة، ومتطلبات المحتوى...',
|
||||
optional: 'اختياري',
|
||||
dismiss: 'تجاهل',
|
||||
generate: 'توليد',
|
||||
resTitle: 'المطالبة المولدة',
|
||||
newNoDataLine1: 'اكتب تعليمات في العمود الأيسر، وانقر فوق توليد لرؤية الاستجابة. ',
|
||||
apply: 'تطبيق',
|
||||
loading: 'تنسيق التطبيق لك...',
|
||||
overwriteTitle: 'تجاوز التكوين الحالي؟',
|
||||
overwriteMessage: 'سيؤدي تطبيق هذه المطالبة إلى تجاوز التكوين الحالي.',
|
||||
template: {
|
||||
pythonDebugger: {
|
||||
name: 'مصحح أخطاء بايثون',
|
||||
instruction: 'برنامج روبوت يمكنه إنشاء وتصحيح الكود الخاص بك بناءً على تعليماتك',
|
||||
},
|
||||
translation: {
|
||||
name: 'ترجمة',
|
||||
instruction: 'مترجم يمكنه ترجمة لغات متعددة',
|
||||
},
|
||||
professionalAnalyst: {
|
||||
name: 'محلل محترف',
|
||||
instruction: 'استخراج الرؤى وتحديد المخاطر وتقطير المعلومات الأساسية من التقارير الطويلة في مذكرة واحدة',
|
||||
},
|
||||
excelFormulaExpert: {
|
||||
name: 'خبير صيغة Excel',
|
||||
instruction: 'روبوت دردشة يمكنه مساعدة المستخدمين المبتدئين على فهم صيغ Excel واستخدامها وإنشائها بناءً على تعليمات المستخدم',
|
||||
},
|
||||
travelPlanning: {
|
||||
name: 'تخطيط السفر',
|
||||
instruction: 'مساعد تخطيط السفر هو أداة ذكية مصممة لمساعدة المستخدمين على التخطيط لرحلاتهم بسهولة',
|
||||
},
|
||||
SQLSorcerer: {
|
||||
name: 'ساحر SQL',
|
||||
instruction: 'تحويل اللغة اليومية إلى استعلامات SQL',
|
||||
},
|
||||
GitGud: {
|
||||
name: 'Git gud',
|
||||
instruction: 'إنشاء أوامر Git مناسبة بناءً على إجراءات التحكم في الإصدار التي وصفها المستخدم',
|
||||
},
|
||||
meetingTakeaways: {
|
||||
name: 'اجتماع الوجبات الجاهزة',
|
||||
instruction: 'تقطير الاجتماعات في ملخصات موجزة بما في ذلك مواضيع المناقشة، والوجبات الجاهزة الرئيسية، وعناصر العمل',
|
||||
},
|
||||
writingsPolisher: {
|
||||
name: 'ملمع الكتابات',
|
||||
instruction: 'استخدم تقنيات التحرير المتقدمة لتحسين كتاباتك',
|
||||
},
|
||||
},
|
||||
press: 'اضغط',
|
||||
to: 'إلى ',
|
||||
insertContext: 'إدراج السياق',
|
||||
optimizePromptTooltip: 'تحسين في مولد المطالبة',
|
||||
optimizationNote: 'ملاحظة التحسين',
|
||||
versions: 'إصدارات',
|
||||
version: 'إصدار',
|
||||
latest: 'الأحدث',
|
||||
},
|
||||
resetConfig: {
|
||||
title: 'تأكيد إعادة التعيين؟',
|
||||
message:
|
||||
'تتجاهل إعادة التعيين التغييرات، وتستعيد التكوين الأخير المنشور.',
|
||||
},
|
||||
errorMessage: {
|
||||
nameOfKeyRequired: 'اسم المفتاح: {{key}} مطلوب',
|
||||
valueOfVarRequired: 'قيمة {{key}} لا يمكن أن تكون فارغة',
|
||||
queryRequired: 'نص الطلب مطلوب.',
|
||||
waitForResponse: 'يرجى الانتظار حتى اكتمال الرد على الرسالة السابقة.',
|
||||
waitForBatchResponse: 'يرجى الانتظار حتى اكتمال الرد على مهمة الدفعة.',
|
||||
notSelectModel: 'يرجى اختيار نموذج',
|
||||
waitForImgUpload: 'يرجى الانتظار حتى تحميل الصورة',
|
||||
waitForFileUpload: 'يرجى الانتظار حتى تحميل الملف/الملفات',
|
||||
},
|
||||
warningMessage: {
|
||||
timeoutExceeded: 'لا يتم عرض النتائج بسبب المهلة. يرجى الرجوع إلى السجلات لجمع النتائج الكاملة.',
|
||||
},
|
||||
chatSubTitle: 'تعليمات',
|
||||
completionSubTitle: 'مقدمة المطالبة',
|
||||
promptTip:
|
||||
'توجه المطالبات استجابات الذكاء الاصطناعي بالتعليمات والقيود. أدرج متغيرات مثل {{input}}. لن تكون هذه المطالبة مرئية للمستخدمين.',
|
||||
formattingChangedTitle: 'تغيير التنسيق',
|
||||
formattingChangedText:
|
||||
'سيؤدي تعديل التنسيق إلى إعادة تعيين منطقة التصحيح، هل أنت متأكد؟',
|
||||
variableTitle: 'المتغيرات',
|
||||
variableTip:
|
||||
'يملأ المستخدمون المتغيرات في نموذج، ويستبدلون المتغيرات تلقائيًا في المطالبة.',
|
||||
notSetVar: 'تسمح المتغيرات للمستخدمين بتقديم كلمات مطالبة أو ملاحظات افتتاحية عند ملء النماذج. يمكنك محاولة إدخال "{{input}}" في كلمات المطالبة.',
|
||||
autoAddVar: 'المتغيرات غير المحددة المشار إليها في ما قبل المطالبة، هل ترغب في إضافتها في نموذج إدخال المستخدم؟',
|
||||
variableTable: {
|
||||
key: 'مفتاح المتغير',
|
||||
name: 'اسم حقل إدخال المستخدم',
|
||||
type: 'نوع الإدخال',
|
||||
action: 'إجراءات',
|
||||
typeString: 'سلسلة',
|
||||
typeSelect: 'تحديد',
|
||||
},
|
||||
varKeyError: {
|
||||
canNoBeEmpty: '{{key}} مطلوب',
|
||||
tooLong: '{{key}} طويل جدًا. لا يمكن أن يكون أطول من 30 حرفًا',
|
||||
notValid: '{{key}} غير صالح. يمكن أن يحتوي فقط على أحرف وأرقام وشرطات سفلية',
|
||||
notStartWithNumber: '{{key}} لا يمكن أن يبدأ برقم',
|
||||
keyAlreadyExists: '{{key}} موجود بالفعل',
|
||||
},
|
||||
otherError: {
|
||||
promptNoBeEmpty: 'لا يمكن أن تكون المطالبة فارغة',
|
||||
historyNoBeEmpty: 'يجب تعيين سجل المحادثة في المطالبة',
|
||||
queryNoBeEmpty: 'يجب تعيين الاستعلام في المطالبة',
|
||||
},
|
||||
variableConfig: {
|
||||
'addModalTitle': 'إضافة حقل إدخال',
|
||||
'editModalTitle': 'تعديل حقل إدخال',
|
||||
'description': 'إعداد للمتغير {{varName}}',
|
||||
'fieldType': 'نوع الحقل',
|
||||
'string': 'نص قصير',
|
||||
'text-input': 'نص قصير',
|
||||
'paragraph': 'فقرة',
|
||||
'select': 'تحديد',
|
||||
'number': 'رقم',
|
||||
'checkbox': 'مربع اختيار',
|
||||
'json': 'كود JSON',
|
||||
'jsonSchema': 'مخطط JSON',
|
||||
'optional': 'اختياري',
|
||||
'single-file': 'ملف واحد',
|
||||
'multi-files': 'قائمة ملفات',
|
||||
'notSet': 'لم يتم التعيين، حاول كتابة {{input}} في بادئة المطالبة',
|
||||
'stringTitle': 'خيارات مربع نص النموذج',
|
||||
'maxLength': 'الحد الأقصى للطول',
|
||||
'options': 'خيارات',
|
||||
'addOption': 'إضافة خيار',
|
||||
'apiBasedVar': 'متغير قائم على API',
|
||||
'varName': 'اسم المتغير',
|
||||
'labelName': 'اسم التسمية',
|
||||
'displayName': 'اسم العرض',
|
||||
'inputPlaceholder': 'يرجى الإدخال',
|
||||
'content': 'المحتوى',
|
||||
'required': 'مطلوب',
|
||||
'placeholder': 'عنصر نائب',
|
||||
'placeholderPlaceholder': 'أدخل نصًا للعرض عندما يكون الحقل فارغًا',
|
||||
'defaultValue': 'القيمة الافتراضية',
|
||||
'defaultValuePlaceholder': 'أدخل قيمة افتراضية لملء الحقل مسبقًا',
|
||||
'unit': 'وحدة',
|
||||
'unitPlaceholder': 'عرض الوحدات بعد الأرقام، مثل الرموز',
|
||||
'tooltips': 'تلميحات الأدوات',
|
||||
'tooltipsPlaceholder': 'أدخل نصًا مفيدًا يظهر عند التمرير فوق التسمية',
|
||||
'showAllSettings': 'عرض جميع الإعدادات',
|
||||
'startSelectedOption': 'بدء الخيار المحدد',
|
||||
'noDefaultSelected': 'لا تحدد',
|
||||
'hide': 'إخفاء',
|
||||
'file': {
|
||||
supportFileTypes: 'أنواع الملفات المدعومة',
|
||||
image: {
|
||||
name: 'صورة',
|
||||
},
|
||||
audio: {
|
||||
name: 'صوت',
|
||||
},
|
||||
document: {
|
||||
name: 'مستند',
|
||||
},
|
||||
video: {
|
||||
name: 'فيديو',
|
||||
},
|
||||
custom: {
|
||||
name: 'أنواع ملفات أخرى',
|
||||
description: 'تحديد أنواع ملفات أخرى.',
|
||||
createPlaceholder: '+ ملحق الملف، مثل .doc',
|
||||
},
|
||||
},
|
||||
'uploadFileTypes': 'تحميل أنواع الملفات',
|
||||
'uploadMethod': 'طريقة التحميل',
|
||||
'localUpload': 'تحميل محلي',
|
||||
'both': 'كلاهما',
|
||||
'maxNumberOfUploads': 'الحد الأقصى لعدد التحميلات',
|
||||
'maxNumberTip': 'وثيقة < {{docLimit}}، صورة < {{imgLimit}}، صوت < {{audioLimit}}، فيديو < {{videoLimit}}',
|
||||
'errorMsg': {
|
||||
labelNameRequired: 'اسم التسمية مطلوب',
|
||||
varNameCanBeRepeat: 'اسم المتغير لا يمكن تكراره',
|
||||
atLeastOneOption: 'خيار واحد على الأقل مطلوب',
|
||||
optionRepeat: 'يوجد خيارات مكررة',
|
||||
},
|
||||
'startChecked': 'البدء محددًا',
|
||||
'noDefaultValue': 'لا توجد قيمة افتراضية',
|
||||
'selectDefaultValue': 'تحديد القيمة الافتراضية',
|
||||
},
|
||||
vision: {
|
||||
name: 'الرؤية',
|
||||
description: 'سيسمح تمكين الرؤية للنموذج بأخذ الصور والإجابة على الأسئلة حولها. ',
|
||||
onlySupportVisionModelTip: 'يدعم نماذج الرؤية فقط',
|
||||
settings: 'الإعدادات',
|
||||
visionSettings: {
|
||||
title: 'إعدادات الرؤية',
|
||||
resolution: 'الدقة',
|
||||
resolutionTooltip: 'ستسمح الدقة المنخفضة للنموذج باستلام نسخة منخفضة الدقة 512 × 512 من الصورة، وتمثيل الصورة بميزانية 65 رمزًا. يتيح ذلك للواجهة البرمجية إرجاع استجابات أسرع واستهلاك عدد أقل من رموز الإدخال لحالات الاستخدام التي لا تتطلب تفاصيل عالية. ستسمح الدقة العالية أولاً للنموذج برؤية الصورة منخفضة الدقة ثم إنشاء مقتطفات مفصلة من الصور المدخلة كمربعات 512 بكسل بناءً على حجم الصورة المدخلة. يستخدم كل مقتطف مفصل ضعف ميزانية الرمز المميز بإجمالي 129 رمزًا.',
|
||||
high: 'عالية',
|
||||
low: 'منخفضة',
|
||||
uploadMethod: 'طريقة التحميل',
|
||||
both: 'كلاهما',
|
||||
localUpload: 'تحميل محلي',
|
||||
url: 'عنوان URL',
|
||||
uploadLimit: 'حد التحميل',
|
||||
},
|
||||
},
|
||||
voice: {
|
||||
name: 'صوت',
|
||||
defaultDisplay: 'صوت افتراضي',
|
||||
description: 'إعدادات تحويل النص إلى كلام',
|
||||
settings: 'الإعدادات',
|
||||
voiceSettings: {
|
||||
title: 'إعدادات الصوت',
|
||||
language: 'اللغة',
|
||||
resolutionTooltip: 'دعم لغة تحويل النص إلى كلام.',
|
||||
voice: 'صوت',
|
||||
autoPlay: 'تشغيل تلقائي',
|
||||
autoPlayEnabled: 'تشغيل',
|
||||
autoPlayDisabled: 'إيقاف',
|
||||
},
|
||||
},
|
||||
openingStatement: {
|
||||
title: 'فاتحة المحادثة',
|
||||
add: 'إضافة',
|
||||
writeOpener: 'تعديل الفاتحة',
|
||||
placeholder: 'اكتب رسالتك الافتتاحية هنا، يمكنك استخدام المتغيرات، حاول كتابة {{variable}}.',
|
||||
openingQuestion: 'أسئلة افتتاحية',
|
||||
openingQuestionPlaceholder: 'يمكنك استخدام المتغيرات، حاول كتابة {{variable}}.',
|
||||
noDataPlaceHolder:
|
||||
'يمكن أن يساعد بدء المحادثة مع المستخدم الذكاء الاصطناعي على إنشاء اتصال أوثق معهم في تطبيقات المحادثة.',
|
||||
varTip: 'يمكنك استخدام المتغيرات، حاول كتابة {{variable}}',
|
||||
tooShort: 'مطلوب ما لا يقل عن 20 كلمة من المطالبة الأولية لإنشاء ملاحظات افتتاحية للمحادثة.',
|
||||
notIncludeKey: 'لا تتضمن المطالبة الأولية المتغير: {{key}}. يرجى إضافته إلى المطالبة الأولية.',
|
||||
},
|
||||
modelConfig: {
|
||||
model: 'نموذج',
|
||||
setTone: 'تعيين نبرة الاستجابات',
|
||||
title: 'النموذج والمعلمات',
|
||||
modeType: {
|
||||
chat: 'دردشة',
|
||||
completion: 'إكمال',
|
||||
},
|
||||
},
|
||||
inputs: {
|
||||
title: 'تصحيح ومعاينة',
|
||||
noPrompt: 'حاول كتابة بعض المطالبات في مدخلات ما قبل المطالبة',
|
||||
userInputField: 'حقل إدخال المستخدم',
|
||||
noVar: 'املأ قيمة المتغير، والتي سيتم استبدالها تلقائيًا في كلمة المطالبة في كل مرة يتم فيها بدء جلسة جديدة.',
|
||||
chatVarTip:
|
||||
'املأ قيمة المتغير، والتي سيتم استبدالها تلقائيًا في كلمة المطالبة في كل مرة يتم فيها بدء جلسة جديدة',
|
||||
completionVarTip:
|
||||
'املأ قيمة المتغير، والتي سيتم استبدالها تلقائيًا في كلمات المطالبة في كل مرة يتم فيها إرسال سؤال.',
|
||||
previewTitle: 'معاينة المطالبة',
|
||||
queryTitle: 'محتوى الاستعلام',
|
||||
queryPlaceholder: 'يرجى إدخال نص الطلب.',
|
||||
run: 'تشغيل',
|
||||
},
|
||||
result: 'نص الإخراج',
|
||||
noResult: 'سيتم عرض الإخراج هنا.',
|
||||
datasetConfig: {
|
||||
settingTitle: 'إعدادات الاسترجاع',
|
||||
knowledgeTip: 'انقر فوق الزر "+" لإضافة معرفة',
|
||||
retrieveOneWay: {
|
||||
title: 'استرجاع N-to-1',
|
||||
description: 'بناءً على نية المستخدم وأوصاف المعرفة، يختار الوكيل بشكل مستقل أفضل معرفة للاستعلام. الأفضل للتطبيقات ذات المعرفة المحددة والمحدودة.',
|
||||
},
|
||||
retrieveMultiWay: {
|
||||
title: 'استرجاع متعدد المسارات',
|
||||
description: 'بناءً على نية المستخدم، يستعلم عبر جميع المعارف، ويسترجع النص ذي الصلة من مصادر متعددة، ويختار أفضل النتائج المطابقة لاستعلام المستخدم بعد إعادة الترتيب.',
|
||||
},
|
||||
embeddingModelRequired: 'مطلوب نموذج تضمين مكون',
|
||||
rerankModelRequired: 'مطلوب نموذج إعادة ترتيب مكون',
|
||||
params: 'معلمات',
|
||||
top_k: 'أفضل K',
|
||||
top_kTip: 'يستخدم لتصفية القطع الأكثر تشابهًا مع أسئلة المستخدم. سيقوم النظام أيضًا بضبط قيمة Top K ديناميكيًا، وفقًا لـ max_tokens للنموذج المحدد.',
|
||||
score_threshold: 'عتبة النتيجة',
|
||||
score_thresholdTip: 'يستخدم لتعيين عتبة التشابه لتصفية القطع.',
|
||||
retrieveChangeTip: 'قد يؤثر تعديل وضع الفهرس ووضع الاسترجاع على التطبيقات المرتبطة بهذه المعرفة.',
|
||||
},
|
||||
debugAsSingleModel: 'تصحيح كنموذج واحد',
|
||||
debugAsMultipleModel: 'تصحيح كنماذج متعددة',
|
||||
duplicateModel: 'تكرار',
|
||||
publishAs: 'نشر كـ',
|
||||
assistantType: {
|
||||
name: 'نوع المساعد',
|
||||
chatAssistant: {
|
||||
name: 'مساعد أساسي',
|
||||
description: 'بناء مساعد قائم على الدردشة باستخدام نموذج لغة كبير',
|
||||
},
|
||||
agentAssistant: {
|
||||
name: 'مساعد وكيل',
|
||||
description: 'بناء وكيل ذكي يمكنه اختيار الأدوات بشكل مستقل لإكمال المهام',
|
||||
},
|
||||
},
|
||||
agent: {
|
||||
agentMode: 'وضع الوكيل',
|
||||
agentModeDes: 'تعيين نوع وضع الاستدلال للوكيل',
|
||||
agentModeType: {
|
||||
ReACT: 'ReAct',
|
||||
functionCall: 'Function Calling',
|
||||
},
|
||||
setting: {
|
||||
name: 'إعدادات الوكيل',
|
||||
description: 'تسمح إعدادات مساعد الوكيل بتعيين وضع الوكيل والميزات المتقدمة مثل المطالبات المضمنة، المتاحة فقط في نوع الوكيل.',
|
||||
maximumIterations: {
|
||||
name: 'الحد الأقصى للتكرارات',
|
||||
description: 'الحد من عدد التكرارات التي يمكن لمساعد الوكيل تنفيذها',
|
||||
},
|
||||
},
|
||||
buildInPrompt: 'المطالبة المضمنة',
|
||||
firstPrompt: 'المطالبة الأولى',
|
||||
nextIteration: 'التكرار التالي',
|
||||
promptPlaceholder: 'اكتب مطالبتك هنا',
|
||||
tools: {
|
||||
name: 'الأدوات',
|
||||
description: 'يمكن أن يؤدي استخدام الأدوات إلى توسيع قدرات LLM، مثل البحث في الإنترنت أو إجراء العمليات الحسابية العلمية',
|
||||
enabled: 'ممكن',
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
112
web/i18n/ar-TN/app-log.ts
Normal file
112
web/i18n/ar-TN/app-log.ts
Normal file
@@ -0,0 +1,112 @@
|
||||
const translation = {
|
||||
title: 'السجلات',
|
||||
description: 'تسجل السجلات حالة تشغيل التطبيق، بما في ذلك مدخلات المستخدم واستجابات الذكاء الاصطناعي.',
|
||||
dateTimeFormat: 'MM/DD/YYYY hh:mm A',
|
||||
table: {
|
||||
header: {
|
||||
time: 'الوقت',
|
||||
endUser: 'المستخدم النهائي',
|
||||
input: 'الإدخال',
|
||||
output: 'الإخراج',
|
||||
summary: 'العنوان',
|
||||
messageCount: 'عدد الرسائل',
|
||||
userRate: 'معدل المستخدم',
|
||||
adminRate: 'معدل المسؤول',
|
||||
startTime: 'وقت البدء',
|
||||
status: 'الحالة',
|
||||
runtime: 'وقت التشغيل',
|
||||
tokens: 'الرموز',
|
||||
user: 'المستخدم',
|
||||
version: 'الإصدار',
|
||||
updatedTime: 'الوقت المحدث',
|
||||
triggered_from: 'محفّز بواسطة',
|
||||
},
|
||||
pagination: {
|
||||
previous: 'السابق',
|
||||
next: 'التالي',
|
||||
},
|
||||
empty: {
|
||||
noChat: 'لا توجد محادثة حتى الآن',
|
||||
noOutput: 'لا توجد مخرجات',
|
||||
element: {
|
||||
title: 'هل هناك أي شخص؟',
|
||||
content: 'راقب وتهميش تفاعلات المستخدمين النهائيين والتطبيقات الذكية هنا لتحسين دقة الذكاء الاصطناعي باستمرار.',
|
||||
},
|
||||
},
|
||||
},
|
||||
detail: {
|
||||
time: 'الوقت',
|
||||
conversationId: 'معرف المحادثة',
|
||||
promptTemplate: 'قالب المطالبة',
|
||||
promptTemplateBeforeChat: 'قالب المطالبة قبل الدردشة · كرسالة نظام',
|
||||
annotationTip: 'تحسينات تم وضع علامة عليها بواسطة {{user}}',
|
||||
timeConsuming: '',
|
||||
second: 'ثانية',
|
||||
tokenCost: 'تكلفة الرموز',
|
||||
loading: 'جاري التحميل',
|
||||
operation: {
|
||||
like: 'إعجاب',
|
||||
dislike: 'لم يعجبني',
|
||||
addAnnotation: 'إضافة تحسين',
|
||||
editAnnotation: 'تعديل التحسين',
|
||||
annotationPlaceholder: 'أدخل الإجابة المتوقعة التي تريد أن يرد بها الذكاء الاصطناعي، والتي يمكن استخدامها لضبط النموذج والتحسين المستمر لجودة توليد النص.',
|
||||
},
|
||||
variables: 'المتغيرات',
|
||||
uploadImages: 'الصور المحملة',
|
||||
modelParams: 'معلمات النموذج',
|
||||
},
|
||||
filter: {
|
||||
period: {
|
||||
today: 'اليوم',
|
||||
last7days: 'آخر 7 أيام',
|
||||
last4weeks: 'آخر 4 أسابيع',
|
||||
last3months: 'آخر 3 أشهر',
|
||||
last12months: 'آخر 12 شهرًا',
|
||||
monthToDate: 'الشهر حتى الآن',
|
||||
quarterToDate: 'الربع حتى الآن',
|
||||
yearToDate: 'السنة حتى الآن',
|
||||
allTime: 'كل الوقت',
|
||||
last30days: 'آخر 30 يومًا',
|
||||
custom: 'مخصص',
|
||||
},
|
||||
annotation: {
|
||||
all: 'الكل',
|
||||
annotated: 'تحسينات موصوفة ({{count}})',
|
||||
not_annotated: 'غير موصوفة',
|
||||
},
|
||||
sortBy: 'رتب حسب:',
|
||||
descending: 'تنازلي',
|
||||
ascending: 'تصاعدي',
|
||||
},
|
||||
workflowTitle: 'سجلات سير العمل',
|
||||
workflowSubtitle: 'سجل تفاصيل تشغيل سير العمل.',
|
||||
runDetail: {
|
||||
title: 'سجل المحادثة',
|
||||
workflowTitle: 'تفاصيل السجل',
|
||||
fileListLabel: 'تفاصيل الملف',
|
||||
fileListDetail: 'تفاصيل',
|
||||
testWithParams: 'اختبار مع المعلمات',
|
||||
},
|
||||
promptLog: 'سجل المطالبة',
|
||||
agentLog: 'سجل الوكيل',
|
||||
viewLog: 'عرض السجل',
|
||||
agentLogDetail: {
|
||||
agentMode: 'وضع الوكيل',
|
||||
toolUsed: 'الأداة المستخدمة',
|
||||
iterations: 'التكرارات',
|
||||
iteration: 'تكرار',
|
||||
finalProcessing: 'المعالجة النهائية',
|
||||
},
|
||||
triggerBy: {
|
||||
debugging: 'تصحيح الأخطاء',
|
||||
appRun: 'تشغيل التطبيق',
|
||||
webhook: 'Webhook',
|
||||
schedule: 'الجدول الزمني',
|
||||
plugin: 'المكون الإضافي',
|
||||
ragPipelineRun: 'تشغيل خط أنابيب RAG',
|
||||
ragPipelineDebugging: 'تصحيح أخطاء RAG',
|
||||
},
|
||||
dateFormat: 'شهر/يوم/سنة',
|
||||
}
|
||||
|
||||
export default translation
|
||||
189
web/i18n/ar-TN/app-overview.ts
Normal file
189
web/i18n/ar-TN/app-overview.ts
Normal file
@@ -0,0 +1,189 @@
|
||||
const translation = {
|
||||
welcome: {
|
||||
firstStepTip: 'للبدء،',
|
||||
enterKeyTip: 'أدخل مفتاح OpenAI API الخاص بك أدناه',
|
||||
getKeyTip: 'احصل على مفتاح API الخاص بك من لوحة تحكم OpenAI',
|
||||
placeholder: 'مفتاح OpenAI API الخاص بك (مثلا sk-xxxx)',
|
||||
},
|
||||
apiKeyInfo: {
|
||||
cloud: {
|
||||
trial: {
|
||||
title: 'أنت تستخدم حصة تجربة {{providerName}}.',
|
||||
description: 'يتم توفير حصة التجربة لأغراض الاختبار الخاصة بك. قبل استنفاد حصة التجربة، يرجى إعداد مزود النموذج الخاص بك أو شراء حصة إضافية.',
|
||||
},
|
||||
exhausted: {
|
||||
title: 'تم استنفاد حصة التجربة الخاصة بك، يرجى إعداد مفتاح API الخاص بك.',
|
||||
description: 'لقد استنفدت حصة التجربة الخاصة بك. يرجى إعداد مزود النموذج الخاص بك أو شراء حصة إضافية.',
|
||||
},
|
||||
},
|
||||
selfHost: {
|
||||
title: {
|
||||
row1: 'للبدء،',
|
||||
row2: 'قم بإعداد مزود النموذج الخاص بك أولاً.',
|
||||
},
|
||||
},
|
||||
callTimes: 'أوقات الاتصال',
|
||||
usedToken: 'رمز مستخدم',
|
||||
setAPIBtn: 'الذهاب لإعداد مزود النموذج',
|
||||
tryCloud: 'أو جرب النسخة السحابية من Dify مع عرض مجاني',
|
||||
},
|
||||
overview: {
|
||||
title: 'نظرة عامة',
|
||||
appInfo: {
|
||||
title: 'تطبيق ويب',
|
||||
explanation: 'تطبيق ويب AI جاهز للاستخدام',
|
||||
accessibleAddress: 'عنوان URL عام',
|
||||
preview: 'معاينة',
|
||||
launch: 'إطلاق',
|
||||
regenerate: 'إعادة إنشاء',
|
||||
regenerateNotice: 'هل تريد إعادة إنشاء عنوان URL العام؟',
|
||||
preUseReminder: 'يرجى تمكين تطبيق الويب قبل المتابعة.',
|
||||
enableTooltip: {
|
||||
description: 'لتمكين هذه الميزة، يرجى إضافة عقدة إدخال المستخدم إلى اللوحة. (قد تكون موجودة بالفعل في المسودة، وتدخل حيز التنفيذ بعد النشر)',
|
||||
learnMore: 'اعرف المزيد',
|
||||
},
|
||||
settings: {
|
||||
entry: 'الإعدادات',
|
||||
title: 'إعدادات تطبيق الويب',
|
||||
modalTip: 'إعدادات تطبيق الويب من جانب العميل. ',
|
||||
webName: 'اسم تطبيق الويب',
|
||||
webDesc: 'وصف تطبيق الويب',
|
||||
webDescTip: 'سيتم عرض هذا النص على جانب العميل، مما يوفر إرشادات أساسية حول كيفية استخدام التطبيق',
|
||||
webDescPlaceholder: 'أدخل وصف تطبيق الويب',
|
||||
language: 'اللغة',
|
||||
workflow: {
|
||||
title: 'سير العمل',
|
||||
subTitle: 'تفاصيل سير العمل',
|
||||
show: 'عرض',
|
||||
hide: 'إخفاء',
|
||||
showDesc: 'عرض أو إخفاء تفاصيل سير العمل في تطبيق الويب',
|
||||
},
|
||||
chatColorTheme: 'سمة لون الدردشة',
|
||||
chatColorThemeDesc: 'تعيين سمة لون روبوت الدردشة',
|
||||
chatColorThemeInverted: 'معكوس',
|
||||
invalidHexMessage: 'قيمة hex غير صالحة',
|
||||
invalidPrivacyPolicy: 'رابط سياسة الخصوصية غير صالح. يرجى استخدام رابط صالح يبدأ بـ http أو https',
|
||||
sso: {
|
||||
label: 'فرض SSO',
|
||||
title: 'تطبيق ويب SSO',
|
||||
description: 'يُطلب من جميع المستخدمين تسجيل الدخول باستخدام SSO قبل استخدام تطبيق الويب',
|
||||
tooltip: 'اتصل بالمسؤول لتمكين تطبيق ويب SSO',
|
||||
},
|
||||
more: {
|
||||
entry: 'عرض المزيد من الإعدادات',
|
||||
copyright: 'حقوق النشر',
|
||||
copyrightTip: 'عرض معلومات حقوق النشر في تطبيق الويب',
|
||||
copyrightTooltip: 'يرجى الترقية إلى الخطة الاحترافية أو أعلى',
|
||||
copyRightPlaceholder: 'أدخل اسم المؤلف أو المنظمة',
|
||||
privacyPolicy: 'سياسة الخصوصية',
|
||||
privacyPolicyPlaceholder: 'أدخل رابط سياسة الخصوصية',
|
||||
privacyPolicyTip: 'يساعد الزوار على فهم البيانات التي يجمعها التطبيق، راجع <privacyPolicyLink>سياسة الخصوصية</privacyPolicyLink> لـ Dify.',
|
||||
customDisclaimer: 'إخلاء مسؤولية مخصص',
|
||||
customDisclaimerPlaceholder: 'أدخل نص إخلاء المسؤولية المخصص',
|
||||
customDisclaimerTip: 'سيتم عرض نص إخلاء المسؤولية المخصص على جانب العميل، مما يوفر معلومات إضافية حول التطبيق',
|
||||
},
|
||||
},
|
||||
embedded: {
|
||||
entry: 'مضمن',
|
||||
title: 'تضمين في الموقع',
|
||||
explanation: 'اختر طريقة لتضمين تطبيق الدردشة في موقعك',
|
||||
iframe: 'لإضافة تطبيق الدردشة في أي مكان على موقعك، أضف هذا iframe إلى كود html الخاص بك.',
|
||||
scripts: 'لإضافة تطبيق دردشة إلى أسفل يمين موقعك، أضف هذا الكود إلى html الخاص بك.',
|
||||
chromePlugin: 'تثبيت ملحق Dify Chatbot Chrome',
|
||||
copied: 'تم النسخ',
|
||||
copy: 'نسخ',
|
||||
},
|
||||
qrcode: {
|
||||
title: 'رمز الاستجابة السريعة للرابط',
|
||||
scan: 'مسح للمشاركة',
|
||||
download: 'تحميل رمز الاستجابة السريعة',
|
||||
},
|
||||
customize: {
|
||||
way: 'طريقة',
|
||||
entry: 'تخصيص',
|
||||
title: 'تخصيص تطبيق ويب AI',
|
||||
explanation: 'يمكنك تخصيص الواجهة الأمامية لتطبيق الويب لتناسب سيناريو واحتياجات أسلوبك.',
|
||||
way1: {
|
||||
name: 'انسخ كود العميل، وقم بتعديله وانشره على Vercel (موصى به)',
|
||||
step1: 'انسخ كود العميل وقم بتعديله',
|
||||
step1Tip: 'انقر هنا لنسخ الكود المصدري إلى حساب GitHub الخاص بك وتعديل الكود',
|
||||
step1Operation: 'Dify-WebClient',
|
||||
step2: 'نشر على Vercel',
|
||||
step2Tip: 'انقر هنا لاستيراد المستودع إلى Vercel والنشر',
|
||||
step2Operation: 'استيراد المستودع',
|
||||
step3: 'تكوين متغيرات البيئة',
|
||||
step3Tip: 'أضف متغيرات البيئة التالية في Vercel',
|
||||
},
|
||||
way2: {
|
||||
name: 'كتابة كود من جانب العميل لاستدعاء API ونشره على خادم',
|
||||
operation: 'التوثيق',
|
||||
},
|
||||
},
|
||||
},
|
||||
apiInfo: {
|
||||
title: 'واجهة برمجة تطبيقات خدمة الخلفية',
|
||||
explanation: 'سهلة الدمج في تطبيقك',
|
||||
accessibleAddress: 'نقطة نهاية واجهة برمجة تطبيقات الخدمة',
|
||||
doc: 'مرجع API',
|
||||
},
|
||||
triggerInfo: {
|
||||
title: 'المشغلات',
|
||||
explanation: 'إدارة مشغلات سير العمل',
|
||||
triggersAdded: 'تمت إضافة {{count}} مشغلات',
|
||||
noTriggerAdded: 'لم تتم إضافة أي مشغل',
|
||||
triggerStatusDescription: 'تظهر حالة عقدة المشغل هنا. (قد تكون موجودة بالفعل في المسودة، وتدخل حيز التنفيذ بعد النشر)',
|
||||
learnAboutTriggers: 'تعرف على المشغلات',
|
||||
},
|
||||
status: {
|
||||
running: 'في الخدمة',
|
||||
disable: 'تعطيل',
|
||||
},
|
||||
disableTooltip: {
|
||||
triggerMode: 'ميزة {{feature}} غير مدعومة في وضع عقدة المشغل.',
|
||||
},
|
||||
},
|
||||
analysis: {
|
||||
title: 'تحليل',
|
||||
ms: 'مللي ثانية',
|
||||
tokenPS: 'الرموز/ثانية',
|
||||
totalMessages: {
|
||||
title: 'إجمالي الرسائل',
|
||||
explanation: 'عدد تفاعلات الذكاء الاصطناعي اليومية؛ يمنع هندسة/تصحيح المطالبة.',
|
||||
},
|
||||
totalConversations: {
|
||||
title: 'إجمالي المحادثات',
|
||||
explanation: 'عدد المحادثات اليومية للذكاء الاصطناعي؛ باستثناء هندسة/تصحيح المطالبة.',
|
||||
},
|
||||
activeUsers: {
|
||||
title: 'المستخدمون النشطون',
|
||||
explanation: 'المستخدمون الفريدون الذين يشاركون في Q&A مع المساعد؛ يستبعد هندسة/تصحيح المطالبة.',
|
||||
},
|
||||
tokenUsage: {
|
||||
title: 'استخدام الرموز',
|
||||
explanation: 'يعكس استخدام الرموز اليومية لنموذج اللغة لتطبيق WebApp، مفيدًا للتحكم في التكلفة.',
|
||||
consumed: 'المستهلكة',
|
||||
},
|
||||
avgSessionInteractions: {
|
||||
title: 'متوسط تفاعلات الجلسة',
|
||||
explanation: 'عدد مفاتيح التواصل المستمر بين المستخدم والذكاء الاصطناعي؛ للمطبيقات القائمة على المحادثة.',
|
||||
},
|
||||
avgUserInteractions: {
|
||||
title: 'متوسط تفاعلات المستخدم',
|
||||
explanation: 'يعكس تكرار الاستخدام اليومي للمستخدمين. يعكس هذا المقياس لزوجة المستخدم.',
|
||||
},
|
||||
userSatisfactionRate: {
|
||||
title: 'معدل رضا المستخدم',
|
||||
explanation: 'عدد الإعجابات لكل 1000 رسالة. يشير هذا إلى النسبة التي يرضى فيها المستخدمون للغاية عن الإجابات.',
|
||||
},
|
||||
avgResponseTime: {
|
||||
title: 'متوسط وقت الاستجابة',
|
||||
explanation: 'الوقت (مللي ثانية) حتى يقوم الذكاء الاصطناعي بالمعالجة/الاستجابة؛ للمطبيقات النصية (text-based).',
|
||||
},
|
||||
tps: {
|
||||
title: 'سرعة إخراج الرمز',
|
||||
explanation: 'قياس أداء LLM. عد الرموز إخراج LLM من بداية الطلب إلى اكتمال الإخراج.',
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
351
web/i18n/ar-TN/app.ts
Normal file
351
web/i18n/ar-TN/app.ts
Normal file
@@ -0,0 +1,351 @@
|
||||
const translation = {
|
||||
createApp: 'إنشاء تطبيق',
|
||||
types: {
|
||||
all: 'الكل',
|
||||
chatbot: 'روبوت دردشة',
|
||||
agent: 'Agent',
|
||||
workflow: 'سير العمل (Workflow)',
|
||||
completion: 'إكمال',
|
||||
advanced: 'Chatflow',
|
||||
basic: 'أساسي',
|
||||
},
|
||||
duplicate: 'نسخ',
|
||||
mermaid: {
|
||||
handDrawn: 'رسم يدوي',
|
||||
classic: 'كلاسيكي',
|
||||
},
|
||||
duplicateTitle: 'نسخ التطبيق',
|
||||
export: 'تصدير DSL',
|
||||
exportFailed: 'فشل تصدير DSL.',
|
||||
importDSL: 'استيراد ملف DSL',
|
||||
createFromConfigFile: 'إنشاء من ملف DSL',
|
||||
importFromDSL: 'استيراد من DSL',
|
||||
importFromDSLFile: 'من ملف DSL',
|
||||
importFromDSLUrl: 'من رابط',
|
||||
importFromDSLUrlPlaceholder: 'لصق رابط DSL هنا',
|
||||
dslUploader: {
|
||||
button: 'اسحب وأفلت الملف، أو',
|
||||
browse: 'تصفح',
|
||||
},
|
||||
deleteAppConfirmTitle: 'حذف هذا التطبيق؟',
|
||||
deleteAppConfirmContent:
|
||||
'حذف التطبيق لا رجعة فيه. لن يتمكن المستخدمون من الوصول إلى تطبيقك بعد الآن، وسيتم حذف جميع تكوينات المطالبة والسجلات بشكل دائم.',
|
||||
appDeleted: 'تم حذف التطبيق',
|
||||
appDeleteFailed: 'فشل حذف التطبيق',
|
||||
join: 'انضم إلى المجتمع',
|
||||
communityIntro:
|
||||
'ناقش مع أعضاء الفريق والمساهمين والمطورين على قنوات مختلفة.',
|
||||
roadmap: 'شاهد خريطة الطريق',
|
||||
newApp: {
|
||||
learnMore: 'اعرف المزيد',
|
||||
startFromBlank: 'إنشاء من البداية',
|
||||
startFromTemplate: 'إنشاء من قالب',
|
||||
foundResult: '{{count}} نتيجة',
|
||||
foundResults: '{{count}} نتائج',
|
||||
noAppsFound: 'لم يتم العثور على تطبيقات',
|
||||
noTemplateFound: 'لم يتم العثور على قوالب',
|
||||
noTemplateFoundTip: 'حاول البحث باستخدام كلمات مفتاحية مختلفة.',
|
||||
chatbotShortDescription: 'روبوت دردشة قائم على LLM مع إعداد بسيط',
|
||||
chatbotUserDescription: 'قم ببناء روبوت دردشة قائم على LLM بسرعة مع تكوين بسيط. يمكنك التبديل إلى Chatflow لاحقًا.',
|
||||
completionShortDescription: 'مساعد AI لمهام توليد النصوص',
|
||||
completionUserDescription: 'قم ببناء مساعد AI لمهام توليد النصوص بسرعة مع تكوين بسيط.',
|
||||
agentShortDescription: 'وكيل ذكي مع الاستدلال واستخدام الأدوات المستقل',
|
||||
agentUserDescription: 'وكيل ذكي قادر على الاستدلال التكراري واستخدام الأدوات بشكل مستقل لتحقيق أهداف المهمة.',
|
||||
workflowShortDescription: 'تدفق وكيل للأتمتة الذكية',
|
||||
workflowUserDescription: 'قم ببناء تدفقات عمل AI مستقلة بشكل مرئي مع بساطة السحب والإفلات.',
|
||||
workflowWarning: 'حاليا في النسخة التجريبية (beta)',
|
||||
advancedShortDescription: 'سير عمل محسن للمحادثات متعددة الأدوار',
|
||||
advancedUserDescription: 'سير عمل مع ميزات ذاكرة إضافية وواجهة روبوت دردشة.',
|
||||
chooseAppType: 'اختر نوع التطبيق',
|
||||
forBeginners: 'أنواع تطبيقات أبسط',
|
||||
forAdvanced: 'للمستخدمين المتقدمين',
|
||||
noIdeaTip: 'لا توجد أفكار؟ تحقق من قوالبنا',
|
||||
captionName: 'اسم التطبيق والأيقونة',
|
||||
appNamePlaceholder: 'أعط اسمًا لتطبيقك',
|
||||
captionDescription: 'الوصف',
|
||||
optional: 'اختياري',
|
||||
appDescriptionPlaceholder: 'أدخل وصف التطبيق',
|
||||
useTemplate: 'استخدم هذا القالب',
|
||||
previewDemo: 'معاينة العرض التوضيحي',
|
||||
chatApp: 'مساعد',
|
||||
chatAppIntro:
|
||||
'أريد بناء تطبيق قائم على الدردشة. يستخدم هذا التطبيق تنسيق سؤال وجواب، مما يسمح بجولات متعددة من المحادثة المستمرة.',
|
||||
agentAssistant: 'مساعد وكيل جديد',
|
||||
completeApp: 'مولد نصوص',
|
||||
completeAppIntro:
|
||||
'أريد إنشاء تطبيق يولد نصوصًا عالية الجودة بناءً على المطالبات، مثل إنشاء المقالات والملخصات والترجمات والمزيد.',
|
||||
showTemplates: 'أريد الاختيار من قالب',
|
||||
hideTemplates: 'العودة إلى اختيار الوضع',
|
||||
Create: 'إنشاء',
|
||||
Cancel: 'إلغاء',
|
||||
Confirm: 'تأكيد',
|
||||
import: 'استيراد',
|
||||
nameNotEmpty: 'لا يمكن أن يكون الاسم فارغًا',
|
||||
appTemplateNotSelected: 'الرجاء تحديد قالب',
|
||||
appTypeRequired: 'الرجاء تحديد نوع التطبيق',
|
||||
appCreated: 'تم إنشاء التطبيق',
|
||||
caution: 'تحذير',
|
||||
appCreateDSLWarning: 'تحذير: قد يؤثر اختلاف إصدار DSL على ميزات معينة',
|
||||
appCreateDSLErrorTitle: 'عدم توافق الإصدار',
|
||||
appCreateDSLErrorPart1: 'تم اكتشاف اختلاف كبير في إصدارات DSL. قد يؤدي فرض الاستيراد إلى تعطل التطبيق.',
|
||||
appCreateDSLErrorPart2: 'هل تريد المتابعة؟',
|
||||
appCreateDSLErrorPart3: 'إصدار DSL للتطبيق الحالي: ',
|
||||
appCreateDSLErrorPart4: 'إصدار DSL المدعوم من النظام: ',
|
||||
appCreateFailed: 'فشل إنشاء التطبيق',
|
||||
dropDSLToCreateApp: 'أفلت ملف DSL هنا لإنشاء تطبيق',
|
||||
},
|
||||
newAppFromTemplate: {
|
||||
byCategories: 'حسب الفئات',
|
||||
searchAllTemplate: 'بحث في كل القوالب...',
|
||||
sidebar: {
|
||||
Recommended: 'موصى به',
|
||||
Agent: 'Agent',
|
||||
Assistant: 'مساعد',
|
||||
HR: 'الموارد البشرية',
|
||||
Workflow: 'سير العمل',
|
||||
Writing: 'كتابة',
|
||||
Programming: 'برمجة',
|
||||
},
|
||||
},
|
||||
editApp: 'تعديل المعلومات',
|
||||
editAppTitle: 'تعديل معلومات التطبيق',
|
||||
editDone: 'تم تحديث معلومات التطبيق',
|
||||
editFailed: 'فشل تحديث معلومات التطبيق',
|
||||
iconPicker: {
|
||||
ok: 'موافق',
|
||||
cancel: 'إلغاء',
|
||||
emoji: 'رموز تعبيرية',
|
||||
image: 'صورة',
|
||||
},
|
||||
answerIcon: {
|
||||
title: 'استخدم أيقونة تطبيق الويب لاستبدال 🤖',
|
||||
description: 'ما إذا كان سيتم استخدام أيقونة تطبيق الويب لاستبدال 🤖 في التطبيق المشترك',
|
||||
descriptionInExplore: 'ما إذا كان سيتم استخدام أيقونة تطبيق الويب لاستبدال 🤖 في الاستكشاف',
|
||||
},
|
||||
switch: 'التبديل إلى Workflow Orchestrate',
|
||||
switchTipStart: 'سيتم إنشاء نسخة تطبيق جديدة لك، وستنتقل النسخة الجديدة إلى Workflow Orchestrate. النسخة الجديدة ستكون ',
|
||||
switchTip: 'غير مسموح',
|
||||
switchTipEnd: ' بالعودة إلى Basic Orchestrate.',
|
||||
switchLabel: 'نسخة التطبيق التي سيتم إنشاؤها',
|
||||
removeOriginal: 'حذف التطبيق الأصلي',
|
||||
switchStart: 'بدء التبديل',
|
||||
openInExplore: 'فتح في الاستكشاف',
|
||||
typeSelector: {
|
||||
all: 'كل الأنواع',
|
||||
chatbot: 'روبوت دردشة',
|
||||
agent: 'Agent',
|
||||
workflow: 'سير العمل',
|
||||
completion: 'إكمال',
|
||||
advanced: 'Chatflow',
|
||||
},
|
||||
tracing: {
|
||||
title: 'تتبع أداء التطبيق',
|
||||
description: 'تكوين مزود LLMOps خارجي وتتبع أداء التطبيق.',
|
||||
config: 'تكوين',
|
||||
view: 'عرض',
|
||||
collapse: 'طي',
|
||||
expand: 'توسيع',
|
||||
tracing: 'تتبع',
|
||||
disabled: 'معطل',
|
||||
disabledTip: 'الرجاء تكوين المزود أولاً',
|
||||
enabled: 'في الخدمة',
|
||||
tracingDescription: 'التقاط السياق الكامل لتنفيذ التطبيق، بما في ذلك مكالمات LLM، والسياق، والمطالبات، وطلبات HTTP، والمزيد، إلى منصة تتبع تابعة لجهة خارجية.',
|
||||
configProviderTitle: {
|
||||
configured: 'تم التكوين',
|
||||
notConfigured: 'تكوين المزود لتمكين التتبع',
|
||||
moreProvider: 'مزيد من المزودين',
|
||||
},
|
||||
arize: {
|
||||
title: 'Arize',
|
||||
description: 'مراقبة LLM على مستوى المؤسسة، والتقييم عبر الإنترنت وغير المتصل بالإنترنت، والمراقبة، والتجريب - بدعم من OpenTelemetry. مصمم خصيصًا لتطبيقات LLM والتطبيقات التي تعتمد على الوكيل.',
|
||||
},
|
||||
phoenix: {
|
||||
title: 'Phoenix',
|
||||
description: 'منصة مفتوحة المصدر تعتمد على OpenTelemetry للمراقبة والتقييم وهندسة المطالبات والتجريب لتدفقات عمل LLM والوكلاء.',
|
||||
},
|
||||
langsmith: {
|
||||
title: 'LangSmith',
|
||||
description: 'منصة مطور شاملة لكل خطوة من خطوات دورة حياة التطبيق المدعوم بـ LLM.',
|
||||
},
|
||||
langfuse: {
|
||||
title: 'Langfuse',
|
||||
description: 'مراقبة LLM مفتوحة المصدر وتقييمها وإدارة المطالبات والمقاييس لتصحيح وتحسين تطبيق LLM الخاص بك.',
|
||||
},
|
||||
opik: {
|
||||
title: 'Opik',
|
||||
description: 'Opik هي منصة مفتوحة المصدر لتقييم واختبار ومراقبة تطبيقات LLM.',
|
||||
},
|
||||
weave: {
|
||||
title: 'Weave',
|
||||
description: 'Weave هي منصة مفتوحة المصدر لتقييم واختبار ومراقبة تطبيقات LLM.',
|
||||
},
|
||||
aliyun: {
|
||||
title: 'Cloud Monitor',
|
||||
description: 'منصة المراقبة المدارة بالكامل والتي لا تحتاج إلى صيانة والمقدمة من Alibaba Cloud، تتيح المراقبة الجاهزة والتتبع وتقييم تطبيقات Dify.',
|
||||
},
|
||||
mlflow: {
|
||||
title: 'MLflow',
|
||||
description: 'MLflow هي منصة مفتوحة المصدر لإدارة التجارب وتقييم ومراقبة تطبيقات LLM.',
|
||||
},
|
||||
databricks: {
|
||||
title: 'Databricks',
|
||||
description: 'توفر Databricks تدفق MLflow مدار بالكامل مع حوكمة وأمان قويين لتخزين بيانات التتبع.',
|
||||
},
|
||||
tencent: {
|
||||
title: 'Tencent APM',
|
||||
description: 'تُوفر مراقبة أداء التطبيقات من Tencent تتبعًا شاملاً وتحليلاً متعدد الأبعاد لتطبيقات LLM.',
|
||||
},
|
||||
inUse: 'قيد الاستخدام',
|
||||
configProvider: {
|
||||
title: 'تكوين ',
|
||||
placeholder: 'أدخل {{key}} الخاص بك',
|
||||
project: 'مشروع',
|
||||
trackingUri: 'رابط التتبع',
|
||||
experimentId: 'معرف التجربة',
|
||||
username: 'اسم المستخدم',
|
||||
password: 'كلمة المرور',
|
||||
publicKey: 'المفتاح العام',
|
||||
secretKey: 'المفتاح السري',
|
||||
viewDocsLink: 'عرض وثائق {{key}}',
|
||||
removeConfirmTitle: 'إزالة تكوين {{key}}؟',
|
||||
removeConfirmContent: 'التكوين الحالي قيد الاستخدام، وستؤدي إزالته إلى إيقاف ميزة التتبع.',
|
||||
clientId: 'معرف العميل (Client ID)',
|
||||
clientSecret: 'سر العميل (Client Secret)',
|
||||
personalAccessToken: 'رمز الوصول الشخصي (القديم)',
|
||||
databricksHost: 'عنوان URL لمساحة عمل Databricks',
|
||||
},
|
||||
},
|
||||
appSelector: {
|
||||
label: 'تطبيق',
|
||||
placeholder: 'اختر تطبيقًا...',
|
||||
params: 'معلمات التطبيق',
|
||||
noParams: 'لا توجد معلمات مطلوبة',
|
||||
},
|
||||
showMyCreatedAppsOnly: 'تم إنشاؤه بواسطتي',
|
||||
structOutput: {
|
||||
moreFillTip: 'يظهر 10 مستويات كحد أقصى من التداخل',
|
||||
required: 'مطلوب',
|
||||
LLMResponse: 'استجابة LLM',
|
||||
configure: 'تكوين',
|
||||
notConfiguredTip: 'لم يتم تكوين الإخراج الهيكلي بعد',
|
||||
structured: 'هيكلي',
|
||||
structuredTip: 'المخرجات الهيكلية هي ميزة تضمن أن يولد النموذج دائمًا استجابات تلتزم بـ JSON Schema الذي قدمته',
|
||||
modelNotSupported: 'النموذج غير مدعوم',
|
||||
modelNotSupportedTip: 'النموذج الحالي لا يدعم هذه الميزة ويتم تخفيضه تلقائيًا إلى حقن المطالبة.',
|
||||
},
|
||||
accessControl: 'التحكم في الوصول إلى تطبيق الويب',
|
||||
accessItemsDescription: {
|
||||
anyone: 'يمكن لأي شخص الوصول إلى تطبيق الويب (لا يلزم تسجيل الدخول)',
|
||||
specific: 'يمكن فقط لأعضاء محددين داخل المنصة الوصول إلى تطبيق الويب',
|
||||
organization: 'يمكن لجميع الأعضاء داخل المنصة الوصول إلى تطبيق الويب',
|
||||
external: 'يمكن فقط للمستخدمين الخارجيين authenticated الوصول إلى تطبيق الويب',
|
||||
},
|
||||
accessControlDialog: {
|
||||
title: 'التحكم في الوصول إلى تطبيق الويب',
|
||||
description: 'تعيين أذونات الوصول إلى تطبيق الويب',
|
||||
accessLabel: 'من لديه حق الوصول',
|
||||
accessItems: {
|
||||
anyone: 'أي شخص لديه الرابط',
|
||||
specific: 'أعضاء محددون داخل المنصة',
|
||||
organization: 'جميع الأعضاء داخل المنصة',
|
||||
external: 'المستخدمون الخارجيون Authenticated',
|
||||
},
|
||||
groups_one: '{{count}} مجموعة',
|
||||
groups_other: '{{count}} مجموعات',
|
||||
members_one: '{{count}} عضو',
|
||||
members_other: '{{count}} أعضاء',
|
||||
noGroupsOrMembers: 'لم يتم تحديد مجموعات أو أعضاء',
|
||||
webAppSSONotEnabledTip: 'الرجاء الاتصال بمسؤول المؤسسة لتكوين المصادقة الخارجية لتطبيق الويب.',
|
||||
operateGroupAndMember: {
|
||||
searchPlaceholder: 'بحث عن مجموعات وأعضاء',
|
||||
allMembers: 'جميع الأعضاء',
|
||||
expand: 'توسيع',
|
||||
noResult: 'لا توجد نتائج',
|
||||
},
|
||||
updateSuccess: 'تم التحديث بنجاح',
|
||||
},
|
||||
publishApp: {
|
||||
title: 'من يمكنه الوصول إلى تطبيق الويب',
|
||||
notSet: 'لم يتم تعيينه',
|
||||
notSetDesc: 'حاليا لا يمكن لأحد الوصول إلى تطبيق الويب. الرجاء تعيين الأذونات.',
|
||||
},
|
||||
noAccessPermission: 'لا يوجد إذن للوصول إلى تطبيق الويب',
|
||||
noUserInputNode: 'عقدة إدخال المستخدم مفقودة',
|
||||
notPublishedYet: 'التطبيق لم ينشر بعد',
|
||||
maxActiveRequests: 'أقصى عدد للطلبات المتزامنة',
|
||||
maxActiveRequestsPlaceholder: 'أدخل 0 لغير محدود',
|
||||
maxActiveRequestsTip: 'الحد الأقصى لعدد الطلبات النشطة المتزامنة لكل تطبيق (0 لغير محدود)',
|
||||
gotoAnything: {
|
||||
searchPlaceholder: 'ابحث أو اكتب @ أو / للأوامر...',
|
||||
searchTitle: 'ابحث عن أي شيء',
|
||||
searching: 'جاري البحث...',
|
||||
noResults: 'لم يتم العثور على نتائج',
|
||||
searchFailed: 'فشل البحث',
|
||||
searchTemporarilyUnavailable: 'البحث غير متاح مؤقتًا',
|
||||
servicesUnavailableMessage: 'قد تواجه بعض خدمات البحث مشكلات. حاول مرة أخرى لاحقًا.',
|
||||
someServicesUnavailable: 'بعض خدمات البحث غير متوفرة',
|
||||
resultCount: '{{count}} نتيجة',
|
||||
resultCount_other: '{{count}} نتائج',
|
||||
inScope: 'في {{scope}}',
|
||||
clearToSearchAll: 'امسح @ للبحث في الكل',
|
||||
useAtForSpecific: 'استخدم @ لأنواع محددة',
|
||||
selectToNavigate: 'اختر للانتقال',
|
||||
startTyping: 'ابدأ الكتابة للبحث',
|
||||
tips: 'اضغط ↑↓ للتنقل',
|
||||
pressEscToClose: 'اضغط ESC للإغلاق',
|
||||
selectSearchType: 'اختر ما تريد البحث عنه',
|
||||
searchHint: 'ابدأ الكتابة للبحث عن كل شيء على الفور',
|
||||
commandHint: 'اكتب @ للتصفح حسب الفئة',
|
||||
slashHint: 'اكتب / لرؤية جميع الأوامر المتاحة',
|
||||
actions: {
|
||||
searchApplications: 'بحث في التطبيقات',
|
||||
searchApplicationsDesc: 'البحث والانتقال إلى تطبيقاتك',
|
||||
searchPlugins: 'بحث في الإضافات',
|
||||
searchPluginsDesc: 'البحث والانتقال إلى إضافاتك',
|
||||
searchKnowledgeBases: 'بحث في قواعد المعرفة',
|
||||
searchKnowledgeBasesDesc: 'البحث والانتقال إلى قواعد المعرفة الخاصة بك',
|
||||
searchWorkflowNodes: 'بحث في عقد سير العمل',
|
||||
searchWorkflowNodesDesc: 'البحث والانتقال إلى العقد في سير العمل الحالي بالاسم أو النوع',
|
||||
searchWorkflowNodesHelp: 'هذه الميزة تعمل فقط عند عرض سير العمل. انتقل إلى سير العمل أولاً.',
|
||||
runTitle: 'أوامر',
|
||||
runDesc: 'تشغيل أوامر سريعة (السمة، اللغة، ...)',
|
||||
themeCategoryTitle: 'السمة',
|
||||
themeCategoryDesc: 'تبديل سمة التطبيق',
|
||||
themeSystem: 'سمة النظام',
|
||||
themeSystemDesc: 'اتبع مظهر نظام التشغيل',
|
||||
themeLight: 'السمة الفاتحة',
|
||||
themeLightDesc: 'استخدم المظهر الفاتح',
|
||||
themeDark: 'السمة الداكنة',
|
||||
themeDarkDesc: 'استخدم المظهر الداكن',
|
||||
languageCategoryTitle: 'اللغة',
|
||||
languageCategoryDesc: 'تبديل لغة الواجهة',
|
||||
languageChangeDesc: 'تغيير لغة واجهة المستخدم',
|
||||
slashDesc: 'تنفيذ الأوامر (اكتب / لرؤية جميع الأوامر المتاحة)',
|
||||
accountDesc: 'الانتقال إلى صفحة الحساب',
|
||||
communityDesc: 'فتح مجتمع Discord',
|
||||
docDesc: 'فتح وثائق المساعدة',
|
||||
feedbackDesc: 'فتح مناقشات ملاحظات المجتمع',
|
||||
zenTitle: 'وضع Zen',
|
||||
zenDesc: 'تبديل وضع التركيز على اللوحة',
|
||||
},
|
||||
emptyState: {
|
||||
noAppsFound: 'لم يتم العثور على تطبيقات',
|
||||
noPluginsFound: 'لم يتم العثور على إضافات',
|
||||
noKnowledgeBasesFound: 'لم يتم العثور على قواعد معرفة',
|
||||
noWorkflowNodesFound: 'لم يتم العثور على عقد سير عمل',
|
||||
tryDifferentTerm: 'جرب مصطلح بحث مختلف',
|
||||
trySpecificSearch: 'جرب {{shortcuts}} لعمليات بحث محددة',
|
||||
},
|
||||
groups: {
|
||||
apps: 'تطبيقات',
|
||||
plugins: 'إضافات',
|
||||
knowledgeBases: 'قواعد المعرفة',
|
||||
workflowNodes: 'عقد سير العمل',
|
||||
commands: 'أوامر',
|
||||
},
|
||||
noMatchingCommands: 'لم يتم العثور على أوامر مطابقة',
|
||||
tryDifferentSearch: 'جرب مصطلح بحث مختلف',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
221
web/i18n/ar-TN/billing.ts
Normal file
221
web/i18n/ar-TN/billing.ts
Normal file
@@ -0,0 +1,221 @@
|
||||
const translation = {
|
||||
currentPlan: 'الخطة الحالية',
|
||||
usagePage: {
|
||||
teamMembers: 'أعضاء الفريق',
|
||||
buildApps: 'بناء التطبيقات',
|
||||
annotationQuota: 'حصة التعليقات التوضيحية',
|
||||
documentsUploadQuota: 'حصة رفع المستندات',
|
||||
vectorSpace: 'تخزين بيانات المعرفة',
|
||||
vectorSpaceTooltip: 'ستستهلك المستندات ذات وضع الفهرسة عالي الجودة موارد تخزين بيانات المعرفة. عندما يصل تخزين بيانات المعرفة إلى الحد الأقصى، لن يتم تحميل مستندات جديدة.',
|
||||
triggerEvents: 'أحداث المشغل',
|
||||
perMonth: 'شهريًا',
|
||||
resetsIn: 'يتم إعادة التعيين في {{count,number}} أيام',
|
||||
},
|
||||
teamMembers: 'أعضاء الفريق',
|
||||
triggerLimitModal: {
|
||||
title: 'ترقية لفتح المزيد من أحداث المشغل',
|
||||
description: 'لقد وصلت إلى الحد الأقصى لمشغلات أحداث سير العمل لهذه الخطة.',
|
||||
dismiss: 'تجاهل',
|
||||
upgrade: 'ترقية',
|
||||
usageTitle: 'أحداث المشغل',
|
||||
},
|
||||
upgradeBtn: {
|
||||
plain: 'عرض الخطة',
|
||||
encourage: 'الترقية الآن',
|
||||
encourageShort: 'ترقية',
|
||||
},
|
||||
viewBilling: 'إدارة الفواتير والاشتراكات',
|
||||
buyPermissionDeniedTip: 'يرجى الاتصال بمسؤول المؤسسة للاشتراك',
|
||||
plansCommon: {
|
||||
title: {
|
||||
plans: 'الخطط',
|
||||
description: 'اختر الخطة التي تناسب احتياجات فريقك.',
|
||||
},
|
||||
freeTrialTipPrefix: 'سجل واحصل على ',
|
||||
freeTrialTip: 'تجربة مجانية لـ 200 مكالمة OpenAI. ',
|
||||
freeTrialTipSuffix: 'لا تتطلب بطاقة ائتمان',
|
||||
yearlyTip: 'ادفع لمدة 10 أشهر، واستمتع بسنة كاملة!',
|
||||
mostPopular: 'الأكثر شعبية',
|
||||
cloud: 'خدمة سحابية',
|
||||
self: 'مستضافة ذاتيًا',
|
||||
planRange: {
|
||||
monthly: 'شهري',
|
||||
yearly: 'سنوي',
|
||||
},
|
||||
month: 'شهر',
|
||||
year: 'سنة',
|
||||
save: 'وفر ',
|
||||
free: 'مجاني',
|
||||
annualBilling: 'الفوترة السنوية توفر {{percent}}%',
|
||||
taxTip: 'جميع أسعار الاشتراك (الشهرية / السنوية) لا تشمل الضرائب المطبقة (مثل ضريبة القيمة المضافة وضريبة المبيعات).',
|
||||
taxTipSecond: 'إذا لم تكن في منطقتك متطلبات ضريبية، فلن تظهر أي ضريبة عند الدفع، ولن يتم تحصيل أي رسوم إضافية طوال فترة الاشتراك.',
|
||||
comparePlanAndFeatures: 'قارن الخطط والميزات',
|
||||
priceTip: 'لكل مساحة عمل/',
|
||||
currentPlan: 'الخطة الحالية',
|
||||
contractSales: 'اتصل بالمبيعات',
|
||||
contractOwner: 'اتصل بمدير الفريق',
|
||||
startForFree: 'ابدأ مجانًا',
|
||||
startBuilding: 'ابدأ البناء',
|
||||
getStarted: 'ابدأ الآن',
|
||||
contactSales: 'اتصل بالمبيعات',
|
||||
talkToSales: 'تحدث إلى المبيعات',
|
||||
modelProviders: 'دعم OpenAI/Anthropic/Llama2/Azure OpenAI/Hugging Face/Replicate',
|
||||
teamWorkspace: '{{count,number}} مساحة عمل للفريق',
|
||||
teamMember_one: '{{count,number}} عضو في الفريق',
|
||||
teamMember_other: '{{count,number}} أعضاء في الفريق',
|
||||
annotationQuota: 'حصة التعليقات التوضيحية',
|
||||
buildApps: '{{count,number}} تطبيقات',
|
||||
documents: '{{count,number}} مستندات معرفة',
|
||||
documentsTooltip: 'الحصة لعدد المستندات المستوردة من مصدر بيانات المعرفة.',
|
||||
vectorSpace: '{{size}} تخزين بيانات المعرفة',
|
||||
vectorSpaceTooltip: 'ستستهلك المستندات ذات وضع الفهرسة عالي الجودة موارد تخزين بيانات المعرفة. عندما يصل تخزين بيانات المعرفة إلى الحد الأقصى، لن يتم تحميل مستندات جديدة.',
|
||||
documentsRequestQuota: '{{count,number}} طلب معرفة/دقيقة',
|
||||
documentsRequestQuotaTooltip: 'يحدد العدد الإجمالي للإجراءات التي يمكن لمساحة العمل تنفيذها كل دقيقة داخل قاعدة المعرفة، بما في ذلك إنشاء مجموعة البيانات، والحذف، والتحديثات، ورفع المستندات، والتعديلات، والأرشفة، واستعلامات قاعدة المعرفة. يتم استخدام هذا المقياس لتقييم أداء طلبات قاعدة المعرفة. على سبيل المثال، إذا أجرى مستخدم Sandbox 10 اختبارات hit متتالية في دقيقة واحدة، فسيتم تقييد مساحة العمل الخاصة به مؤقتًا من تنفيذ الإجراءات التالية للدقيقة التالية: إنشاء مجموعة البيانات، والحذف، والتحديثات، ورفع المستندات أو التعديلات. ',
|
||||
apiRateLimit: 'حد معدل API',
|
||||
apiRateLimitUnit: '{{count,number}}',
|
||||
unlimitedApiRate: 'لا يوجد حد لمعدل API لـ Dify',
|
||||
apiRateLimitTooltip: 'ينطبق حد معدل API على جميع الطلبات التي يتم إجراؤها من خلال Dify API، بما في ذلك توليد النصوص، ومحادثات الدردشة، وتنفيذ سير العمل، ومعالجة المستندات.',
|
||||
documentProcessingPriority: ' أولوية معالجة المستندات',
|
||||
documentProcessingPriorityTip: 'لأولوية معالجة مستندات أعلى، يرجى ترقية خطتك.',
|
||||
documentProcessingPriorityUpgrade: 'معالجة المزيد من البيانات بدقة أعلى وسرعة أكبر.',
|
||||
priority: {
|
||||
'standard': 'قياسي',
|
||||
'priority': 'أولوية',
|
||||
'top-priority': 'أولوية قصوى',
|
||||
},
|
||||
triggerEvents: {
|
||||
sandbox: '{{count,number}} أحداث مشغل',
|
||||
professional: '{{count,number}} أحداث مشغل/شهر',
|
||||
unlimited: 'أحداث مشغل غير محدودة',
|
||||
tooltip: 'عدد الأحداث التي تبدأ سير العمل تلقائيًا من خلال مشغلات الإضافات أو الجدول الزمني أو Webhook.',
|
||||
},
|
||||
workflowExecution: {
|
||||
standard: 'تنفيذ سير عمل قياسي',
|
||||
faster: 'تنفيذ سير عمل أسرع',
|
||||
priority: 'تنفيذ سير عمل ذو أولوية',
|
||||
tooltip: 'أولوية وسرعة قائمة انتظار تنفيذ سير العمل.',
|
||||
},
|
||||
startNodes: {
|
||||
limited: 'ما يصل إلى {{count}} مشغلات/سير عمل',
|
||||
unlimited: 'مشغلات غير محدودة/سير عمل',
|
||||
},
|
||||
logsHistory: '{{days}} تاريخ السجلات',
|
||||
customTools: 'أدوات مخصصة',
|
||||
unavailable: 'غير متوفر',
|
||||
days: 'أيام',
|
||||
unlimited: 'غير محدود',
|
||||
support: 'الدعم',
|
||||
supportItems: {
|
||||
communityForums: 'منتديات المجتمع',
|
||||
emailSupport: 'دعم البريد الإلكتروني',
|
||||
priorityEmail: 'أولوية دعم البريد الإلكتروني والدردشة',
|
||||
logoChange: 'تغيير الشعار',
|
||||
SSOAuthentication: 'مصادقة SSO',
|
||||
personalizedSupport: 'دعم مخصص',
|
||||
dedicatedAPISupport: 'دعم API مخصص',
|
||||
customIntegration: 'تكامل ودعم مخصص',
|
||||
ragAPIRequest: 'طلبات RAG API',
|
||||
bulkUpload: 'رفع المستندات بالجملة',
|
||||
agentMode: 'وضع الوكيل',
|
||||
workflow: 'سير العمل',
|
||||
llmLoadingBalancing: 'موازنة حمل LLM',
|
||||
llmLoadingBalancingTooltip: 'أضف مفاتيح API متعددة للنماذج، مما يتيح تجاوز حدود معدل API بشكل فعال. ',
|
||||
},
|
||||
comingSoon: 'قريبا',
|
||||
member: 'عضو',
|
||||
memberAfter: 'عضو',
|
||||
messageRequest: {
|
||||
title: '{{count,number}} أرصدة الرسائل',
|
||||
titlePerMonth: '{{count,number}} أرصدة رسائل/شهر',
|
||||
tooltip: 'يتم توفير أرصدة الرسائل لمساعدتك على تجربة نماذج OpenAI المختلفة بسهولة في Dify. يتم استهلاك الأرصدة بناءً على نوع النموذج. بمجرد نفادها، يمكنك التبديل إلى مفتاح OpenAI API الخاص بك.',
|
||||
},
|
||||
annotatedResponse: {
|
||||
title: '{{count,number}} حدود حصة التعليقات التوضيحية',
|
||||
tooltip: 'يوفر التحرير اليدوي والتعليق على الردود قدرات إجابة على الأسئلة عالية الجودة وقابلة للتخصيص للتطبيقات. (ينطبق فقط في تطبيقات الدردشة)',
|
||||
},
|
||||
ragAPIRequestTooltip: 'يشير إلى عدد مكالمات API التي تستدعي فقط قدرات معالجة قاعدة المعرفة في Dify.',
|
||||
receiptInfo: 'يمكن لمالك الفريق ومشرف الفريق فقط الاشتراك وعرض معلومات الفوترة',
|
||||
},
|
||||
plans: {
|
||||
sandbox: {
|
||||
name: 'Sandbox',
|
||||
for: 'تجربة مجانية للقدرات الأساسية',
|
||||
description: 'جرب الميزات الأساسية مجانًا.',
|
||||
},
|
||||
professional: {
|
||||
name: 'احترافي',
|
||||
for: 'للمطورين المستقلين / الفرق الصغيرة',
|
||||
description: 'للمطورين المستقلين والفرق الصغيرة المستعدة لبناء تطبيقات الذكاء الاصطناعي الإنتاجية.',
|
||||
},
|
||||
team: {
|
||||
name: 'فريق',
|
||||
for: 'للفرق متوسطة الحجم',
|
||||
description: 'للفرق متوسطة الحجم التي تتطلب التعاون وإنتاجية أعلى.',
|
||||
},
|
||||
community: {
|
||||
name: 'مجتمع',
|
||||
for: 'للمستخدمين الأفراد، أو الفرق الصغيرة، أو المشاريع غير التجارية',
|
||||
description: 'للمتحمسين للمصادر المفتوحة، والمطورين الأفراد، والمشاريع غير التجارية',
|
||||
price: 'مجاني',
|
||||
btnText: 'ابدأ الآن',
|
||||
includesTitle: 'ميزات مجانية:',
|
||||
features: ['تم إصدار جميع الميزات الأساسية تحت المستودع العام', 'مساحة عمل واحدة', 'متوافق مع ترخيص ديفي المفتوح المصدر'],
|
||||
},
|
||||
premium: {
|
||||
name: 'بريميوم',
|
||||
for: 'للمؤسسات والفرق متوسطة الحجم',
|
||||
description: 'للمؤسسات متوسطة الحجم التي تحتاج إلى مرونة في النشر ودعم معزز',
|
||||
price: 'قابل للتطوير',
|
||||
priceTip: 'استنادًا إلى سوق السحابة',
|
||||
btnText: 'احصل على بريميوم على',
|
||||
includesTitle: 'كل شيء من المجتمع، بالإضافة إلى:',
|
||||
comingSoon: 'دعم Microsoft Azure و Google Cloud قريبا',
|
||||
features: ['الاعتمادية المدارة ذاتيًا من قبل مختلف مزودي السحابة', 'مساحة عمل واحدة', 'تخصيص شعار وهوية التطبيق الإلكتروني', 'دعم البريد الإلكتروني والمحادثة ذو الأولوية'],
|
||||
},
|
||||
enterprise: {
|
||||
name: 'مؤسسة (Enterprise)',
|
||||
for: 'للفرق كبيرة الحجم',
|
||||
description: 'للمؤسسات التي تتطلب أمانًا وامتثالًا وقابلية للتوسع وتحكمًا وحلولًا مخصصة على مستوى المؤسسة',
|
||||
price: 'مخصص',
|
||||
priceTip: 'الفوترة السنوية فقط',
|
||||
btnText: 'اتصل بالمبيعات',
|
||||
includesTitle: 'كل شيء من <highlight>بريميوم</highlight>، بالإضافة إلى:',
|
||||
features: ['حلول نشر قابلة للتوسع على مستوى المؤسسات', 'تفويض الترخيص التجاري', 'ميزات حصرية للمؤسسات', 'مساحات عمل متعددة وإدارة المؤسسات', 'تسجيل الدخول الموحد', 'اتفاقيات مستوى الخدمة المتفاوض عليها من قبل شركاء ديفي', 'الأمان والتحكم المتقدم', 'التحديثات والصيانة بواسطة Dify رسميًا', 'الدعم الفني المهني'],
|
||||
},
|
||||
},
|
||||
vectorSpace: {
|
||||
fullTip: 'مساحة المتجه ممتلئة.',
|
||||
fullSolution: 'قم بترقية خطتك للحصول على مساحة أكبر.',
|
||||
},
|
||||
apps: {
|
||||
fullTip1: 'ترقية لإنشاء المزيد من التطبيقات',
|
||||
fullTip1des: 'لقد وصلت إلى الحد الأقصى لبناء التطبيقات في هذه الخطة',
|
||||
fullTip2: 'تم الوصول إلى حد الخطة',
|
||||
fullTip2des: 'يوصى بتنظيف التطبيقات غير النشطة لتحرير الاستخدام، أو الاتصال بنا.',
|
||||
contactUs: 'اتصل بنا',
|
||||
},
|
||||
annotatedResponse: {
|
||||
fullTipLine1: 'قم بترقية خطتك لـ',
|
||||
fullTipLine2: 'التعليق على المزيد من المحادثات.',
|
||||
quotaTitle: 'حصة رد التعليقات التوضيحية',
|
||||
},
|
||||
viewBillingTitle: 'الفوترة والاشتراكات',
|
||||
viewBillingDescription: 'إدارة طرق الدفع والفواتير وتغييرات الاشتراك',
|
||||
viewBillingAction: 'يدير',
|
||||
upgrade: {
|
||||
uploadMultiplePages: {
|
||||
title: 'قم بالترقية لتحميل عدة مستندات دفعة واحدة',
|
||||
description: 'لقد وصلت إلى حد التحميل — يمكن اختيار ورفع مستند واحد فقط في كل مرة على الخطة الحالية الخاصة بك.',
|
||||
},
|
||||
uploadMultipleFiles: {
|
||||
title: 'قم بالترقية لفتح ميزة تحميل المستندات دفعة واحدة',
|
||||
description: 'قم بتحميل المزيد من المستندات دفعة واحدة لتوفير الوقت وتحسين الكفاءة.',
|
||||
},
|
||||
addChunks: {
|
||||
title: 'قم بالترقية لمواصلة إضافة المقاطع',
|
||||
description: 'لقد وصلت إلى الحد الأقصى لإضافة الأجزاء لهذا الخطة.',
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
788
web/i18n/ar-TN/common.ts
Normal file
788
web/i18n/ar-TN/common.ts
Normal file
@@ -0,0 +1,788 @@
|
||||
const translation = {
|
||||
theme: {
|
||||
theme: 'السمة',
|
||||
light: 'فاتح',
|
||||
dark: 'داكن',
|
||||
auto: 'النظام',
|
||||
},
|
||||
api: {
|
||||
success: 'نجاح',
|
||||
actionSuccess: 'نجح الإجراء',
|
||||
saved: 'تم الحفظ',
|
||||
create: 'تم الإنشاء',
|
||||
remove: 'تمت الإزالة',
|
||||
},
|
||||
operation: {
|
||||
create: 'إنشاء',
|
||||
confirm: 'تأكيد',
|
||||
cancel: 'إلغاء',
|
||||
clear: 'مسح',
|
||||
save: 'حفظ',
|
||||
yes: 'نعم',
|
||||
no: 'لا',
|
||||
deleteConfirmTitle: 'حذف؟',
|
||||
confirmAction: 'يرجى تأكيد الإجراء الخاص بك.',
|
||||
saveAndEnable: 'حفظ وتمكين',
|
||||
edit: 'تعديل',
|
||||
add: 'إضافة',
|
||||
added: 'تمت الإضافة',
|
||||
refresh: 'إعادة تشغيل',
|
||||
reset: 'إعادة تعيين',
|
||||
search: 'بحث',
|
||||
noSearchResults: 'لم يتم العثور على {{content}}',
|
||||
resetKeywords: 'إعادة تعيين الكلمات الرئيسية',
|
||||
selectCount: 'تم تحديد {{count}}',
|
||||
searchCount: 'ابحث عن {{count}} {{content}}',
|
||||
noSearchCount: '0 {{content}}',
|
||||
change: 'تغيير',
|
||||
remove: 'إزالة',
|
||||
send: 'إرسال',
|
||||
copy: 'نسخ',
|
||||
copied: 'تم النسخ',
|
||||
lineBreak: 'فاصل أسطر',
|
||||
sure: 'أنا متأكد',
|
||||
download: 'تنزيل',
|
||||
downloadSuccess: 'اكتمل التنزيل.',
|
||||
downloadFailed: 'فشل التنزيل. يرجى المحاولة مرة أخرى لاحقًا.',
|
||||
viewDetails: 'عرض التفاصيل',
|
||||
delete: 'حذف',
|
||||
now: 'الآن',
|
||||
deleteApp: 'حذف التطبيق',
|
||||
settings: 'الإعدادات',
|
||||
setup: 'إعداد',
|
||||
config: 'تكوين',
|
||||
getForFree: 'احصل عليه مجانا',
|
||||
reload: 'إعادة تحميل',
|
||||
ok: 'موافق',
|
||||
log: 'سجل',
|
||||
learnMore: 'تعرف على المزيد',
|
||||
params: 'معلمات',
|
||||
duplicate: 'تكرار',
|
||||
rename: 'إعادة تسمية',
|
||||
audioSourceUnavailable: 'مصدر الصوت غير متاح',
|
||||
close: 'إغلاق',
|
||||
copyImage: 'نسخ الصورة',
|
||||
imageCopied: 'تم نسخ الصورة',
|
||||
zoomOut: 'تصغير',
|
||||
zoomIn: 'تكبير',
|
||||
openInNewTab: 'فتح في علامة تبويب جديدة',
|
||||
in: 'في',
|
||||
saveAndRegenerate: 'حفظ وإعادة إنشاء القطع الفرعية',
|
||||
view: 'عرض',
|
||||
viewMore: 'عرض المزيد',
|
||||
regenerate: 'إعادة إنشاء',
|
||||
submit: 'إرسال',
|
||||
skip: 'تخطي',
|
||||
format: 'تنسيق',
|
||||
more: 'المزيد',
|
||||
selectAll: 'تحديد الكل',
|
||||
deSelectAll: 'إلغاء تحديد الكل',
|
||||
},
|
||||
errorMsg: {
|
||||
fieldRequired: '{{field}} مطلوب',
|
||||
urlError: 'يجب أن يبدأ العنوان بـ http:// أو https://',
|
||||
},
|
||||
placeholder: {
|
||||
input: 'يرجى الإدخال',
|
||||
select: 'يرجى التحديد',
|
||||
search: 'بحث...',
|
||||
},
|
||||
noData: 'لا توجد بيانات',
|
||||
label: {
|
||||
optional: '(اختياري)',
|
||||
},
|
||||
voice: {
|
||||
language: {
|
||||
zhHans: 'الصينية',
|
||||
zhHant: 'الصينية التقليدية',
|
||||
enUS: 'الإنجليزية',
|
||||
deDE: 'الألمانية',
|
||||
frFR: 'الفرنسية',
|
||||
esES: 'الإسبانية',
|
||||
itIT: 'الإيطالية',
|
||||
thTH: 'التايلاندية',
|
||||
idID: 'الإندونيسية',
|
||||
jaJP: 'اليابانية',
|
||||
koKR: 'الكورية',
|
||||
ptBR: 'البرتغالية',
|
||||
ruRU: 'الروسية',
|
||||
ukUA: 'الأوكرانية',
|
||||
viVN: 'الفيتنامية',
|
||||
plPL: 'البولندية',
|
||||
roRO: 'الرومانية',
|
||||
hiIN: 'الهندية',
|
||||
trTR: 'التركية',
|
||||
faIR: 'الفارسية',
|
||||
},
|
||||
},
|
||||
unit: {
|
||||
char: 'أحرف',
|
||||
},
|
||||
actionMsg: {
|
||||
noModification: 'لا توجد تعديلات في الوقت الحالي.',
|
||||
modifiedSuccessfully: 'تم التعديل بنجاح',
|
||||
modifiedUnsuccessfully: 'فشل التعديل',
|
||||
copySuccessfully: 'تم النسخ بنجاح',
|
||||
paySucceeded: 'نجح الدفع',
|
||||
payCancelled: 'تم إلغاء الدفع',
|
||||
generatedSuccessfully: 'تم الإنشاء بنجاح',
|
||||
generatedUnsuccessfully: 'فشل الإنشاء',
|
||||
},
|
||||
model: {
|
||||
params: {
|
||||
temperature: 'درجة الحرارة',
|
||||
temperatureTip:
|
||||
'تتحكم في العشوائية: يؤدي التخفيض إلى إكمالات أقل عشوائية. مع اقتراب درجة الحرارة من الصفر، سيصبح النموذج حتميًا ومتكررًا.',
|
||||
top_p: 'أعلى P',
|
||||
top_pTip:
|
||||
'تتحكم في التنوع عبر عينات النواة: 0.5 تعني أنه يتم النظر في نصف جميع الخيارات المرجحة للاحتمالية.',
|
||||
presence_penalty: 'عقوبة الحضور',
|
||||
presence_penaltyTip:
|
||||
'مقدار معاقبة الرموز الجديدة بناءً على ما إذا كانت تظهر في النص حتى الآن.\nيزيد من احتمال تحدث النموذج عن مواضيع جديدة.',
|
||||
frequency_penalty: 'عقوبة التردد',
|
||||
frequency_penaltyTip:
|
||||
'مقدار معاقبة الرموز الجديدة بناءً على ترددها الحالي في النص حتى الآن.\nيقلل من احتمال تكرار النموذج لنفس السطر حرفيًا.',
|
||||
max_tokens: 'أقصى رمز',
|
||||
max_tokensTip:
|
||||
'يستخدم للحد من الطول الأقصى للرد، بالرموز. \nقد تحد القيم الأكبر من المساحة المتبقية للكلمات السريعة وسجلات الدردشة والمعرفة. \nيوصى بضبطه أقل من الثلثين\ngpt-4-1106-preview، gpt-4-vision-preview أقصى رمز (إدخال 128k إخراج 4k)',
|
||||
maxTokenSettingTip: 'إعداد الرموز القصوى الخاص بك مرتفع، مما قد يحد من المساحة للمطالبات والاستعلامات والبيانات. فكر في ضبطه أقل من 2/3.',
|
||||
setToCurrentModelMaxTokenTip: 'يتم تحديث الحد الأقصى للرموز إلى 80٪ من الحد الأقصى لرموز النموذج الحالي {{maxToken}}.',
|
||||
stop_sequences: 'تسلسلات التوقف',
|
||||
stop_sequencesTip: 'ما يصل إلى أربعة تسلسلات حيث ستتوقف API عن توليد المزيد من الرموز. لن يحتوي النص المرتجع على تسلسل التوقف.',
|
||||
stop_sequencesPlaceholder: 'أدخل التسلسل واضغط على Tab',
|
||||
},
|
||||
tone: {
|
||||
Creative: 'إبداعي',
|
||||
Balanced: 'متوازن',
|
||||
Precise: 'دقيق',
|
||||
Custom: 'مخصص',
|
||||
},
|
||||
addMoreModel: 'انتقل إلى الإعدادات لإضافة المزيد من النماذج',
|
||||
settingsLink: 'إعدادات مزود النموذج',
|
||||
capabilities: 'قدرات متعددة الوسائط',
|
||||
},
|
||||
menus: {
|
||||
status: 'بيتا',
|
||||
explore: 'استكشاف',
|
||||
apps: 'الاستوديو',
|
||||
appDetail: 'تفاصيل التطبيق',
|
||||
account: 'الحساب',
|
||||
plugins: 'الإضافات',
|
||||
exploreMarketplace: 'استكشاف السوق',
|
||||
pluginsTips: 'ادمج الإضافات الخارجية أو أنشئ إضافات AI متوافقة مع ChatGPT.',
|
||||
datasets: 'المعرفة',
|
||||
datasetsTips: 'قريباً: استيراد بيانات النص الخاصة بك أو كتابة البيانات في الوقت الفعلي عبر Webhook لتحسين سياق LLM.',
|
||||
newApp: 'تطبيق جديد',
|
||||
newDataset: 'إنشاء معرفة',
|
||||
tools: 'الأدوات',
|
||||
},
|
||||
userProfile: {
|
||||
settings: 'الإعدادات',
|
||||
contactUs: 'اتصل بنا',
|
||||
emailSupport: 'دعم البريد الإلكتروني',
|
||||
workspace: 'مساحة العمل',
|
||||
createWorkspace: 'إنشاء مساحة عمل',
|
||||
helpCenter: 'عرض المستندات',
|
||||
support: 'دعم',
|
||||
compliance: 'الامتثال',
|
||||
forum: 'المنتدى',
|
||||
roadmap: 'خارطة الطريق',
|
||||
github: 'GitHub',
|
||||
community: 'المجتمع',
|
||||
about: 'حول',
|
||||
logout: 'تسجيل الخروج',
|
||||
},
|
||||
compliance: {
|
||||
soc2Type1: 'تقرير SOC 2 النوع الأول',
|
||||
soc2Type2: 'تقرير SOC 2 النوع الثاني',
|
||||
iso27001: 'شهادة ISO 27001:2022',
|
||||
gdpr: 'GDPR DPA',
|
||||
sandboxUpgradeTooltip: 'متاح فقط مع خطة المحترفين أو الفريق.',
|
||||
professionalUpgradeTooltip: 'متاح فقط مع خطة الفريق أو أعلى.',
|
||||
},
|
||||
settings: {
|
||||
accountGroup: 'عام',
|
||||
workplaceGroup: 'مساحة العمل',
|
||||
generalGroup: 'عام',
|
||||
account: 'حسابي',
|
||||
members: 'الأعضاء',
|
||||
billing: 'الفوترة',
|
||||
integrations: 'التكاملات',
|
||||
language: 'اللغة',
|
||||
provider: 'مزود النموذج',
|
||||
dataSource: 'مصدر البيانات',
|
||||
plugin: 'الإضافات',
|
||||
apiBasedExtension: 'ملحق API',
|
||||
},
|
||||
account: {
|
||||
account: 'الحساب',
|
||||
myAccount: 'حسابي',
|
||||
studio: 'الاستوديو',
|
||||
avatar: 'الصورة الرمزية',
|
||||
name: 'الاسم',
|
||||
email: 'البريد الإلكتروني',
|
||||
password: 'كلمة المرور',
|
||||
passwordTip: 'يمكنك تعيين كلمة مرور دائمية إذا كنت لا ترغب في استخدام رموز تسجيل الدخول المؤقتة',
|
||||
setPassword: 'تعيين كلمة مرور',
|
||||
resetPassword: 'إعادة تعيين كلمة المرور',
|
||||
currentPassword: 'كلمة المرور الحالية',
|
||||
newPassword: 'كلمة مرور جديدة',
|
||||
confirmPassword: 'تأكيد كلمة المرور',
|
||||
notEqual: 'كلمتا المرور مختلفتان.',
|
||||
langGeniusAccount: 'بيانات الحساب',
|
||||
langGeniusAccountTip: 'بيانات المستخدم الخاصة بحسابك.',
|
||||
editName: 'تعديل الاسم',
|
||||
showAppLength: 'عرض {{length}} تطبيقات',
|
||||
delete: 'حذف الحساب',
|
||||
deleteTip: 'يرجى ملاحظة أنه بمجرد التأكيد، بصفتك مالكًا لأي مساحات عمل، سيتم جدولة مساحات العمل الخاصة بك في قائمة انتظار للحذف الدائم، وسيتم جدولة جميع بيانات المستخدم الخاصة بك للحذف الدائم.',
|
||||
deletePrivacyLinkTip: 'لمزيد من المعلومات حول كيفية تعاملنا مع بياناتك، يرجى الاطلاع على ',
|
||||
deletePrivacyLink: 'سياسة الخصوصية.',
|
||||
deleteSuccessTip: 'يحتاج حسابك إلى وقت للانتهاء من الحذف. سنرسل إليك بريدًا إلكترونيًا عندما ينتهي كل شيء.',
|
||||
deleteLabel: 'للتأكيد، يرجى كتابة بريدك الإلكتروني أدناه',
|
||||
deletePlaceholder: 'يرجى إدخال بريدك الإلكتروني',
|
||||
sendVerificationButton: 'إرسال رمز التحقق',
|
||||
verificationLabel: 'رمز التحقق',
|
||||
verificationPlaceholder: 'الصق الرمز المكون من 6 أرقام',
|
||||
permanentlyDeleteButton: 'حذف الحساب نهائيًا',
|
||||
feedbackTitle: 'تعليق',
|
||||
feedbackLabel: 'أخبرنا لماذا حذفت حسابك؟',
|
||||
feedbackPlaceholder: 'اختياري',
|
||||
editWorkspaceInfo: 'تعديل معلومات مساحة العمل',
|
||||
workspaceName: 'اسم مساحة العمل',
|
||||
workspaceIcon: 'رمز مساحة العمل',
|
||||
changeEmail: {
|
||||
title: 'تغيير البريد الإلكتروني',
|
||||
verifyEmail: 'تحقق من بريدك الإلكتروني الحالي',
|
||||
newEmail: 'إعداد عنوان بريد إلكتروني جديد',
|
||||
verifyNew: 'تحقق من بريدك الإلكتروني الجديد',
|
||||
authTip: 'بمجرد تغيير بريدك الإلكتروني، لن تتمكن حسابات Google أو GitHub المرتبطة ببريدك الإلكتروني القديم من تسجيل الدخول إلى هذا الحساب.',
|
||||
content1: 'إذا تابعت، فسنرسل رمز تحقق إلى <email>{{email}}</email> لإعادة المصادقة.',
|
||||
content2: 'بريدك الإلكتروني الحالي هو <email>{{email}}</email>. تم إرسال رمز التحقق إلى عنوان البريد الإلكتروني هذا.',
|
||||
content3: 'أدخل بريدًا إلكترونيًا جديدًا وسنرسل لك رمز التحقق.',
|
||||
content4: 'لقد أرسلنا لك للتو رمز تحقق مؤقت إلى <email>{{email}}</email>.',
|
||||
codeLabel: 'رمز التحقق',
|
||||
codePlaceholder: 'الصق الرمز المكون من 6 أرقام',
|
||||
emailLabel: 'بريد إلكتروني جديد',
|
||||
emailPlaceholder: 'أدخل بريدًا إلكترونيًا جديدًا',
|
||||
existingEmail: 'مستخدم بهذا البريد الإلكتروني موجود بالفعل.',
|
||||
unAvailableEmail: 'هذا البريد الإلكتروني غير متاح مؤقتًا.',
|
||||
sendVerifyCode: 'إرسال رمز التحقق',
|
||||
continue: 'متابعة',
|
||||
changeTo: 'تغيير إلى {{email}}',
|
||||
resendTip: 'لم تتلق رمزًا؟',
|
||||
resendCount: 'إعادة إرسال في {{count}} ثانية',
|
||||
resend: 'إعادة إرسال',
|
||||
},
|
||||
},
|
||||
members: {
|
||||
team: 'الفريق',
|
||||
invite: 'إضافة',
|
||||
name: 'الاسم',
|
||||
lastActive: 'آخر نشاط',
|
||||
role: 'الأدوار',
|
||||
pending: 'قيد الانتظار...',
|
||||
owner: 'المالك',
|
||||
admin: 'المسؤول',
|
||||
adminTip: 'يمكنه بناء التطبيقات وإدارة إعدادات الفريق',
|
||||
normal: 'عادي',
|
||||
normalTip: 'يمكنه استخدام التطبيقات فقط، ولا يمكنه بناء التطبيقات',
|
||||
builder: 'باني',
|
||||
builderTip: 'يمكنه بناء وتعديل تطبيقاته الخاصة',
|
||||
editor: 'محرر',
|
||||
editorTip: 'يمكنه بناء وتعديل التطبيقات',
|
||||
datasetOperator: 'مسؤول المعرفة',
|
||||
datasetOperatorTip: 'يمكنه إدارة قاعدة المعرفة فقط',
|
||||
inviteTeamMember: 'إضافة عضو فريق',
|
||||
inviteTeamMemberTip: 'يمكنهم الوصول إلى بيانات فريقك مباشرة بعد تسجيل الدخول.',
|
||||
emailNotSetup: 'لم يتم إعداد خادم البريد الإلكتروني، لذا لا يمكن إرسال رسائل بريد إلكتروني للدعوة. يرجى إخطار المستخدمين برابط الدعوة الذي سيتم إصداره بعد الدعوة بدلاً من ذلك.',
|
||||
email: 'البريد الإلكتروني',
|
||||
emailInvalid: 'تنسيق البريد الإلكتروني غير صالح',
|
||||
emailPlaceholder: 'يرجى إدخال رسائل البريد الإلكتروني',
|
||||
sendInvite: 'إرسال دعوة',
|
||||
invitedAsRole: 'تمت الدعوة كمستخدم {{role}}',
|
||||
invitationSent: 'تم إرسال الدعوة',
|
||||
invitationSentTip: 'تم إرسال الدعوة، ويمكنهم تسجيل الدخول إلى Dify للوصول إلى بيانات فريقك.',
|
||||
invitationLink: 'رابط الدعوة',
|
||||
failedInvitationEmails: 'لم تتم دعوة المستخدمين أدناه بنجاح',
|
||||
ok: 'موافق',
|
||||
removeFromTeam: 'إزالة من الفريق',
|
||||
removeFromTeamTip: 'سيتم إزالة وصول الفريق',
|
||||
setAdmin: 'تعيين كمسؤول',
|
||||
setMember: 'تعيين كعضو عادي',
|
||||
setBuilder: 'تعيين كباني',
|
||||
setEditor: 'تعيين كمحرر',
|
||||
disInvite: 'إلغاء الدعوة',
|
||||
deleteMember: 'حذف العضو',
|
||||
you: '(أنت)',
|
||||
transferOwnership: 'نقل الملكية',
|
||||
transferModal: {
|
||||
title: 'نقل ملكية مساحة العمل',
|
||||
warning: 'أنت على وشك نقل ملكية "{{workspace}}". يسري هذا المفعول فورًا ولا يمكن التراجع عنه.',
|
||||
warningTip: 'ستصبح عضوًا مسؤولاً، وسيتمتع المالك الجديد بالتحكم الكامل.',
|
||||
sendTip: 'إذا تابعت، فسنرسل رمز تحقق إلى <email>{{email}}</email> لإعادة المصادقة.',
|
||||
verifyEmail: 'تحقق من بريدك الإلكتروني الحالي',
|
||||
verifyContent: 'بريدك الإلكتروني الحالي هو <email>{{email}}</email>.',
|
||||
verifyContent2: 'سنرسل رمز تحقق مؤقت إلى هذا البريد الإلكتروني لإعادة المصادقة.',
|
||||
codeLabel: 'رمز التحقق',
|
||||
codePlaceholder: 'الصق الرمز المكون من 6 أرقام',
|
||||
resendTip: 'لم تتلق رمزًا؟',
|
||||
resendCount: 'إعادة إرسال في {{count}} ثانية',
|
||||
resend: 'إعادة إرسال',
|
||||
transferLabel: 'نقل ملكية مساحة العمل إلى',
|
||||
transferPlaceholder: 'حدد عضو مساحة عمل...',
|
||||
sendVerifyCode: 'إرسال رمز التحقق',
|
||||
continue: 'متابعة',
|
||||
transfer: 'نقل ملكية مساحة العمل',
|
||||
},
|
||||
},
|
||||
feedback: {
|
||||
title: 'تقديم تعليق',
|
||||
subtitle: 'من فضلك أخبرنا ما الخطأ في هذه الاستجابة',
|
||||
content: 'محتوى التعليق',
|
||||
placeholder: 'يرجى وصف ما حدث خطأ أو كيف يمكننا التحسين...',
|
||||
},
|
||||
integrations: {
|
||||
connected: 'متصل',
|
||||
google: 'Google',
|
||||
googleAccount: 'تسجيل الدخول بحساب Google',
|
||||
github: 'GitHub',
|
||||
githubAccount: 'تسجيل الدخول بحساب GitHub',
|
||||
connect: 'اتصال',
|
||||
},
|
||||
language: {
|
||||
displayLanguage: 'لغة العرض',
|
||||
timezone: 'المنطقة الزمنية',
|
||||
},
|
||||
provider: {
|
||||
apiKey: 'مفتاح API',
|
||||
enterYourKey: 'أدخل مفتاح API الخاص بك هنا',
|
||||
invalidKey: 'مفتاح OpenAI API غير صالح',
|
||||
validatedError: 'فشل التحقق: ',
|
||||
validating: 'جارٍ التحقق من المفتاح...',
|
||||
saveFailed: 'فشل حفظ مفتاح api',
|
||||
apiKeyExceedBill: 'لا يحتوي مفتاح API هذا على حصة متاحة، يرجى القراءة',
|
||||
addKey: 'إضافة مفتاح',
|
||||
comingSoon: 'قريباً',
|
||||
editKey: 'تعديل',
|
||||
invalidApiKey: 'مفتاح API غير صالح',
|
||||
azure: {
|
||||
apiBase: 'قاعدة API',
|
||||
apiBasePlaceholder: 'عنوان URL لقاعدة API لنقطة نهاية Azure OpenAI الخاصة بك.',
|
||||
apiKey: 'مفتاح API',
|
||||
apiKeyPlaceholder: 'أدخل مفتاح API الخاص بك هنا',
|
||||
helpTip: 'تعلم خدمة Azure OpenAI',
|
||||
},
|
||||
openaiHosted: {
|
||||
openaiHosted: 'OpenAI المستضافة',
|
||||
onTrial: 'في التجربة',
|
||||
exhausted: 'نفدت الحصة',
|
||||
desc: 'تسمح لك خدمة استضافة OpenAI المقدمة من Dify باستخدام نماذج مثل GPT-3.5. قبل نفاد حصة التجربة الخاصة بك، تحتاج إلى إعداد موفري نماذج آخرين.',
|
||||
callTimes: 'أوقات الاتصال',
|
||||
usedUp: 'نفدت حصة التجربة. أضف مزود النموذج الخاص بك.',
|
||||
useYourModel: 'تستخدم حاليًا مزود النموذج الخاص بك.',
|
||||
close: 'إغلاق',
|
||||
},
|
||||
anthropicHosted: {
|
||||
anthropicHosted: 'Anthropic Claude',
|
||||
onTrial: 'في التجربة',
|
||||
exhausted: 'نفدت الحصة',
|
||||
desc: 'نموذج قوي يتفوق في مجموعة واسعة من المهام من الحوار المعقد وإنشاء المحتوى الإبداعي إلى التعليمات التفصيلية.',
|
||||
callTimes: 'أوقات الاتصال',
|
||||
usedUp: 'نفدت حصة التجربة. أضف مزود النموذج الخاص بك.',
|
||||
useYourModel: 'تستخدم حاليًا مزود النموذج الخاص بك.',
|
||||
close: 'إغلاق',
|
||||
trialQuotaTip: 'ستنتهي حصة التجربة الخاصة بك في Anthropic في 2025/03/17 ولن تكون متاحة بعد ذلك. يرجى الاستفادة منها في الوقت المحدد.',
|
||||
},
|
||||
anthropic: {
|
||||
using: 'قدرة التضمين تستخدم',
|
||||
enableTip: 'لتمكين نموذج Anthropic، تحتاج إلى الارتباط بـ OpenAI أو خدمة Azure OpenAI أولاً.',
|
||||
notEnabled: 'غير ممكن',
|
||||
keyFrom: 'احصل على مفتاح API الخاص بك من Anthropic',
|
||||
},
|
||||
encrypted: {
|
||||
front: 'سيتم تشفير مفتاح API الخاص بك وتخزينه باستخدام تقنية',
|
||||
back: '.',
|
||||
},
|
||||
},
|
||||
modelProvider: {
|
||||
notConfigured: 'لم يتم تكوين نموذج النظام بالكامل بعد',
|
||||
systemModelSettings: 'إعدادات نموذج النظام',
|
||||
systemModelSettingsLink: 'لماذا من الضروري إعداد نموذج النظام؟',
|
||||
selectModel: 'اختر نموذجك',
|
||||
setupModelFirst: 'يرجى إعداد نموذجك أولاً',
|
||||
systemReasoningModel: {
|
||||
key: 'نموذج التفكير النظامي',
|
||||
tip: 'تعيين نموذج الاستنتاج الافتراضي لاستخدامه لإنشاء التطبيقات، بالإضافة إلى ميزات مثل إنشاء اسم الحوار واقتراح السؤال التالي ستستخدم أيضًا نموذج الاستنتاج الافتراضي.',
|
||||
},
|
||||
embeddingModel: {
|
||||
key: 'نموذج التضمين',
|
||||
tip: 'تعيين النموذج الافتراضي لمعالجة تضمين المستندات للمعرفة، حيث يستخدم كل من استرجاع واستيراد المعرفة نموذج التضمين هذا لمعالجة التوجيه. سيؤدي التبديل إلى أن يكون البعد المتجه بين المعرفة المستوردة والسؤال غير متسق، مما يؤدي إلى فشل الاسترجاع. لتجنب فشل الاسترجاع، يرجى عدم تبديل هذا النموذج حسب الرغبة.',
|
||||
required: 'نموذج التضمين مطلوب',
|
||||
},
|
||||
speechToTextModel: {
|
||||
key: 'نموذج تحويل الكلام إلى نص',
|
||||
tip: 'تعيين النموذج الافتراضي لإدخال تحويل الكلام إلى نص في المحادثة.',
|
||||
},
|
||||
ttsModel: {
|
||||
key: 'نموذج تحويل النص إلى كلام',
|
||||
tip: 'تعيين النموذج الافتراضي لإدخال تحويل النص إلى كلام في المحادثة.',
|
||||
},
|
||||
rerankModel: {
|
||||
key: 'نموذج إعادة الترتيب',
|
||||
tip: 'سيعيد نموذج إعادة الترتيب ترتيب قائمة المستندات المرشحة بناءً على المطابقة الدلالية مع استعلام المستخدم، مما يحسن نتائج الترتيب الدلالي',
|
||||
},
|
||||
apiKey: 'مفتاح API',
|
||||
quota: 'حصة',
|
||||
searchModel: 'نموذج البحث',
|
||||
noModelFound: 'لم يتم العثور على نموذج لـ {{model}}',
|
||||
models: 'النماذج',
|
||||
showMoreModelProvider: 'عرض المزيد من مزودي النماذج',
|
||||
selector: {
|
||||
tip: 'تمت إزالة هذا النموذج. يرجى إضافة نموذج أو تحديد نموذج آخر.',
|
||||
emptyTip: 'لا توجد نماذج متاحة',
|
||||
emptySetting: 'يرجى الانتقال إلى الإعدادات للتكوين',
|
||||
rerankTip: 'يرجى إعداد نموذج إعادة الترتيب',
|
||||
},
|
||||
card: {
|
||||
quota: 'حصة',
|
||||
onTrial: 'في التجربة',
|
||||
paid: 'مدفوع',
|
||||
quotaExhausted: 'نفدت الحصة',
|
||||
callTimes: 'أوقات الاتصال',
|
||||
tokens: 'رموز',
|
||||
buyQuota: 'شراء حصة',
|
||||
priorityUse: 'أولوية الاستخدام',
|
||||
removeKey: 'إزالة مفتاح API',
|
||||
tip: 'ستعطى الأولوية للحصة المدفوعة. سيتم استخدام الحصة التجريبية بعد نفاد الحصة المدفوعة.',
|
||||
},
|
||||
item: {
|
||||
deleteDesc: 'يتم استخدام {{modelName}} كنماذج تفكير النظام. لن تكون بعض الوظائف متاحة بعد الإزالة. يرجى التأكيد.',
|
||||
freeQuota: 'حصة مجانية',
|
||||
},
|
||||
addApiKey: 'أضف مفتاح API الخاص بك',
|
||||
invalidApiKey: 'مفتاح API غير صالح',
|
||||
encrypted: {
|
||||
front: 'سيتم تشفير مفتاح API الخاص بك وتخزينه باستخدام تقنية',
|
||||
back: '.',
|
||||
},
|
||||
freeQuota: {
|
||||
howToEarn: 'كيف تكسب',
|
||||
},
|
||||
addMoreModelProvider: 'أضف المزيد من مزودي النماذج',
|
||||
addModel: 'إضافة نموذج',
|
||||
modelsNum: '{{num}} نماذج',
|
||||
showModels: 'عرض النماذج',
|
||||
showModelsNum: 'عرض {{num}} نماذج',
|
||||
collapse: 'طي',
|
||||
config: 'تكوين',
|
||||
modelAndParameters: 'النموذج والمعلمات',
|
||||
model: 'النموذج',
|
||||
featureSupported: '{{feature}} مدعوم',
|
||||
callTimes: 'أوقات الاتصال',
|
||||
credits: 'أرصدة الرسائل',
|
||||
buyQuota: 'شراء حصة',
|
||||
getFreeTokens: 'احصل على رموز مجانية',
|
||||
priorityUsing: 'أولوية الاستخدام',
|
||||
deprecated: 'مهمل',
|
||||
confirmDelete: 'تأكيد الحذف؟',
|
||||
quotaTip: 'الرموز المجانية المتاحة المتبقية',
|
||||
loadPresets: 'تحميل الإعدادات المسبقة',
|
||||
parameters: 'المعلمات',
|
||||
loadBalancing: 'موازنة التحميل',
|
||||
loadBalancingDescription: 'تكوين بيانات اعتماد متعددة للنموذج واستدعاؤها تلقائيًا. ',
|
||||
loadBalancingHeadline: 'موازنة التحميل',
|
||||
configLoadBalancing: 'تكوين موازنة التحميل',
|
||||
modelHasBeenDeprecated: 'تم إهمال هذا النموذج',
|
||||
providerManaged: 'مدار من قبل المزود',
|
||||
providerManagedDescription: 'استخدم مجموعة واحدة من بيانات الاعتماد المقدمة من مزود النموذج.',
|
||||
defaultConfig: 'التكوين الافتراضي',
|
||||
apiKeyStatusNormal: 'حالة مفتاح API طبيعية',
|
||||
apiKeyRateLimit: 'تم الوصول إلى حد المعدل، متاح بعد {{seconds}} ثانية',
|
||||
addConfig: 'إضافة تكوين',
|
||||
editConfig: 'تعديل التكوين',
|
||||
loadBalancingLeastKeyWarning: 'لتمكين موازنة التحميل، يجب تمكين مفتاحين على الأقل.',
|
||||
loadBalancingInfo: 'بشكل افتراضي، تستخدم موازنة التحميل استراتيجية Round-robin. إذا تم تشغيل تحديد المعدل، فسيتم تطبيق فترة تباطؤ مدتها دقيقة واحدة.',
|
||||
upgradeForLoadBalancing: 'قم بترقية خطتك لتمكين موازنة التحميل.',
|
||||
toBeConfigured: 'ليتم تكوينه',
|
||||
configureTip: 'قم بإعداد مفتاح api أو أضف نموذجًا للاستخدام',
|
||||
installProvider: 'تثبيت مزودي النماذج',
|
||||
installDataSourceProvider: 'تثبيت مزودي مصادر البيانات',
|
||||
discoverMore: 'اكتشف المزيد في ',
|
||||
emptyProviderTitle: 'لم يتم إعداد مزود النموذج',
|
||||
emptyProviderTip: 'يرجى تثبيت مزود نموذج أولاً.',
|
||||
auth: {
|
||||
unAuthorized: 'غير مصرح به',
|
||||
authRemoved: 'تمت إزالة المصادقة',
|
||||
apiKeys: 'مفاتيح API',
|
||||
addApiKey: 'إضافة مفتاح API',
|
||||
addModel: 'إضافة نموذج',
|
||||
addNewModel: 'إضافة نموذج جديد',
|
||||
addCredential: 'إضافة بيانات اعتماد',
|
||||
addModelCredential: 'إضافة بيانات اعتماد النموذج',
|
||||
editModelCredential: 'تعديل بيانات اعتماد النموذج',
|
||||
modelCredentials: 'بيانات اعتماد النموذج',
|
||||
modelCredential: 'بيانات اعتماد النموذج',
|
||||
configModel: 'تكوين النموذج',
|
||||
configLoadBalancing: 'تكوين موازنة التحميل',
|
||||
authorizationError: 'خطأ في التفويض',
|
||||
specifyModelCredential: 'تحديد بيانات اعتماد النموذج',
|
||||
specifyModelCredentialTip: 'استخدم بيانات اعتماد نموذج مكونة.',
|
||||
providerManaged: 'مدار من قبل المزود',
|
||||
providerManagedTip: 'يتم استضافة التكوين الحالي بواسطة المزود.',
|
||||
apiKeyModal: {
|
||||
title: 'تكوين تفويض مفتاح API',
|
||||
desc: 'بعد تكوين بيانات الاعتماد، يمكن لجميع الأعضاء داخل مساحة العمل استخدام هذا النموذج عند تنظيم التطبيقات.',
|
||||
addModel: 'إضافة نموذج',
|
||||
},
|
||||
manageCredentials: 'إدارة بيانات الاعتماد',
|
||||
customModelCredentials: 'بيانات اعتماد النموذج المخصصة',
|
||||
addNewModelCredential: 'إضافة بيانات اعتماد نموذج جديدة',
|
||||
removeModel: 'إزالة النموذج',
|
||||
selectModelCredential: 'تحديد بيانات اعتماد النموذج',
|
||||
customModelCredentialsDeleteTip: 'بيانات الاعتماد قيد الاستخدام ولا يمكن حذفها',
|
||||
},
|
||||
parametersInvalidRemoved: 'بعض المعلمات غير صالحة وتمت إزالتها',
|
||||
},
|
||||
dataSource: {
|
||||
add: 'إضافة مصدر بيانات',
|
||||
connect: 'اتصال',
|
||||
configure: 'تكوين',
|
||||
notion: {
|
||||
title: 'Notion',
|
||||
description: 'استخدام Notion كمصدر بيانات للمعرفة.',
|
||||
connectedWorkspace: 'مساحة العمل المتصلة',
|
||||
addWorkspace: 'إضافة مساحة عمل',
|
||||
connected: 'متصل',
|
||||
disconnected: 'غير متصل',
|
||||
changeAuthorizedPages: 'تغيير الصفحات المصرح بها',
|
||||
integratedAlert: 'تم دمج Notion عبر بيانات الاعتماد الداخلية، ولا حاجة لإعادة التفويض.',
|
||||
pagesAuthorized: 'الصفحات المصرح بها',
|
||||
sync: 'مزامنة',
|
||||
remove: 'إزالة',
|
||||
selector: {
|
||||
pageSelected: 'الصفحات المحددة',
|
||||
searchPages: 'بحث في الصفحات...',
|
||||
noSearchResult: 'لا توجد نتائج بحث',
|
||||
addPages: 'إضافة صفحات',
|
||||
preview: 'معاينة',
|
||||
},
|
||||
},
|
||||
website: {
|
||||
title: 'موقع الكتروني',
|
||||
description: 'استيراد المحتوى من المواقع الإلكترونية باستخدام زحف الويب.',
|
||||
with: 'مع',
|
||||
configuredCrawlers: 'الزواحف المكونة',
|
||||
active: 'نشط',
|
||||
inactive: 'غير نشط',
|
||||
},
|
||||
},
|
||||
plugin: {
|
||||
serpapi: {
|
||||
apiKey: 'مفتاح API',
|
||||
apiKeyPlaceholder: 'أدخل مفتاح API الخاص بك',
|
||||
keyFrom: 'احصل على مفتاح SerpAPI الخاص بك من صفحة حساب SerpAPI',
|
||||
},
|
||||
},
|
||||
apiBasedExtension: {
|
||||
title: 'توفر ملحقات API إدارة مركزية لواجهة برمجة التطبيقات، مما يبسط التكوين لسهولة الاستخدام عبر تطبيقات Dify.',
|
||||
link: 'تعرف على كيفية تطوير ملحق API الخاص بك.',
|
||||
add: 'إضافة ملحق API',
|
||||
selector: {
|
||||
title: 'ملحق API',
|
||||
placeholder: 'يرجى تحديد ملحق API',
|
||||
manage: 'إدارة ملحق API',
|
||||
},
|
||||
modal: {
|
||||
title: 'إضافة ملحق API',
|
||||
editTitle: 'تعديل ملحق API',
|
||||
name: {
|
||||
title: 'الاسم',
|
||||
placeholder: 'يرجى إدخال الاسم',
|
||||
},
|
||||
apiEndpoint: {
|
||||
title: 'نقطة نهاية API',
|
||||
placeholder: 'يرجى إدخال نقطة نهاية API',
|
||||
},
|
||||
apiKey: {
|
||||
title: 'مفتاح API',
|
||||
placeholder: 'يرجى إدخال مفتاح API',
|
||||
lengthError: 'لا يمكن أن يكون طول مفتاح API أقل من 5 أحرف',
|
||||
},
|
||||
},
|
||||
type: 'النوع',
|
||||
},
|
||||
about: {
|
||||
changeLog: 'سجل التغييرات',
|
||||
updateNow: 'تحديث الآن',
|
||||
nowAvailable: 'Dify {{version}} متاح الآن.',
|
||||
latestAvailable: 'Dify {{version}} هو أحدث إصدار متاح.',
|
||||
},
|
||||
appMenus: {
|
||||
overview: 'المراقبة',
|
||||
promptEng: 'تنسيق',
|
||||
apiAccess: 'وصول API',
|
||||
logAndAnn: 'السجلات والتعليقات التوضيحية',
|
||||
logs: 'السجلات',
|
||||
},
|
||||
environment: {
|
||||
testing: 'اختبار',
|
||||
development: 'تطوير',
|
||||
},
|
||||
appModes: {
|
||||
completionApp: 'مولد النص',
|
||||
chatApp: 'تطبيق الدردشة',
|
||||
},
|
||||
datasetMenus: {
|
||||
documents: 'المستندات',
|
||||
hitTesting: 'اختبار الاسترجاع',
|
||||
settings: 'الإعدادات',
|
||||
emptyTip: 'لم يتم دمج هذه المعرفة في أي تطبيق. يرجى الرجوع إلى المستند للحصول على إرشادات.',
|
||||
viewDoc: 'عرض المستندات',
|
||||
relatedApp: 'التطبيقات المرتبطة',
|
||||
noRelatedApp: 'لا توجد تطبيقات مرتبطة',
|
||||
pipeline: 'خط الأنابيب',
|
||||
},
|
||||
voiceInput: {
|
||||
speaking: 'تحدث الآن...',
|
||||
converting: 'التحويل إلى نص...',
|
||||
notAllow: 'الميكروفون غير مصرح به',
|
||||
},
|
||||
modelName: {
|
||||
'gpt-3.5-turbo': 'GPT-3.5-Turbo',
|
||||
'gpt-3.5-turbo-16k': 'GPT-3.5-Turbo-16K',
|
||||
'gpt-4': 'GPT-4',
|
||||
'gpt-4-32k': 'GPT-4-32K',
|
||||
'text-davinci-003': 'Text-Davinci-003',
|
||||
'text-embedding-ada-002': 'Text-Embedding-Ada-002',
|
||||
'whisper-1': 'Whisper-1',
|
||||
'claude-instant-1': 'Claude-Instant',
|
||||
'claude-2': 'Claude-2',
|
||||
},
|
||||
chat: {
|
||||
renameConversation: 'إعادة تسمية المحادثة',
|
||||
conversationName: 'اسم المحادثة',
|
||||
conversationNamePlaceholder: 'يرجى إدخال اسم المحادثة',
|
||||
conversationNameCanNotEmpty: 'اسم المحادثة مطلوب',
|
||||
citation: {
|
||||
title: 'الاستشهادات',
|
||||
linkToDataset: 'رابط المعرفة',
|
||||
characters: 'الشخصيات:',
|
||||
hitCount: 'عدد الاسترجاع:',
|
||||
vectorHash: 'تجزئة المتجه:',
|
||||
hitScore: 'درجة الاسترجاع:',
|
||||
},
|
||||
inputPlaceholder: 'تحدث إلى {{botName}}',
|
||||
thinking: 'يفكر...',
|
||||
thought: 'فكر',
|
||||
resend: 'إعادة إرسال',
|
||||
},
|
||||
promptEditor: {
|
||||
placeholder: 'اكتب كلمة المطالبة هنا، أدخل \'{\' لإدراج متغير، أدخل \'/\' لإدراج كتلة محتوى مطالبة',
|
||||
context: {
|
||||
item: {
|
||||
title: 'السياق',
|
||||
desc: 'إدراج قالب السياق',
|
||||
},
|
||||
modal: {
|
||||
title: '{{num}} معرفة في السياق',
|
||||
add: 'إضافة سياق ',
|
||||
footer: 'يمكنك إدارة السياقات في قسم السياق أدناه.',
|
||||
},
|
||||
},
|
||||
history: {
|
||||
item: {
|
||||
title: 'سجل المحادثة',
|
||||
desc: 'إدراج قالب الرسالة التاريخية',
|
||||
},
|
||||
modal: {
|
||||
title: 'مثال',
|
||||
user: 'مرحبًا',
|
||||
assistant: 'مرحبًا! كيف يمكنني مساعدتك اليوم؟',
|
||||
edit: 'تعديل أسماء أدوار المحادثة',
|
||||
},
|
||||
},
|
||||
variable: {
|
||||
item: {
|
||||
title: 'المتغيرات والأدوات الخارجية',
|
||||
desc: 'إدراج المتغيرات والأدوات الخارجية',
|
||||
},
|
||||
outputToolDisabledItem: {
|
||||
title: 'المتغيرات',
|
||||
desc: 'إدراج المتغيرات',
|
||||
},
|
||||
modal: {
|
||||
add: 'متغير جديد',
|
||||
addTool: 'أداة جديدة',
|
||||
},
|
||||
},
|
||||
query: {
|
||||
item: {
|
||||
title: 'استعلام',
|
||||
desc: 'إدراج قالب استعلام المستخدم',
|
||||
},
|
||||
},
|
||||
existed: 'موجود بالفعل في المطالبة',
|
||||
},
|
||||
imageUploader: {
|
||||
uploadFromComputer: 'تحميل من الكمبيوتر',
|
||||
uploadFromComputerReadError: 'فشل قراءة الصورة، يرجى المحاولة مرة أخرى.',
|
||||
uploadFromComputerUploadError: 'فشل تحميل الصورة، يرجى التحميل مرة أخرى.',
|
||||
uploadFromComputerLimit: 'لا يمكن أن تتجاوز صور التحميل {{size}} ميجابايت',
|
||||
pasteImageLink: 'لصق رابط الصورة',
|
||||
pasteImageLinkInputPlaceholder: 'لصق رابط الصورة هنا',
|
||||
pasteImageLinkInvalid: 'رابط الصورة غير صالح',
|
||||
imageUpload: 'تحميل الصورة',
|
||||
},
|
||||
fileUploader: {
|
||||
uploadFromComputer: 'تحميل محلي',
|
||||
pasteFileLink: 'لصق رابط الملف',
|
||||
pasteFileLinkInputPlaceholder: 'أدخل URL...',
|
||||
uploadFromComputerReadError: 'فشل قراءة الملف، يرجى المحاولة مرة أخرى.',
|
||||
uploadFromComputerUploadError: 'فشل تحميل الملف، يرجى التحميل مرة أخرى.',
|
||||
uploadFromComputerLimit: 'تحميل {{type}} لا يمكن أن يتجاوز {{size}}',
|
||||
pasteFileLinkInvalid: 'رابط الملف غير صالح',
|
||||
fileExtensionNotSupport: 'امتداد الملف غير مدعوم',
|
||||
fileExtensionBlocked: 'تم حظر نوع الملف هذا لأسباب أمنية',
|
||||
},
|
||||
tag: {
|
||||
placeholder: 'جميع العلامات',
|
||||
addNew: 'إضافة علامة جديدة',
|
||||
noTag: 'لا توجد علامات',
|
||||
noTagYet: 'لا توجد علامات بعد',
|
||||
addTag: 'إضافة علامات',
|
||||
editTag: 'تعديل العلامات',
|
||||
manageTags: 'إدارة العلامات',
|
||||
selectorPlaceholder: 'اكتب للبحث أو الإنشاء',
|
||||
create: 'إنشاء',
|
||||
delete: 'حذف العلامة',
|
||||
deleteTip: 'العلامة قيد الاستخدام، هل تريد حذفها؟',
|
||||
created: 'تم إنشاء العلامة بنجاح',
|
||||
failed: 'فشل إنشاء العلامة',
|
||||
},
|
||||
license: {
|
||||
expiring: 'تنتهي في يوم واحد',
|
||||
expiring_plural: 'تنتهي في {{count}} أيام',
|
||||
unlimited: 'غير محدود',
|
||||
},
|
||||
pagination: {
|
||||
perPage: 'عناصر لكل صفحة',
|
||||
},
|
||||
avatar: {
|
||||
deleteTitle: 'إزالة الصورة الرمزية',
|
||||
deleteDescription: 'هل أنت متأكد أنك تريد إزالة صورة ملفك الشخصي؟ سيستخدم حسابك الصورة الرمزية الأولية الافتراضية.',
|
||||
},
|
||||
imageInput: {
|
||||
dropImageHere: 'أسقط صورتك هنا، أو',
|
||||
browse: 'تصفح',
|
||||
supportedFormats: 'يدعم PNG و JPG و JPEG و WEBP و GIF',
|
||||
},
|
||||
you: 'أنت',
|
||||
dynamicSelect: {
|
||||
error: 'فشل تحميل الخيارات',
|
||||
noData: 'لا توجد خيارات متاحة',
|
||||
loading: 'تحميل الخيارات...',
|
||||
selected: '{{count}} محدد',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
32
web/i18n/ar-TN/custom.ts
Normal file
32
web/i18n/ar-TN/custom.ts
Normal file
@@ -0,0 +1,32 @@
|
||||
const translation = {
|
||||
custom: 'تخصيص',
|
||||
upgradeTip: {
|
||||
title: 'تحديث خطتك',
|
||||
des: 'قم بترقية خطتك لتخصيص علامتك التجارية',
|
||||
prefix: 'قم بترقية خطتك لـ',
|
||||
suffix: 'تخصيص علامتك التجارية.',
|
||||
},
|
||||
webapp: {
|
||||
title: 'تخصيص العلامة التجارية لتطبيق الويب',
|
||||
removeBrand: 'إزالة Powered by Dify',
|
||||
changeLogo: 'تغيير صورة Powered by Brand',
|
||||
changeLogoTip: 'تنسيق SVG أو PNG بحجم أدنى 40x40px',
|
||||
},
|
||||
app: {
|
||||
title: 'تخصيص العلامة التجارية لرأس التطبيق',
|
||||
changeLogoTip: 'تنسيق SVG أو PNG بحجم أدنى 80x80px',
|
||||
},
|
||||
upload: 'تحميل',
|
||||
uploading: 'جاري التحميل',
|
||||
uploadedFail: 'فشل تحميل الصورة، يرجى إعادة التحميل.',
|
||||
change: 'تغيير',
|
||||
apply: 'تطبيق',
|
||||
restore: 'استعادة الافتراضيات',
|
||||
customize: {
|
||||
contactUs: ' اتصل بنا ',
|
||||
prefix: 'لتخصيص شعار العلامة التجارية داخل التطبيق، يرجى',
|
||||
suffix: 'للترقية إلى إصدار Enterprise.',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
217
web/i18n/ar-TN/dataset-creation.ts
Normal file
217
web/i18n/ar-TN/dataset-creation.ts
Normal file
@@ -0,0 +1,217 @@
|
||||
const translation = {
|
||||
steps: {
|
||||
header: {
|
||||
fallbackRoute: 'المعرفة',
|
||||
},
|
||||
one: 'مصدر البيانات',
|
||||
two: 'معالجة المستندات',
|
||||
three: 'التنفيذ والانتهاء',
|
||||
},
|
||||
error: {
|
||||
unavailable: 'هذه المعرفة غير متاحة',
|
||||
},
|
||||
firecrawl: {
|
||||
configFirecrawl: 'تكوين 🔥Firecrawl',
|
||||
apiKeyPlaceholder: 'مفتاح API من firecrawl.dev',
|
||||
getApiKeyLinkText: 'احصل على مفتاح API الخاص بك من firecrawl.dev',
|
||||
},
|
||||
watercrawl: {
|
||||
configWatercrawl: 'تكوين Watercrawl',
|
||||
apiKeyPlaceholder: 'مفتاح API من watercrawl.dev',
|
||||
getApiKeyLinkText: 'احصل على مفتاح API الخاص بك من watercrawl.dev',
|
||||
},
|
||||
jinaReader: {
|
||||
configJinaReader: 'تكوين Jina Reader',
|
||||
apiKeyPlaceholder: 'مفتاح API من jina.ai',
|
||||
getApiKeyLinkText: 'احصل على مفتاح API المجاني الخاص بك في jina.ai',
|
||||
},
|
||||
stepOne: {
|
||||
filePreview: 'معاينة الملف',
|
||||
pagePreview: 'معاينة الصفحة',
|
||||
dataSourceType: {
|
||||
file: 'استيراد من ملف',
|
||||
notion: 'مزامنة من Notion',
|
||||
web: 'مزامنة من موقع ويب',
|
||||
},
|
||||
uploader: {
|
||||
title: 'تحميل ملف',
|
||||
button: 'اسحب وأفلت الملف أو المجلد، أو',
|
||||
buttonSingleFile: 'اسحب وأفلت الملف، أو',
|
||||
browse: 'تصفح',
|
||||
tip: 'يدعم {{supportTypes}}. بحد أقصى {{batchCount}} في الدفعة الواحدة و {{size}} ميجابايت لكل منها. الحد الأقصى الإجمالي {{totalCount}} ملفات.',
|
||||
validation: {
|
||||
typeError: 'نوع الملف غير مدعوم',
|
||||
size: 'الملف كبير جدًا. الحد الأقصى هو {{size}} ميجابايت',
|
||||
count: 'ملفات متعددة غير مدعومة',
|
||||
filesNumber: 'لقد وصلت إلى حد تحميل الدفعة البالغ {{filesNumber}}.',
|
||||
},
|
||||
cancel: 'إلغاء',
|
||||
change: 'تغيير',
|
||||
failed: 'فشل التحميل',
|
||||
},
|
||||
notionSyncTitle: 'Notion غير متصل',
|
||||
notionSyncTip: 'للمزامنة مع Notion، يجب إنشاء اتصال بـ Notion أولاً.',
|
||||
connect: 'الذهاب للاتصال',
|
||||
cancel: 'إلغاء',
|
||||
button: 'التالي',
|
||||
emptyDatasetCreation: 'أريد إنشاء معرفة فارغة',
|
||||
modal: {
|
||||
title: 'إنشاء معرفة فارغة',
|
||||
tip: 'لن تحتوي المعرفة الفارغة على أي مستندات، ويمكنك تحميل المستندات في أي وقت.',
|
||||
input: 'اسم المعرفة',
|
||||
placeholder: 'يرجى الإدخال',
|
||||
nameNotEmpty: 'لا يمكن أن يكون الاسم فارغًا',
|
||||
nameLengthInvalid: 'يجب أن يكون الاسم بين 1 إلى 40 حرفًا',
|
||||
cancelButton: 'إلغاء',
|
||||
confirmButton: 'إنشاء',
|
||||
failed: 'فشل الإنشاء',
|
||||
},
|
||||
website: {
|
||||
chooseProvider: 'اختر مزودًا',
|
||||
fireCrawlNotConfigured: 'Firecrawl غير مكون',
|
||||
fireCrawlNotConfiguredDescription: 'قم بتكوين Firecrawl باستخدام مفتاح API لاستخدامه.',
|
||||
jinaReaderNotConfigured: 'Jina Reader غير مكون',
|
||||
jinaReaderNotConfiguredDescription: 'قم بإعداد Jina Reader عن طريق إدخال مفتاح API المجاني للوصول.',
|
||||
waterCrawlNotConfigured: 'Watercrawl غير مكون',
|
||||
waterCrawlNotConfiguredDescription: 'قم بتكوين Watercrawl باستخدام مفتاح API لاستخدامه.',
|
||||
configure: 'تكوين',
|
||||
configureFirecrawl: 'تكوين Firecrawl',
|
||||
configureWatercrawl: 'تكوين Watercrawl',
|
||||
configureJinaReader: 'تكوين Jina Reader',
|
||||
run: 'تشغيل',
|
||||
running: 'جارٍ التشغيل',
|
||||
firecrawlTitle: 'استخراج محتوى الويب باستخدام 🔥Firecrawl',
|
||||
firecrawlDoc: 'مستندات Firecrawl',
|
||||
watercrawlTitle: 'استخراج محتوى الويب باستخدام Watercrawl',
|
||||
watercrawlDoc: 'مستندات Watercrawl',
|
||||
jinaReaderTitle: 'تحويل الموقع بالكامل إلى Markdown',
|
||||
jinaReaderDoc: 'تعرف على المزيد حول Jina Reader',
|
||||
jinaReaderDocLink: 'https://jina.ai/reader',
|
||||
useSitemap: 'استخدام خريطة الموقع',
|
||||
useSitemapTooltip: 'اتبع خريطة الموقع للزحف إلى الموقع. إذا لم يكن كذلك، سيقوم Jina Reader بالزحف بشكل متكرر بناءً على صلة الصفحة، مما يؤدي إلى صفحات أقل ولكن بجودة أعلى.',
|
||||
options: 'خيارات',
|
||||
crawlSubPage: 'الزحف إلى الصفحات الفرعية',
|
||||
limit: 'الحد',
|
||||
maxDepth: 'أقصى عمق',
|
||||
excludePaths: 'استبعاد المسارات',
|
||||
includeOnlyPaths: 'تضمين المسارات فقط',
|
||||
extractOnlyMainContent: 'استخراج المحتوى الرئيسي فقط (بدون رؤوس، قوائم تنقل، تذييلات، إلخ.)',
|
||||
exceptionErrorTitle: 'حدث استثناء أثناء تشغيل مهمة الزحف:',
|
||||
unknownError: 'خطأ غير معروف',
|
||||
totalPageScraped: 'إجمالي الصفحات التي تم كشطها:',
|
||||
selectAll: 'تحديد الكل',
|
||||
resetAll: 'إعادة تعيين الكل',
|
||||
scrapTimeInfo: 'تم كشط {{total}} صفحة في المجموع خلال {{time}} ثانية',
|
||||
preview: 'معاينة',
|
||||
maxDepthTooltip: 'أقصى عمق للزحف بالنسبة لعنوان URL المدخل. العمق 0 يكشط فقط صفحة عنوان URL المدخل، العمق 1 يكشط عنوان URL وكل شيء بعد عنوان URL المدخل + / واحد، وهكذا.',
|
||||
},
|
||||
},
|
||||
stepTwo: {
|
||||
segmentation: 'إعدادات القطعة',
|
||||
auto: 'تلقائي',
|
||||
autoDescription: 'تحديد القواعد والتقطيع والمعالجة المسبقة تلقائيًا. يوصى به للمستخدمين غير المألوفين.',
|
||||
custom: 'مخصص',
|
||||
customDescription: 'تخصيص قواعد القطع وطول القطع وقواعد المعالجة المسبقة، إلخ.',
|
||||
general: 'عام',
|
||||
generalTip: 'وضع تقطيع النص العام، القطع المسترجعة والمستردة هي نفسها.',
|
||||
parentChild: 'الأصل والطفل',
|
||||
parentChildTip: 'عند استخدام وضع الأصل والطفل، يتم استخدام القطعة الفرعية للاسترجاع ويتم استخدام القطعة الأصلية للاستدعاء كسياق.',
|
||||
parentChunkForContext: 'القطعة الأصلية للسياق',
|
||||
childChunkForRetrieval: 'القطعة الفرعية للاسترجاع',
|
||||
paragraph: 'فقرة',
|
||||
paragraphTip: 'يقسم هذا الوضع النص إلى فقرات بناءً على المحددات وأقصى طول للقطعة، باستخدام النص المقسم كقطعة أصلية للاسترجاع.',
|
||||
fullDoc: 'مستند كامل',
|
||||
fullDocTip: 'يتم استخدام المستند بأكمله كقطعة أصلية ويتم استرجاعه مباشرة. يرجى ملاحظة أنه لأسباب تتعلق بالأداء، سيتم اقتطاع النص الذي يتجاوز 10000 رمز تلقائيًا.',
|
||||
qaTip: 'عند استخدام بيانات الأسئلة والأجوبة المهيكلة، يمكنك إنشاء مستندات تقرن الأسئلة بالأجوبة. يتم فهرسة هذه المستندات بناءً على جزء السؤال، مما يسمح للنظام باسترجاع الإجابات ذات الصلة بناءً على تشابه الاستعلام.',
|
||||
separator: 'محدد',
|
||||
separatorTip: 'المحدد هو الحرف المستخدم لفصل النص. \\n\\n و \\n هي محددات شائعة الاستخدام لفصل الفقرات والأسطر. جنبًا إلى جنب مع الفواصل (\\n\\n,\\n)، سيتم تقسيم الفقرات حسب الأسطر عند تجاوز الحد الأقصى لطول القطعة. يمكنك أيضًا استخدام محددات خاصة محددة بنفسك (مثل ***).',
|
||||
separatorPlaceholder: '\\n\\n للفقرات؛ \\n للأسطر',
|
||||
maxLength: 'أقصى طول للقطعة',
|
||||
maxLengthCheck: 'يجب أن يكون أقصى طول للقطعة أقل من {{limit}}',
|
||||
overlap: 'تداخل القطعة',
|
||||
overlapTip: 'يمكن أن يؤدي تعيين تداخل القطعة إلى الحفاظ على الصلة الدلالية بينها، مما يعزز تأثير الاسترجاع. يوصى بتعيين 10٪ -25٪ من الحد الأقصى لحجم القطعة.',
|
||||
overlapCheck: 'يجب ألا يكون تداخل القطعة أكبر من أقصى طول للقطعة',
|
||||
rules: 'قواعد المعالجة المسبقة للنص',
|
||||
removeExtraSpaces: 'استبدال المسافات المتتالية والأسطر الجديدة وعلامات الجدولة',
|
||||
removeUrlEmails: 'حذف جميع عناوين URL وعناوين البريد الإلكتروني',
|
||||
removeStopwords: 'إزالة كلمات التوقف مثل "a", "an", "the"',
|
||||
preview: 'معاينة',
|
||||
previewChunk: 'معاينة القطعة',
|
||||
reset: 'إعادة تعيين',
|
||||
indexMode: 'طريقة الفهرسة',
|
||||
qualified: 'عالية الجودة',
|
||||
highQualityTip: 'بمجرد الانتهاء من التضمين في وضع الجودة العالية، لا يتوفر الرجوع إلى الوضع الاقتصادي.',
|
||||
recommend: 'نوصي',
|
||||
qualifiedTip: 'يساعد استدعاء نموذج التضمين لمعالجة المستندات من أجل استرجاع أكثر دقة LLM على إنشاء إجابات عالية الجودة.',
|
||||
warning: 'يرجى إعداد مفتاح API لمزود النموذج أولاً.',
|
||||
click: 'الذهاب إلى الإعدادات',
|
||||
economical: 'اقتصادي',
|
||||
economicalTip: 'استخدام 10 كلمات رئيسية لكل قطعة للاسترجاع، لا يتم استهلاك أي رموز على حساب تقليل دقة الاسترجاع.',
|
||||
QATitle: 'التقسيم بتنسيق سؤال وجواب',
|
||||
QATip: 'سيؤدي تمكين هذا الخيار إلى استهلاك المزيد من الرموز',
|
||||
QALanguage: 'التقسيم باستخدام',
|
||||
useQALanguage: 'تقطيع بتنسيق سؤال وجواب في',
|
||||
estimateCost: 'تقدير',
|
||||
estimateSegment: 'القطع المقدرة',
|
||||
segmentCount: 'قطع',
|
||||
calculating: 'جارٍ الحساب...',
|
||||
fileSource: 'معالجة المستندات مسبقًا',
|
||||
notionSource: 'معالجة الصفحات مسبقًا',
|
||||
websiteSource: 'معالجة الموقع مسبقًا',
|
||||
other: 'وغيرها ',
|
||||
fileUnit: ' ملفات',
|
||||
notionUnit: ' صفحات',
|
||||
webpageUnit: ' صفحات',
|
||||
previousStep: 'الخطوة السابقة',
|
||||
nextStep: 'حفظ ومعالجة',
|
||||
save: 'حفظ ومعالجة',
|
||||
cancel: 'إلغاء',
|
||||
sideTipTitle: 'لماذا التقطيع والمعالجة المسبقة؟',
|
||||
sideTipP1: 'عند معالجة البيانات النصية، يعد التقطيع والتنظيف خطوتين مهمتين للمعالجة المسبقة.',
|
||||
sideTipP2: 'يقسم التقسيم النص الطويل إلى فقرات حتى تتمكن النماذج من فهمه بشكل أفضل. هذا يحسن جودة وصلة نتائج النموذج.',
|
||||
sideTipP3: 'يزيل التنظيف الأحرف والتنسيقات غير الضرورية، مما يجعل المعرفة أنظف وأسهل في التحليل.',
|
||||
sideTipP4: 'يؤدي التقطيع والتنظيف السليمتان إلى تحسين أداء النموذج، مما يوفر نتائج أكثر دقة وقيمة.',
|
||||
previewTitle: 'معاينة',
|
||||
previewTitleButton: 'معاينة',
|
||||
previewButton: 'التبديل إلى تنسيق سؤال وجواب',
|
||||
previewSwitchTipStart: 'معاينة القطعة الحالية بتنسيق نصي، وسيؤدي التبديل إلى معاينة تنسيق سؤال وجواب إلى',
|
||||
previewSwitchTipEnd: ' استهلاك رموز إضافية',
|
||||
characters: 'أحرف',
|
||||
indexSettingTip: 'لتغيير طريقة الفهرسة ونموذج التضمين، يرجى الانتقال إلى ',
|
||||
retrievalSettingTip: 'لتغيير إعداد الاسترجاع، يرجى الانتقال إلى ',
|
||||
datasetSettingLink: 'إعدادات المعرفة.',
|
||||
previewChunkTip: 'انقر فوق زر "معاينة القطعة" على اليسار لتحميل المعاينة',
|
||||
previewChunkCount: '{{count}} قطعة مقدرة',
|
||||
switch: 'تبديل',
|
||||
qaSwitchHighQualityTipTitle: 'يتطلب تنسيق سؤال وجواب طريقة فهرسة عالية الجودة',
|
||||
qaSwitchHighQualityTipContent: 'حاليا، تدعم طريقة الفهرسة عالية الجودة فقط تقطيع تنسيق سؤال وجواب. هل ترغب في التبديل إلى وضع الجودة العالية؟',
|
||||
notAvailableForParentChild: 'غير متاح لفهرس الأصل والطفل',
|
||||
notAvailableForQA: 'غير متاح لفهرس الأسئلة والأجوبة',
|
||||
parentChildDelimiterTip: 'المحدد هو الحرف المستخدم لفصل النص. يوصى باستخدام \\n\\n لتقسيم المستند الأصلي إلى قطع أصلية كبيرة. يمكنك أيضًا استخدام محددات خاصة محددة بنفسك.',
|
||||
parentChildChunkDelimiterTip: 'المحدد هو الحرف المستخدم لفصل النص. يوصى باستخدام \\n لتقسيم القطع الأصلية إلى قطع فرعية صغيرة. يمكنك أيضًا استخدام محددات خاصة محددة بنفسك.',
|
||||
},
|
||||
stepThree: {
|
||||
creationTitle: '🎉 تم إنشاء المعرفة',
|
||||
creationContent: 'قمنا بتسمية المعرفة تلقائيًا، يمكنك تعديلها في أي وقت.',
|
||||
label: 'اسم المعرفة',
|
||||
additionTitle: '🎉 تم تحميل المستند',
|
||||
additionP1: 'تم تحميل المستند إلى المعرفة',
|
||||
additionP2: '، يمكنك العثور عليه في قائمة مستندات المعرفة.',
|
||||
stop: 'إيقاف المعالجة',
|
||||
resume: 'استئناف المعالجة',
|
||||
navTo: 'الذهاب إلى المستند',
|
||||
sideTipTitle: 'ما التالي',
|
||||
sideTipContent: 'بعد الانتهاء من فهرسة المستندات، يمكنك إدارة المستندات وتعديلها، وتشغيل اختبارات الاسترجاع، وتعديل إعدادات المعرفة. يمكن بعد ذلك دمج المعرفة في تطبيقك كسياق، لذا تأكد من ضبط إعداد الاسترجاع لضمان الأداء الأمثل.',
|
||||
modelTitle: 'هل أنت متأكد من إيقاف التضمين؟',
|
||||
modelContent: 'إذا كنت بحاجة إلى استئناف المعالجة لاحقًا، فستستمر من حيث توقفت.',
|
||||
modelButtonConfirm: 'تأكيد',
|
||||
modelButtonCancel: 'إلغاء',
|
||||
},
|
||||
otherDataSource: {
|
||||
title: 'الاتصال بمصادر بيانات أخرى؟',
|
||||
description: 'حاليًا، تحتوي قاعدة معرفة Dify فقط على مصادر بيانات محدودة. تعد المساهمة بمصدر بيانات في قاعدة معرفة Dify طريقة رائعة للمساعدة في تعزيز مرونة النظام الأساسي وقوته لجميع المستخدمين. دليل المساهمة الخاص بنا يسهل البدء. يرجى النقر على الرابط أدناه لمعرفة المزيد.',
|
||||
learnMore: 'تعرف على المزيد',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
408
web/i18n/ar-TN/dataset-documents.ts
Normal file
408
web/i18n/ar-TN/dataset-documents.ts
Normal file
@@ -0,0 +1,408 @@
|
||||
const translation = {
|
||||
list: {
|
||||
title: 'المستندات',
|
||||
desc: 'يتم عرض جميع ملفات المعرفة هنا، ويمكن ربط المعرفة بأكملها باقتباسات Dify أو فهرستها عبر مكون الدردشة الإضافي.',
|
||||
learnMore: 'تعرف على المزيد',
|
||||
addFile: 'إضافة ملف',
|
||||
addPages: 'إضافة صفحات',
|
||||
addUrl: 'إضافة عنوان URL',
|
||||
table: {
|
||||
header: {
|
||||
fileName: 'الاسم',
|
||||
chunkingMode: 'وضع التقطيع',
|
||||
words: 'الكلمات',
|
||||
hitCount: 'عدد الاسترجاع',
|
||||
uploadTime: 'وقت التحميل',
|
||||
status: 'الحالة',
|
||||
action: 'إجراء',
|
||||
},
|
||||
rename: 'إعادة تسمية',
|
||||
name: 'الاسم',
|
||||
},
|
||||
action: {
|
||||
uploadFile: 'تحميل ملف جديد',
|
||||
settings: 'إعدادات التقطيع',
|
||||
addButton: 'إضافة قطعة',
|
||||
add: 'إضافة قطعة',
|
||||
batchAdd: 'إضافة دفعة',
|
||||
archive: 'أرشيف',
|
||||
unarchive: 'إلغاء الأرشفة',
|
||||
delete: 'حذف',
|
||||
enableWarning: 'لا يمكن تمكين الملف المؤرشف',
|
||||
sync: 'مزامنة',
|
||||
pause: 'إيقاف مؤقت',
|
||||
resume: 'استئناف',
|
||||
},
|
||||
index: {
|
||||
enable: 'تمكين',
|
||||
disable: 'تعطيل',
|
||||
all: 'الكل',
|
||||
enableTip: 'يمكن فهرسة الملف',
|
||||
disableTip: 'لا يمكن فهرسة الملف',
|
||||
},
|
||||
sort: {
|
||||
uploadTime: 'وقت التحميل',
|
||||
hitCount: 'عدد الاسترجاع',
|
||||
},
|
||||
status: {
|
||||
queuing: 'في الانتظار',
|
||||
indexing: 'فهرسة',
|
||||
paused: 'متوقف مؤقتًا',
|
||||
error: 'خطأ',
|
||||
available: 'متاح',
|
||||
enabled: 'ممكن',
|
||||
disabled: 'معطل',
|
||||
archived: 'مؤرشف',
|
||||
},
|
||||
empty: {
|
||||
title: 'لا يوجد وثائق بعد',
|
||||
upload: {
|
||||
tip: 'يمكنك تحميل الملفات، والمزامنة من الموقع، أو من تطبيقات الويب مثل Notion و GitHub، إلخ.',
|
||||
},
|
||||
sync: {
|
||||
tip: 'سيقوم Dify بتنزيل الملفات بشكل دوري من Notion وإكمال المعالجة.',
|
||||
},
|
||||
},
|
||||
delete: {
|
||||
title: 'هل أنت متأكد من الحذف؟',
|
||||
content: 'إذا كنت بحاجة إلى استئناف المعالجة لاحقًا، فستستمر من حيث توقفت',
|
||||
},
|
||||
batchModal: {
|
||||
title: 'إضافة قطع دفعة واحدة',
|
||||
csvUploadTitle: 'اسحب وأفلت ملف CSV هنا، أو ',
|
||||
browse: 'تصفح',
|
||||
tip: 'يجب أن يتوافق ملف CSV مع الهيكل التالي:',
|
||||
question: 'سؤال',
|
||||
answer: 'إجابة',
|
||||
contentTitle: 'محتوى القطعة',
|
||||
content: 'محتوى',
|
||||
template: 'قم بتنزيل القالب هنا',
|
||||
cancel: 'إلغاء',
|
||||
run: 'تشغيل الدفعة',
|
||||
runError: 'فشل تشغيل الدفعة',
|
||||
processing: 'في معالجة الدفعة',
|
||||
completed: 'اكتمل الاستيراد',
|
||||
error: 'خطأ في الاستيراد',
|
||||
ok: 'موافق',
|
||||
},
|
||||
},
|
||||
metadata: {
|
||||
title: 'البيانات الوصفية',
|
||||
desc: 'يسمح تصنيف البيانات الوصفية للمستندات للذكاء الاصطناعي بالوصول إليها في الوقت المناسب ويكشف مصدر المراجع للمستخدمين.',
|
||||
dateTimeFormat: 'MMMM D, YYYY hh:mm A',
|
||||
docTypeSelectTitle: 'يرجى تحديد نوع المستند',
|
||||
docTypeChangeTitle: 'تغيير نوع المستند',
|
||||
docTypeSelectWarning:
|
||||
'إذا تم تغيير نوع المستند، فلن يتم الاحتفاظ بالبيانات الوصفية المملوءة الآن',
|
||||
firstMetaAction: 'هيا بنا',
|
||||
placeholder: {
|
||||
add: 'إضافة ',
|
||||
select: 'تحديد ',
|
||||
},
|
||||
source: {
|
||||
upload_file: 'تحميل الملف',
|
||||
notion: 'مزامنة من Notion',
|
||||
github: 'مزامنة من Github',
|
||||
local_file: 'ملف محلي',
|
||||
website_crawl: 'زحف الموقع',
|
||||
online_document: 'مستند عبر الإنترنت',
|
||||
},
|
||||
type: {
|
||||
book: 'كتاب',
|
||||
webPage: 'صفحة ويب',
|
||||
paper: 'ورقة بحثية',
|
||||
socialMediaPost: 'منشور وسائل التواصل الاجتماعي',
|
||||
personalDocument: 'مستند شخصي',
|
||||
businessDocument: 'مستند أعمال',
|
||||
IMChat: 'دردشة فورية',
|
||||
wikipediaEntry: 'إدخال ويكيبيديا',
|
||||
notion: 'مزامنة من Notion',
|
||||
github: 'مزامنة من Github',
|
||||
technicalParameters: 'المعلمات الفنية',
|
||||
},
|
||||
field: {
|
||||
processRule: {
|
||||
processDoc: 'معالجة المستند',
|
||||
segmentRule: 'قاعدة القطع',
|
||||
segmentLength: 'طول القطع',
|
||||
processClean: 'تنظيف عملية النص',
|
||||
},
|
||||
book: {
|
||||
title: 'العنوان',
|
||||
language: 'اللغة',
|
||||
author: 'المؤلف',
|
||||
publisher: 'الناشر',
|
||||
publicationDate: 'تاريخ النشر',
|
||||
ISBN: 'ISBN',
|
||||
category: 'الفئة',
|
||||
},
|
||||
webPage: {
|
||||
title: 'العنوان',
|
||||
url: 'عنوان URL',
|
||||
language: 'اللغة',
|
||||
authorPublisher: 'المؤلف/الناشر',
|
||||
publishDate: 'تاريخ النشر',
|
||||
topicKeywords: 'الموضوع/الكلمات الرئيسية',
|
||||
description: 'الوصف',
|
||||
},
|
||||
paper: {
|
||||
title: 'العنوان',
|
||||
language: 'اللغة',
|
||||
author: 'المؤلف',
|
||||
publishDate: 'تاريخ النشر',
|
||||
journalConferenceName: 'اسم المجلة/المؤتمر',
|
||||
volumeIssuePage: 'المجلد/العدد/الصفحة',
|
||||
DOI: 'DOI',
|
||||
topicsKeywords: 'المواضيع/الكلمات الرئيسية',
|
||||
abstract: 'الملخص',
|
||||
},
|
||||
socialMediaPost: {
|
||||
platform: 'المنصة',
|
||||
authorUsername: 'المؤلف/اسم المستخدم',
|
||||
publishDate: 'تاريخ النشر',
|
||||
postURL: 'عنوان URL للمنشور',
|
||||
topicsTags: 'المواضيع/العلامات',
|
||||
},
|
||||
personalDocument: {
|
||||
title: 'العنوان',
|
||||
author: 'المؤلف',
|
||||
creationDate: 'تاريخ الإنشاء',
|
||||
lastModifiedDate: 'تاريخ آخر تعديل',
|
||||
documentType: 'نوع المستند',
|
||||
tagsCategory: 'العلامات/الفئة',
|
||||
},
|
||||
businessDocument: {
|
||||
title: 'العنوان',
|
||||
author: 'المؤلف',
|
||||
creationDate: 'تاريخ الإنشاء',
|
||||
lastModifiedDate: 'تاريخ آخر تعديل',
|
||||
documentType: 'نوع المستند',
|
||||
departmentTeam: 'القسم/الفريق',
|
||||
},
|
||||
IMChat: {
|
||||
chatPlatform: 'منصة الدردشة',
|
||||
chatPartiesGroupName: 'أطراف الدردشة/اسم المجموعة',
|
||||
participants: 'المشاركون',
|
||||
startDate: 'تاريخ البدء',
|
||||
endDate: 'تاريخ الانتهاء',
|
||||
topicsKeywords: 'المواضيع/الكلمات الرئيسية',
|
||||
fileType: 'نوع الملف',
|
||||
},
|
||||
wikipediaEntry: {
|
||||
title: 'العنوان',
|
||||
language: 'اللغة',
|
||||
webpageURL: 'عنوان URL لصفحة الويب',
|
||||
editorContributor: 'المحرر/المساهم',
|
||||
lastEditDate: 'تاريخ آخر تعديل',
|
||||
summaryIntroduction: 'الملخص/المقدمة',
|
||||
},
|
||||
notion: {
|
||||
title: 'العنوان',
|
||||
language: 'اللغة',
|
||||
author: 'المؤلف',
|
||||
createdTime: 'وقت الإنشاء',
|
||||
lastModifiedTime: 'وقت آخر تعديل',
|
||||
url: 'عنوان URL',
|
||||
tag: 'العلامة',
|
||||
description: 'الوصف',
|
||||
},
|
||||
github: {
|
||||
repoName: 'اسم المستودع',
|
||||
repoDesc: 'وصف المستودع',
|
||||
repoOwner: 'مالك المستودع',
|
||||
fileName: 'اسم الملف',
|
||||
filePath: 'مسار الملف',
|
||||
programmingLang: 'لغة البرمجة',
|
||||
url: 'عنوان URL',
|
||||
license: 'الرخصة',
|
||||
lastCommitTime: 'وقت آخر التزام',
|
||||
lastCommitAuthor: 'مؤلف آخر التزام',
|
||||
},
|
||||
originInfo: {
|
||||
originalFilename: 'اسم الملف الأصلي',
|
||||
originalFileSize: 'حجم الملف الأصلي',
|
||||
uploadDate: 'تاريخ التحميل',
|
||||
lastUpdateDate: 'تاريخ آخر تحديث',
|
||||
source: 'المصدر',
|
||||
},
|
||||
technicalParameters: {
|
||||
segmentSpecification: 'مواصفات القطع',
|
||||
segmentLength: 'طول القطع',
|
||||
avgParagraphLength: 'متوسط طول الفقرة',
|
||||
paragraphs: 'الفقرات',
|
||||
hitCount: 'عدد الاسترجاع',
|
||||
embeddingTime: 'وقت التضمين',
|
||||
embeddedSpend: 'إنفاق التضمين',
|
||||
},
|
||||
},
|
||||
languageMap: {
|
||||
zh: 'صيني',
|
||||
en: 'إنجليزي',
|
||||
es: 'إسباني',
|
||||
fr: 'فرنسي',
|
||||
de: 'ألماني',
|
||||
ja: 'ياباني',
|
||||
ko: 'كوري',
|
||||
ru: 'روسي',
|
||||
ar: 'عربي',
|
||||
pt: 'برتغالي',
|
||||
it: 'إيطالي',
|
||||
nl: 'هولندي',
|
||||
pl: 'بولندي',
|
||||
sv: 'سويدي',
|
||||
tr: 'تركي',
|
||||
he: 'عبري',
|
||||
hi: 'هندي',
|
||||
da: 'دنماركي',
|
||||
fi: 'فنلندي',
|
||||
no: 'نرويجي',
|
||||
hu: 'مجري',
|
||||
el: 'يوناني',
|
||||
cs: 'تشيكي',
|
||||
th: 'تايلاندي',
|
||||
id: 'إندونيسي',
|
||||
},
|
||||
categoryMap: {
|
||||
book: {
|
||||
fiction: 'خيال',
|
||||
biography: 'سيرة شخصية',
|
||||
history: 'تاريخ',
|
||||
science: 'علوم',
|
||||
technology: 'تكنولوجيا',
|
||||
education: 'تعليم',
|
||||
philosophy: 'فلسفة',
|
||||
religion: 'دين',
|
||||
socialSciences: 'علوم اجتماعية',
|
||||
art: 'فن',
|
||||
travel: 'سفر',
|
||||
health: 'صحة',
|
||||
selfHelp: 'تطوير الذات',
|
||||
businessEconomics: 'أعمال واقتصاد',
|
||||
cooking: 'طبخ',
|
||||
childrenYoungAdults: 'أطفال وشباب',
|
||||
comicsGraphicNovels: 'قصص مصورة وروايات مصورة',
|
||||
poetry: 'شعر',
|
||||
drama: 'دراما',
|
||||
other: 'أخرى',
|
||||
},
|
||||
personalDoc: {
|
||||
notes: 'ملاحظات',
|
||||
blogDraft: 'مسودة مدونة',
|
||||
diary: 'مذكرات',
|
||||
researchReport: 'تقرير بحث',
|
||||
bookExcerpt: 'مقتطف من كتاب',
|
||||
schedule: 'جدول',
|
||||
list: 'قائمة',
|
||||
projectOverview: 'نظرة عامة على المشروع',
|
||||
photoCollection: 'مجموعة صور',
|
||||
creativeWriting: 'كتابة إبداعية',
|
||||
codeSnippet: 'مقتطف كود',
|
||||
designDraft: 'مسودة تصميم',
|
||||
personalResume: 'سيرة ذاتية شخصية',
|
||||
other: 'أخرى',
|
||||
},
|
||||
businessDoc: {
|
||||
meetingMinutes: 'محضر اجتماع',
|
||||
researchReport: 'تقرير بحث',
|
||||
proposal: 'اقتراح',
|
||||
employeeHandbook: 'دليل الموظف',
|
||||
trainingMaterials: 'مواد تدريبية',
|
||||
requirementsDocument: 'وثيقة المتطلبات',
|
||||
designDocument: 'وثيقة التصميم',
|
||||
productSpecification: 'مواصفات المنتج',
|
||||
financialReport: 'تقرير مالي',
|
||||
marketAnalysis: 'تحليل السوق',
|
||||
projectPlan: 'خطة المشروع',
|
||||
teamStructure: 'هيكل الفريق',
|
||||
policiesProcedures: 'السياسات والإجراءات',
|
||||
contractsAgreements: 'العقود والاتفاقيات',
|
||||
emailCorrespondence: 'مراسلات البريد الإلكتروني',
|
||||
other: 'أخرى',
|
||||
},
|
||||
},
|
||||
},
|
||||
embedding: {
|
||||
waiting: 'انتظار التضمين...',
|
||||
processing: 'معالجة التضمين...',
|
||||
paused: 'تم إيقاف التضمين مؤقتًا',
|
||||
completed: 'اكتمل التضمين',
|
||||
error: 'خطأ في التضمين',
|
||||
docName: 'مستند المعالجة المسبقة',
|
||||
mode: 'إعداد التقطيع',
|
||||
segmentLength: 'أقصى طول للقطعة',
|
||||
textCleaning: 'قواعد المعالجة المسبقة للنص',
|
||||
segments: 'الفقرات',
|
||||
highQuality: 'وضع عالي الجودة',
|
||||
economy: 'الوضع الاقتصادي',
|
||||
estimate: 'الاستهلاك المقدر',
|
||||
stop: 'إيقاف المعالجة',
|
||||
pause: 'إيقاف مؤقت',
|
||||
resume: 'استئناف',
|
||||
automatic: 'تلقائي',
|
||||
custom: 'مخصص',
|
||||
hierarchical: 'الأصل والطفل',
|
||||
previewTip: 'ستتوفر معاينة الفقرة بعد اكتمال التضمين',
|
||||
parentMaxTokens: 'الأصل',
|
||||
childMaxTokens: 'الطفل',
|
||||
},
|
||||
segment: {
|
||||
paragraphs: 'الفقرات',
|
||||
chunks_one: 'قطعة',
|
||||
chunks_other: 'قطع',
|
||||
parentChunks_one: 'قطعة أصلية',
|
||||
parentChunks_other: 'قطع أصلية',
|
||||
childChunks_one: 'قطعة فرعية',
|
||||
childChunks_other: 'قطع فرعية',
|
||||
searchResults_zero: 'نتيجة',
|
||||
searchResults_one: 'نتيجة',
|
||||
searchResults_other: 'نتائج',
|
||||
empty: 'لم يتم العثور على أي قطعة',
|
||||
clearFilter: 'مسح التصفية',
|
||||
chunk: 'قطعة',
|
||||
parentChunk: 'قطعة أصلية',
|
||||
newChunk: 'قطعة جديدة',
|
||||
childChunk: 'قطعة فرعية',
|
||||
newChildChunk: 'قطعة فرعية جديدة',
|
||||
keywords: 'كلمات رئيسية',
|
||||
addKeyWord: 'إضافة كلمة رئيسية',
|
||||
keywordEmpty: 'لا يمكن أن تكون الكلمة الرئيسية فارغة',
|
||||
keywordError: 'الحد الأقصى لطول الكلمة الرئيسية هو 20',
|
||||
keywordDuplicate: 'الكلمة الرئيسية موجودة بالفعل',
|
||||
characters_one: 'حرف',
|
||||
characters_other: 'أحرف',
|
||||
hitCount: 'عدد الاسترجاع',
|
||||
vectorHash: 'تجزئة المتجه: ',
|
||||
questionPlaceholder: 'أضف السؤال هنا',
|
||||
questionEmpty: 'لا يمكن أن يكون السؤال فارغًا',
|
||||
answerPlaceholder: 'أضف الإجابة هنا',
|
||||
answerEmpty: 'لا يمكن أن تكون الإجابة فارغة',
|
||||
contentPlaceholder: 'أضف المحتوى هنا',
|
||||
contentEmpty: 'لا يمكن أن يكون المحتوى فارغًا',
|
||||
newTextSegment: 'قطعة نصية جديدة',
|
||||
newQaSegment: 'قطعة سؤال وجواب جديدة',
|
||||
addChunk: 'إضافة قطعة',
|
||||
addChildChunk: 'إضافة قطعة فرعية',
|
||||
addAnother: 'إضافة أخرى',
|
||||
delete: 'حذف هذه القطعة؟',
|
||||
chunkAdded: 'تم إضافة قطعة واحدة',
|
||||
childChunkAdded: 'تم إضافة قطعة فرعية واحدة',
|
||||
editChunk: 'تعديل القطعة',
|
||||
editParentChunk: 'تعديل القطعة الأصلية',
|
||||
editChildChunk: 'تعديل القطعة الفرعية',
|
||||
chunkDetail: 'تفاصيل القطعة',
|
||||
regenerationConfirmTitle: 'هل تريد إعادة إنشاء القطع الفرعية؟',
|
||||
regenerationConfirmMessage: 'سوف تؤدي إعادة إنشاء القطع الفرعية إلى استبدال القطع الفرعية الحالية، بما في ذلك القطع المعدلة والقطع المضافة حديثًا. لا يمكن التراجع عن إعادة الإنشاء.',
|
||||
regeneratingTitle: 'إعادة إنشاء القطع الفرعية',
|
||||
regeneratingMessage: 'قد يستغرق هذا لحظة، يرجى الانتظار...',
|
||||
regenerationSuccessTitle: 'اكتملت إعادة الإنشاء',
|
||||
regenerationSuccessMessage: 'يمكنك إغلاق هذه النافذة.',
|
||||
edited: 'معدل',
|
||||
editedAt: 'تم التعديل في',
|
||||
dateTimeFormat: 'MM/DD/YYYY h:mm',
|
||||
expandChunks: 'توسيع القطع',
|
||||
collapseChunks: 'طي القطع',
|
||||
allFilesUploaded: 'يجب تحميل جميع الملفات قبل الحفظ',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
40
web/i18n/ar-TN/dataset-hit-testing.ts
Normal file
40
web/i18n/ar-TN/dataset-hit-testing.ts
Normal file
@@ -0,0 +1,40 @@
|
||||
const translation = {
|
||||
title: 'اختبار الاسترجاع',
|
||||
settingTitle: 'إعداد الاسترجاع',
|
||||
desc: 'اختبار تأثير مطابقة المعرفة بناءً على نص الاستعلام المقدم.',
|
||||
dateTimeFormat: 'MM/DD/YYYY hh:mm A',
|
||||
records: 'سجلات',
|
||||
table: {
|
||||
header: {
|
||||
source: 'المصدر',
|
||||
time: 'وقت',
|
||||
queryContent: 'محتوى الاستعلام',
|
||||
},
|
||||
},
|
||||
input: {
|
||||
title: 'النص المصدر',
|
||||
placeholder: 'يرجى إدخال نص، ويوصى بجملة تعريفية قصيرة.',
|
||||
countWarning: 'ما يصل إلى 200 حرف.',
|
||||
indexWarning: 'معرفة عالية الجودة فقط.',
|
||||
testing: 'اختبار',
|
||||
},
|
||||
hit: {
|
||||
title: '{{num}} قطع مسترجعة',
|
||||
emptyTip: 'ستظهر نتائج اختبار الاسترجاع هنا',
|
||||
},
|
||||
noRecentTip: 'لا توجد نتائج استعلام حديثة هنا',
|
||||
viewChart: 'عرض مخطط VECTOR',
|
||||
viewDetail: 'عرض التفاصيل',
|
||||
chunkDetail: 'تفاصيل المقطع',
|
||||
hitChunks: 'إصابة {{num}} مقاطع فرعية',
|
||||
open: 'فتح',
|
||||
keyword: 'الكلمات الرئيسية',
|
||||
imageUploader: {
|
||||
tip: 'قم بتحميل الصور أو إسقاطها (الحد الأقصى {{batchCount}}، {{size}} ميغابايت لكل صورة)',
|
||||
tooltip: 'رفع الصور (الحد الأقصى {{batchCount}}، {{size}} ميغابايت لكل صورة)',
|
||||
dropZoneTip: 'اسحب الملف هنا للتحميل',
|
||||
singleChunkAttachmentLimitTooltip: 'لا يمكن أن يتجاوز عدد المرفقات ذات القطعة الواحدة {{limit}}',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
165
web/i18n/ar-TN/dataset-pipeline.ts
Normal file
165
web/i18n/ar-TN/dataset-pipeline.ts
Normal file
@@ -0,0 +1,165 @@
|
||||
const translation = {
|
||||
creation: {
|
||||
backToKnowledge: 'العودة إلى المعرفة',
|
||||
createFromScratch: {
|
||||
title: 'سير عمل معرفة فارغ',
|
||||
description: 'إنشاء سير عمل مخصص من الصفر مع التحكم الكامل في معالجة البيانات وهيكلها.',
|
||||
},
|
||||
importDSL: 'استيراد من ملف DSL',
|
||||
createKnowledge: 'إنشاء المعرفة',
|
||||
errorTip: 'فشل إنشاء قاعدة المعرفة',
|
||||
successTip: 'تم إنشاء قاعدة المعرفة بنجاح',
|
||||
caution: 'تنبيه',
|
||||
},
|
||||
templates: {
|
||||
customized: 'مخصص',
|
||||
},
|
||||
operations: {
|
||||
choose: 'اختر',
|
||||
details: 'التفاصيل',
|
||||
editInfo: 'تعديل المعلومات',
|
||||
useTemplate: 'استخدام سير عمل المعرفة هذا',
|
||||
backToDataSource: 'العودة إلى مصدر البيانات',
|
||||
process: 'معالجة',
|
||||
dataSource: 'مصدر البيانات',
|
||||
saveAndProcess: 'حفظ ومعالجة',
|
||||
preview: 'معاينة',
|
||||
exportPipeline: 'تصدير سير العمل',
|
||||
convert: 'تحويل',
|
||||
},
|
||||
knowledgeNameAndIcon: 'اسم وأيقونة المعرفة',
|
||||
knowledgeNameAndIconPlaceholder: 'يرجى إدخال اسم قاعدة المعرفة',
|
||||
knowledgeDescription: 'وصف المعرفة',
|
||||
knowledgeDescriptionPlaceholder: 'صف ما يوجد في قاعدة المعرفة هذه. يسمح الوصف التفصيلي للذكاء الاصطناعي بالوصول إلى محتوى مجموعة البيانات بشكل أكثر دقة. إذا كان فارغًا، فسيستخدم Dify استراتيجية المطابقة الافتراضية. (اختياري)',
|
||||
knowledgePermissions: 'أذونات',
|
||||
editPipelineInfo: 'تعديل معلومات سير العمل',
|
||||
pipelineNameAndIcon: 'اسم وأيقونة سير العمل',
|
||||
deletePipeline: {
|
||||
title: 'هل أنت متأكد من حذف قالب سير العمل هذا؟',
|
||||
content: 'حذف قالب سير العمل لا رجعة فيه.',
|
||||
},
|
||||
publishPipeline: {
|
||||
success: {
|
||||
message: 'تم نشر سير عمل المعرفة',
|
||||
tip: '<CustomLink>الذهاب إلى المستندات</CustomLink> لإضافة أو إدارة المستندات.',
|
||||
},
|
||||
error: {
|
||||
message: 'فشل نشر سير عمل المعرفة',
|
||||
},
|
||||
},
|
||||
publishTemplate: {
|
||||
success: {
|
||||
message: 'تم نشر قالب سير العمل',
|
||||
tip: 'يمكنك استخدام هذا القالب في صفحة الإنشاء.',
|
||||
learnMore: 'تعرف على المزيد',
|
||||
},
|
||||
error: {
|
||||
message: 'فشل نشر قالب سير العمل',
|
||||
},
|
||||
},
|
||||
exportDSL: {
|
||||
successTip: 'تم تصدير DSL لسير العمل بنجاح',
|
||||
errorTip: 'فشل تصدير DSL لسير العمل',
|
||||
},
|
||||
details: {
|
||||
createdBy: 'بواسطة {{author}}',
|
||||
structure: 'الهيكل',
|
||||
structureTooltip: 'يحدد هيكل القطعة كيفية تقسيم المستندات وفهرستها - تقديم أوضاع عامة، الأصل والطفل، والأسئلة والأجوبة - وهي فريدة لكل قاعدة معرفة.',
|
||||
},
|
||||
testRun: {
|
||||
title: 'تشغيل اختباري',
|
||||
tooltip: 'في وضع التشغيل الاختباري، يُسمح باستيراد مستند واحد فقط في كل مرة لسهولة التصحيح والملاحظة.',
|
||||
steps: {
|
||||
dataSource: 'مصدر البيانات',
|
||||
documentProcessing: 'معالجة المستندات',
|
||||
},
|
||||
dataSource: {
|
||||
localFiles: 'الملفات المحلية',
|
||||
},
|
||||
notion: {
|
||||
title: 'اختر صفحات Notion',
|
||||
docTitle: 'مستندات Notion',
|
||||
},
|
||||
},
|
||||
inputField: 'حقل الإدخال',
|
||||
inputFieldPanel: {
|
||||
title: 'حقول إدخال المستخدم',
|
||||
description: 'تُستخدم حقول إدخال المستخدم لتعريف وجمع المتغيرات المطلوبة أثناء عملية تنفيذ سير العمل. يمكن للمستخدمين تخصيص نوع الحقل وتكوين قيمة الإدخال بمرونة لتلبية احتياجات مصادر البيانات المختلفة أو خطوات معالجة المستندات.',
|
||||
uniqueInputs: {
|
||||
title: 'مدخلات فريدة لكل مدخل',
|
||||
tooltip: 'المدخلات الفريدة يمكن الوصول إليها فقط لمصدر البيانات المحدد وعقده النهائية. لن يحتاج المستخدمون إلى تعبئتها عند اختيار مصادر بيانات أخرى. ستظهر فقط حقول الإدخال المشار إليها بواسطة متغيرات مصدر البيانات في الخطوة الأولى (مصدر البيانات). ستظهر جميع الحقول الأخرى في الخطوة الثانية (معالجة المستندات).',
|
||||
},
|
||||
globalInputs: {
|
||||
title: 'مدخلات عالمية لجميع المداخل',
|
||||
tooltip: 'المدخلات العالمية مشتركة عبر جميع العقد. سيحتاج المستخدمون إلى تعبئتها عند اختيار أي مصدر بيانات. على سبيل المثال، يمكن تطبيق حقول مثل المحدد والحد الأقصى لطول القطعة بشكل موحد عبر مصادر بيانات متعددة. ستظهر فقط حقول الإدخال المشار إليها بواسطة متغيرات مصدر البيانات في الخطوة الأولى (مصدر البيانات). ستظهر جميع الحقول الأخرى في الخطوة الثانية (معالجة المستندات).',
|
||||
},
|
||||
addInputField: 'إضافة حقل إدخال',
|
||||
editInputField: 'تعديل حقل إدخال',
|
||||
preview: {
|
||||
stepOneTitle: 'مصدر البيانات',
|
||||
stepTwoTitle: 'معالجة المستندات',
|
||||
},
|
||||
error: {
|
||||
variableDuplicate: 'اسم المتغير موجود بالفعل. يرجى اختيار اسم مختلف.',
|
||||
},
|
||||
},
|
||||
addDocuments: {
|
||||
title: 'إضافة مستندات',
|
||||
steps: {
|
||||
chooseDatasource: 'اختر مصدر بيانات',
|
||||
processDocuments: 'معالجة المستندات',
|
||||
processingDocuments: 'جارٍ معالجة المستندات',
|
||||
},
|
||||
backToDataSource: 'مصدر البيانات',
|
||||
stepOne: {
|
||||
preview: 'معاينة',
|
||||
},
|
||||
stepTwo: {
|
||||
chunkSettings: 'إعدادات القطعة',
|
||||
previewChunks: 'معاينة القطع',
|
||||
},
|
||||
stepThree: {
|
||||
learnMore: 'تعرف على المزيد',
|
||||
},
|
||||
characters: 'أحرف',
|
||||
selectOnlineDocumentTip: 'معالجة ما يصل إلى {{count}} صفحة',
|
||||
selectOnlineDriveTip: 'معالجة ما يصل إلى {{count}} ملف، بحد أقصى {{fileSize}} ميجابايت لكل منها',
|
||||
},
|
||||
documentSettings: {
|
||||
title: 'إعدادات المستند',
|
||||
},
|
||||
onlineDocument: {
|
||||
pageSelectorTitle: '{{name}} صفحات',
|
||||
},
|
||||
onlineDrive: {
|
||||
notConnected: '{{name}} غير متصل',
|
||||
notConnectedTip: 'للمزامنة مع {{name}}، يجب إنشاء اتصال بـ {{name}} أولاً.',
|
||||
breadcrumbs: {
|
||||
allBuckets: 'جميع حاويات التخزين السحابية',
|
||||
allFiles: 'جميع الملفات',
|
||||
searchResult: 'العثور على {{searchResultsLength}} عناصر في مجلد "{{folderName}}"',
|
||||
searchPlaceholder: 'بحث في الملفات...',
|
||||
},
|
||||
notSupportedFileType: 'نوع الملف هذا غير مدعوم',
|
||||
emptyFolder: 'هذا المجلد فارغ',
|
||||
emptySearchResult: 'لم يتم العثور على أي عناصر',
|
||||
resetKeywords: 'إعادة تعيين الكلمات الرئيسية',
|
||||
},
|
||||
credentialSelector: {
|
||||
},
|
||||
configurationTip: 'تكوين {{pluginName}}',
|
||||
conversion: {
|
||||
title: 'التحويل إلى سير عمل المعرفة',
|
||||
descriptionChunk1: 'يمكنك الآن تحويل قاعدة المعرفة الحالية لاستخدام سير عمل المعرفة لمعالجة المستندات',
|
||||
descriptionChunk2: ' - نهج أكثر انفتاحًا ومرونة مع الوصول إلى الإضافات من سوقنا. سيطبق هذا طريقة المعالجة الجديدة على جميع المستندات المستقبلية.',
|
||||
warning: 'لا يمكن التراجع عن هذا الإجراء.',
|
||||
confirm: {
|
||||
title: 'تأكيد',
|
||||
content: 'هذا الإجراء دائم. لن تتمكن من العودة إلى الطريقة السابقة. يرجى التأكيد للتحويل.',
|
||||
},
|
||||
errorMessage: 'فشل تحويل مجموعة البيانات إلى سير عمل',
|
||||
successMessage: 'تم تحويل مجموعة البيانات إلى سير عمل بنجاح',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
52
web/i18n/ar-TN/dataset-settings.ts
Normal file
52
web/i18n/ar-TN/dataset-settings.ts
Normal file
@@ -0,0 +1,52 @@
|
||||
const translation = {
|
||||
title: 'إعدادات المعرفة',
|
||||
desc: 'هنا يمكنك تعديل الخصائص وإعدادات الاسترجاع لهذه المعرفة.',
|
||||
form: {
|
||||
name: 'اسم المعرفة',
|
||||
nameAndIcon: 'الاسم والأيقونة',
|
||||
namePlaceholder: 'يرجى إدخال اسم المعرفة',
|
||||
nameError: 'لا يمكن أن يكون الاسم فارغًا',
|
||||
desc: 'الوصف',
|
||||
descInfo: 'يرجى كتابة وصف نصي واضح لتوضيح محتوى المعرفة. سيتم استخدام هذا الوصف كأساس للمطابقة عند الاختيار من بين معارف متعددة للاستنتاج.',
|
||||
descPlaceholder: 'صف ما يوجد في مجموعة البيانات هذه. يسمح الوصف التفصيلي للذكاء الاصطناعي بالوصول إلى محتوى مجموعة البيانات في الوقت المناسب. إذا كان فارغًا، فسيستخدم Dify استراتيجية المطابقة الافتراضية.',
|
||||
helpText: 'تعرف على كيفية كتابة وصف جيد لمجموعة البيانات.',
|
||||
descWrite: 'تعرف على كيفية كتابة وصف جيد للمعرفة.',
|
||||
permissions: 'أذونات',
|
||||
permissionsOnlyMe: 'أنا فقط',
|
||||
permissionsAllMember: 'جميع أعضاء الفريق',
|
||||
permissionsInvitedMembers: 'أعضاء الفريق الجزئيين',
|
||||
me: '(أنت)',
|
||||
onSearchResults: 'لا يوجد أعضاء يطابقون استعلام البحث الخاص بك.\nحاول البحث مرة أخرى.',
|
||||
chunkStructure: {
|
||||
title: 'هيكل القطعة',
|
||||
learnMore: 'تعرف على المزيد',
|
||||
description: ' حول هيكل القطعة.',
|
||||
},
|
||||
indexMethod: 'طريقة الفهرسة',
|
||||
indexMethodHighQuality: 'جودة عالية',
|
||||
indexMethodHighQualityTip: 'يساعد استدعاء نموذج التضمين لمعالجة المستندات من أجل استرجاع أكثر دقة LLM على إنشاء إجابات عالية الجودة.',
|
||||
upgradeHighQualityTip: 'بمجرد الترقية إلى وضع الجودة العالية، لا يتوفر الرجوع إلى الوضع الاقتصادي',
|
||||
indexMethodEconomy: 'اقتصادي',
|
||||
indexMethodEconomyTip: 'استخدام {{count}} كلمات رئيسية لكل قطعة للاسترجاع، لا يتم استهلاك أي رموز على حساب دقة الاسترجاع المنخفضة.',
|
||||
numberOfKeywords: 'عدد الكلمات الرئيسية',
|
||||
embeddingModel: 'نموذج التضمين',
|
||||
embeddingModelTip: 'لتغيير النموذج المضمن، يرجى الانتقال إلى ',
|
||||
embeddingModelTipLink: 'الإعدادات',
|
||||
retrievalSetting: {
|
||||
title: 'إعداد الاسترجاع',
|
||||
method: 'طريقة الاسترجاع',
|
||||
learnMore: 'تعرف على المزيد',
|
||||
description: ' حول طريقة الاسترجاع.',
|
||||
longDescription: ' حول طريقة الاسترجاع، يمكنك تغيير هذا في أي وقت في إعدادات المعرفة.',
|
||||
multiModalTip: 'عندما يدعم نموذج التضمين متعدد الوسائط، يرجى اختيار نموذج إعادة ترتيب متعدد الوسائط للحصول على أداء أفضل.',
|
||||
},
|
||||
externalKnowledgeAPI: 'واجهة برمجة تطبيقات المعرفة الخارجية',
|
||||
externalKnowledgeID: 'معرف المعرفة الخارجية',
|
||||
retrievalSettings: 'إعدادات الاسترجاع',
|
||||
save: 'حفظ',
|
||||
indexMethodChangeToEconomyDisabledTip: 'غير متوفر للرجوع من الجودة العالية إلى الوضع الاقتصادي',
|
||||
searchModel: 'نموذج البحث',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
251
web/i18n/ar-TN/dataset.ts
Normal file
251
web/i18n/ar-TN/dataset.ts
Normal file
@@ -0,0 +1,251 @@
|
||||
const translation = {
|
||||
knowledge: 'المعرفة',
|
||||
chunkingMode: {
|
||||
general: 'عام',
|
||||
parentChild: 'الأصل والطفل',
|
||||
qa: 'سؤال وجواب',
|
||||
graph: 'رسم بياني',
|
||||
},
|
||||
parentMode: {
|
||||
paragraph: 'فقرة',
|
||||
fullDoc: 'مستند كامل',
|
||||
},
|
||||
externalTag: 'خارجي',
|
||||
externalAPI: 'واجهة برمجة تطبيقات خارجية',
|
||||
externalAPIPanelTitle: 'واجهة برمجة تطبيقات المعرفة الخارجية',
|
||||
externalKnowledgeId: 'معرف المعرفة الخارجية',
|
||||
externalKnowledgeName: 'اسم المعرفة الخارجية',
|
||||
externalKnowledgeDescription: 'وصف المعرفة',
|
||||
externalKnowledgeIdPlaceholder: 'يرجى إدخال معرف المعرفة',
|
||||
externalKnowledgeNamePlaceholder: 'يرجى إدخال اسم قاعدة المعرفة',
|
||||
externalKnowledgeDescriptionPlaceholder: 'صف ما يوجد في قاعدة المعرفة هذه (اختياري)',
|
||||
learnHowToWriteGoodKnowledgeDescription: 'تعرف على كيفية كتابة وصف جيد للمعرفة',
|
||||
externalAPIPanelDescription: 'تُستخدم واجهة برمجة تطبيقات المعرفة الخارجية للاتصال بقاعدة معرفة خارج Dify واسترجاع المعرفة من قاعدة المعرفة تلك.',
|
||||
externalAPIPanelDocumentation: 'تعرف على كيفية إنشاء واجهة برمجة تطبيقات المعرفة الخارجية',
|
||||
externalKnowledgeBase: 'قاعدة المعرفة الخارجية',
|
||||
localDocs: 'مستندات محلية',
|
||||
documentCount: ' مستندات',
|
||||
docAllEnabled_one: '{{count}} مستند ممكن',
|
||||
docAllEnabled_other: 'تم تمكين جميع المستندات البالغ عددها {{count}}',
|
||||
partialEnabled_one: 'إجمالي {{count}} مستند، {{num}} متاح',
|
||||
partialEnabled_other: 'إجمالي {{count}} مستندات، {{num}} متاح',
|
||||
wordCount: ' ألف كلمة',
|
||||
appCount: ' تطبيقات مرتبطة',
|
||||
updated: 'محدث',
|
||||
createDataset: 'إنشاء المعرفة',
|
||||
createFromPipeline: 'إنشاء من سير عمل المعرفة',
|
||||
createNewExternalAPI: 'إنشاء واجهة برمجة تطبيقات معرفة خارجية جديدة',
|
||||
noExternalKnowledge: 'لا توجد واجهة برمجة تطبيقات معرفة خارجية حتى الآن، انقر هنا لإنشاء',
|
||||
createExternalAPI: 'إضافة واجهة برمجة تطبيقات معرفة خارجية',
|
||||
editExternalAPIFormTitle: 'تعديل واجهة برمجة تطبيقات المعرفة الخارجية',
|
||||
editExternalAPITooltipTitle: 'المعرفة المرتبطة',
|
||||
editExternalAPIConfirmWarningContent: {
|
||||
front: 'ترتبط واجهة برمجة تطبيقات المعرفة الخارجية هذه بـ',
|
||||
end: 'معرفة خارجية، وسيتم تطبيق هذا التعديل عليها جميعًا. هل أنت متأكد أنك تريد حفظ هذا التغيير؟',
|
||||
},
|
||||
editExternalAPIFormWarning: {
|
||||
front: 'ترتبط واجهة برمجة التطبيقات الخارجية هذه بـ',
|
||||
end: 'معرفة خارجية',
|
||||
},
|
||||
deleteExternalAPIConfirmWarningContent: {
|
||||
title: {
|
||||
front: 'حذف',
|
||||
end: '؟',
|
||||
},
|
||||
content: {
|
||||
front: 'ترتبط واجهة برمجة تطبيقات المعرفة الخارجية هذه بـ',
|
||||
end: 'معرفة خارجية. سيؤدي حذف واجهة برمجة التطبيقات هذه إلى إبطالها جميعًا. هل أنت متأكد أنك تريد حذف واجهة برمجة التطبيقات هذه؟',
|
||||
},
|
||||
noConnectionContent: 'هل أنت متأكد من حذف واجهة برمجة التطبيقات هذه؟',
|
||||
},
|
||||
selectExternalKnowledgeAPI: {
|
||||
placeholder: 'اختر واجهة برمجة تطبيقات معرفة خارجية',
|
||||
},
|
||||
connectDataset: 'الاتصال بقاعدة معرفة خارجية',
|
||||
connectDatasetIntro: {
|
||||
title: 'كيفية الاتصال بقاعدة معرفة خارجية',
|
||||
content: {
|
||||
front: 'للاتصال بقاعدة معرفة خارجية، تحتاج إلى إنشاء واجهة برمجة تطبيقات خارجية أولاً. يرجى القراءة بعناية والرجوع إلى',
|
||||
link: 'تعرف على كيفية إنشاء واجهة برمجة تطبيقات خارجية',
|
||||
end: '. ثم ابحث عن معرف المعرفة المقابل واملأه في النموذج على اليسار. إذا كانت جميع المعلومات صحيحة، فسيقفز تلقائيًا إلى اختبار الاسترجاع في قاعدة المعرفة بعد النقر فوق زر الاتصال.',
|
||||
},
|
||||
learnMore: 'تعرف على المزيد',
|
||||
},
|
||||
connectHelper: {
|
||||
helper1: 'تصل بقواعد المعرفة الخارجية عبر API ومعرف قاعدة المعرفة. حاليًا، ',
|
||||
helper2: 'يتم دعم وظيفة الاسترجاع فقط',
|
||||
helper3: '. نوصي بشدة أن تقوم بـ ',
|
||||
helper4: 'قراءة وثائق المساعدة',
|
||||
helper5: ' بعناية قبل استخدام هذه الميزة.',
|
||||
},
|
||||
createDatasetIntro: 'استيراد بيانات النص الخاصة بك أو كتابة البيانات في الوقت الفعلي عبر Webhook لتحسين سياق LLM.',
|
||||
deleteDatasetConfirmTitle: 'حذف هذه المعرفة؟',
|
||||
deleteDatasetConfirmContent:
|
||||
'حذف المعرفة لا رجعة فيه. لن يتمكن المستخدمون بعد الآن من الوصول إلى معرفتك، وسيتم حذف جميع تكوينات الموجه والسجلات بشكل دائم.',
|
||||
datasetUsedByApp: 'يتم استخدام المعرفة بواسطة بعض التطبيقات. لن تتمكن التطبيقات بعد الآن من استخدام هذه المعرفة، وسيتم حذف جميع تكوينات الموجه والسجلات بشكل دائم.',
|
||||
datasetDeleted: 'تم حذف المعرفة',
|
||||
datasetDeleteFailed: 'فشل حذف المعرفة',
|
||||
didYouKnow: 'هل تعلم؟',
|
||||
intro1: 'يمكن دمج المعرفة في تطبيق Dify ',
|
||||
intro2: 'كسياق',
|
||||
intro3: '،',
|
||||
intro4: 'أو ',
|
||||
intro5: 'يمكن نشرها',
|
||||
intro6: ' كخدمة مستقلة.',
|
||||
unavailable: 'غير متاح',
|
||||
datasets: 'المعرفة',
|
||||
datasetsApi: 'الوصول إلى API',
|
||||
externalKnowledgeForm: {
|
||||
connect: 'اتصال',
|
||||
cancel: 'إلغاء',
|
||||
},
|
||||
externalAPIForm: {
|
||||
name: 'الاسم',
|
||||
endpoint: 'نقطة نهاية API',
|
||||
apiKey: 'مفتاح API',
|
||||
save: 'حفظ',
|
||||
cancel: 'إلغاء',
|
||||
edit: 'تعديل',
|
||||
encrypted: {
|
||||
front: 'سيتم تشفير رمز API الخاص بك وتخزينه باستخدام',
|
||||
end: 'تقنية.',
|
||||
},
|
||||
},
|
||||
retrieval: {
|
||||
semantic_search: {
|
||||
title: 'بحث المتجهات',
|
||||
description: 'إنشاء تضمينات الاستعلام والبحث عن قطعة النص الأكثر تشابهًا مع تمثيلها المتجه.',
|
||||
},
|
||||
full_text_search: {
|
||||
title: 'بحث النص الكامل',
|
||||
description: 'فهرسة جميع المصطلحات في المستند، مما يسمح للمستخدمين بالبحث عن أي مصطلح واسترجاع قطعة نصية ذات صلة تحتوي على تلك المصطلحات.',
|
||||
},
|
||||
hybrid_search: {
|
||||
title: 'بحث هجين',
|
||||
description: 'تنفيذ البحث بالنص الكامل والبحث المتجه في وقت واحد، وإعادة الترتيب لتحديد أفضل تطابق لاستعلام المستخدم. يمكن للمستخدمين اختيار تعيين الأوزان أو التكوين لنموذج إعادة الترتيب.',
|
||||
recommend: 'نوصي',
|
||||
},
|
||||
keyword_search: {
|
||||
title: 'فهرس معكوس',
|
||||
description: 'الفهرس المعكوس هو هيكل يستخدم للاسترجاع الفعال. منظم حسب المصطلحات، يشير كل مصطلح إلى المستندات أو صفحات الويب التي تحتوي عليه.',
|
||||
},
|
||||
change: 'تغيير',
|
||||
changeRetrievalMethod: 'تغيير طريقة الاسترجاع',
|
||||
},
|
||||
docsFailedNotice: 'فشل فهرسة المستندات',
|
||||
retry: 'إعادة المحاولة',
|
||||
documentsDisabled: '{{num}} مستندات معطلة - غير نشطة لأكثر من 30 يومًا',
|
||||
enable: 'تمكين',
|
||||
indexingTechnique: {
|
||||
high_quality: 'HQ',
|
||||
economy: 'ECO',
|
||||
},
|
||||
indexingMethod: {
|
||||
semantic_search: 'VECTOR',
|
||||
full_text_search: 'FULL TEXT',
|
||||
hybrid_search: 'HYBRID',
|
||||
invertedIndex: 'فهرس معكوس',
|
||||
},
|
||||
defaultRetrievalTip: 'يستخدم الاسترجاع متعدد المسارات افتراضيًا. يتم استرجاع المعرفة من قواعد معرفة متعددة ثم إعادة ترتيبها.',
|
||||
mixtureHighQualityAndEconomicTip: 'مطلوب نموذج إعادة الترتيب لخلط قواعد المعرفة عالية الجودة والاقتصادية.',
|
||||
inconsistentEmbeddingModelTip: 'مطلوب نموذج إعادة الترتيب إذا كانت نماذج التضمين لقواعد المعرفة المختارة غير متسقة.',
|
||||
mixtureInternalAndExternalTip: 'مطلوب نموذج إعادة الترتيب لخلط المعرفة الداخلية والخارجية.',
|
||||
allExternalTip: 'عند استخدام المعرفة الخارجية فقط، يمكن للمستخدم اختيار ما إذا كان سيمكن نموذج إعادة الترتيب. إذا لم يتم تمكينه، فسيتم فرز القطع المسترجعة بناءً على الدرجات. عندما تكون استراتيجيات الاسترجاع لقواعد المعرفة المختلفة غير متسقة، فستكون غير دقيقة.',
|
||||
retrievalSettings: 'إعداد الاسترجاع',
|
||||
rerankSettings: 'إعداد إعادة الترتيب',
|
||||
weightedScore: {
|
||||
title: 'الدرجة المرجحة',
|
||||
description: 'من خلال تعديل الأوزان المخصصة، تحدد استراتيجية إعادة الترتيب هذه ما إذا كانت الأولوية للمطابقة الدلالية أو الكلمات الرئيسية.',
|
||||
semanticFirst: 'الدلالي أولاً',
|
||||
keywordFirst: 'الكلمة الرئيسية أولاً',
|
||||
customized: 'مخصص',
|
||||
semantic: 'دلالي',
|
||||
keyword: 'كلمة رئيسية',
|
||||
},
|
||||
nTo1RetrievalLegacy: 'سيتم إيقاف الاسترجاع من N إلى 1 رسميًا اعتبارًا من سبتمبر. يوصى باستخدام أحدث استرجاع متعدد المسارات للحصول على نتائج أفضل. ',
|
||||
nTo1RetrievalLegacyLink: 'تعرف على المزيد',
|
||||
nTo1RetrievalLegacyLinkText: ' سيتم إيقاف الاسترجاع من N إلى 1 رسميًا في سبتمبر.',
|
||||
batchAction: {
|
||||
selected: 'محدد',
|
||||
enable: 'تمكين',
|
||||
disable: 'تعطيل',
|
||||
archive: 'أرشيف',
|
||||
delete: 'حذف',
|
||||
cancel: 'إلغاء',
|
||||
},
|
||||
preprocessDocument: '{{num}} معالجة المستندات مسبقًا',
|
||||
allKnowledge: 'كل المعرفة',
|
||||
allKnowledgeDescription: 'حدد لعرض كل المعرفة في مساحة العمل هذه. يمكن لمالك مساحة العمل فقط إدارة كل المعرفة.',
|
||||
embeddingModelNotAvailable: 'نموذج التضمين غير متوفر.',
|
||||
metadata: {
|
||||
metadata: 'بيانات وصفية',
|
||||
addMetadata: 'إضافة بيانات وصفية',
|
||||
chooseTime: 'اختر وقتًا...',
|
||||
createMetadata: {
|
||||
title: 'بيانات وصفية جديدة',
|
||||
back: 'رجوع',
|
||||
type: 'نوع',
|
||||
name: 'الاسم',
|
||||
namePlaceholder: 'إضافة اسم البيانات الوصفية',
|
||||
},
|
||||
checkName: {
|
||||
empty: 'لا يمكن أن يكون اسم البيانات الوصفية فارغًا',
|
||||
invalid: 'يمكن أن يحتوي اسم البيانات الوصفية فقط على أحرف صغيرة وأرقام وشرطات سفلية ويجب أن يبدأ بحرف صغير',
|
||||
tooLong: 'لا يمكن أن يتجاوز اسم البيانات الوصفية {{max}} حرفًا',
|
||||
},
|
||||
batchEditMetadata: {
|
||||
editMetadata: 'تعديل البيانات الوصفية',
|
||||
editDocumentsNum: 'تعديل {{num}} مستندات',
|
||||
applyToAllSelectDocument: 'تطبيق على جميع المستندات المحددة',
|
||||
applyToAllSelectDocumentTip: 'إنشاء جميع البيانات الوصفية المعدلة والجديدة أعلاه تلقائيًا لجميع المستندات المحددة، وإلا فإن تعديل البيانات الوصفية سينطبق فقط على المستندات التي تحتوي عليها.',
|
||||
multipleValue: 'قيمة متعددة',
|
||||
},
|
||||
selectMetadata: {
|
||||
search: 'بحث في البيانات الوصفية',
|
||||
newAction: 'بيانات وصفية جديدة',
|
||||
manageAction: 'إدارة',
|
||||
},
|
||||
datasetMetadata: {
|
||||
description: 'يمكنك إدارة جميع البيانات الوصفية في هذه المعرفة هنا. سيتم مزامنة التعديلات مع كل مستند.',
|
||||
addMetaData: 'إضافة بيانات وصفية',
|
||||
values: '{{num}} قيم',
|
||||
disabled: 'معطل',
|
||||
rename: 'إعادة تسمية',
|
||||
name: 'الاسم',
|
||||
namePlaceholder: 'اسم البيانات الوصفية',
|
||||
builtIn: 'مدمج',
|
||||
builtInDescription: 'يتم استخراج البيانات الوصفية المدمجة وإنشاؤها تلقائيًا. يجب تمكينه قبل الاستخدام ولا يمكن تعديله.',
|
||||
deleteTitle: 'تأكيد الحذف',
|
||||
deleteContent: 'هل أنت متأكد أنك تريد حذف البيانات الوصفية "{{name}}"',
|
||||
},
|
||||
documentMetadata: {
|
||||
metadataToolTip: 'تعمل البيانات الوصفية كمرشح حاسم يعزز دقة وملاءمة استرجاع المعلومات. يمكنك تعديل وإضافة بيانات وصفية لهذا المستند هنا.',
|
||||
startLabeling: 'بدء التصنيف',
|
||||
documentInformation: 'معلومات المستند',
|
||||
technicalParameters: 'المعلمات الفنية',
|
||||
},
|
||||
},
|
||||
serviceApi: {
|
||||
title: 'واجهة برمجة تطبيقات الخدمة',
|
||||
enabled: 'في الخدمة',
|
||||
disabled: 'معطل',
|
||||
card: {
|
||||
title: 'واجهة برمجة تطبيقات خدمة الخلفية',
|
||||
endpoint: 'نقطة نهاية واجهة برمجة تطبيقات الخدمة',
|
||||
apiKey: 'مفتاح API',
|
||||
apiReference: 'مرجع API',
|
||||
},
|
||||
},
|
||||
cornerLabel: {
|
||||
unavailable: 'غير متاح',
|
||||
pipeline: 'خط أنابيب',
|
||||
},
|
||||
multimodal: 'متعدد الوسائط',
|
||||
imageUploader: {
|
||||
button: 'اسحب وأفلت الملف أو المجلد، أو',
|
||||
browse: 'تصفح',
|
||||
tip: '{{supportTypes}} (الحد الأقصى {{batchCount}}، {{size}} ميغابايت لكل منها)',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
76
web/i18n/ar-TN/education.ts
Normal file
76
web/i18n/ar-TN/education.ts
Normal file
@@ -0,0 +1,76 @@
|
||||
const translation = {
|
||||
toVerified: 'احصل على التحقق التعليمي',
|
||||
toVerifiedTip: {
|
||||
front: 'أنت الآن مؤهل للحصول على حالة التحقق التعليمي. يرجى إدخال معلومات التعليم الخاصة بك أدناه لإكمال العملية والحصول على',
|
||||
coupon: 'كوبون حصري 100٪',
|
||||
end: 'لخطة Dify الاحترافية.',
|
||||
},
|
||||
currentSigned: 'تم تسجيل الدخول حاليًا باسم',
|
||||
form: {
|
||||
schoolName: {
|
||||
title: 'اسم مدرستك',
|
||||
placeholder: 'أدخل الاسم الرسمي الكامل لمدرستك',
|
||||
},
|
||||
schoolRole: {
|
||||
title: 'دورك في المدرسة',
|
||||
option: {
|
||||
student: 'طالب',
|
||||
teacher: 'معلم',
|
||||
administrator: 'مسؤول المدرسة',
|
||||
},
|
||||
},
|
||||
terms: {
|
||||
title: 'الشروط والاتفاقيات',
|
||||
desc: {
|
||||
front: 'المعلومات الخاصة بك واستخدام حالة التحقق التعليمي تخضع لـ',
|
||||
and: 'و',
|
||||
end: '. من خلال الإرسال:',
|
||||
termsOfService: 'شروط الخدمة',
|
||||
privacyPolicy: 'سياسة الخصوصية',
|
||||
},
|
||||
option: {
|
||||
age: 'أؤكد أن عمري 18 عامًا على الأقل',
|
||||
inSchool: 'أؤكد أنني مسجل أو موظف في المؤسسة المقدمة. قد تطلب Dify إثبات التسجيل/التوظيف. إذا قدمت معلومات خاطئة حول أهليتي، فأوافق على دفع أي رسوم تم التنازل عنها مبدئيًا بناءً على حالة التعليم الخاصة بي.',
|
||||
},
|
||||
},
|
||||
},
|
||||
submit: 'إرسال',
|
||||
submitError: 'فشل إرسال النموذج. يرجى المحاولة مرة أخرى لاحقًا.',
|
||||
learn: 'تعرف على كيفية التحقق من التعليم',
|
||||
successTitle: 'لقد حصلت على التحقق التعليمي من Dify',
|
||||
successContent: 'لقد أصدرنا كوبون خصم 100٪ لخطة Dify Professional لحسابك. الكوبون ساري لمدة عام واحد، يرجى استخدامه خلال فترة الصلاحية.',
|
||||
rejectTitle: 'تم رفض التحقق التعليمي الخاص بك في Dify',
|
||||
rejectContent: 'لسوء الحظ، أنت غير مؤهل للحصول على حالة التحقق التعليمي وبالتالي لا يمكنك الحصول على كوبون حصري 100٪ لخطة Dify Professional إذا كنت تستخدم عنوان البريد الإلكتروني هذا.',
|
||||
emailLabel: 'بريدك الإلكتروني الحالي',
|
||||
notice: {
|
||||
dateFormat: 'MM/DD/YYYY',
|
||||
expired: {
|
||||
title: 'انتهت حالة التعليم الخاصة بك',
|
||||
summary: {
|
||||
line1: 'لا يزال بإمكانك الوصول إلى Dify واستخدامه. ',
|
||||
line2: 'ومع ذلك، لم تعد مؤهلاً للحصول على كوبونات خصم التعليم الجديدة.',
|
||||
},
|
||||
},
|
||||
isAboutToExpire: {
|
||||
title: 'ستنتهي حالة التعليم الخاصة بك في {{date}}',
|
||||
summary: 'لا تقلق - لن يؤثر هذا على اشتراكك الحالي، لكنك لن تحصل على خضم التعليم عند تجديده ما لم تتحقق من حالتك مرة أخرى.',
|
||||
},
|
||||
stillInEducation: {
|
||||
title: 'هل ما زلت في التعليم؟',
|
||||
expired: 'تحقق مرة أخرى الآن للحصول على كوبون جديد للعام الدراسي القادم. سنضيفه إلى حسابك ويمكنك استخدامه للترقية التالية.',
|
||||
isAboutToExpire: 'تحقق مرة أخرى الآن للحصول على كوبون جديد للعام الدراسي القادم. سيتم حفظه في حسابك وجاهز للاستخدام في تجديدك التالي.',
|
||||
},
|
||||
alreadyGraduated: {
|
||||
title: 'تخرجت بالفعل؟',
|
||||
expired: 'لا تتردد في الترقية في أي وقت للحصول على الوصول الكامل إلى الميزات المدفوعة.',
|
||||
isAboutToExpire: 'سيظل اشتراكك الحالي نشطًا. عندما ينتهي، سيتم نقلك إلى خطة Sandbox، أو يمكنك الترقية في أي وقت لاستعادة الوصول الكامل إلى الميزات المدفوعة.',
|
||||
},
|
||||
action: {
|
||||
dismiss: 'تجاهل',
|
||||
upgrade: 'ترقية',
|
||||
reVerify: 'إعادة التحقق',
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
44
web/i18n/ar-TN/explore.ts
Normal file
44
web/i18n/ar-TN/explore.ts
Normal file
@@ -0,0 +1,44 @@
|
||||
const translation = {
|
||||
title: 'استكشاف',
|
||||
sidebar: {
|
||||
discovery: 'اكتشاف',
|
||||
chat: 'دردشة',
|
||||
workspace: 'مساحة العمل',
|
||||
action: {
|
||||
pin: 'تثبيت',
|
||||
unpin: 'إلغاء التثبيت',
|
||||
rename: 'إعادة تسمية',
|
||||
delete: 'حذف',
|
||||
},
|
||||
delete: {
|
||||
title: 'حذف التطبيق',
|
||||
content: 'هل أنت متأكد أنك تريد حذف هذا التطبيق؟',
|
||||
},
|
||||
},
|
||||
apps: {
|
||||
title: 'استكشاف التطبيقات',
|
||||
description: 'استخدم تطبيقات القوالب هذه فورًا أو خصص تطبيقاتك الخاصة بناءً على القوالب.',
|
||||
allCategories: 'موصى به',
|
||||
},
|
||||
appCard: {
|
||||
addToWorkspace: 'إضافة إلى مساحة العمل',
|
||||
customize: 'تخصيص',
|
||||
},
|
||||
appCustomize: {
|
||||
title: 'إنشاء تطبيق من {{name}}',
|
||||
subTitle: 'أيقونة التطبيق واسمه',
|
||||
nameRequired: 'اسم التطبيق مطلوب',
|
||||
},
|
||||
category: {
|
||||
Agent: 'وكيل',
|
||||
Assistant: 'مساعد',
|
||||
Writing: 'كتابة',
|
||||
Translate: 'ترجمة',
|
||||
Programming: 'برمجة',
|
||||
HR: 'الموارد البشرية',
|
||||
Workflow: 'سير العمل',
|
||||
Entertainment: 'ترفيه',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
8
web/i18n/ar-TN/layout.ts
Normal file
8
web/i18n/ar-TN/layout.ts
Normal file
@@ -0,0 +1,8 @@
|
||||
const translation = {
|
||||
sidebar: {
|
||||
expandSidebar: 'توسيع الشريط الجانبي',
|
||||
collapseSidebar: 'طي الشريط الجانبي',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
126
web/i18n/ar-TN/login.ts
Normal file
126
web/i18n/ar-TN/login.ts
Normal file
@@ -0,0 +1,126 @@
|
||||
const translation = {
|
||||
pageTitle: 'تسجيل الدخول إلى Dify',
|
||||
pageTitleForE: 'مرحبًا، لنبدأ!',
|
||||
welcome: '👋 مرحبًا! يرجى تسجيل الدخول للبدء.',
|
||||
email: 'عنوان البريد الإلكتروني',
|
||||
emailPlaceholder: 'بريدك الإلكتروني',
|
||||
password: 'كلمة المرور',
|
||||
passwordPlaceholder: 'كلمة المرور الخاصة بك',
|
||||
name: 'اسم المستخدم',
|
||||
namePlaceholder: 'اسم المستخدم الخاص بك',
|
||||
forget: 'نسيت كلمة المرور؟',
|
||||
signBtn: 'تسجيل الدخول',
|
||||
continueWithCode: 'المتابعة مع الرمز',
|
||||
sendVerificationCode: 'إرسال رمز التحقق',
|
||||
usePassword: 'استخدام كلمة المرور',
|
||||
useVerificationCode: 'استخدام رمز التحقق',
|
||||
or: 'أو',
|
||||
installBtn: 'إعداد',
|
||||
setAdminAccount: 'إعداد حساب مسؤول',
|
||||
setAdminAccountDesc: 'أقصى امتيازات لحساب المسؤول، والتي يمكن استخدامها لإنشاء التطبيقات وإدارة مزودي LLM، إلخ.',
|
||||
createAndSignIn: 'إنشاء وتسجيل الدخول',
|
||||
oneMoreStep: 'خطوة واحدة أخرى',
|
||||
createSample: 'بناءً على هذه المعلومات، سنقوم بإنشاء تطبيق تجريبي لك',
|
||||
invitationCode: 'رمز الدعوة',
|
||||
invitationCodePlaceholder: 'رمز الدعوة الخاص بك',
|
||||
interfaceLanguage: 'لغة الواجهة',
|
||||
timezone: 'المنطقة الزمنية',
|
||||
go: 'الذهاب إلى Dify',
|
||||
sendUsMail: 'أرسل لنا مقدمتك عبر البريد الإلكتروني، وسنتعامل مع طلب الدعوة.',
|
||||
acceptPP: 'لقد قرأت وأوافق على سياسة الخصوصية',
|
||||
reset: 'يرجى تشغيل الأمر التالي لإعادة تعيين كلمة المرور الخاصة بك',
|
||||
withGitHub: 'المتابعة مع GitHub',
|
||||
withGoogle: 'المتابعة مع Google',
|
||||
withSSO: 'المتابعة مع SSO',
|
||||
rightTitle: 'أطلق العنان للإمكانات الكاملة لـ LLM',
|
||||
rightDesc: 'بناء تطبيقات الذكاء الاصطناعي الجذابة بصريًا والقابلة للتشغيل والقابلة للتحسين بسهولة.',
|
||||
tos: 'شروط الخدمة',
|
||||
pp: 'سياسة الخصوصية',
|
||||
tosDesc: 'بالتسجيل، فإنك توافق على',
|
||||
goToInit: 'إذا لم تقم بتهيئة الحساب، يرجى الانتقال إلى صفحة التهيئة',
|
||||
dontHave: 'ليس لديك؟',
|
||||
invalidInvitationCode: 'رمز دعوة غير صالح',
|
||||
accountAlreadyInited: 'تمت تهيئة الحساب بالفعل',
|
||||
forgotPassword: 'نسيت كلمة المرور؟',
|
||||
resetLinkSent: 'تم إرسال رابط إعادة التعيين',
|
||||
sendResetLink: 'إرسال رابط إعادة التعيين',
|
||||
backToSignIn: 'العودة لتسجيل الدخول',
|
||||
forgotPasswordDesc: 'يرجى إدخال عنوان بريدك الإلكتروني لإعادة تعيين كلمة المرور الخاصة بك. سنرسل لك بريدًا إلكترونيًا يحتوي على تعليمات حول كيفية إعادة تعيين كلمة المرور الخاصة بك.',
|
||||
checkEmailForResetLink: 'يرجى التحقق من بريدك الإلكتروني للحصول على رابط لإعادة تعيين كلمة المرور الخاصة بك. إذا لم يظهر في غضون بضع دقائق، فتأكد من التحقق من مجلد الرسائل غير المرغوب فيها.',
|
||||
passwordChanged: 'سجل الدخول الآن',
|
||||
changePassword: 'تعيين كلمة مرور',
|
||||
changePasswordTip: 'يرجى إدخال كلمة مرور جديدة لحسابك',
|
||||
changePasswordBtn: 'تعيين كلمة مرور',
|
||||
invalidToken: 'رمز غير صالح أو منتهي الصلاحية',
|
||||
confirmPassword: 'تأكيد كلمة المرور',
|
||||
confirmPasswordPlaceholder: 'تأكيد كلمة المرور الجديدة',
|
||||
passwordChangedTip: 'تم تغيير كلمة المرور الخاصة بك بنجاح',
|
||||
error: {
|
||||
emailEmpty: 'عنوان البريد الإلكتروني مطلوب',
|
||||
emailInValid: 'يرجى إدخال عنوان بريد إلكتروني صالح',
|
||||
nameEmpty: 'الاسم مطلوب',
|
||||
passwordEmpty: 'كلمة المرور مطلوبة',
|
||||
passwordLengthInValid: 'يجب أن تتكون كلمة المرور من 8 أحرف على الأقل',
|
||||
passwordInvalid: 'يجب أن تحتوي كلمة المرور على أحرف وأرقام، ويجب أن يكون الطول أكبر من 8',
|
||||
registrationNotAllowed: 'الحساب غير موجود. يرجى الاتصال بمسؤول النظام للتسجيل.',
|
||||
invalidEmailOrPassword: 'بريد إلكتروني أو كلمة مرور غير صالحة.',
|
||||
},
|
||||
license: {
|
||||
tip: 'قبل بدء تشغيل Dify Community Edition، اقرأ GitHub',
|
||||
link: 'ترخيص مفتوح المصدر',
|
||||
},
|
||||
join: 'انضم ',
|
||||
joinTipStart: 'يدعوك للانضمام إلى ',
|
||||
joinTipEnd: ' فريق على Dify',
|
||||
invalid: 'انتهت صلاحية الرابط',
|
||||
explore: 'استكشاف Dify',
|
||||
activatedTipStart: 'لقد انضممت إلى',
|
||||
activatedTipEnd: 'فريق',
|
||||
activated: 'سجل الدخول الآن',
|
||||
adminInitPassword: 'كلمة مرور تهيئة المسؤول',
|
||||
validate: 'تحقق',
|
||||
checkCode: {
|
||||
checkYourEmail: 'تحقق من بريدك الإلكتروني',
|
||||
tipsPrefix: 'نرسل رمز التحقق إلى ',
|
||||
validTime: 'ضع في اعتبارك أن الرمز صالح لمدة 5 دقائق',
|
||||
verificationCode: 'رمز التحقق',
|
||||
verificationCodePlaceholder: 'أدخل رمزًا مكونًا من 6 أرقام',
|
||||
verify: 'تحقق',
|
||||
didNotReceiveCode: 'لم تتلق الرمز؟ ',
|
||||
resend: 'إعادة الإرسال',
|
||||
useAnotherMethod: 'استخدام طريقة أخرى',
|
||||
emptyCode: 'الرمز مطلوب',
|
||||
invalidCode: 'رمز غير صالح',
|
||||
},
|
||||
resetPassword: 'إعادة تعيين كلمة المرور',
|
||||
resetPasswordDesc: 'اكتب البريد الإلكتروني الذي استخدمته للتسجيل في Dify وسنرسل لك بريدًا إلكترونيًا لإعادة تعيين كلمة المرور.',
|
||||
backToLogin: 'العودة لتسجيل الدخول',
|
||||
setYourAccount: 'إعداد حسابك',
|
||||
enterYourName: 'يرجى إدخال اسم المستخدم الخاص بك',
|
||||
back: 'عودة',
|
||||
noLoginMethod: 'طريقة المصادقة غير مكونة',
|
||||
noLoginMethodTip: 'يرجى الاتصال بمسؤول النظام لإضافة طريقة مصادقة.',
|
||||
licenseExpired: 'انتهت صلاحية الترخيص',
|
||||
licenseExpiredTip: 'انتهت صلاحية ترخيص Dify Enterprise لمساحة العمل الخاصة بك. يرجى الاتصال بالمسؤول لمواصلة استخدام Dify.',
|
||||
licenseLost: 'فقدان الترخيص',
|
||||
licenseLostTip: 'فشل الاتصال بخادم ترخيص Dify. يرجى الاتصال بالمسؤول لمواصلة استخدام Dify.',
|
||||
licenseInactive: 'الترخيص غير نشط',
|
||||
licenseInactiveTip: 'ترخيص Dify Enterprise لمساحة العمل الخاصة بك غير نشط. يرجى الاتصال بالمسؤول لمواصلة استخدام Dify.',
|
||||
webapp: {
|
||||
login: 'تسجيل الدخول',
|
||||
noLoginMethod: 'طريقة المصادقة غير مكونة لتطبيق الويب',
|
||||
noLoginMethodTip: 'يرجى الاتصال بمسؤول النظام لإضافة طريقة مصادقة.',
|
||||
disabled: 'مصادقة Webapp معطلة. يرجى الاتصال بمسؤول النظام لتمكينها. يمكنك محاولة استخدام التطبيق مباشرة.',
|
||||
},
|
||||
signup: {
|
||||
noAccount: 'ليس لديك حساب؟ ',
|
||||
signUp: 'اشتراك',
|
||||
createAccount: 'إنشاء حسابك',
|
||||
welcome: '👋 مرحبًا! يرجى ملء التفاصيل للبدء.',
|
||||
verifyMail: 'المتابعة مع رمز التحقق',
|
||||
haveAccount: 'لديك حساب بالفعل؟ ',
|
||||
signIn: 'تسجيل الدخول',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
27
web/i18n/ar-TN/oauth.ts
Normal file
27
web/i18n/ar-TN/oauth.ts
Normal file
@@ -0,0 +1,27 @@
|
||||
const translation = {
|
||||
tips: {
|
||||
loggedIn: 'يريد هذا التطبيق الوصول إلى المعلومات التالية من حساب Dify Cloud الخاص بك.',
|
||||
notLoggedIn: 'يريد هذا التطبيق الوصول إلى حساب Dify Cloud الخاص بك',
|
||||
needLogin: 'يرجى تسجيل الدخول للتفويض',
|
||||
common: 'نحن نحترم خصوصيتك وسنستخدم هذه المعلومات فقط لتحسين تجربتك مع أدوات المطورين لدينا.',
|
||||
},
|
||||
connect: 'الاتصال بـ',
|
||||
continue: 'متابعة',
|
||||
switchAccount: 'تبديل الحساب',
|
||||
login: 'تسجيل الدخول',
|
||||
scopes: {
|
||||
name: 'الاسم',
|
||||
email: 'البريد الإلكتروني',
|
||||
avatar: 'الصورة الرمزية',
|
||||
languagePreference: 'تفضيل اللغة',
|
||||
timezone: 'المنطقة الزمنية',
|
||||
},
|
||||
error: {
|
||||
invalidParams: 'معلمات غير صالحة',
|
||||
authorizeFailed: 'فشل التفويض',
|
||||
authAppInfoFetchFailed: 'فشل جلب معلومات التطبيق للتفويض',
|
||||
},
|
||||
unknownApp: 'تطبيق غير معروف',
|
||||
}
|
||||
|
||||
export default translation
|
||||
40
web/i18n/ar-TN/pipeline.ts
Normal file
40
web/i18n/ar-TN/pipeline.ts
Normal file
@@ -0,0 +1,40 @@
|
||||
const translation = {
|
||||
common: {
|
||||
goToAddDocuments: 'الذهاب لإضافة مستندات',
|
||||
publishAs: 'النشر كقالب سير عمل مخصص',
|
||||
confirmPublish: 'تأكيد النشر',
|
||||
confirmPublishContent: 'بعد نشر سير عمل المعرفة بنجاح، لا يمكن تعديل هيكل التقطيع لقاعدة المعرفة هذه. هل أنت متأكد أنك تريد نشرها؟',
|
||||
publishAsPipeline: {
|
||||
name: 'اسم وأيقونة سير العمل',
|
||||
namePlaceholder: 'يرجى إدخال اسم سير عمل المعرفة هذا. (مطلوب) ',
|
||||
description: 'وصف المعرفة',
|
||||
descriptionPlaceholder: 'يرجى إدخال وصف سير عمل المعرفة هذا. (اختياري) ',
|
||||
},
|
||||
testRun: 'تشغيل اختباري',
|
||||
preparingDataSource: 'جارٍ إعداد مصدر البيانات',
|
||||
reRun: 'إعادة التشغيل',
|
||||
processing: 'جارٍ المعالجة',
|
||||
},
|
||||
inputField: {
|
||||
create: 'إنشاء حقل إدخال المستخدم',
|
||||
manage: 'إدارة',
|
||||
},
|
||||
publishToast: {
|
||||
title: 'لم يتم نشر سير العمل هذا بعد',
|
||||
desc: 'عندما لا يتم نشر سير العمل، يمكنك تعديل هيكل التقطيع في عقدة قاعدة المعرفة، وسيتم حفظ تنظيم السير العمل والتغييرات تلقائيًا كمسودة.',
|
||||
},
|
||||
result: {
|
||||
resultPreview: {
|
||||
loading: 'جاري المعالجة... ارجو الانتظار',
|
||||
error: 'حدث خطأ أثناء التنفيذ',
|
||||
viewDetails: 'عرض التفاصيل',
|
||||
footerTip: 'في وضع التشغيل الاختباري، يمكن معاينة ما يصل إلى {{count}} قطعة',
|
||||
},
|
||||
},
|
||||
ragToolSuggestions: {
|
||||
title: 'اقتراحات لـ RAG',
|
||||
noRecommendationPlugins: 'لا توجد إضافات موصى بها، ابحث عن المزيد في <CustomLink>السوق</CustomLink>',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
26
web/i18n/ar-TN/plugin-tags.ts
Normal file
26
web/i18n/ar-TN/plugin-tags.ts
Normal file
@@ -0,0 +1,26 @@
|
||||
const translation = {
|
||||
allTags: 'كل العلامات',
|
||||
searchTags: 'البحث في العلامات',
|
||||
tags: {
|
||||
agent: 'وكيل',
|
||||
rag: 'RAG',
|
||||
search: 'بحث',
|
||||
image: 'صورة',
|
||||
videos: 'فيديوهات',
|
||||
weather: 'طقس',
|
||||
finance: 'تمويل',
|
||||
design: 'تصميم',
|
||||
travel: 'سفر',
|
||||
social: 'اجتماعي',
|
||||
news: 'أخبار',
|
||||
medical: 'طبي',
|
||||
productivity: 'إنتاجية',
|
||||
education: 'تعليم',
|
||||
business: 'أعمال',
|
||||
entertainment: 'ترفيه',
|
||||
utilities: 'أدوات مساعدة',
|
||||
other: 'أخرى',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
186
web/i18n/ar-TN/plugin-trigger.ts
Normal file
186
web/i18n/ar-TN/plugin-trigger.ts
Normal file
@@ -0,0 +1,186 @@
|
||||
const translation = {
|
||||
subscription: {
|
||||
title: 'الاشتراكات',
|
||||
listNum: '{{num}} اشتراكات',
|
||||
empty: {
|
||||
title: 'لا توجد اشتراكات',
|
||||
button: 'اشتراك جديد',
|
||||
},
|
||||
createButton: {
|
||||
oauth: 'اشتراك جديد باستخدام OAuth',
|
||||
apiKey: 'اشتراك جديد باستخدام مفتاح API',
|
||||
manual: 'الصق عنوان URL لإنشاء اشتراك جديد',
|
||||
},
|
||||
createSuccess: 'تم إنشاء الاشتراك بنجاح',
|
||||
createFailed: 'فشل إنشاء الاشتراك',
|
||||
maxCount: 'الحد الأقصى {{num}} اشتراكات',
|
||||
selectPlaceholder: 'حدد اشتراكًا',
|
||||
noSubscriptionSelected: 'لم يتم تحديد أي اشتراك',
|
||||
subscriptionRemoved: 'تمت إزالة الاشتراك',
|
||||
list: {
|
||||
title: 'الاشتراكات',
|
||||
addButton: 'إضافة',
|
||||
tip: 'استلام الأحداث عبر الاشتراك',
|
||||
item: {
|
||||
enabled: 'ممكن',
|
||||
disabled: 'معطل',
|
||||
credentialType: {
|
||||
api_key: 'مفتاح API',
|
||||
oauth2: 'OAuth',
|
||||
unauthorized: 'يدوي',
|
||||
},
|
||||
actions: {
|
||||
delete: 'حذف',
|
||||
deleteConfirm: {
|
||||
title: 'حذف {{name}}؟',
|
||||
success: 'تم حذف الاشتراك {{name}} بنجاح',
|
||||
error: 'فشل حذف الاشتراك {{name}}',
|
||||
content: 'بمجرد الحذف، لا يمكن استعادة هذا الاشتراك. يرجى التأكيد.',
|
||||
contentWithApps: 'الاشتراك الحالي مشار إليه بواسطة {{count}} تطبيقات. سيؤدي حذفه إلى توقف التطبيقات المكونة عن تلقي أحداث الاشتراك.',
|
||||
confirm: 'تأكيد الحذف',
|
||||
cancel: 'إلغاء',
|
||||
confirmInputWarning: 'يرجى إدخال الاسم الصحيح للتأكيد.',
|
||||
confirmInputPlaceholder: 'أدخل "{{name}}" للتأكيد.',
|
||||
confirmInputTip: 'يرجى إدخال "{{name}}" للتأكيد.',
|
||||
},
|
||||
},
|
||||
status: {
|
||||
active: 'نشط',
|
||||
inactive: 'غير نشط',
|
||||
},
|
||||
usedByNum: 'تستخدم من قبل {{num}} سير عمل',
|
||||
noUsed: 'لا يوجد سير عمل مستخدم',
|
||||
},
|
||||
},
|
||||
addType: {
|
||||
title: 'إضافة اشتراك',
|
||||
description: 'اختر الطريقة التي تريد بها إنشاء اشتراك المشغل الخاص بك',
|
||||
options: {
|
||||
apikey: {
|
||||
title: 'إنشاء باستخدام مفتاح API',
|
||||
description: 'إنشاء اشتراك تلقائيًا باستخدام بيانات اعتماد API',
|
||||
},
|
||||
oauth: {
|
||||
title: 'إنشاء باستخدام OAuth',
|
||||
description: 'التفويض مع منصة تابعة لجهة خارجية لإنشاء اشتراك',
|
||||
clientSettings: 'إعدادات عميل OAuth',
|
||||
clientTitle: 'عميل OAuth',
|
||||
default: 'افتراضي',
|
||||
custom: 'مخصص',
|
||||
},
|
||||
manual: {
|
||||
title: 'الإعداد اليدوي',
|
||||
description: 'الصق عنوان URL لإنشاء اشتراك جديد',
|
||||
tip: 'تكوين عنوان URL على منصة تابعة لجهة خارجية يدويًا',
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
modal: {
|
||||
steps: {
|
||||
verify: 'تحقق',
|
||||
configuration: 'تكوين',
|
||||
},
|
||||
common: {
|
||||
cancel: 'إلغاء',
|
||||
back: 'رجوع',
|
||||
next: 'التالي',
|
||||
create: 'إنشاء',
|
||||
verify: 'تحقق',
|
||||
authorize: 'تفويض',
|
||||
creating: 'جارٍ الإنشاء...',
|
||||
verifying: 'جارٍ التحقق...',
|
||||
authorizing: 'جارٍ التفويض...',
|
||||
},
|
||||
oauthRedirectInfo: 'نظرًا لعدم العثور على أسرار عميل النظام لمزود الأداة هذا، فإن إعداده يدويًا مطلوب، بالنسبة لـ redirect_uri، يرجى الاستخدام',
|
||||
apiKey: {
|
||||
title: 'إنشاء باستخدام مفتاح API',
|
||||
verify: {
|
||||
title: 'التحقق من بيانات الاعتماد',
|
||||
description: 'يرجى تقديم بيانات اعتماد واجهة برمجة التطبيقات الخاصة بك للتحقق من الوصول',
|
||||
error: 'فشل التحقق من بيانات الاعتماد. يرجى التحقق من مفتاح API الخاص بك.',
|
||||
success: 'تم التحقق من بيانات الاعتماد بنجاح',
|
||||
},
|
||||
configuration: {
|
||||
title: 'تكوين الاشتراك',
|
||||
description: 'إعداد معلمات الاشتراك الخاصة بك',
|
||||
},
|
||||
},
|
||||
oauth: {
|
||||
title: 'إنشاء باستخدام OAuth',
|
||||
authorization: {
|
||||
title: 'تفويض OAuth',
|
||||
description: 'تفويض Dify للوصول إلى حسابك',
|
||||
redirectUrl: 'عنوان URL لإعادة التوجيه',
|
||||
redirectUrlHelp: 'استخدم عنوان URL هذا في تكوين تطبيق OAuth الخاص بك',
|
||||
authorizeButton: 'تفويض مع {{provider}}',
|
||||
waitingAuth: 'في انتظار التفويض...',
|
||||
authSuccess: 'تم التفويض بنجاح',
|
||||
authFailed: 'فشل الحصول على معلومات تفويض OAuth',
|
||||
waitingJump: 'تم التفويض، في انتظار الانتقال',
|
||||
},
|
||||
configuration: {
|
||||
title: 'تكوين الاشتراك',
|
||||
description: 'إعداد معلمات الاشتراك الخاصة بك بعد التفويض',
|
||||
success: 'تم تكوين OAuth بنجاح',
|
||||
failed: 'فشل تكوين OAuth',
|
||||
},
|
||||
remove: {
|
||||
success: 'تمت إزالة OAuth بنجاح',
|
||||
failed: 'فشل إزالة OAuth',
|
||||
},
|
||||
save: {
|
||||
success: 'تم حفظ تكوين OAuth بنجاح',
|
||||
},
|
||||
},
|
||||
manual: {
|
||||
title: 'الإعداد اليدوي',
|
||||
description: 'تكوين اشتراك web hook الخاص بك يدويًا',
|
||||
logs: {
|
||||
title: 'سجلات الطلب',
|
||||
request: 'طلب',
|
||||
loading: 'في انتظار الطلب من {{pluginName}}...',
|
||||
},
|
||||
},
|
||||
form: {
|
||||
subscriptionName: {
|
||||
label: 'اسم الاشتراك',
|
||||
placeholder: 'أدخل اسم الاشتراك',
|
||||
required: 'اسم الاشتراك مطلوب',
|
||||
},
|
||||
callbackUrl: {
|
||||
label: 'عنوان URL لرد الاتصال',
|
||||
description: 'سيتلقى عنوان URL هذا أحداث web hook',
|
||||
tooltip: 'توفير نقطة نهاية يمكن الوصول إليها بشكل عام يمكنها استلام طلبات رد الاتصال من مزود المشغل.',
|
||||
placeholder: 'جارٍ الإنشاء...',
|
||||
privateAddressWarning: 'يبدو أن عنوان URL هذا هو عنوان داخلي، مما قد يتسبب في فشل طلبات web hook. يمكنك تغيير TRIGGER_URL إلى عنوان عام.',
|
||||
},
|
||||
},
|
||||
errors: {
|
||||
createFailed: 'فشل إنشاء الاشتراك',
|
||||
verifyFailed: 'فشل التحقق من بيانات الاعتماد',
|
||||
authFailed: 'فشل التفويض',
|
||||
networkError: 'خطأ في الشبكة، يرجى المحاولة مرة أخرى',
|
||||
},
|
||||
},
|
||||
events: {
|
||||
title: 'الأحداث المتاحة',
|
||||
description: 'الأحداث التي يمكن لمكون المشغل الإضافي هذا الاشتراك فيها',
|
||||
empty: 'لا توجد أحداث متاحة',
|
||||
event: 'حدث',
|
||||
events: 'أحداث',
|
||||
actionNum: '{{num}} {{event}} متضمن',
|
||||
item: {
|
||||
parameters: '{{count}} معلمات',
|
||||
noParameters: 'لا توجد معلمات',
|
||||
},
|
||||
output: 'إخراج',
|
||||
},
|
||||
node: {
|
||||
status: {
|
||||
warning: 'قطع الاتصال',
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
325
web/i18n/ar-TN/plugin.ts
Normal file
325
web/i18n/ar-TN/plugin.ts
Normal file
@@ -0,0 +1,325 @@
|
||||
const translation = {
|
||||
metadata: {
|
||||
title: 'الإضافات',
|
||||
},
|
||||
category: {
|
||||
all: 'الكل',
|
||||
models: 'نماذج',
|
||||
tools: 'أدوات',
|
||||
agents: 'استراتيجيات الوكيل',
|
||||
extensions: 'ملحقات',
|
||||
triggers: 'مشغلات',
|
||||
bundles: 'حزم',
|
||||
datasources: 'مصادر البيانات',
|
||||
},
|
||||
categorySingle: {
|
||||
model: 'نموذج',
|
||||
tool: 'أداة',
|
||||
agent: 'استراتيجية الوكيل',
|
||||
extension: 'ملحق',
|
||||
trigger: 'مشغل',
|
||||
bundle: 'حزمة',
|
||||
datasource: 'مصدر بيانات',
|
||||
},
|
||||
search: 'بحث',
|
||||
allCategories: 'جميع الفئات',
|
||||
searchCategories: 'بحث في الفئات',
|
||||
searchPlugins: 'بحث في الإضافات',
|
||||
from: 'من',
|
||||
findMoreInMarketplace: 'ابحث عن المزيد في السوق',
|
||||
searchInMarketplace: 'بحث في السوق',
|
||||
fromMarketplace: 'من السوق',
|
||||
endpointsEnabled: 'تم تمكين {{num}} مجموعة من نقاط النهاية',
|
||||
searchTools: 'بحث في الأدوات...',
|
||||
installPlugin: 'تثبيت الإضافة',
|
||||
installFrom: 'تثبيت من',
|
||||
deprecated: 'مهمل',
|
||||
list: {
|
||||
noInstalled: 'لم يتم تثبيت أي إضافات',
|
||||
notFound: 'لم يتم العثور على أي إضافات',
|
||||
source: {
|
||||
marketplace: 'تثبيت من السوق',
|
||||
github: 'تثبيت من GitHub',
|
||||
local: 'تثبيت من ملف الحزمة المحلية',
|
||||
},
|
||||
},
|
||||
source: {
|
||||
marketplace: 'السوق',
|
||||
github: 'GitHub',
|
||||
local: 'ملف الحزمة المحلية',
|
||||
},
|
||||
detailPanel: {
|
||||
switchVersion: 'تبديل الإصدار',
|
||||
categoryTip: {
|
||||
marketplace: 'مثبت من السوق',
|
||||
github: 'مثبت من Github',
|
||||
local: 'إضافة محلية',
|
||||
debugging: 'تصحيح الإضافة',
|
||||
},
|
||||
operation: {
|
||||
install: 'تثبيت',
|
||||
detail: 'التفاصيل',
|
||||
update: 'تحديث',
|
||||
info: 'معلومات الإضافة',
|
||||
checkUpdate: 'التحقق من التحديث',
|
||||
viewDetail: 'عرض التفاصيل',
|
||||
remove: 'إزالة',
|
||||
back: 'رجوع',
|
||||
},
|
||||
actionNum: '{{num}} {{action}} متضمن',
|
||||
strategyNum: '{{num}} {{strategy}} متضمن',
|
||||
endpoints: 'نقاط النهاية',
|
||||
endpointsTip: 'توفر هذه الإضافة وظائف محددة عبر نقاط النهاية، ويمكنك تكوين مجموعات نقاط نهاية متعددة لمساحة العمل الحالية.',
|
||||
endpointsDocLink: 'عرض المستند',
|
||||
endpointsEmpty: 'انقر فوق الزر "+" لإضافة نقطة نهاية',
|
||||
endpointDisableTip: 'تعطيل نقطة النهاية',
|
||||
endpointDisableContent: 'هل ترغب في تعطيل {{name}}؟ ',
|
||||
endpointDeleteTip: 'إزالة نقطة النهاية',
|
||||
endpointDeleteContent: 'هل ترغب في إزالة {{name}}؟ ',
|
||||
endpointModalTitle: 'إعداد نقطة النهاية',
|
||||
endpointModalDesc: 'بمجرد التكوين، يمكن استخدام الميزات التي توفرها الإضافة عبر نقاط نهاية API.',
|
||||
serviceOk: 'الخدمة جيدة',
|
||||
disabled: 'معطل',
|
||||
modelNum: '{{num}} نماذج متضمنة',
|
||||
toolSelector: {
|
||||
title: 'إضافة أداة',
|
||||
toolSetting: 'إعدادات الأداة',
|
||||
toolLabel: 'أداة',
|
||||
descriptionLabel: 'وصف الأداة',
|
||||
descriptionPlaceholder: 'وصف موجز لغرض الأداة، على سبيل المثال، الحصول على درجة الحرارة لموقع معين.',
|
||||
placeholder: 'حدد أداة...',
|
||||
settings: 'إعدادات المستخدم',
|
||||
params: 'تكوين الاستنتاج',
|
||||
paramsTip1: 'يتحكم في معلمات استنتاج LLM.',
|
||||
paramsTip2: 'عند إيقاف تشغيل "تلقائي"، يتم استخدام القيمة الافتراضية.',
|
||||
auto: 'تلقائي',
|
||||
empty: 'انقر فوق الزر "+" لإضافة أدوات. يمكنك إضافة أدوات متعددة.',
|
||||
uninstalledTitle: 'الأداة غير مثبتة',
|
||||
uninstalledContent: 'تم تثبيت هذه الإضافة من المخزون المحلي / GitHub. يرجى الاستخدام بعد التثبيت.',
|
||||
uninstalledLink: 'إدارة في الإضافات',
|
||||
unsupportedTitle: 'إجراء غير مدعوم',
|
||||
unsupportedContent: 'إصدار الإضافة المثبت لا يوفر هذا الإجراء.',
|
||||
unsupportedContent2: 'انقر لتبديل الإصدار.',
|
||||
unsupportedMCPTool: 'لا يدعم إصدار إضافة استراتيجية الوكيل المحدد حاليًا أدوات MCP.',
|
||||
},
|
||||
configureApp: 'تكوين التطبيق',
|
||||
configureModel: 'تكوين النموذج',
|
||||
configureTool: 'تكوين الأداة',
|
||||
deprecation: {
|
||||
fullMessage: 'تم إهمال هذه الإضافة بسبب {{deprecatedReason}}، ولن يتم تحديثها بعد الآن. يرجى استخدام <CustomLink href=\'https://example.com/\'>{{-alternativePluginId}}</CustomLink> بدلاً من ذلك.',
|
||||
onlyReason: 'تم إهمال هذه الإضافة بسبب {{deprecatedReason}} ولن يتم تحديثها بعد الآن.',
|
||||
noReason: 'تم إهمال هذه الإضافة ولن يتم تحديثها بعد الآن.',
|
||||
reason: {
|
||||
businessAdjustments: 'تعديلات الأعمال',
|
||||
ownershipTransferred: 'نقل الملكية',
|
||||
noMaintainer: 'لا يوجد مشرف',
|
||||
},
|
||||
},
|
||||
},
|
||||
install: '{{num}} تثبيتات',
|
||||
installAction: 'تثبيت',
|
||||
debugInfo: {
|
||||
title: 'تصحيح الأخطاء',
|
||||
viewDocs: 'عرض المستندات',
|
||||
},
|
||||
privilege: {
|
||||
title: 'تفضيلات الإضافة',
|
||||
whoCanInstall: 'من يمكنه تثبيت وإدارة الإضافات؟',
|
||||
whoCanDebug: 'من يمكنه تصحيح الإضافات؟',
|
||||
everyone: 'الجميع',
|
||||
admins: 'المسؤولون',
|
||||
noone: 'لا أحد',
|
||||
},
|
||||
autoUpdate: {
|
||||
automaticUpdates: 'تحديثات تلقائية',
|
||||
updateTime: 'وقت التحديث',
|
||||
specifyPluginsToUpdate: 'تحديد الإضافات للتحديث',
|
||||
strategy: {
|
||||
disabled: {
|
||||
name: 'معطل',
|
||||
description: 'لن يتم تحديث الإضافات تلقائيًا',
|
||||
},
|
||||
fixOnly: {
|
||||
name: 'إصلاح فقط',
|
||||
description: 'التحديث التلقائي لإصدارات التصحيح فقط (على سبيل المثال، 1.0.1 → 1.0.2). لن تؤدي تغييرات الإصدار الثانوي إلى تشغيل التحديثات.',
|
||||
selectedDescription: 'التحديث التلقائي لإصدارات التصحيح فقط',
|
||||
},
|
||||
latest: {
|
||||
name: 'الأحدث',
|
||||
description: 'التحديث دائمًا إلى أحدث إصدار',
|
||||
selectedDescription: 'التحديث دائمًا إلى أحدث إصدار',
|
||||
},
|
||||
},
|
||||
updateTimeTitle: 'وقت التحديث',
|
||||
upgradeMode: {
|
||||
all: 'تحديث الكل',
|
||||
exclude: 'استبعاد المحدد',
|
||||
partial: 'المحدد فقط',
|
||||
},
|
||||
upgradeModePlaceholder: {
|
||||
exclude: 'لن يتم تحديث الإضافات المحددة تلقائيًا',
|
||||
partial: 'سيتم تحديث الإضافات المحددة فقط تلقائيًا. لم يتم تحديد أي إضافات حاليًا، لذلك لن يتم تحديث أي إضافات تلقائيًا.',
|
||||
},
|
||||
excludeUpdate: 'لن يتم تحديث الإضافات {{num}} التالية تلقائيًا',
|
||||
partialUPdate: 'سيتم تحديث الإضافات {{num}} التالية فقط تلقائيًا',
|
||||
operation: {
|
||||
clearAll: 'مسح الكل',
|
||||
select: 'تحديد الإضافات',
|
||||
},
|
||||
nextUpdateTime: 'التحديث التلقائي التالي: {{time}}',
|
||||
pluginDowngradeWarning: {
|
||||
title: 'خفض إصدار الإضافة',
|
||||
description: 'التحديث التلقائي ممكن حاليًا لهذه الإضافة. قد يؤدي خفض الإصدار إلى استبدال تغييراتك أثناء التحديث التلقائي التالي.',
|
||||
downgrade: 'خفض على أي حال',
|
||||
exclude: 'استبعاد من التحديث التلقائي',
|
||||
},
|
||||
noPluginPlaceholder: {
|
||||
noFound: 'لم يتم العثور على أي إضافات',
|
||||
noInstalled: 'لم يتم تثبيت أي إضافات',
|
||||
},
|
||||
updateSettings: 'إعدادات التحديث',
|
||||
changeTimezone: 'لتغيير المنطقة الزمنية، انتقل إلى <setTimezone>الإعدادات</setTimezone>',
|
||||
},
|
||||
pluginInfoModal: {
|
||||
title: 'معلومات الإضافة',
|
||||
repository: 'المستودع',
|
||||
release: 'الإصدار',
|
||||
packageName: 'الحزمة',
|
||||
},
|
||||
action: {
|
||||
checkForUpdates: 'التحقق من وجود تحديثات',
|
||||
pluginInfo: 'معلومات الإضافة',
|
||||
delete: 'إزالة الإضافة',
|
||||
deleteContentLeft: 'هل ترغب في إزالة ',
|
||||
deleteContentRight: ' الإضافة؟',
|
||||
usedInApps: 'يتم استخدام هذه الإضافة في {{num}} تطبيقات.',
|
||||
},
|
||||
installModal: {
|
||||
installPlugin: 'تثبيت الإضافة',
|
||||
installComplete: 'اكتمل التثبيت',
|
||||
installedSuccessfully: 'تم التثبيت بنجاح',
|
||||
installedSuccessfullyDesc: 'تم تثبيت الإضافة بنجاح.',
|
||||
uploadFailed: 'فشل التحميل',
|
||||
installFailed: 'فشل التثبيت',
|
||||
installFailedDesc: 'فشل تثبيت الإضافة.',
|
||||
install: 'تثبيت',
|
||||
installing: 'جارٍ التثبيت...',
|
||||
uploadingPackage: 'جارٍ تحميل {{packageName}}...',
|
||||
readyToInstall: 'على وشك تثبيت الإضافة التالية',
|
||||
readyToInstallPackage: 'على وشك تثبيت الإضافة التالية',
|
||||
readyToInstallPackages: 'على وشك تثبيت الإضافات {{num}} التالية',
|
||||
fromTrustSource: 'يرجى التأكد من تثبيت الإضافات فقط من <trustSource>مصدر موثوق</trustSource>.',
|
||||
dropPluginToInstall: 'أفلت حزمة الإضافة هنا للتثبيت',
|
||||
labels: {
|
||||
repository: 'المستودع',
|
||||
version: 'الإصدار',
|
||||
package: 'الحزمة',
|
||||
},
|
||||
close: 'إغلاق',
|
||||
cancel: 'إلغاء',
|
||||
back: 'رجوع',
|
||||
next: 'التالي',
|
||||
pluginLoadError: 'خطأ في تحميل الإضافة',
|
||||
pluginLoadErrorDesc: 'لن يتم تثبيت هذه الإضافة',
|
||||
installWarning: 'لا يسمح بتثبيت هذه الإضافة.',
|
||||
},
|
||||
installFromGitHub: {
|
||||
installPlugin: 'تثبيت الإضافة من GitHub',
|
||||
updatePlugin: 'تحديث الإضافة من GitHub',
|
||||
installedSuccessfully: 'تم التثبيت بنجاح',
|
||||
installFailed: 'فشل التثبيت',
|
||||
uploadFailed: 'فشل التحميل',
|
||||
gitHubRepo: 'مستودع GitHub',
|
||||
selectVersion: 'حدد الإصدار',
|
||||
selectVersionPlaceholder: 'يرجى تحديد إصدار',
|
||||
installNote: 'يرجى التأكد من تثبيت الإضافات فقط من مصدر موثوق.',
|
||||
selectPackage: 'حدد الحزمة',
|
||||
selectPackagePlaceholder: 'يرجى تحديد حزمة',
|
||||
},
|
||||
upgrade: {
|
||||
title: 'تثبيت الإضافة',
|
||||
successfulTitle: 'تم التثبيت بنجاح',
|
||||
description: 'على وشك تثبيت الإضافة التالية',
|
||||
usedInApps: 'تستخدم في {{num}} تطبيقات',
|
||||
upgrade: 'تثبيت',
|
||||
upgrading: 'جارٍ التثبيت...',
|
||||
close: 'إغلاق',
|
||||
},
|
||||
error: {
|
||||
inValidGitHubUrl: 'عنوان URL لـ GitHub غير صالح. يرجى إدخال عنوان URL صالح بالتنسيق: https://github.com/owner/repo',
|
||||
fetchReleasesError: 'غير قادر على استرجاع الإصدارات. يرجى المحاولة مرة أخرى لاحقًا.',
|
||||
noReleasesFound: 'لم يتم العثور على إصدارات. يرجى التحقق من مستودع GitHub أو عنوان URL المدخل.',
|
||||
},
|
||||
marketplace: {
|
||||
empower: 'تمكين تطوير الذكاء الاصطناعي الخاص بك',
|
||||
discover: 'اكتشف',
|
||||
and: 'و',
|
||||
difyMarketplace: 'سوق Dify',
|
||||
moreFrom: 'المزيد من السوق',
|
||||
noPluginFound: 'لم يتم العثور على إضافة',
|
||||
pluginsResult: '{{num}} نتائج',
|
||||
sortBy: 'فرز حسب',
|
||||
sortOption: {
|
||||
mostPopular: 'الأكثر شيوعًا',
|
||||
recentlyUpdated: 'تم التحديث مؤخرًا',
|
||||
newlyReleased: 'صدر حديثًا',
|
||||
firstReleased: 'صدر لأول مرة',
|
||||
},
|
||||
viewMore: 'عرض المزيد',
|
||||
verifiedTip: 'تم التحقق بواسطة Dify',
|
||||
partnerTip: 'تم التحقق بواسطة شريك Dify',
|
||||
},
|
||||
task: {
|
||||
installing: 'تثبيت {{installingLength}} إضافات، 0 تم.',
|
||||
installingWithSuccess: 'تثبيت {{installingLength}} إضافات، {{successLength}} نجاح.',
|
||||
installingWithError: 'تثبيت {{installingLength}} إضافات، {{successLength}} نجاح، {{errorLength}} فشل',
|
||||
installError: '{{errorLength}} إضافات فشل تثبيتها، انقر للعرض',
|
||||
installedError: '{{errorLength}} إضافات فشل تثبيتها',
|
||||
clearAll: 'مسح الكل',
|
||||
installSuccess: 'تم تثبيت {{successLength}} من الإضافات بنجاح',
|
||||
installed: 'مثبت',
|
||||
runningPlugins: 'تثبيت الإضافات',
|
||||
successPlugins: 'تم تثبيت الإضافات بنجاح',
|
||||
errorPlugins: 'فشل في تثبيت الإضافات',
|
||||
},
|
||||
requestAPlugin: 'طلب إضافة',
|
||||
publishPlugins: 'نشر الإضافات',
|
||||
difyVersionNotCompatible: 'إصدار Dify الحالي غير متوافق مع هذه الإضافة، يرجى الترقية إلى الحد الأدنى للإصدار المطلوب: {{minimalDifyVersion}}',
|
||||
auth: {
|
||||
default: 'افتراضي',
|
||||
custom: 'مخصص',
|
||||
setDefault: 'تعيين كافتراضي',
|
||||
useOAuth: 'استخدام OAuth',
|
||||
useOAuthAuth: 'استخدام تفويض OAuth',
|
||||
addOAuth: 'إضافة OAuth',
|
||||
setupOAuth: 'إعداد عميل OAuth',
|
||||
useApi: 'استخدام مفتاح API',
|
||||
addApi: 'إضافة مفتاح API',
|
||||
useApiAuth: 'تكوين تفويض مفتاح API',
|
||||
useApiAuthDesc: 'بعد تكوين بيانات الاعتماد، يمكن لجميع الأعضاء داخل مساحة العمل استخدام هذه الأداة عند تنظيم التطبيقات.',
|
||||
oauthClientSettings: 'إعدادات عميل OAuth',
|
||||
saveOnly: 'حفظ فقط',
|
||||
saveAndAuth: 'حفظ وتفويض',
|
||||
authorization: 'تفويض',
|
||||
authorizations: 'تفويضات',
|
||||
authorizationName: 'اسم التفويض',
|
||||
workspaceDefault: 'افتراضي مساحة العمل',
|
||||
authRemoved: 'تمت إزالة التفويض',
|
||||
clientInfo: 'نظرًا لعدم العثور على أسرار عميل النظام لمزود الأداة هذا، فإن إعداده يدويًا مطلوب، بالنسبة لـ redirect_uri، يرجى الاستخدام',
|
||||
oauthClient: 'عميل OAuth',
|
||||
credentialUnavailable: 'بيانات الاعتماد غير متوفرة حاليًا. يرجى الاتصال بالمسؤول.',
|
||||
credentialUnavailableInButton: 'بيانات الاعتماد غير متوفرة',
|
||||
customCredentialUnavailable: 'بيانات الاعتماد المخصصة غير متوفرة حاليًا',
|
||||
unavailable: 'غير متاح',
|
||||
connectedWorkspace: 'مساحة العمل المتصلة',
|
||||
emptyAuth: 'يرجى تكوين المصادقة',
|
||||
},
|
||||
readmeInfo: {
|
||||
title: 'الملف التمهيدي',
|
||||
needHelpCheckReadme: 'تحتاج للمساعدة؟ تحقق من الملف التمهيدي.',
|
||||
noReadmeAvailable: 'لا يوجد ملف تمهيدي متاح',
|
||||
failedToFetch: 'فشل جلب الملف التمهيدي',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
4
web/i18n/ar-TN/register.ts
Normal file
4
web/i18n/ar-TN/register.ts
Normal file
@@ -0,0 +1,4 @@
|
||||
const translation = {
|
||||
}
|
||||
|
||||
export default translation
|
||||
31
web/i18n/ar-TN/run-log.ts
Normal file
31
web/i18n/ar-TN/run-log.ts
Normal file
@@ -0,0 +1,31 @@
|
||||
const translation = {
|
||||
input: 'إدخال',
|
||||
result: 'نتيجة',
|
||||
detail: 'تفاصيل',
|
||||
tracing: 'تتبع',
|
||||
resultPanel: {
|
||||
status: 'الحالة',
|
||||
time: 'الوقت المستغرق',
|
||||
tokens: 'إجمالي الرموز',
|
||||
},
|
||||
meta: {
|
||||
title: 'البيانات الوصفية',
|
||||
status: 'الحالة',
|
||||
version: 'الإصدار',
|
||||
executor: 'المنفذ',
|
||||
startTime: 'وقت البدء',
|
||||
time: 'الوقت المستغرق',
|
||||
tokens: 'إجمالي الرموز',
|
||||
steps: 'خطوات التشغيل',
|
||||
},
|
||||
resultEmpty: {
|
||||
title: 'هذا التشغيل يخرج فقط تنسيق JSON،',
|
||||
tipLeft: 'يرجى الذهاب إلى ',
|
||||
link: 'لوحة التفاصيل',
|
||||
tipRight: ' لعرضه.',
|
||||
},
|
||||
actionLogs: 'سجلات العمل',
|
||||
circularInvocationTip: 'يوجد استدعاء دائري للأدوات/العقد في سير العمل الحالي.',
|
||||
}
|
||||
|
||||
export default translation
|
||||
86
web/i18n/ar-TN/share.ts
Normal file
86
web/i18n/ar-TN/share.ts
Normal file
@@ -0,0 +1,86 @@
|
||||
const translation = {
|
||||
common: {
|
||||
welcome: '',
|
||||
appUnavailable: 'التطبيق غير متوفر',
|
||||
appUnknownError: 'التطبيق غير متوفر',
|
||||
},
|
||||
chat: {
|
||||
newChat: 'بدء دردشة جديدة',
|
||||
newChatTip: 'موجود بالفعل في دردشة جديدة',
|
||||
chatSettingsTitle: 'إعداد الدردشة الجديدة',
|
||||
chatFormTip: 'لا يمكن تعديل إعدادات الدردشة بعد بدء الدردشة.',
|
||||
pinnedTitle: 'مثبت',
|
||||
unpinnedTitle: 'الأخيرة',
|
||||
newChatDefaultName: 'محادثة جديدة',
|
||||
resetChat: 'إعادة تعيين المحادثة',
|
||||
viewChatSettings: 'عرض إعدادات الدردشة',
|
||||
poweredBy: 'مشغل بواسطة',
|
||||
prompt: 'مطالبة',
|
||||
privatePromptConfigTitle: 'إعدادات المحادثة',
|
||||
publicPromptConfigTitle: 'المطالبة الأولية',
|
||||
configStatusDes: 'قبل البدء، يمكنك تعديل إعدادات المحادثة',
|
||||
configDisabled:
|
||||
'تم استخدام إعدادات الجلسة السابقة لهذه الجلسة.',
|
||||
startChat: 'بدء الدردشة',
|
||||
privacyPolicyLeft:
|
||||
'يرجى قراءة ',
|
||||
privacyPolicyMiddle:
|
||||
'سياسة الخصوصية',
|
||||
privacyPolicyRight:
|
||||
' المقدمة من مطور التطبيق.',
|
||||
deleteConversation: {
|
||||
title: 'حذف المحادثة',
|
||||
content: 'هل أنت متأكد أنك تريد حذف هذه المحادثة؟',
|
||||
},
|
||||
tryToSolve: 'حاول الحل',
|
||||
temporarySystemIssue: 'عذرًا، مشكلة مؤقتة في النظام.',
|
||||
expand: 'توسيع',
|
||||
collapse: 'طي',
|
||||
},
|
||||
generation: {
|
||||
tabs: {
|
||||
create: 'تشغيل مرة واحدة',
|
||||
batch: 'تشغيل دفعة',
|
||||
saved: 'محفوظ',
|
||||
},
|
||||
savedNoData: {
|
||||
title: 'لم تقم بحفظ نتيجة بعد!',
|
||||
description: 'ابدأ في إنشاء المحتوى، وابحث عن نتائجك المحفوظة هنا.',
|
||||
startCreateContent: 'ابدأ في إنشاء المحتوى',
|
||||
},
|
||||
title: 'إكمال الذكاء الاصطناعي',
|
||||
queryTitle: 'محتوى الاستعلام',
|
||||
completionResult: 'نتيجة الإكمال',
|
||||
queryPlaceholder: 'اكتب محتوى الاستعلام الخاص بك...',
|
||||
run: 'تنفيذ',
|
||||
execution: 'تشغيل',
|
||||
executions: '{{num}} عمليات تشغيل',
|
||||
copy: 'نسخ',
|
||||
resultTitle: 'إكمال الذكاء الاصطناعي',
|
||||
noData: 'سيعطيك الذكاء الاصطناعي ما تريد هنا.',
|
||||
csvUploadTitle: 'اسحب وأفلت ملف CSV هنا، أو ',
|
||||
browse: 'تصفح',
|
||||
csvStructureTitle: 'يجب أن يتوافق ملف CSV مع الهيكل التالي:',
|
||||
downloadTemplate: 'تنزيل النموذج هنا',
|
||||
field: 'حقل',
|
||||
stopRun: 'إيقاف التشغيل',
|
||||
batchFailed: {
|
||||
info: '{{num}} عمليات تنفيذ فاشلة',
|
||||
retry: 'إعادة المحاولة',
|
||||
outputPlaceholder: 'لا يوجد محتوى إخراج',
|
||||
},
|
||||
errorMsg: {
|
||||
empty: 'يرجى إدخال محتوى في الملف الذي تم تحميله.',
|
||||
fileStructNotMatch: 'ملف CSV الذي تم تحميله لا يطابق الهيكل.',
|
||||
emptyLine: 'الصف {{rowIndex}} فارغ',
|
||||
invalidLine: 'الصف {{rowIndex}}: قيمة {{varName}} لا يمكن أن تكون فارغة',
|
||||
moreThanMaxLengthLine: 'الصف {{rowIndex}}: قيمة {{varName}} لا يمكن أن تكون أكثر من {{maxLength}} حرفًا',
|
||||
atLeastOne: 'يرجى إدخال صف واحد على الأقل في الملف الذي تم تحميله.',
|
||||
},
|
||||
},
|
||||
login: {
|
||||
backToHome: 'العودة إلى الصفحة الرئيسية',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
45
web/i18n/ar-TN/time.ts
Normal file
45
web/i18n/ar-TN/time.ts
Normal file
@@ -0,0 +1,45 @@
|
||||
const translation = {
|
||||
daysInWeek: {
|
||||
Sun: 'الأحد',
|
||||
Mon: 'الاثنين',
|
||||
Tue: 'الثلاثاء',
|
||||
Wed: 'الأربعاء',
|
||||
Thu: 'الخميس',
|
||||
Fri: 'الجمعة',
|
||||
Sat: 'السبت',
|
||||
},
|
||||
months: {
|
||||
January: 'يناير',
|
||||
February: 'فبراير',
|
||||
March: 'مارس',
|
||||
April: 'أبريل',
|
||||
May: 'مايو',
|
||||
June: 'يونيو',
|
||||
July: 'يوليو',
|
||||
August: 'أغسطس',
|
||||
September: 'سبتمبر',
|
||||
October: 'أكتوبر',
|
||||
November: 'نوفمبر',
|
||||
December: 'ديسمبر',
|
||||
},
|
||||
operation: {
|
||||
now: 'الآن',
|
||||
ok: 'موافق',
|
||||
cancel: 'إلغاء',
|
||||
pickDate: 'اختر التاريخ',
|
||||
},
|
||||
title: {
|
||||
pickTime: 'اختر الوقت',
|
||||
},
|
||||
defaultPlaceholder: 'اختر وقتًا...',
|
||||
// Date format configurations
|
||||
dateFormats: {
|
||||
display: 'MMMM D, YYYY',
|
||||
displayWithTime: 'MMMM D, YYYY hh:mm A',
|
||||
input: 'YYYY-MM-DD',
|
||||
output: 'YYYY-MM-DD',
|
||||
outputWithTime: 'YYYY-MM-DDTHH:mm:ss.SSSZ',
|
||||
},
|
||||
}
|
||||
|
||||
export default translation
|
||||
264
web/i18n/ar-TN/tools.ts
Normal file
264
web/i18n/ar-TN/tools.ts
Normal file
@@ -0,0 +1,264 @@
|
||||
const translation = {
|
||||
title: 'أدوات',
|
||||
createCustomTool: 'إنشاء أداة مخصصة',
|
||||
customToolTip: 'تعرف على المزيد حول أدوات Dify المخصصة',
|
||||
type: {
|
||||
builtIn: 'أدوات',
|
||||
custom: 'مخصص',
|
||||
workflow: 'سير عمل',
|
||||
},
|
||||
contribute: {
|
||||
line1: 'أنا مهتم بـ ',
|
||||
line2: 'المساهمة بأدوات في Dify.',
|
||||
viewGuide: 'عرض الدليل',
|
||||
},
|
||||
author: 'بواسطة',
|
||||
auth: {
|
||||
authorized: 'مفوض',
|
||||
setup: 'إعداد التفويض للاستخدام',
|
||||
setupModalTitle: 'إعداد التفويض',
|
||||
setupModalTitleDescription: 'بعد تكوين بيانات الاعتماد، يمكن لجميع الأعضاء داخل مساحة العمل استخدام هذه الأداة عند تنظيم التطبيقات.',
|
||||
},
|
||||
includeToolNum: '{{num}} {{action}} متضمن',
|
||||
addToolModal: {
|
||||
type: 'نوع',
|
||||
category: 'فئة',
|
||||
added: 'أضيف',
|
||||
custom: {
|
||||
title: 'لا توجد أداة مخصصة متاحة',
|
||||
tip: 'إنشاء أداة مخصصة',
|
||||
},
|
||||
workflow: {
|
||||
title: 'لا يوجد أداة سير عمل متاحة',
|
||||
tip: 'نشر سير العمل كأدوات في الاستوديو',
|
||||
},
|
||||
mcp: {
|
||||
title: 'لا توجد أداة MCP متاحة',
|
||||
tip: 'إضافة خادم MCP',
|
||||
},
|
||||
agent: {
|
||||
title: 'لا توجد استراتيجية وكيل متاحة',
|
||||
},
|
||||
},
|
||||
createTool: {
|
||||
title: 'إنشاء أداة مخصصة',
|
||||
editAction: 'تكوين',
|
||||
editTitle: 'تعديل أداة مخصصة',
|
||||
name: 'الاسم',
|
||||
toolNamePlaceHolder: 'أدخل اسم الأداة',
|
||||
nameForToolCall: 'اسم استدعاء الأداة',
|
||||
nameForToolCallPlaceHolder: 'يستخدم للتعرف على الآلة، مثل getCurrentWeather, list_pets',
|
||||
nameForToolCallTip: 'يدعم فقط الأرقام والحروف والشرطات السفلية.',
|
||||
description: 'الوصف',
|
||||
descriptionPlaceholder: 'وصف موجز لغرض الأداة، على سبيل المثال، الحصول على درجة الحرارة لموقع معين.',
|
||||
schema: 'المخطط',
|
||||
schemaPlaceHolder: 'أدخل مخطط OpenAPI الخاص بك هنا',
|
||||
viewSchemaSpec: 'عرض مواصفات OpenAPI-Swagger',
|
||||
importFromUrl: 'استيراد من عنوان URL',
|
||||
importFromUrlPlaceHolder: 'https://...',
|
||||
urlError: 'يرجى إدخال عنوان URL صالح',
|
||||
examples: 'أمثلة',
|
||||
exampleOptions: {
|
||||
json: 'Weather(JSON)',
|
||||
yaml: 'Pet Store(YAML)',
|
||||
blankTemplate: 'قالب فارغ',
|
||||
},
|
||||
availableTools: {
|
||||
title: 'الأدوات المتاحة',
|
||||
name: 'الاسم',
|
||||
description: 'الوصف',
|
||||
method: 'الطريقة',
|
||||
path: 'المسار',
|
||||
action: 'الإجراءات',
|
||||
test: 'اختبار',
|
||||
},
|
||||
authMethod: {
|
||||
title: 'طريقة التفويض',
|
||||
type: 'نوع التفويض',
|
||||
keyTooltip: 'مفتاح رأس Http، يمكنك تركه بـ "Authorization" إذا لم يكن لديك فكرة عما هو عليه أو تعيينه إلى قيمة مخصصة',
|
||||
queryParam: 'معلمة الاستعلام',
|
||||
queryParamTooltip: 'اسم معلمة استعلام مفتاح API للتمرير، على سبيل المثال "key" في "https://example.com/test?key=API_KEY".',
|
||||
types: {
|
||||
none: 'لا شيء',
|
||||
api_key_header: 'رأس',
|
||||
api_key_query: 'معلمة استعلام',
|
||||
apiKeyPlaceholder: 'اسم رأس HTTP لمفتاح API',
|
||||
apiValuePlaceholder: 'أدخل مفتاح API',
|
||||
queryParamPlaceholder: 'اسم معلمة الاستعلام لمفتاح API',
|
||||
},
|
||||
key: 'مفتاح',
|
||||
value: 'قيمة',
|
||||
},
|
||||
authHeaderPrefix: {
|
||||
title: 'نوع المصادقة',
|
||||
types: {
|
||||
basic: 'أساسي',
|
||||
bearer: 'Bearer',
|
||||
custom: 'مخصص',
|
||||
},
|
||||
},
|
||||
privacyPolicy: 'سياسة الخصوصية',
|
||||
privacyPolicyPlaceholder: 'يرجى إدخال سياسة الخصوصية',
|
||||
toolInput: {
|
||||
title: 'إدخال الأداة',
|
||||
name: 'الاسم',
|
||||
required: 'مطلوب',
|
||||
method: 'الطريقة',
|
||||
methodSetting: 'إعداد',
|
||||
methodSettingTip: 'يملأ المستخدم تكوين الأداة',
|
||||
methodParameter: 'معلمة',
|
||||
methodParameterTip: 'يملأ LLM أثناء الاستنتاج',
|
||||
label: 'العلامات',
|
||||
labelPlaceholder: 'اختر العلامات (اختياري)',
|
||||
description: 'الوصف',
|
||||
descriptionPlaceholder: 'وصف معنى المعلمة',
|
||||
},
|
||||
toolOutput: {
|
||||
title: 'إخراج الأداة',
|
||||
name: 'الاسم',
|
||||
reserved: 'محجوز',
|
||||
reservedParameterDuplicateTip: 'text و json و files هي متغيرات محجوزة. لا يمكن أن تظهر المتغيرات بهذه الأسماء في مخطط الإخراج.',
|
||||
description: 'الوصف',
|
||||
},
|
||||
customDisclaimer: 'إخلاء مسؤولية مخصص',
|
||||
customDisclaimerPlaceholder: 'يرجى إدخال إخلاء مسؤولية مخصص',
|
||||
confirmTitle: 'تأكيد الحفظ؟',
|
||||
confirmTip: 'ستتأثر التطبيقات التي تستخدم هذه الأداة',
|
||||
deleteToolConfirmTitle: 'حذف هذه الأداة؟',
|
||||
deleteToolConfirmContent: 'حذف الأداة لا رجعة فيه. لن يتمكن المستخدمون بعد الآن من الوصول إلى أداتك.',
|
||||
},
|
||||
test: {
|
||||
title: 'اختبار',
|
||||
parametersValue: 'المعلمات والقيمة',
|
||||
parameters: 'المعلمات',
|
||||
value: 'القيمة',
|
||||
testResult: 'نتائج الاختبار',
|
||||
testResultPlaceholder: 'ستظهر نتيجة الاختبار هنا',
|
||||
},
|
||||
thought: {
|
||||
using: 'يستخدم',
|
||||
used: 'مستخدم',
|
||||
requestTitle: 'طلب',
|
||||
responseTitle: 'استجابة',
|
||||
},
|
||||
setBuiltInTools: {
|
||||
info: 'معلومات',
|
||||
setting: 'إعداد',
|
||||
toolDescription: 'وصف الأداة',
|
||||
parameters: 'معلمات',
|
||||
string: 'سلسلة',
|
||||
number: 'رقم',
|
||||
file: 'ملف',
|
||||
required: 'مطلوب',
|
||||
infoAndSetting: 'المعلومات والإعدادات',
|
||||
},
|
||||
noCustomTool: {
|
||||
title: 'لا توجد أدوات مخصصة!',
|
||||
content: 'أضف وأدر أدواتك المخصصة هنا لبناء تطبيقات الذكاء الاصطناعي.',
|
||||
createTool: 'إنشاء أداة',
|
||||
},
|
||||
noSearchRes: {
|
||||
title: 'عذرًا، لا توجد نتائج!',
|
||||
content: 'لم نتمكن من العثور على أي أدوات تطابق بحثك.',
|
||||
reset: 'إعادة تعيين البحث',
|
||||
},
|
||||
builtInPromptTitle: 'موجه',
|
||||
toolRemoved: 'تمت إزالة الأداة',
|
||||
notAuthorized: 'غير مفوض',
|
||||
howToGet: 'كيفية الحصول على',
|
||||
openInStudio: 'فتح في الاستوديو',
|
||||
toolNameUsageTip: 'اسم استدعاء الأداة لمنطق الوكيل والتحفيز',
|
||||
copyToolName: 'نسخ الاسم',
|
||||
noTools: 'لم يتم العثور على أدوات',
|
||||
mcp: {
|
||||
create: {
|
||||
cardTitle: 'إضافة خادم MCP (HTTP)',
|
||||
cardLink: 'تعرف على المزيد حول تكامل خادم MCP',
|
||||
},
|
||||
noConfigured: 'غير مكون',
|
||||
updateTime: 'محدث',
|
||||
toolsCount: '{{count}} أدوات',
|
||||
noTools: 'لا توجد أدوات متاحة',
|
||||
modal: {
|
||||
title: 'إضافة خادم MCP (HTTP)',
|
||||
editTitle: 'تعديل خادم MCP (HTTP)',
|
||||
name: 'الاسم والأيقونة',
|
||||
namePlaceholder: 'قم بتسمية خادم MCP الخاص بك',
|
||||
serverUrl: 'عنوان URL للخادم',
|
||||
serverUrlPlaceholder: 'عنوان URL لنقطة نهاية الخادم',
|
||||
serverUrlWarning: 'قد يؤدي تحديث عنوان الخادم إلى تعطيل التطبيقات التي تعتمد على هذا الخادم',
|
||||
serverIdentifier: 'معرف الخادم',
|
||||
serverIdentifierTip: 'معرف فريد لخادم MCP داخل مساحة العمل. أحرف صغيرة وأرقام وشرطات سفلية وواصلات فقط. ما يصل إلى 24 حرفًا.',
|
||||
serverIdentifierPlaceholder: 'معرف فريد، على سبيل المثال، my-mcp-server',
|
||||
serverIdentifierWarning: 'لن يتم التعرف على الخادم بواسطة التطبيقات الموجودة بعد تغيير المعرف',
|
||||
headers: 'رؤوس',
|
||||
headersTip: 'رؤوس HTTP إضافية للإرسال مع طلبات خادم MCP',
|
||||
headerKey: 'اسم الرأس',
|
||||
headerValue: 'قيمة الرأس',
|
||||
headerKeyPlaceholder: 'على سبيل المثال، Authorization',
|
||||
headerValuePlaceholder: 'على سبيل المثال، Bearer token123',
|
||||
addHeader: 'إضافة رأس',
|
||||
noHeaders: 'لم يتم تكوين رؤوس مخصصة',
|
||||
maskedHeadersTip: 'يتم إخفاء قيم الرأس للأمان. ستقوم التغييرات بتحديث القيم الفعلية.',
|
||||
cancel: 'إلغاء',
|
||||
save: 'حفظ',
|
||||
confirm: 'إضافة وتفويض',
|
||||
timeout: 'مهلة',
|
||||
sseReadTimeout: 'مهلة قراءة SSE',
|
||||
timeoutPlaceholder: '30',
|
||||
authentication: 'المصادقة',
|
||||
useDynamicClientRegistration: 'استخدام تسجيل العميل الديناميكي',
|
||||
redirectUrlWarning: 'يرجى تكوين عنوان URL لإعادة توجيه OAuth الخاص بك إلى:',
|
||||
clientID: 'معرف العميل',
|
||||
clientSecret: 'سر العميل',
|
||||
clientSecretPlaceholder: 'سر العميل',
|
||||
configurations: 'التكوينات',
|
||||
},
|
||||
delete: 'إزالة خادم MCP',
|
||||
deleteConfirmTitle: 'هل ترغب في إزالة {{mcp}}؟',
|
||||
operation: {
|
||||
edit: 'تعديل',
|
||||
remove: 'إزالة',
|
||||
},
|
||||
authorize: 'تفويض',
|
||||
authorizing: 'جارٍ التفويض...',
|
||||
authorizingRequired: 'التفويض مطلوب',
|
||||
authorizeTip: 'بعد التفويض، سيتم عرض الأدوات هنا.',
|
||||
update: 'تحديث',
|
||||
updating: 'جارٍ التحديث',
|
||||
gettingTools: 'جارٍ الحصول على الأدوات...',
|
||||
updateTools: 'جارٍ تحديث الأدوات...',
|
||||
toolsEmpty: 'لم يتم تحميل الأدوات',
|
||||
getTools: 'احصل على الأدوات',
|
||||
toolUpdateConfirmTitle: 'تحديث قائمة الأدوات',
|
||||
toolUpdateConfirmContent: 'قد يؤثر تحديث قائمة الأدوات على التطبيقات الموجودة. هل ترغب في المتابعة؟',
|
||||
toolsNum: '{{count}} أدوات متضمنة',
|
||||
onlyTool: 'أداة واحدة متضمنة',
|
||||
identifier: 'معرف الخادم (انقر للنسخ)',
|
||||
server: {
|
||||
title: 'خادم MCP',
|
||||
url: 'عنوان URL للخادم',
|
||||
reGen: 'هل تريد إعادة إنشاء عنوان URL للخادم؟',
|
||||
addDescription: 'إضافة وصف',
|
||||
edit: 'تعديل الوصف',
|
||||
modal: {
|
||||
addTitle: 'إضافة وصف لتمكين خادم MCP',
|
||||
editTitle: 'تعديل الوصف',
|
||||
description: 'الوصف',
|
||||
descriptionPlaceholder: 'اشرح ما تفعله هذه الأداة وكيف يجب استخدامها بواسطة LLM',
|
||||
parameters: 'المعلمات',
|
||||
parametersTip: 'أضف أوصافًا لكل معلمة لمساعدة LLM على فهم الغرض منها والقيود المفروضة عليها.',
|
||||
parametersPlaceholder: 'الغرض من المعلمة والقيود',
|
||||
confirm: 'تمكين خادم MCP',
|
||||
},
|
||||
publishTip: 'التطبيق غير منشور. يرجى نشر التطبيق أولاً.',
|
||||
},
|
||||
toolItem: {
|
||||
noDescription: 'لا يوجد وصف',
|
||||
parameters: 'المعلمات',
|
||||
},
|
||||
},
|
||||
allTools: 'جميع الأدوات',
|
||||
}
|
||||
|
||||
export default translation
|
||||
1296
web/i18n/ar-TN/workflow.ts
Normal file
1296
web/i18n/ar-TN/workflow.ts
Normal file
File diff suppressed because it is too large
Load Diff
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Quelle',
|
||||
text: 'Text',
|
||||
time: 'Zeit',
|
||||
queryContent: 'Inhaltsabfrage',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Fuente',
|
||||
text: 'Texto',
|
||||
time: 'Tiempo',
|
||||
queryContent: 'Contenido de la consulta',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'منبع',
|
||||
text: 'متن',
|
||||
time: 'زمان',
|
||||
queryContent: 'محتوای پرسوجو',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Source',
|
||||
text: 'Texte',
|
||||
time: 'Temps',
|
||||
queryContent: 'Contenu de la requête',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'स्रोत',
|
||||
text: 'पाठ',
|
||||
time: 'समय',
|
||||
queryContent: 'सवाल की सामग्री',
|
||||
},
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
const translation = {
|
||||
table: {
|
||||
header: {
|
||||
text: 'Teks',
|
||||
source: 'Sumber',
|
||||
time: 'Waktu',
|
||||
queryContent: 'Konten Query',
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Fonte',
|
||||
text: 'Testo',
|
||||
time: 'Ora',
|
||||
queryContent: 'Contenuto della query',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: '소스',
|
||||
text: '텍스트',
|
||||
time: '시간',
|
||||
queryContent: '질의 내용',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Źródło',
|
||||
text: 'Tekst',
|
||||
time: 'Czas',
|
||||
queryContent: 'Treść zapytania',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Origem',
|
||||
text: 'Texto',
|
||||
time: 'Hora',
|
||||
queryContent: 'Conteúdo da Consulta',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Sursă',
|
||||
text: 'Text',
|
||||
time: 'Timp',
|
||||
queryContent: 'Conținutul cererii',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Источник',
|
||||
text: 'Текст',
|
||||
time: 'Время',
|
||||
queryContent: 'Содержимое запроса',
|
||||
},
|
||||
|
||||
@@ -6,7 +6,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Vir',
|
||||
text: 'Besedilo',
|
||||
time: 'Čas',
|
||||
queryContent: 'Vsebina poizvedbe',
|
||||
},
|
||||
|
||||
@@ -6,7 +6,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'ที่มา',
|
||||
text: 'ข้อความ',
|
||||
time: 'เวลา',
|
||||
queryContent: 'เนื้อหาคำถาม',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Kaynak',
|
||||
text: 'Metin',
|
||||
time: 'Zaman',
|
||||
queryContent: 'Sorgu İçeriği',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Джерело',
|
||||
text: 'Текст',
|
||||
time: 'Час',
|
||||
queryContent: 'Вміст запиту',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: 'Nguồn',
|
||||
text: 'Văn bản',
|
||||
time: 'Thời gian',
|
||||
queryContent: 'Nội dung truy vấn',
|
||||
},
|
||||
|
||||
@@ -5,7 +5,6 @@ const translation = {
|
||||
table: {
|
||||
header: {
|
||||
source: '資料來源',
|
||||
text: '文字',
|
||||
time: '時間',
|
||||
queryContent: '查詢內容',
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user