diff --git a/bin/cli-users b/bin/cli-users index ea308ae44f..950f2a5387 100755 --- a/bin/cli-users +++ b/bin/cli-users @@ -312,10 +312,59 @@ async function verifyUserEmail(userID, email) { } } +/** + * createUser will prompt the user for the user information when creating a + * local user. + */ +async function createUser() { + try { + const answers = await inquirer.prompt([ + { + name: 'email', + message: 'Email', + }, + { + name: 'username', + message: 'Username', + }, + { + name: 'password', + message: 'Password', + type: 'password', + }, + { + name: 'role', + message: 'Role', + type: 'list', + choices: USER_ROLES, + }, + ]); + + const { email, username, password, role } = answers; + + // Create the user. + const user = await UsersService.createLocalUser(email, password, username); + + // Set the role. + await UsersService.setRole(user.id, role); + + console.log(`Created User[${user.id}]`); + util.shutdown(0); + } catch (err) { + console.error(err); + util.shutdown(1); + } +} + //============================================================================== // Setting up the program command line arguments. //============================================================================== +program + .command('create') + .description('creates a local user') + .action(createUser); + program .command('delete ') .description('delete a user') diff --git a/client/coral-framework/services/i18n.js b/client/coral-framework/services/i18n.js index f467f7f533..1468f92eb2 100644 --- a/client/coral-framework/services/i18n.js +++ b/client/coral-framework/services/i18n.js @@ -4,6 +4,7 @@ import get from 'lodash/get'; import merge from 'lodash/merge'; import moment from 'moment'; +import 'moment/locale/ar'; import 'moment/locale/da'; import 'moment/locale/de'; import 'moment/locale/es'; @@ -12,6 +13,7 @@ import 'moment/locale/pt-br'; import { createStorage } from 'coral-framework/services/storage'; +import arTA from 'timeago.js/locales/ar'; import daTA from 'timeago.js/locales/da'; import deTA from 'timeago.js/locales/de'; import esTA from 'timeago.js/locales/es'; @@ -21,6 +23,7 @@ import zh_CNTA from 'timeago.js/locales/zh_CN'; import zh_TWTA from 'timeago.js/locales/zh_TW'; import nl from 'timeago.js/locales/nl'; +import ar from '../../../locales/ar.yml'; import en from '../../../locales/en.yml'; import da from '../../../locales/da.yml'; import de from '../../../locales/de.yml'; @@ -33,6 +36,7 @@ import nl_NL from '../../../locales/nl_NL.yml'; const defaultLanguage = process.env.TALK_DEFAULT_LANG; const translations = { + ...ar, ...en, ...da, ...de, @@ -88,6 +92,7 @@ export function setupTranslations() { lang = defaultLanguage; } + ta.register('ar', arTA); ta.register('es', esTA); ta.register('da', daTA); ta.register('de', deTA); diff --git a/docs/_config.yml b/docs/_config.yml index 1c2a7fdf6a..513b27d6bb 100644 --- a/docs/_config.yml +++ b/docs/_config.yml @@ -73,14 +73,12 @@ deploy: sidebar: top: - - title: Github + - title: GitHub url: https://github.com/coralproject/ - title: Docker url: https://hub.docker.com/r/coralproject/ - title: Roadmap url: https://www.pivotaltracker.com/n/projects/1863625 - - title: Google Group - url: https://groups.google.com/forum/#!forum/coral-talk-users side: - title: Installation children: @@ -142,10 +140,8 @@ sidebar: url: /reference/server/ - title: GraphQL url: /reference/graphql/ - - title: FAQ - children: - - title: FAQ - url: /faq/ + - title: Contact + url: /contact/ - title: Migrating children: - title: Migrating to v4.0.0 diff --git a/docs/source/01-03-installation-from-source.md b/docs/source/01-03-installation-from-source.md index 8bab26ff8d..8b6f52228e 100644 --- a/docs/source/01-03-installation-from-source.md +++ b/docs/source/01-03-installation-from-source.md @@ -6,7 +6,7 @@ permalink: /installation-from-source/ To install Talk from Source, ensure that you have Node version 8+. Installing via source is the recommended method when developing as it give you the best tooling. We release versions using semantic versioning, and do so to -our [Github Releases](https://github.com/coralproject/talk/releases) page. +our [GitHub Releases](https://github.com/coralproject/talk/releases) page. There you can download archives of older versions or the latest release. The examples following will download the latest code on our master branch. diff --git a/docs/source/05-01-faq.md b/docs/source/contact.md similarity index 82% rename from docs/source/05-01-faq.md rename to docs/source/contact.md index 06d0b0669d..029652fea0 100644 --- a/docs/source/05-01-faq.md +++ b/docs/source/contact.md @@ -1,6 +1,6 @@ --- -title: FAQ -permalink: /faq/ +title: Contact +permalink: /contact/ --- ## How can I get help integrating Talk into my newsroom? @@ -10,8 +10,8 @@ We're here to help with newsrooms of all sizes. Email our Integration Engineer ## How do I request a feature or submit a bug? -The best way is to [submit a Github issue](https://github.com/coralproject/talk/issues). Make sure you give plenty of details, our Core Team can usually respond within a few hours on weekdays. +The best way is to [submit a GitHub issue](https://github.com/coralproject/talk/issues). Make sure you give plenty of details, our Core Team can usually respond within a few hours on weekdays. ## How can our dev team contribute to Talk? -We are lucky to work with newsroom dev teams and individual contributors who span the world, and come from newsrooms of all sizes. You can read our [Contribution Guide](https://github.com/coralproject/talk/blob/master/CONTRIBUTING.md) to get started, but feel free to reach out to us via Github, or get in touch directly with Jeff via jeff@mozillafoundation.org. +We are lucky to work with newsroom dev teams and individual contributors who span the world, and come from newsrooms of all sizes. You can read our [Contribution Guide](https://github.com/coralproject/talk/blob/master/CONTRIBUTING.md) to get started, but feel free to reach out to us via GitHub, or get in touch directly with Jeff via jeff@mozillafoundation.org. diff --git a/docs/source/integrating/translations-i18n.md b/docs/source/integrating/translations-i18n.md index 2466dcdc08..e1f0020089 100644 --- a/docs/source/integrating/translations-i18n.md +++ b/docs/source/integrating/translations-i18n.md @@ -23,6 +23,6 @@ That would set the language to French. To add a new Talk translation, simply translate the `en.yml` file (https://github.com/coralproject/talk/blob/master/locales/en.yml) into a new yml file with the language code of your choice. You can find supported language codes here: http://www.localeplanet.com/icu/iso639.html -If you are a developer contributing a new language, you'll need to add the required i18n support in the i18n files (or you can leave that to us if you like). If you're a non-developer, you can submit the translation via Github if you feel comfortable doing that, or feel free to email it to us via our Support: support@coralproject.net +If you are a developer contributing a new language, you'll need to add the required i18n support in the i18n files (or you can leave that to us if you like). If you're a non-developer, you can submit the translation via GitHub if you feel comfortable doing that, or feel free to email it to us via our Support: support@coralproject.net -If you want to suggest a new language or put a placeholder for a translation you’re working on, feel free to create a Github issue: https://github.com/coralproject/talk/issues/new +If you want to suggest a new language or put a placeholder for a translation you’re working on, feel free to create a GitHub issue: https://github.com/coralproject/talk/issues/new diff --git a/docs/themes/coral/layout/partial/sidebar.swig b/docs/themes/coral/layout/partial/sidebar.swig index ad453136fb..d6d4fbab1b 100644 --- a/docs/themes/coral/layout/partial/sidebar.swig +++ b/docs/themes/coral/layout/partial/sidebar.swig @@ -7,16 +7,22 @@ diff --git a/docs/themes/coral/source/js/main.js b/docs/themes/coral/source/js/main.js index 0ee3fe5575..23e6db6a9d 100644 --- a/docs/themes/coral/source/js/main.js +++ b/docs/themes/coral/source/js/main.js @@ -28,7 +28,7 @@ $(document).ready(function() { }); // Setup the menu controls. - $('a.sidebar__header').on('click', function(e) { + $('a.sidebar__header:not(.sidebar__header__link)').on('click', function(e) { e.preventDefault(); $('.sidebar__section.toggled').removeClass('toggled'); $(this) diff --git a/locales/ar.yml b/locales/ar.yml new file mode 100644 index 0000000000..dccda38265 --- /dev/null +++ b/locales/ar.yml @@ -0,0 +1,480 @@ +ar: + your_account_has_been_suspended: تم تعليق حسابك مؤقتا. + your_account_has_been_banned: تم حظر حسابك. + your_username_has_been_rejected: تم تعليق حسابك لعدم صلاحية اسم المستخدم الخاصة بك. لاستعادة حسابك رجاء أدخل اسم مستخدم جديدة. + embed_comments_tab: تعليقات + bandialog: + are_you_sure: "أنت متأكد أنك تريد حظر {0}؟" + ban_user: "حظر المستخدم؟" + banned_user: "مستخدم محظور" + cancel: "إلغاء" + note: "ملاحظة: {0}" + note_reject_comment: "حظر هذا المستخدم سيضع هذا التعليق في قائمة الرفض." + note_ban_user: "حظر هذا المستخدم لن يسمح له بالتعليق أو التفاعل أو الإبلاغ عن تعليقات." + yes_ban_user: "نعم، احظر المستخدم" + write_a_message: "أكتب رسالة" + send: "أرسل" + notify_ban_headline: "أبلغ المستخدم بالحظر" + notify_ban_description: "سيتم إبلاغ المستخدم عن طريق البريد الإلكتروني بأنه قد تم حظره من المجموعة" + email_message_ban: "العزيز {0},\n\nتم الدخول باستخدام حسابك وانتهاك قواعد المجموعة، لذا لقد تم حظر حسابك. لن تستطيع التعليق مجددا، أو الإعجاب أو الإبلاغ عن تعليقات. إذا كنت ترى أن ذلك تم بالخطأ، رجاء إبلاغ أحد أعضاء الفريق الخاص بالمجموعة." + bio_offensive: "السيرة الذاتية مسيئة" + cancel: "إلغاء" + confirm_email: + click_to_confirm: "إضغط في الأسفل لتأكيد البريد الألكتروني" + confirm: "تأكيد" + password_reset: + mail_sent: 'إذا كان لديك حساب مسجل، فقد تم إرسال رابط إعادة تعيين كلمة المرور إلى هذا البريد الإلكتروني' + set_new_password: "تغيير كلمة السر الخاصة بك" + new_password: "كلمة السر الجديدة" + new_password_help: "كلمة السر يجب أن تكون 8 أحرف على الأقل" + confirm_new_password: "تأكيد كلمة السر الجديدة" + change_password: "تغيير كلمة السر" + characters_remaining: "هناك أحرف متبقية" + comment: + anon: "غير معلوم" + undo_reject: "ابطال العملية" + ban_user: "حظر المستخدم" + comment: "نشر تعليق" + edited: محرر + flagged: "إشارة" + view_context: "عرض السياق" + comment_box: + post: "نشر" + cancel: "إلغاء" + reply: "رد" + comment: "نشر تعليق" + name: "الاسم" + comment_post_notif: "تم نشر تعليقك." + comment_post_notif_premod: "شكرا لك على النشر. سيراجع فريق الإشراف لدينا تعليقك قريبا." + comment_post_banned_word: "تعليقك يحتوي على كلمة أو أكثر غير مسموح بها، لذا لن يتم نشره. إذا كنت تعتقد أن هذه الرسالة خطأ، رجاء الاتصال بفريق الإشراف لدينا." + characters_remaining: "أحرف متبقية" + comment_offensive: "هذا التعليق مسيء" + comment_singular: تعليق + comment_plural: تعليقات + comment_post_banned_word: "تعليقك يحتوي على كلمة أو أكثر غير مسموح بها، لذا لن يتم نشره. إذا كنت تعتقد أن هذه الرسالة خطأ، رجاء الاتصال بفريق الإشراف لدينا." + comment_post_notif: "تم نشر تعليقك." + comment_post_notif_premod: "شكرا لك على النشر. سيراجع فريق الإشراف لدينا تعليقك قريبا." + common: + copy: 'نسخ' + error: 'حدث خطأ.' + reply: 'رد' + replies: 'ردود' + reaction: 'رد فعل' + reactions: 'ردود أفعال' + story: 'قصة' + flagged_usernames: + notify_approved: '{0} وافق على اسم المستخدم {1}' + notify_rejected: '{0} رفض اسم المستخدم {1}' + notify_flagged: '{0} بلغ عن اسم المستخدم {1}' + notify_changed: 'المستخدم {0} غير اسم المستخدم الخاص به إلى {1}' + community: + account_creation_date: "تاريخ إنشاء الحساب" + active: فعال + admin: إداري + ads_marketing: "هذا يبدو وكأنه إعلان/تسويق" + are_you_sure: "متأكد أنك تريد حظر {0}؟" + ban_user: "حظر المستخدم؟" + banned: محظور + banned_user: "مستخدم محظور" + cancel: إلغاء + dont_like_username: "غير معجب باسم المستخدم" + flaggedaccounts: "أسماء المستخدمين المبلغ عنها" + flags: شارات + impersonating: "انتحال شخصية" + loading: "تحميل النتائج" + moderator: مشرف + newsroom_role: "دور غرفة الأخبار" + no_flagged_accounts: "قائمة أسماء المستخدمين المبلغ عنها فارغة حاليا." + no_results: "لم يتم العثور على مستخدمين باسم المستخدم أو عنوان البريد الإلكتروني هذا. انهم يختبئون!" + offensive: "مسيء" + other: أخرى + people: أشخاص + role: "اختر الدور..." + select_status: "اختر الحالة..." + spam_ads: "بريد مؤذي/إعلانات" + staff: "فريق العمل" + status: الحالة + username_and_email: "اسم المستخدم والبريد الإلكتروني" + yes_ban_user: "نعم إحظر المستخدم" + commenter: "معلق" + configure: + apply: طبق + banned_word_text: "التعليقات التي تحتوي على هذه الكلمات أو العبارات سيتم حذفها آليا من جدول التعليقات. اطبع كلمة واضغط Enter أو Tab لزيادة الكلمة. اختياريا الصق قائمة مقسمة بالفصلات." + banned_words_title: "قائمة بالكلمات المحظورة" + close: "اغلق" + close_after: "اغلق التعليقات بعد" + close_stream: "اغلق الجدول" + close_stream_configuration: "تم إغلاق جدول التعليقات هذا. بفتحك لهذا الجدول سيتم قبول وعرض تعليقات جديدة" + closed_comments_desc: "اكتب رسالة ليتم عرضها عندما يتم إغلاق جدول التعليقات ولا يتم قبول أي تعليقات جديدة." + closed_comments_label: "اكتب رسالة..." + closed_stream_settings: "رسالة الجدول المغلق" + comment_count_error: "رجاء كتابة رقم صحيح." + comment_count_header: "الحد من طول التعليق" + comment_count_text_post: حروف + comment_count_text_pre: "سيتم وضع حد للتعليقات عند" + comment_settings: إعدادات + comment_stream: "جدول التعليقات" + comment_stream_will_close: "سيتم إغلاق جدول التعليق" + community: المجموعة + configure: تهيئة + copy_and_paste: "انسخ والصق التعليمات البرمجية في الأسفل بنظام إدارة المحتوى لتضمين تعليقك داخل المقالات" + custom_css_url: "رابط CSS مخصص" + custom_css_url_desc: "رابط CSS الذي سيتجاوز أنماط جدول التعليقات المضمن. يمكن أن يكون داخلي أو خارجي." + days: أيام + description: "كإداري يمكنك تعديل إعدادات جدول التعليقات لهذه القصة:" + domain_list_text: "أدخل عناوين النطاقات التي سوف تسمح فيها لTalk.. مثلا بيئات التدريج و الإنتاج (مثلا localhost:3000 staging.domain.com domain.com)." + domain_list_title: "النطاقات المسموح بها" + edit_comment_timeframe_heading: "عدل الإطار الزمني للتعليق" + edit_comment_timeframe_text_pre: "سيكون لدى المعلقين" + edit_comment_timeframe_text_post: "ثوان لتحرير تعليقاتهم." + embed_comment_stream: "تضمين الجدول" + enable_premod_links_text: "يجب على المشرفين الموافقة على أي تعليق يحتوي على رابط قبل نشره." + enable_pre_moderation: "تمكين الإشراف المسبق" + enable_pre_moderation_text: "يجب على المشرفين الموافقة على أي تعليق قبل نشره." + enable_premod_links: "إشراف مسبق على التعليقات التي تحتوي على روابط" + enable_premod: "تمكين الإشراف المسبق" + enable_premod_description: "يجب على المشرفين الموافقة على أي تعليق قبل نشره." + enable_premod_links_description: "يجب على المشرفين الموافقة على أي تعليق يحتوي على رابط قبل نشره." + enable_questionbox: "اطرح سؤال على القراء" + enable_questionbox_description: "هذا السؤال سيظهر في الجزء العلوي من جدول التعليقات هذا. اسأل القراء عن مسألة معينة في المقال او اطرح أسئلة نقاشية.. الخ." + hours: ساعات + include_comment_stream: "ادراج وصف جدول التعليقات للقراء" + include_comment_stream_desc: "اكتب رسالة ليتم إضافتها إلى الجزء العلوي من جدول التعليقات. ضع موضوعا، اشمل القواعد الإرشادية للمجموعة .. الخ" + include_text: "ادرج النص هنا." + include_question_here: "اكتب سؤالك هنا:" + moderate: اشرف + moderation_settings: "اعدادات الإشراف" + open: "مفتوح" + open_stream: "افتح الجدول" + open_stream_configuration: "جدول التعليقات هذا مفتوح. بإغلاق هذا الجدول لن يتم قبول تعليقات جديدة، وستبقى التعليقات القديمة ظاهرة." + require_email_verification: "يلزم التحقق من البريد الإلكتروني" + require_email_verification_text: "يجب على المستخدمين الجدد التحقق من بريدهم الإلكتروني قبل التعليق" + save_changes: "احفظ التعديلات" + shortcuts: اختصارات + sign_out: "خروج" + stories: قصص + stream_settings: "اعدادات الجدول" + suspect_word_title: "قائمة الكلمات المشبوهة" + suspect_word_text: "التعليقات التي تحتوي على هذه الكلمات أو العبارات سيتم تمييزها في جدول التعليقات. اطبع كلمة واضغط Enter أو Tab لزيادة الكلمة. اختياريا الصق قائمة مقسمة بالفصلات." + tech_settings: "إعدادات تقنية" + title: "تهيئة جدول التعليق" + weeks: أسابيع + wordlist: "الكلمات المحظورة" + continue: "واصل" + createdisplay: + check_the_form: "استمارة غير صالحة. يرجى التحقق من الحقول" + continue: "تابع بنفس اسم المستخدم الخاص بفيسبوك" + error_create: "حدث خطأ أثناء تغيير اسم المستخدم" + fake_comment_body: "هذا مثال للتعليق. يمكن للقراء تبادل الأفكار والآراء مع غرف الأخبار في قسم التعليقات." + fake_comment_date: "منذ دقيقة" + if_you_dont_change_your_name: "إذا لم تقم بتغيير اسم المستخدم الخاص بك في هذه الخطوة سوف يظهر اسم المستخدم الخاص بفيسبوك جنبا إلى جنب مع كل تعليقاتك." + required_field: "حقل مطلوب" + save: حفظ + special_characters: "يمكن أن تحتوي أسماء المستخدمين على أحرف وأرقام و _ فقط" + username: اسم المستخدم + write_your_username: "عدل اسم المستخدم" + your_username: "يظهر اسم المستخدم في كل تعليق تنشره." + done: تم + edit_comment: + body_input_label: "عدل هذا التعليق" + save_button: "حفظ التغييرات" + edit_window_expired: "لم يعد بإمكانك تعديل هذا التعليق. انتهت صلاحية نافذة الوقت للقيام بذلك. لماذا لا تنشر آخر؟" + edit_window_expired_close: "أغلق" + edit_window_timer_prefix: "نافذة التعديل : " + second: "ثانية" + seconds_plural: "ثوان" + minute: "دقيقة" + minutes_plural: "دقائق" + email: + suspended: + subject: "تم تعليق حسابك" + banned: + subject: "تم حظر حسابك" + body: "وفقا لإرشادات مجتمع كورال بروجيكت، تم حظر حسابك. لم يعد مسموحا لك التعليق أو وضع إشارات أو التفاعل مع مجتمعنا." + confirm: + has_been_requested: "تم طلب تأكيد بالبريد الإلكتروني للحساب التالي:" + to_confirm: "لتأكيد الحساب، يرجى زيارة الرابط التالي:" + confirm_email: ".تأكيد عنوان البريد الإلكتروني" + if_you_did_not: "إذا لم تطلب ذلك، يمكنك تجاهل هذه الرسالة الإلكترونية." + subject: "تأكيد البريد الإلكتروني" + password_reset: + we_received_a_request: "لقد تلقينا طلبا لإعادة تعيين كلمة المرور. إذا لم تطلب هذا التغيير، فيمكنك تجاهل هذه الرسالة الإلكترونية." + if_you_did: "اذا فعلت،" + please_click: "الرجاء النقر هنا لإعادة تعيين كلمة المرور" + embedlink: + copy: "نسخ إلى الحافظة" + error: + COMMENT_PARENT_NOT_VISIBLE: "التعليق الذي ترد عليه تمت إزالته أو غير موجود." + EMAIL_VERIFICATION_TOKEN_INVALID: "رمز التحقق من البريد الإلكتروني غير صالح." + PASSWORD_RESET_TOKEN_INVALID: "رابط إعادة تعيين كلمة المرور غير صالح." + COMMENT_TOO_SHORT: "يجب أن تكون التعليقات أكثر من حرف واحد، يرجى مراجعة تعليقك وإعادة المحاولة." + NOT_AUTHORIZED: "غير مصرح لك بتنفيذ هذا الإجراء." + NO_SPECIAL_CHARACTERS: "يمكن أن تحتوي أسماء المستخدمين على أحرف, أرقام و _ فقط" + PASSWORD_LENGTH: "كلمة المرور قصيرة جدا" + PROFANITY_ERROR: "يجب ألا تحتوي أسماء المستخدمين على الألفاظ النابية. يرجى الاتصال بالإداري إذا كنت تعتقد أن هذا خطأ." + RATE_LIMIT_EXCEEDED: "تجاوز حد المعدل" + USERNAME_IN_USE: "اسم المستخدم قيد الاستخدام" + USERNAME_REQUIRED: "يجب إدخال اسم مستخدم" + EMAIL_NOT_VERIFIED: "لم يتم التحقق من عنوان البريد الإلكتروني" + EDIT_WINDOW_ENDED: "لم يعد بإمكانك تحرير هذا التعليق. نافذة الوقت للقيام بذلك قد انتهت صلاحيتها." + EDIT_USERNAME_NOT_AUTHORIZED: "ليس لديك إذن بتحديث اسم المستخدم الخاص بك." + SAME_USERNAME_PROVIDED: "يجب عليك تقديم اسم مستخدم مختلف." + EMAIL_IN_USE: "البريد الالكتروني قيد الاستخدام" + EMAIL_REQUIRED: "مطلوب عنوان البريد الإلكتروني" + LOGIN_MAXIMUM_EXCEEDED: "لقد أجريت العديد من محاولات إدخال كلمة المرور غير الناجحة. أرجو الإنتظار." + PASSWORD_REQUIRED: "يجب إدخال كلمة مرور" + COMMENTING_CLOSED: "تم إغلاق فاعلية التعليق" + NOT_FOUND: "المورد غير موجود" + ALREADY_EXISTS: "المورد موجود من قبل" + INVALID_ASSET_URL: "رابط المادة غير صالح" + CANNOT_IGNORE_STAFF: "لا يمكن تجاهل الموظفين." + email: "ليس بريدا إلكترونيا صالحا" + confirm_password: "كلمات المرور غير متطابقة. يرجى التحقق مرة أخرى" + network_error: "فشل الاتصال بالخادم. تحقق من اتصالك بالإنترنت وحاول مرة أخرى." + email_not_verified: "عنوان البريد الإلكتروني {0} لم يتم التحقق منه." + email_password: "مجموعة البريد الإلكتروني و / أو كلمة المرور غير صحيحة." + organization_name: "يجب أن يحتوي اسم المؤسسة على أحرف أو أرقام فقط." + password: "يجب أن تكون كلمة المرور 8 أحرف على الأقل" + username: "يمكن أن تحتوي أسماء المستخدمين على أرقام, أحرف و _ فقط" + unexpected: "حدث خطأ غير متوقع. آسف!" + required_field: "هذه الخانة مطلوبه" + temporarily_suspended: "حسابك معلق حاليا. سيتم إعادة تنشيطه {0}. يرجى الاتصال بنا إذا كان لديك أي أسئلة." + flag_comment: "الإبلاغ عن تعليق" + flag_reason: "سبب الإبلاغ (اختياري)" + flag_username: "بلغ عن اسم المستخدم" + framework: + banned_account_header: "حسابك محظور حاليا." + banned_account_body: "هذا يعني أنه لا يمكنك الإعجاب ، أو الإبلاغ ، أو كتابة التعليقات." + comment: تعليق + comment_is_ignored: "هذا التعليق مخفي لأنك تجاهلت هذا المستخدم." + comment_is_rejected: "لقد رفضت هذا التعليق." + comment_is_hidden: "هذا التعليق غير متاح." + comments: تعليقات + configure_stream: "تهيئة" + content_not_available: "هذا المحتوى غير متوفر" + edit_name: + button: أرسل + error: "يمكن أن تحتوي أسماء المستخدمين على أحرف, أرقام و _ فقط" + label: "اسم مستخدم جديد" + msg: "تم تعليق حسابك حاليا نظرا لأن اسم المستخدم قد اعتبر غير لائق. لاستعادة حسابك، يرجى إدخال اسم مستخدم جديد. يرجى الاتصال بنا إذا كان لديك أي أسئلة." + changed_name: + msg: "يتم مراجعة تغيير اسم المستخدم من قبل فريق الإشراف لدينا." + my_comments: "تعليقاتي" + my_profile: "ملفي" + new_count: "شاهد {0} أكثر {1}" + profile: الملف الشخصي + show_all_comments: "عرض كل التعليقات" + success_bio_update: "تم تحديث السيرة الذاتية" + success_name_update: "تم تحديث اسم المستخدم" + success_update_settings: "تم تطبيق التغييرات التي أجريتها على جدول التعليقات في هذه المقالة" + show_all_replies: عرض جميع الردود + show_more_replies: عرض المزيد من الردود + view_more_comments: "عرض مزيد من التعليقات" + view_reply: "عرض الرد" + from_settings_page: "من صفحة الملف الشخصي يمكنك مشاهدة سجل التعليقات." + like: إعجاب + loading_results: "جار تحميل النتائج" + marketing: "هذا يشبه الإعلان / التسويق" + moderate_this_stream: "أشرف على هذا الجدول" + flags: + reasons: + user: + username_offensive: "مسيء" + username_nolike: "لم يعجبنى" + username_impersonating: "إنتحال شخصية" + username_spam: "غير مرغوب فيه" + username_other: "آخر" + comment: + comment_offensive: "مسيء" + comment_spam: "غير مرغوب فيه" + comment_noagree: "أعارض" + comment_other: "آخر" + suspect_word: "كلمة مشتبهة" + banned_word: "كلمة محظورة" + body_count: "يتجاوز النص الحد الأقصى للطول المسموح" + trust: "ثقة" + links: "رابط" + modqueue: + account: "account flags" + actions: Actions + all: all + all_streams: "All Streams" + notify_edited: '{0} edited comment "{1}"' + notify_accepted: '{0} accepted comment "{1}"' + notify_rejected: '{0} rejected comment "{1}"' + notify_flagged: '{0} flagged comment "{1}"' + notify_reset: '{0} reset status of comment "{1}"' + approve: "Approve" + approved: "Approved" + ban_user: "Ban" + billion: B + close: Close + empty_queue: "No more comments to moderate! You're all caught up. Go have some ☕️" + flagged: flagged + reported: reported + less_detail: "Less detail" + likes: likes + million: M + mod_faster: "Moderate faster with keyboard shortcuts" + moderate: "Moderate →" + more_detail: "More detail" + new: New + newest_first: "Newest First" + navigation: Navigation + next_comment: "Go to the next comment" + toggle_search: "Open search" + next_queue: "Switch queues" + oldest_first: "Oldest First" + premod: pre-mod + prev_comment: "Go to the previous comment" + reject: "Reject" + rejected: "Rejected" + reply: "Reply" + select_stream: "Select Stream" + shift_key: "⇧" + shortcuts: "Shortcuts" + sort: "Sort" + show_shortcuts: "Show Shortcuts" + singleview: "Zen mode" + thismenu: "Open this menu" + jump_to_queue: "Jump to specific queue" + thousand: k + try_these: "Try these" + view_more_shortcuts: "View more shortcuts" + my_comment_history: "سجل التعليقات" + name: اسم + no_agree_comment: "لا أوافق على هذا التعليق" + no_like_bio: "أنا لا أحب هذه السيرة الذاتية" + no_like_username: "أنا لا أحب اسم المستخدم هذا" + already_flagged_username: "لقد سبق لك وضع علامة باسم المستخدم هذا." + other: آخر + permalink: شارك + personal_info: "هذا التعليق يكشف عن معلومات تعريف شخصية" + post: نشر + profile: الملف الشخصي + profile_settings: "إعدادات الملف الشخصي" + reply: رد + report: أبلغ + report_notif: "شكرا على الإبلاغ عن هذا التعليق. تم إبلاغ فريق الإشراف لدينا وسيراجعه قريبًا." + report_notif_remove: "لقد تمت إزالة بلاغك." + reported: بلغ عنه + comment_history_blank: + title: You have not written any comments + info: A history of your comments will appear here + settings: + from_settings_page: "من صفحة الملف الشخصي يمكنك مشاهدة سجل التعليقات." + my_comment_history: "سجل التعليقات" + profile: الملف الشخصي + profile_settings: "إعدادات الملف الشخصي" + sign_in: "تسجيل الدخول" + to_access: "للوصول إلى الملف الشخصي" + user_no_comment: "لم تترك تعليقا مطلقا. إنضم إلى المحادثة!" + stream: + all_comments: "كل التعليقات" + temporarily_suspended: "وفقا لإرشادات المجموعة {0}، تم تعليق حسابك مؤقتا. الرجاء إعادة الانضمام إلى المحادثة {1}." + comment_not_found: "تمت إزالة هذا التعليق أو أنه غير موجود." + no_comments: "لا توجد تعليقات حتى الآن، لماذا لا تكتب واحد؟" + no_comments_and_closed: "لم تكن هناك تعليقات على هذه المقالة." + step_1_header: "بلغ عن مشكلة" + step_2_header: "ساعدنا على الفهم" + step_3_header: "شكرا لك على المساهمة الخاصة بك" + streams: + all: All + article: Story + closed: Closed + empty_result: "No assets match this search. Maybe try widening your search?" + filter_streams: "Filter Streams" + newest: Newest + oldest: Oldest + open: Open + pubdate: "Publication Date" + search: Search + sort_by: "Sort By" + status: "Stream Status" + stream_status: "Stream Status" + suspenduser: + title_suspend: "Suspend User" + description_suspend: "You are suspending {0}. This comment will go to the Rejected queue, and {0} will not be allowed to like, report, reply or post until the suspension time is complete." + select_duration: "Select suspension duration" + one_hour: "1 hour" + hours: "{0} hours" + days: "{0} days" + hour: "{0} hours" + day: "{0} days" + cancel: "Cancel" + suspend_user: "Suspend User" + email_message_suspend: "Dear {0},\n\nIn accordance with {1}’s community guidelines, your account has been temporarily suspended. During the suspension, you will be unable to comment, flag or engage with fellow commenters. Please rejoin the conversation {2}." + title_notify: "Notify the user of their temporary suspension" + notify_suspend_until: "User {0} has been temporarily suspended. This suspension will automatically end {1}." + description_notify: "Suspending this user will temporarily disable their account." + write_message: "Write a message" + send: Send + reject_username: + username: username + no_cancel: "No cancel" + description_reject: "Would you like to temporarily ban this user because of their {0}? Doing so will temporarily suspend this user until they rewrite their {0}." + title_notify: "Notify the user of their temporary suspension" + description_notify: "Suspending this user will temporarily disable their account." + title_reject: "We noticed you rejected a username" + suspend_user: "Suspend User" + yes_suspend: "Yes suspend" + email_message_reject: "Another member of the community recently flagged your username for review. Because of its content your user was rejected. This means you can no longer comment, like, or flag content until you rewrite your username. Please e-mail us if you have any questions or concerns." + write_message: "Write a message" + send: Send + thank_you: "نحن نقدر سلامتك وردود الفعل. سيراجع المشرف التقرير الخاص بك" + user: + bio_flags: "flags for this bio" + user_bio: "User Bio" + username_flags: "flags for this username" + user_detail: + remove_suspension: "Remove Suspension" + suspend: "Suspend User" + remove_ban: "Remove Ban" + ban: "Ban User" + member_since: "Member Since" + email: "Email" + total_comments: "Total Comments" + reject_rate: "Reject Rate" + reports: "Reports" + all: "All" + rejected: "Rejected" + account_history: "Account History" + account_history: + user_banned: "User banned" + ban_removed: "Ban removed" + username_status: "Username {0}" + suspended: "Suspended, {0}" + suspension_removed: "Suspension removed" + system: "System" + date: "Date" + action: "Action" + taken_by: "Taken By" + user_impersonating: "هذا المستخدم ينتحل شخصية" + user_no_comment: "لم تترك تعليقا مطلقا. إنضم إلى المحادثة!" + username_offensive: "اسم المستخدم هذا مسيء" + view_conversation: "عرض المحادثة" + install: + initial: + description: "Let's set up your Talk community in just a few short steps." + submit: "Get Started" + add_organization: + description: "Please tell us the name of your organization. This will appear in emails when inviting new team members." + label: "Organization Name" + save: "Save" + create: + email: "Email address" + username: "Username" + password: "Password" + confirm_password: "Confirm Password" + save: "Save" + permitted_domains: + title: "Permitted domains" + description: "Enter the domains you would like to permit for Talk, e.g. your local, staging and production environments (ex. localhost:3000, staging.domain.com, domain.com)." + submit: "Finish install" + final: + description: "Thanks for installing Talk! We sent an email to verify your email address. While you finish setting up the account, you can start engaging with your readers now." + launch: "Launch Talk" + close: "Close this Installer" + admin_sidebar: + view_options: "View Options" + sort_comments: "Sort Comments" diff --git a/plugins/talk-plugin-akismet/client/translations.yml b/plugins/talk-plugin-akismet/client/translations.yml index 6cc19a4925..3dd13731ba 100644 --- a/plugins/talk-plugin-akismet/client/translations.yml +++ b/plugins/talk-plugin-akismet/client/translations.yml @@ -1,3 +1,17 @@ +ar: + error: + COMMENT_IS_SPAM: | + تبدو اللغة في هذا التعليق مثل الرسائل غير المرغوب فيها. تستطيع تعديل التعليق أو تقديمه على أي حال لمراجعة مشرف. + talk-plugin-akismet: + spam: "بريد غير مرغوب فيه" + spam_comment: "بريد غير مرغوب فيه" + detected: "الكشف عنها من قبل Akismet" + still_spam: | + شكرا لكم. سيراجع فريق الإشراف لدينا تعليقك قريبا. + flags: + reasons: + comment: + spam_comment: "تم اكتشاف الرسائل غير المرغوب فيها" da: error: COMMENT_IS_SPAM: | @@ -61,7 +75,7 @@ fr: nl_NL: error: COMMENT_IS_SPAM: | - Deze reactie ziet er uit als spam. Je kan je reactie + Deze reactie ziet er uit als spam. Je kan je reactie wijzigen, of indienen zodat ons moderatieteam het kan beoordelen. talk-plugin-akismet: spam: "Spam" diff --git a/plugins/talk-plugin-auth/client/translations.yml b/plugins/talk-plugin-auth/client/translations.yml index 9731da90a0..6d6f8a6d6e 100644 --- a/plugins/talk-plugin-auth/client/translations.yml +++ b/plugins/talk-plugin-auth/client/translations.yml @@ -1,3 +1,48 @@ +ar: + talk-plugin-auth: + login: + email_verify_cta: "يرجى التحقق من عنوان البريد الإلكتروني الخاص بك." + request_new_verify_email: "طلب بريد إلكتروني آخر" + verify_email: "شكرا لك على إنشاء حساب جديد! لقد أرسلنا رسالة إلكترونية إلى البريد الإلكتروني الذي قدمته للتحقق من حسابك." + verify_email2: "يجب إثبات ملكية حسابك قبل التفاعل مع المجموعة." + not_you: "ليس انت؟" + logged_in_as: "تسجيل الدخول ك" + facebook_sign_in: "تسجيل الدخول باستخدام الفيسبوك" + facebook_sign_up: "اشترك عبر حساب فايسبوك" + logout: "خروج" + sign_in: "تسجيل الدخول" + sign_in_to_join: "سجل الدخول للانضمام إلى المحادثة" + or: "أو" + email: "البريد الإلكتروني" + password: "كلمة المرور" + forgot_your_pass: "نسيت كلمة المرور؟" + need_an_account: "تحتاج الى حساب؟" + register: "تسجيل" + sign_up: "سجل" + confirm_password: "تأكيد كلمة المرور" + username: "اسم المستخدم" + already_have_an_account: "هل لديك حساب؟" + recover_password: "إستعادة كلمة المرور" + email_in_use: "البريد الالكتروني قيد الاستخدام" + email_or_username_in_use: "البريد الإلكتروني أو اسم المستخدم قيد الاستخدام" + required_field: "هذه الخانة مطلوبه" + passwords_dont_match: "كلمات المرور غير متطابقة." + special_characters: "يمكن أن تحتوي أسماء المستخدمين على أحرف وأرقام و _ فقط" + sign_in_to_comment: "تسجيل الدخول للتعليق" + check_the_form: "استمارة غير صالحة. يرجى التحقق من الحقول" + set_username_dialog: + check_the_form: "استمارة غير صالحة. يرجى التحقق من الحقول" + continue: "تابع بنفس اسم المستخدم الخاص بفيسبوك" + error_create: "حدث خطأ أثناء تغيير اسم المستخدم" + fake_comment_body: "هذا مثال للتعليق. يمكن للقراء تبادل الأفكار والآراء مع غرف الأخبار في قسم التعليقات." + fake_comment_date: "منذ دقيقة" + if_you_dont_change_your_name: "إذا لم تقم بتغيير اسم المستخدم الخاص بك في هذه الخطوة سوف يظهر اسم المستخدم الخاص بفيسبوك جنبا إلى جنب مع كل تعليقاتك." + required_field: "حقل مطلوب" + save: حفظ + special_characters: "يمكن أن تحتوي أسماء المستخدمين على أحرف, أرقام و _ فقط" + username: اسم المستخدم + write_your_username: "عدل اسم المستخدم" + your_username: "يظهر اسم المستخدم في كل تعليق تنشره." da: talk-plugin-auth: login: diff --git a/plugins/talk-plugin-author-menu/client/translations.yml b/plugins/talk-plugin-author-menu/client/translations.yml index 34f270d50b..4335b17e1c 100644 --- a/plugins/talk-plugin-author-menu/client/translations.yml +++ b/plugins/talk-plugin-author-menu/client/translations.yml @@ -1,3 +1,5 @@ +ar: + talk-plugin-author-menu: da: talk-plugin-author-menu: en: diff --git a/plugins/talk-plugin-facebook-auth/client/translations.yml b/plugins/talk-plugin-facebook-auth/client/translations.yml index ab72134f45..ff2ba457de 100644 --- a/plugins/talk-plugin-facebook-auth/client/translations.yml +++ b/plugins/talk-plugin-facebook-auth/client/translations.yml @@ -1,3 +1,7 @@ +ar: + talk-plugin-facebook-auth: + sign_in: "تسجيل الدخول عبر حساب الفيسبوك" + sign_up: "اشترك عبر حساب الفيسبوك" en: talk-plugin-facebook-auth: sign_in: "Sign in with Facebook" @@ -21,4 +25,4 @@ zh_TW: de: talk-plugin-facebook-auth: sign_in: "Mit Facebook anmelden" - sign_up: "Mit Facebook registrieren" \ No newline at end of file + sign_up: "Mit Facebook registrieren" diff --git a/plugins/talk-plugin-featured-comments/client/translations.yml b/plugins/talk-plugin-featured-comments/client/translations.yml index 003372403f..8b4aeefda3 100644 --- a/plugins/talk-plugin-featured-comments/client/translations.yml +++ b/plugins/talk-plugin-featured-comments/client/translations.yml @@ -1,3 +1,18 @@ +ar: + talk-plugin-featured-comments: + un_feature: إلغاء التميّز + feature: ميّز + featured: متميز + featured_comments: التعليقات المميزة + go_to_conversation: انتقل إلى المحادثة + tooltip_description: تعليقات مختارة من قبل فريقنا تستحق القراءة + notify_self_featured: 'التعليق من {0} هو الآن مميّز و موافق عليه' + notify_featured: '{0} ميّز و وافق على التعليق "{1}"' + notify_unfeatured: '{0} ألغي تميّز التعليق "{1}"' + feature_comment: ميّز التعليق؟ + are_you_sure: هل أنت متأكد أنك تريد تميّز هذا التعليق؟ + cancel: إلغاء + yes_feature_comment: نعم، ميّز التعليق؟ da: talk-plugin-featured-comments: un_feature: Un-Feature diff --git a/plugins/talk-plugin-flag-details/client/translations.yml b/plugins/talk-plugin-flag-details/client/translations.yml index b0fe6ccae2..163cb8a5df 100644 --- a/plugins/talk-plugin-flag-details/client/translations.yml +++ b/plugins/talk-plugin-flag-details/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-flag-details: + flags: تقارير da: talk-plugin-flag-details: flags: Reports diff --git a/plugins/talk-plugin-google-auth/client/translations.yml b/plugins/talk-plugin-google-auth/client/translations.yml index fd926f3ee3..c686230d6c 100644 --- a/plugins/talk-plugin-google-auth/client/translations.yml +++ b/plugins/talk-plugin-google-auth/client/translations.yml @@ -1,3 +1,7 @@ +ar: + talk-plugin-google-auth: + sign_in: "تسجيل الدخول عبر حساب جوجل" + sign_up: "اشترك عبر حساب جوجل" en: talk-plugin-google-auth: sign_in: "Sign in with Google" diff --git a/plugins/talk-plugin-ignore-user/client/translations.yml b/plugins/talk-plugin-ignore-user/client/translations.yml index 33e5b10ed1..84a4ca11c1 100644 --- a/plugins/talk-plugin-ignore-user/client/translations.yml +++ b/plugins/talk-plugin-ignore-user/client/translations.yml @@ -1,3 +1,15 @@ +ar: + talk-plugin-ignore-user: + section_title: المستخدمون الذين تم تجاهلهم + section_info: لأنك تجاهلت المعلقين التاليين، يتم إخفاء تعليقاتهم. + stop_ignoring: إيقاف التجاهل + ignore_user: تجاهل المستخدم + cancel: إلغاء + confirmation: | + عند تجاهل المستخدم، سيتم إخفاء جميع التعليقات التي كتبها على الموقع منك. يمكنك التراجع عن هذا لاحقا من ملفي الشخصي. + notify_success: | + أنت الآن تتجاهل {0}. يمكنك التراجع عن هذا الإجراء من ملفي الشخصي. + confirmation_title: تجاهل {0}؟ da: talk-plugin-ignore-user: section_title: Ignored users diff --git a/plugins/talk-plugin-like/client/translations.yml b/plugins/talk-plugin-like/client/translations.yml index 5f44db4c70..f122aa0248 100644 --- a/plugins/talk-plugin-like/client/translations.yml +++ b/plugins/talk-plugin-like/client/translations.yml @@ -1,3 +1,7 @@ +ar: + talk-plugin-like: + like: أعجبني + liked: إعجاب da: talk-plugin-like: like: Like diff --git a/plugins/talk-plugin-love/client/translations.yml b/plugins/talk-plugin-love/client/translations.yml index 24744c2f99..872d77460d 100644 --- a/plugins/talk-plugin-love/client/translations.yml +++ b/plugins/talk-plugin-love/client/translations.yml @@ -1,3 +1,7 @@ +ar: + talk-plugin-love: + love: Love + loved: Loved da: talk-plugin-love: love: Love diff --git a/plugins/talk-plugin-member-since/client/translations.yml b/plugins/talk-plugin-member-since/client/translations.yml index f63f5a1fd1..ab194c61e8 100644 --- a/plugins/talk-plugin-member-since/client/translations.yml +++ b/plugins/talk-plugin-member-since/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-member-since: + member_since: "عضو منذ" da: talk-plugin-member-since: member_since: "Member Since" diff --git a/plugins/talk-plugin-moderation-actions/client/translations.yml b/plugins/talk-plugin-moderation-actions/client/translations.yml index 9052d03f53..191df68fe7 100644 --- a/plugins/talk-plugin-moderation-actions/client/translations.yml +++ b/plugins/talk-plugin-moderation-actions/client/translations.yml @@ -1,3 +1,15 @@ +ar: + talk-plugin-moderation-actions: + reject_comment: "رفض" + approve_comment: "موافقة" + approved_comment: "موافق عليه" + moderation_actions: "إجراءات الإشراف" + ban_user: "حجب المستخدم" + ban_user_dialog_sub: "هل أنت متأكد أنك تريد حجب هذا المستخدم؟" + ban_user_dialog_copy: "ملاحظة: سيؤدي حجب هذا المستخدم أيضا إلى وضع هذا التعليق في قائمة الرفض." + ban_user_dialog_cancel: "إلغاء" + ban_user_dialog_yes: "نعم، احجب المستخدم" + ban_user_dialog_headline: "احجب المستخدم؟" da: talk-plugin-moderation-actions: reject_comment: "Reject" diff --git a/plugins/talk-plugin-offtopic/client/translations.json b/plugins/talk-plugin-offtopic/client/translations.json index 826b3e15b3..c923c7c172 100644 --- a/plugins/talk-plugin-offtopic/client/translations.json +++ b/plugins/talk-plugin-offtopic/client/translations.json @@ -1,4 +1,8 @@ { + "ar": { + "off_topic": "خارج الموضوع", + "hide_off_topic": "إخفاء التعليقات التي خارجة عن الموضوع" + }, "da": { "off_topic": "Off Topic", "hide_off_topic": "Hide Off-Topic Comments" diff --git a/plugins/talk-plugin-profile-settings/client/translations.yml b/plugins/talk-plugin-profile-settings/client/translations.yml index cd8edb4154..33805a49b3 100644 --- a/plugins/talk-plugin-profile-settings/client/translations.yml +++ b/plugins/talk-plugin-profile-settings/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-profile-settings: + tab: إعدادات en: talk-plugin-profile-settings: tab: Settings diff --git a/plugins/talk-plugin-respect/client/translations.yml b/plugins/talk-plugin-respect/client/translations.yml index 22497ea521..f7540e545c 100644 --- a/plugins/talk-plugin-respect/client/translations.yml +++ b/plugins/talk-plugin-respect/client/translations.yml @@ -1,3 +1,7 @@ +ar: + talk-plugin-respect: + respect: احترم + respected: احترام da: talk-plugin-respect: respect: Respect diff --git a/plugins/talk-plugin-sort-most-liked/client/translations.yml b/plugins/talk-plugin-sort-most-liked/client/translations.yml index f9e48d261f..963561cfd8 100644 --- a/plugins/talk-plugin-sort-most-liked/client/translations.yml +++ b/plugins/talk-plugin-sort-most-liked/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-sort-most-liked: + label: الأكثر إعجاباً أولاً da: talk-plugin-sort-most-liked: label: Most liked first diff --git a/plugins/talk-plugin-sort-most-loved/client/translations.yml b/plugins/talk-plugin-sort-most-loved/client/translations.yml index c290e4a533..dfb24ff442 100644 --- a/plugins/talk-plugin-sort-most-loved/client/translations.yml +++ b/plugins/talk-plugin-sort-most-loved/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-sort-most-loved: + label: الأكثر حبً أولاً da: talk-plugin-sort-most-loved: label: Most loved first diff --git a/plugins/talk-plugin-sort-most-replied/client/translations.yml b/plugins/talk-plugin-sort-most-replied/client/translations.yml index dacdb93fb3..1325d9dd11 100644 --- a/plugins/talk-plugin-sort-most-replied/client/translations.yml +++ b/plugins/talk-plugin-sort-most-replied/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-sort-most-replied: + label: الأكثر ردودً أولاً da: talk-plugin-sort-most-replied: label: Most replied first diff --git a/plugins/talk-plugin-sort-most-respected/client/translations.yml b/plugins/talk-plugin-sort-most-respected/client/translations.yml index 736cc63c12..7821452378 100644 --- a/plugins/talk-plugin-sort-most-respected/client/translations.yml +++ b/plugins/talk-plugin-sort-most-respected/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-sort-most-respected: + label: الأكثر احتراماً أولاً da: talk-plugin-sort-most-respected: label: Most respected first diff --git a/plugins/talk-plugin-sort-newest/client/translations.yml b/plugins/talk-plugin-sort-newest/client/translations.yml index e85eec18e1..294a1a0709 100644 --- a/plugins/talk-plugin-sort-newest/client/translations.yml +++ b/plugins/talk-plugin-sort-newest/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-sort-newest: + label: الأحدث أولاً da: talk-plugin-sort-newest: label: Newest first diff --git a/plugins/talk-plugin-sort-oldest/client/translations.yml b/plugins/talk-plugin-sort-oldest/client/translations.yml index f12fe8e433..7a6cd6e969 100644 --- a/plugins/talk-plugin-sort-oldest/client/translations.yml +++ b/plugins/talk-plugin-sort-oldest/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-sort-oldest: + label: الأقدم أولاً da: talk-plugin-sort-oldest: label: Oldest first diff --git a/plugins/talk-plugin-subscriber/client/translations.yml b/plugins/talk-plugin-subscriber/client/translations.yml index 65b438779d..4cf4829787 100644 --- a/plugins/talk-plugin-subscriber/client/translations.yml +++ b/plugins/talk-plugin-subscriber/client/translations.yml @@ -1,3 +1,6 @@ +ar: + talk-plugin-subscriber: + subscriber: "Subscriber" da: talk-plugin-subscriber: subscriber: "Subscriber" diff --git a/plugins/talk-plugin-toxic-comments/client/translations.yml b/plugins/talk-plugin-toxic-comments/client/translations.yml index 10fe80ec3b..73c993ec5b 100644 --- a/plugins/talk-plugin-toxic-comments/client/translations.yml +++ b/plugins/talk-plugin-toxic-comments/client/translations.yml @@ -1,3 +1,19 @@ +ar: + error: + COMMENT_IS_TOXIC: | + هل أنت واثق؟ قد تنتهك اللغة الواردة في هذا التعليق إرشادات المجموعة. يمكنك تعديل التعليق أو إرساله لمراجعته. + talk-plugin-toxic-comments: + unlikely: "من غير المرجح" + highly_likely: "من المرجح جدا" + possibly: "ربما" + likely: "مرجح" + toxic_comment: "تعليق سام" + still_toxic: | + قد يظل هذا التعليق المعدل منتهكاً لإرشادات المجموعة. سيراجع فريق الإشراف لدينا تعليقك قريبا. + flags: + reasons: + comment: + toxic_comment: "من المرجح جدا أن يكون ساماً" da: error: COMMENT_IS_TOXIC: | diff --git a/plugins/talk-plugin-viewing-options/client/translations.yml b/plugins/talk-plugin-viewing-options/client/translations.yml index 1e4eada60d..9586263e0a 100644 --- a/plugins/talk-plugin-viewing-options/client/translations.yml +++ b/plugins/talk-plugin-viewing-options/client/translations.yml @@ -1,3 +1,8 @@ +ar: + talk-plugin-viewing-options: + viewing_options: "خيارات العرض" + sort: فرز + filter: تصفية da: talk-plugin-viewing-options: viewing_options: "Viewing Options" diff --git a/test/server/services/tokens.js b/test/server/services/tokens.js index 7ff598936b..b62aa328ad 100644 --- a/test/server/services/tokens.js +++ b/test/server/services/tokens.js @@ -19,7 +19,7 @@ describe('services.TokensService', () => { describe('#create', () => { it('can create the token without error', async () => { - let token = await TokensService.create(user.id, 'Github Token'); + let token = await TokensService.create(user.id, 'GitHub Token'); expect(token).to.be.an.object; expect(token.jwt).to.be.a.string; expect(token.pat).to.be.an.object; @@ -35,7 +35,7 @@ describe('services.TokensService', () => { describe('#revoke', () => { it('can revoke a token', async () => { - let { pat: { id } } = await TokensService.create(user.id, 'Github Token'); + let { pat: { id } } = await TokensService.create(user.id, 'GitHub Token'); let tokens = await TokensService.list(user.id); expect(tokens).to.have.length(1); @@ -54,7 +54,7 @@ describe('services.TokensService', () => { describe('#validate', () => { it('will allow a valid token', async () => { // Create a token. - let { pat: { id } } = await TokensService.create(user.id, 'Github Token'); + let { pat: { id } } = await TokensService.create(user.id, 'GitHub Token'); // Validate it. await TokensService.validate(user.id, id); @@ -62,7 +62,7 @@ describe('services.TokensService', () => { it('will not allow an invalid token', async () => { // Create a token. - let { pat: { id } } = await TokensService.create(user.id, 'Github Token'); + let { pat: { id } } = await TokensService.create(user.id, 'GitHub Token'); // Revoke it. await TokensService.revoke(user.id, id); @@ -78,7 +78,7 @@ describe('services.TokensService', () => { expect(tokens).to.have.length(0); // Create a token. - let { pat: { id } } = await TokensService.create(user.id, 'Github Token'); + let { pat: { id } } = await TokensService.create(user.id, 'GitHub Token'); tokens = await TokensService.list(user.id); expect(tokens).to.have.length(1);