Пожалуйста, отправьте письмо по адресу {{emailID}} с вашего зарегистрированного адреса электронной почты.
Ваш запрос будет обработан в течение 72 часов
", - "change_email": "Изменить email адрес", + "change_email": "Изменить адрес электронной почты", "ok": "ОК", "success": "Успешно", "error": "Ошибка", - "note": "", + "note": "Заметка", "offline_message": "Вы не в сети, кэшированные воспоминания отображаются", "install": "Устанавливать", "install_mobile_app": "Установите наше приложение Android или iOS для автоматического резервного копирования всех ваших фотографий", @@ -226,11 +226,11 @@ "delete_photos": "Удалить фото", "keep_photos": "Оставить фото", "share_album": "Поделиться альбомом", - "sharing_with_self": "", - "sharing_already_shared": "", + "sharing_with_self": "Вы не можете поделиться с самим собой", + "sharing_already_shared": "Вы уже поделились этим с {{email}}", "sharing_album_not_allowed": "Делиться альбомом запрещено", "sharing_disabled_for_free_accounts": "Совместное использование отключено для бесплатных аккаунтов", - "sharing_user_does_not_exist": "", + "sharing_user_does_not_exist": "Пользователь с такой электронной почтой не найден", "search": "Поиск", "search_results": "Результаты поиска", "no_results": "Ничего не найдено", @@ -246,9 +246,9 @@ "terms_and_conditions": "Я согласен с тем, что условия и политика конфиденциальности", "people": "Люди", "indexing_scheduled": "Индексация запланирована...", - "indexing_photos": "", - "indexing_fetching": "", - "indexing_people": "", + "indexing_photos": "Обновление индексов...", + "indexing_fetching": "Синхронизация индексов...", + "indexing_people": "Синхронизация людей...", "syncing_wait": "Синхронизация...", "people_empty_too_few": "Люди будут показаны здесь, когда будет достаточно фотографий человека", "unnamed_person": "Безымянный человек", @@ -371,7 +371,7 @@ "leave_shared_album": "Да, уходи", "confirm_remove_message": "Выбранные элементы будут удалены из этого альбома. Элементы, которые есть только в этом альбоме, будут перемещены в раздел Без категории.", "confirm_remove_incl_others_message": "Некоторые из удаляемых вами элементов были добавлены другими пользователями, и вы потеряете к ним доступ.", - "oldest": "Старейший", + "oldest": "Самые старые", "last_updated": "Последнее обновление", "name": "Имя", "fix_creation_time": "Назначьте время", @@ -388,7 +388,7 @@ "sharing_details": "Обмен подробностями", "modify_sharing": "Изменить общий доступ", "add_collaborators": "Добавление соавторов", - "add_new_email": "Добавить новый email адрес", + "add_new_email": "Добавить новую электронную почту", "shared_with_people_count_zero": "Делитесь с конкретными людьми", "shared_with_people_count_one": "Совместно с 1 человеком", "shared_with_people_count": "Поделился с {{count, number}} люди", @@ -495,8 +495,8 @@ "stop_watching_folder_message": "Ваши существующие файлы не будут удалены, но Ente прекратит автоматическое обновление связанного альбома Ente при внесении изменений в эту папку.", "yes_stop": "Да, остановись", "change_folder": "Изменить папку", - "view_logs": "", - "view_logs_message": "", + "view_logs": "Просмотреть логи", + "view_logs_message": "При этом будут показаны журналы отладки, которые вы можете отправить нам по электронной почте, чтобы помочь в устранении вашей проблемы.
Обратите внимание, что будут указаны имена файлов, которые помогут отслеживать проблемы с конкретными файлами.
", "weak_device_hint": "Используемый вами веб-браузер недостаточно мощный, чтобы зашифровать ваши фотографии. Пожалуйста, попробуйте войти в Ente на своем компьютере или загрузить мобильное/настольное приложение Ente.", "drag_and_drop_hint": "Или перетащите в основное окно", "authenticate": "Проверка подлинности", @@ -595,8 +595,8 @@ "image": "Изображение", "video": "Видео", "live_photo": "Живое фото", - "live": "", - "edit_image": "", + "live": "Прямая трансляция", + "edit_image": "Редактировать изображение", "photo_editor": "Редактор фото", "confirm_editor_close": "Вы уверены, что хотите закрыть редактор?", "confirm_editor_close_message": "Загрузите отредактированное изображение или сохраните копию в ente, чтобы сохранить внесенные изменения.", @@ -625,9 +625,9 @@ "reset": "Сбросить", "faster_upload": "Более быстрая загрузка данных", "faster_upload_description": "Загрузка маршрута через близлежащие серверы", - "open_ente_on_startup": "", + "open_ente_on_startup": "Открывать Enter при запуске", "cast_album_to_tv": "Воспроизвести альбом на ТВ", - "cast_to_tv": "", + "cast_to_tv": "Воспроизвести на ТВ", "enter_cast_pin_code": "Введите код, который вы видите на экране телевизора ниже, чтобы выполнить сопряжение с этим устройством.", "code": "Код", "pair_device_to_tv": "Сопряжение устройств", @@ -639,7 +639,7 @@ "pair_with_pin": "Соединение с помощью булавки", "pair_with_pin_description": "Пара с PIN-кодом работает с любым экраном, на котором вы хотите посмотреть ваш альбом.", "visit_cast_url": "Перейдите на страницу {{url}} на устройстве, которое вы хотите подключить.", - "passkeys": "Passkeys", + "passkeys": "Ключ доступа", "passkey_fetch_failed": "Не удалось получить ваши ключи.", "manage_passkey": "Управление ключами", "delete_passkey": "Удалить пароль", @@ -675,15 +675,15 @@ "server_endpoint": "Конечная точка сервера", "more_information": "Дополнительная информация", "save": "Сохранить", - "theme": "", - "system": "", - "light": "", - "dark": "", - "streamable_videos": "", - "processing_videos_status": "", - "share_favorites": "", - "person_favorites": "", - "shared_favorites": "", - "added_by_name": "", - "unowned_files_not_processed": "" + "theme": "Тема", + "system": "Системная", + "light": "Светлая", + "dark": "Тёмная", + "streamable_videos": "Потоковое видео", + "processing_videos_status": "Обработка видео...", + "share_favorites": "Поделиться избранными", + "person_favorites": "{{name}} избранных", + "shared_favorites": "Общие избранные", + "added_by_name": "Добавлено {{name}}", + "unowned_files_not_processed": "Файлы, добавленные другими пользователями, не были обработаны" } diff --git a/web/packages/base/locales/vi-VN/translation.json b/web/packages/base/locales/vi-VN/translation.json index 6b3904aca7..6212bc57a2 100644 --- a/web/packages/base/locales/vi-VN/translation.json +++ b/web/packages/base/locales/vi-VN/translation.json @@ -1,19 +1,19 @@ { "intro_slide_1_title": "Sao lưu riêng tưVui lòng gửi email đến {{emailID}} từ địa chỉ email đã đăng ký của bạn.
Yêu cầu của bạn sẽ được xử lý trong vòng 72 giờ.
", "change_email": "Đổi email", "ok": "OK", "success": "Thành công", "error": "Lỗi", - "note": "", - "offline_message": "Bạn đang ngoại tuyến, các kỷ niệm đã được lưu vào bộ nhớ cache đang được hiển thị", + "note": "Ghi chú", + "offline_message": "Bạn đang ngoại tuyến, các kỷ niệm hiển thị là từ bộ nhớ đệm", "install": "Cài đặt", "install_mobile_app": "Cài đặt ứng dụng Android hoặc iOS của chúng tôi để tự động sao lưu tất cả ảnh của bạn", - "download_app": "Tải xuống ứng dụng desktop", - "download_app_message": "Xin lỗi, thao tác này hiện chỉ được hỗ trợ trên ứng dụng desktop của chúng tôi", + "download_app": "Tải xuống ứng dụng máy tính", + "download_app_message": "Rất tiếc, thao tác này hiện chỉ hỗ trợ trên ứng dụng máy tính", "subscription": "Gói đăng ký", "manage_payment_method": "Quản lý phương thức thanh toán", "manage_family": "Quản lý gia đình", "family_plan": "Gói gia đình", "leave_family_plan": "Rời khỏi gói gia đình", "leave": "Rời", - "leave_family_plan_confirm": "Bạn có chắc chắn muốn rời khỏi gói gia đình không?", + "leave_family_plan_confirm": "Bạn có chắc muốn rời khỏi gói gia đình không?", "choose_plan": "Chọn gói của bạn", - "manage_plan": "Quản lý đăng ký của bạn", - "current_usage": "Sử dụng hiện tại là {{usage}}", - "two_months_free": "Nhận 2 tháng miễn phí với các gói hàng năm", - "free_plan_option": "Tiếp tục với gói miễn phí", - "free_plan_description": "{{storage}} miễn phí mãi mãi", + "manage_plan": "Quản lý gói đăng ký", + "current_usage": "Hiện dùng {{usage}}", + "two_months_free": "Nhận 2 tháng miễn phí với các gói theo năm", + "free_plan_option": "Dùng tiếp gói miễn phí", + "free_plan_description": "{{storage}} miễn phí vĩnh viễn", "active": "Hoạt động", - "subscription_info_free": "Bạn đang ở gói miễn phí", - "subscription_info_family": "Bạn đang ở gói gia đình do", - "subscription_info_expired": "Gói đăng ký của bạn đã hết hạn, vui lòng gia hạn", - "subscription_info_renewal_cancelled": "Gói đăng ký của bạn sẽ bị hủy vào {{date, date}}", - "subscription_info_storage_quota_exceeded": "Bạn đã vượt quá hạn mức lưu trữ của mình, vui lòng nâng cấp", + "subscription_info_free": "Bạn đang dùng gói miễn phí", + "subscription_info_family": "Bạn đang dùng gói gia đình của", + "subscription_info_expired": "Gói của bạn đã hết hạn, vui lòng gia hạn", + "subscription_info_renewal_cancelled": "Gói của bạn sẽ bị hủy vào {{date, date}}", + "subscription_info_storage_quota_exceeded": "Bạn đã vượt hạn mức lưu trữ của mình, vui lòng nâng cấp", "subscription_status_renewal_active": "Gia hạn vào {{date, date}}", "subscription_status_renewal_cancelled": "Kết thúc vào {{date, date}}", "add_on_valid_till": "Gói bổ sung {{storage}} của bạn có hiệu lực đến {{date, date}}", "subscription_expired": "Gói đăng ký đã hết hạn", - "storage_quota_exceeded": "Đã vượt quá giới hạn lưu trữ", - "subscription_purchase_success": "Chúng tôi đã nhận được thanh toán của bạn
Gói đăng ký của bạn có hiệu lực đến {{date, date}}
", + "storage_quota_exceeded": "Đã vượt hạn mức lưu trữ", + "subscription_purchase_success": "Chúng tôi đã nhận được thanh toán
Gói của bạn có hiệu lực đến {{date, date}}
", "subscription_purchase_cancelled": "Giao dịch của bạn đã bị hủy, vui lòng thử lại nếu bạn muốn đăng ký", - "subscription_purchase_failed": "Giao dịch đăng ký không thành công, vui lòng thử lại", - "subscription_verification_error": "Xác minh gói đăng ký không thành công", - "update_payment_method_message": "Chúng tôi xin lỗi, thanh toán không thành công khi chúng tôi cố gắng tính phí thẻ của bạn, vui lòng cập nhật phương thức thanh toán của bạn và thử lại", + "subscription_purchase_failed": "Giao dịch không thành công, vui lòng thử lại", + "subscription_verification_error": "Xác minh gói không thành công", + "update_payment_method_message": "Rất tiếc, thẻ của bạn thanh toán không thành công, vui lòng cập nhật phương thức thanh toán và thử lại", "payment_method_authentication_failed": "Chúng tôi không thể xác thực phương thức thanh toán của bạn. Vui lòng chọn phương thức thanh toán khác và thử lại", "update_payment_method": "Cập nhật phương thức thanh toán", - "monthly": "Hàng tháng", - "yearly": "Hàng năm", - "month_short": "th", + "monthly": "Theo tháng", + "yearly": "Theo năm", + "month_short": "tháng", "year": "năm", "update_subscription": "Thay đổi gói", "update_subscription_title": "Xác nhận thay đổi gói", - "update_subscription_message": "Bạn có chắc chắn muốn thay đổi gói của mình không?", - "cancel_subscription": "Hủy đăng ký", - "cancel_subscription_message": "Tất cả dữ liệu của bạn sẽ bị xóa khỏi máy chủ của chúng tôi vào cuối kỳ thanh toán này.
Bạn có chắc chắn muốn hủy đăng ký của mình không?
", - "cancel_subscription_with_addon_message": "Bạn có chắc chắn muốn hủy đăng ký của mình không?
", - "subscription_cancel_success": "Hủy đăng ký thành công", - "reactivate_subscription": "Kích hoạt lại đăng ký", - "reactivate_subscription_message": "Khi được kích hoạt lại, bạn sẽ bị tính phí vào {{date, date}}", - "subscription_activate_success": "Kích hoạt đăng ký thành công", + "update_subscription_message": "Bạn có chắc muốn thay đổi gói của mình không?", + "cancel_subscription": "Hủy gói", + "cancel_subscription_message": "Toàn bộ dữ liệu của bạn sẽ bị xóa khỏi máy chủ của chúng tôi vào cuối kỳ thanh toán này.
Bạn có chắc muốn hủy gói của mình không?
", + "cancel_subscription_with_addon_message": "Bạn có chắc muốn hủy gói của mình không?
", + "subscription_cancel_success": "Hủy gói thành công", + "reactivate_subscription": "Kích hoạt lại gói", + "reactivate_subscription_message": "Khi kích hoạt lại, bạn sẽ bị tính phí vào {{date, date}}", + "subscription_activate_success": "Kích hoạt gói thành công ", "thank_you": "Cảm ơn bạn", - "cancel_subscription_on_mobile": "Hủy đăng ký di động", - "cancel_subscription_on_mobile_message": "Vui lòng hủy đăng ký của bạn từ ứng dụng di động để kích hoạt một đăng ký ở đây", - "mail_to_manage_subscription": "Vui lòng liên hệ với chúng tôi tại {{emailID}} để quản lý đăng ký của bạn", + "cancel_subscription_on_mobile": "Hủy gói trên điện thoại", + "cancel_subscription_on_mobile_message": "Vui lòng hủy gói của bạn từ ứng dụng di động để kích hoạt một gói ở đây", + "mail_to_manage_subscription": "Vui lòng liên hệ với chúng tôi qua {{emailID}} để quản lý gói của bạn", "rename": "Đổi tên", "rename_file": "Đổi tên tệp", "rename_album": "Đổi tên album", "delete_album": "Xóa album", "delete_album_title": "Xóa album?", - "delete_album_message": "Có xóa các bức ảnh (và video) có trong album này từ tất cả các album khác mà chúng là một phần không?", + "delete_album_message": "Xóa luôn các tấm ảnh (và video) có trong album này khỏi toàn bộ album khác cũng đang chứa chúng?", "delete_photos": "Xóa ảnh", "keep_photos": "Giữ ảnh", "share_album": "Chia sẻ album", - "sharing_with_self": "", - "sharing_already_shared": "", + "sharing_with_self": "Bạn không thể chia sẻ với chính mình", + "sharing_already_shared": "Bạn đã chia sẻ với {{email}} rồi", "sharing_album_not_allowed": "Chia sẻ album không được phép", - "sharing_disabled_for_free_accounts": "Chia sẻ bị vô hiệu hóa cho các tài khoản miễn phí", - "sharing_user_does_not_exist": "", + "sharing_disabled_for_free_accounts": "Tài khoản miễn phí không thể chia sẻ", + "sharing_user_does_not_exist": "Không tìm thấy người dùng với email này", "search": "Tìm kiếm", "search_results": "Kết quả tìm kiếm", "no_results": "Không tìm thấy kết quả", - "search_hint": "Tìm kiếm album, ngày tháng, mô tả, ...", + "search_hint": "Tìm album, ngày chụp, mô tả,...", "album": "Album", "date": "Ngày", "description": "Mô tả", "file_type": "Loại tệp", "magic": "Ma thuật", - "photos_count_zero": "Không có kỷ niệm", - "photos_count_one": "1 kỷ niệm", - "photos_count": "{{count, number}} kỷ niệm", - "terms_and_conditions": "Tôi đồng ý với các điều khoản và chính sách bảo mật", + "photos_count_zero": "Chưa có ảnh nào", + "photos_count_one": "1 ảnh", + "photos_count": "{{count, number}} ảnh", + "terms_and_conditions": "Tôi đồng ý điều khoản và chính sách bảo mật", "people": "Người", - "indexing_scheduled": "Lập chỉ mục đã được lên lịch...", - "indexing_photos": "", - "indexing_fetching": "", - "indexing_people": "", + "indexing_scheduled": "Đã lên lịch lập chỉ mục...", + "indexing_photos": "Đang cập nhật chỉ mục...", + "indexing_fetching": "Đang đồng bộ chỉ mục...", + "indexing_people": "Đang đồng bộ người...", "syncing_wait": "Đang đồng bộ...", - "people_empty_too_few": "Người sẽ được hiển thị ở đây khi có đủ ảnh của một người", - "unnamed_person": "Người không tên", + "people_empty_too_few": "Sẽ hiện người ở đây khi có ảnh của một người", + "unnamed_person": "Chưa đặt tên", "add_a_name": "Thêm một tên", "new_person": "Người mới", "add_name": "Thêm tên", "rename_person": "Đổi tên người", "reset_person_confirm": "Đặt lại người?", - "reset_person_confirm_message": "Tên, nhóm khuôn mặt và gợi ý cho người này sẽ được đặt lại", + "reset_person_confirm_message": "Tên, nhóm khuôn mặt và những gợi ý cho người này sẽ bị đặt lại", "ignore": "Bỏ qua", "ignore_person_confirm": "Bỏ qua người?", "ignore_person_confirm_message": "Nhóm khuôn mặt này sẽ không được hiển thị trong danh sách người", "ignored": "Đã bỏ qua", "show_person": "Hiển thị người", - "review_suggestions": "Xem xét gợi ý", + "review_suggestions": "Xem qua gợi ý", "saved_choices": "Lựa chọn đã lưu", "discard_changes": "Bỏ qua thay đổi", "discard_changes_confirm_message": "Bạn có thay đổi chưa được lưu. Những thay đổi này sẽ bị mất nếu bạn đóng mà không lưu", - "people_suggestions_finding": "Tìm kiếm khuôn mặt tương tự...", - "people_suggestions_empty": "Không còn gợi ý nào cho bây giờ", + "people_suggestions_finding": "Tìm khuôn mặt tương tự...", + "people_suggestions_empty": "Không còn gợi ý nào", "info": "Thông tin", "file_name": "Tên tệp", "caption_placeholder": "Thêm mô tả", @@ -277,79 +277,79 @@ "map": "Bản đồ", "enable_map": "Bật bản đồ", "enable_maps_confirm": "Bật bản đồ?", - "enable_maps_confirm_message": "Điều này sẽ hiển thị ảnh của bạn trên bản đồ thế giới.
Bản đồ được lưu trữ bởi OpenStreetMap, và vị trí chính xác của ảnh của bạn sẽ không bao giờ được chia sẻ.
Bạn có thể tắt tính năng này bất cứ lúc nào từ Cài đặt.
", + "enable_maps_confirm_message": "Ảnh của bạn sẽ hiển thị trên bản đồ thế giới.
Bản đồ được lưu trữ bởi OpenStreetMap, và vị trí chính xác ảnh của bạn không bao giờ được chia sẻ.
Bạn có thể tắt tính năng này bất cứ lúc nào từ Cài đặt.
", "disable_map": "Tắt bản đồ", "disable_maps_confirm": "Tắt bản đồ?", - "disable_maps_confirm_message": "Điều này sẽ tắt hiển thị ảnh của bạn trên bản đồ thế giới.
Bạn có thể bật tính năng này bất cứ lúc nào từ Cài đặt.
", + "disable_maps_confirm_message": "Ảnh của bạn sẽ thôi hiển thị trên bản đồ thế giới.
Bạn có thể bật tính năng này bất cứ lúc nào từ Cài đặt.
", "details": "Chi tiết", - "view_exif": "Xem tất cả dữ liệu Exif", - "no_exif": "Không có dữ liệu Exif", + "view_exif": "Xem thông số Exif", + "no_exif": "No Exif data", "exif": "Exif", - "two_factor": "Xác thực hai yếu tố", - "two_factor_authentication": "Xác thực hai yếu tố", + "two_factor": "Xác thực 2 bước", + "two_factor_authentication": "Xác thực 2 bước", "two_factor_qr_help": "Quét mã QR bên dưới bằng ứng dụng xác thực yêu thích của bạn", "two_factor_manual_entry_title": "Nhập mã thủ công", "two_factor_manual_entry_message": "Vui lòng nhập mã này vào ứng dụng xác thực yêu thích của bạn", - "scan_qr_title": "Quét mã QR thay thế", - "enable_two_factor": "Bật xác thực hai yếu tố", + "scan_qr_title": "Quét mã QR", + "enable_two_factor": "Bật xác thực 2 bước", "enable": "Bật", "enabled": "Đã bật", - "lost_2fa_device": "Thiết bị xác thực hai yếu tố bị mất", + "lost_2fa_device": "Mất thiết bị xác thực 2 bước", "incorrect_code": "Mã không chính xác", - "two_factor_info": "Thêm một lớp bảo mật bổ sung bằng cách yêu cầu nhiều hơn email và mật khẩu của bạn để đăng nhập vào tài khoản của bạn", + "two_factor_info": "Thêm một lớp bảo mật bổ sung bằng cách yêu cầu nhiều hơn email và mật khẩu của bạn để đăng nhập", "disable": "Tắt", "reconfigure": "Cấu hình lại", "reconfigure_two_factor_hint": "Cập nhật thiết bị xác thực của bạn", - "update_two_factor": "Cập nhật xác thực hai yếu tố", - "update_two_factor_message": "Tiếp tục sẽ làm vô hiệu hóa bất kỳ thiết bị xác thực nào đã được cấu hình trước đó", + "update_two_factor": "Cập nhật xác thực 2 bước", + "update_two_factor_message": "Tiếp tục sẽ khiến mọi thiết bị xác thực được cấu hình trước đó bị vô hiệu hóa", "update": "Cập nhật", - "disable_two_factor": "Tắt xác thực hai yếu tố", - "disable_two_factor_message": "Bạn có chắc chắn muốn tắt xác thực hai yếu tố của mình không", + "disable_two_factor": "Tắt xác thực 2 bước", + "disable_two_factor_message": "Bạn có chắc muốn tắt xác thực 2 bước không", "export_data": "Xuất dữ liệu", "select_folder": "Chọn thư mục", "select_zips": "Chọn tệp zip", "faq": "Câu hỏi thường gặp", - "takeout_hint": "Giải nén tất cả các tệp zip vào cùng một thư mục và tải lên. Hoặc tải lên các tệp zip trực tiếp. Xem Câu hỏi thường gặp để biết chi tiết.", - "destination": "Điểm đến", + "takeout_hint": "Giải nén tất cả tệp zip vào cùng một thư mục và tải lên. Hoặc tải lên trực tiếp các tệp zip. Xem Câu hỏi thường gặp để biết thêm.", + "destination": "Đích đến", "start": "Bắt đầu", - "last_export_time": "Thời gian xuất cuối cùng", + "last_export_time": "Thời gian xuất gần nhất", "export_again": "Đồng bộ lại", - "local_storage_not_accessible": "Trình duyệt của bạn hoặc một tiện ích mở rộng đang chặn Ente không lưu dữ liệu vào bộ nhớ cục bộ", + "local_storage_not_accessible": "Trình duyệt của bạn hoặc một tiện ích mở rộng đang chặn Ente lưu dữ liệu vào bộ nhớ thiết bị", "email_already_taken": "Email đã được sử dụng", "live_photos_detected": "Các tệp ảnh và video từ Live Photos của bạn đã được gộp thành một tệp duy nhất", "ignored_uploads": "Tải lên đã bị bỏ qua", - "ignored_uploads_hint": "Bỏ qua những tệp này vì có tệp có tên và nội dung trùng khớp trong cùng một album", + "ignored_uploads_hint": "Những tệp này bị bỏ qua vì có tên và nội dung trùng khớp trong cùng một album", "file_not_uploaded_list": "Các tệp sau không được tải lên", "failed_uploads": "Tải lên không thành công", - "failed_uploads_hint": "Sẽ có một tùy chọn để thử lại khi việc tải lên hoàn tất", - "retry_failed_uploads": "Thử lại các tệp tải lên không thành công", + "failed_uploads_hint": "Sẽ có tùy chọn thử lại sau khi việc tải lên hoàn tất", + "retry_failed_uploads": "Thử tải lên lại các tệp không thành công", "thumbnail_generation_failed": "Tạo hình thu nhỏ không thành công", "thumbnail_generation_failed_hint": "Các tệp này đã được tải lên, nhưng rất tiếc chúng tôi không thể tạo hình thu nhỏ cho chúng.", "unsupported_files": "Tệp không được hỗ trợ", "unsupported_files_hint": "Ente chưa hỗ trợ các định dạng tệp này", "blocked_uploads": "Tải lên bị chặn", - "blocked_uploads_hint": "Trình duyệt của bạn hoặc một tiện ích mở rộng đang ngăn Ente sử dụngeTags để tải lên các tệp lớn.",
+ "blocked_uploads_hint": "Trình duyệt của bạn hoặc một tiện ích mở rộng đang chặn Ente sử dụng eTags để tải lên các tệp lớn.",
"large_files": "Tệp lớn",
- "large_files_hint": "Các tệp này đã không được tải lên vì chúng vượt quá giới hạn kích thước tệp tối đa của chúng tôi",
+ "large_files_hint": "Các tệp này không thể tải lên vì chúng vượt quá dung lượng tệp tối đa của chúng tôi",
"insufficient_storage": "Không đủ dung lượng lưu trữ",
- "insufficient_storage_hint": "Các tệp này đã không được tải lên vì chúng vượt quá giới hạn kích thước tối đa cho gói lưu trữ của bạn",
- "uploads_in_progress": "Tải lên đang tiến hành",
+ "insufficient_storage_hint": "Các tệp này không thể tải lên vì chúng vượt quá dung lượng tối đa gói của bạn",
+ "uploads_in_progress": "Đang tải lên",
"successful_uploads": "Tải lên thành công",
"upload_to_album": "Tải lên album",
"add_to_album": "Thêm vào album",
"move_to_album": "Di chuyển đến album",
- "unhide_to_album": "Hiện lại vào album",
+ "unhide_to_album": "Hiện lại trong album",
"restore_to_album": "Khôi phục vào album",
"section_all": "Tất cả",
"section_uncategorized": "Chưa phân loại",
"section_archive": "Lưu trữ",
"section_hidden": "Ẩn",
"section_trash": "Thùng rác",
- "favorites": "Yêu thích",
+ "favorites": "Đã thích",
"archive": "Lưu trữ",
"archive_album": "Lưu trữ album",
- "unarchive": "Khôi phục lưu trữ",
- "unarchive_album": "Khôi phục lưu trữ album",
+ "unarchive": "Bỏ lưu trữ",
+ "unarchive_album": "Bỏ lưu trữ album",
"hide_collection": "Ẩn album",
"unhide_collection": "Hiện lại album",
"move": "Di chuyển",
@@ -357,28 +357,28 @@
"remove": "Xóa",
"yes_remove": "Có, xóa",
"remove_from_album": "Xóa khỏi album",
- "move_to_trash": "Di chuyển vào thùng rác",
- "trash_files_message": "Các tệp đã chọn sẽ bị xóa khỏi tất cả các album và di chuyển vào thùng rác.",
- "trash_file_message": "Tệp sẽ bị xóa khỏi tất cả các album và di chuyển vào thùng rác.",
+ "move_to_trash": "Cho vào thùng rác",
+ "trash_files_message": "Các tệp đã chọn sẽ bị xóa khỏi tất cả album và cho vào thùng rác.",
+ "trash_file_message": "Tệp sẽ bị xóa khỏi tất cả album và cho vào thùng rác.",
"delete_permanently": "Xóa vĩnh viễn",
"restore": "Khôi phục",
- "empty_trash": "Làm rỗng thùng rác",
- "empty_trash_title": "Làm rỗng thùng rác?",
+ "empty_trash": "Xóa sạch thùng rác",
+ "empty_trash_title": "Xóa sạch thùng rác?",
"empty_trash_message": "Các tệp này sẽ bị xóa vĩnh viễn khỏi tài khoản Ente của bạn.",
"leave_album": "Rời album",
- "leave_shared_album_title": "Rời album chia sẻ?",
- "leave_shared_album_message": "Bạn sẽ rời album, và nó sẽ không còn hiển thị cho bạn.",
+ "leave_shared_album_title": "Rời album được chia sẻ?",
+ "leave_shared_album_message": "Bạn sẽ rời album, và nó sẽ không còn hiển thị với bạn.",
"leave_shared_album": "Có, rời",
"confirm_remove_message": "Các mục đã chọn sẽ bị xóa khỏi album này. Các mục chỉ có trong album này sẽ được chuyển đến Chưa phân loại.",
- "confirm_remove_incl_others_message": "Một số mục bạn đang xóa đã được thêm bởi người khác, và bạn sẽ mất quyền truy cập vào chúng.",
+ "confirm_remove_incl_others_message": "Vài mục mà bạn đang xóa được thêm bởi người khác, và bạn sẽ mất quyền truy cập vào chúng.",
"oldest": "Cũ nhất",
- "last_updated": "Cập nhật lần cuối",
+ "last_updated": "Mới cập nhật",
"name": "Tên",
"fix_creation_time": "Sửa thời gian",
"fix_creation_time_in_progress": "Đang sửa thời gian",
"fix_creation_time_file_updated": "Thời gian tệp đã được cập nhật",
"fix_creation_time_completed": "Đã cập nhật thành công tất cả các tệp",
- "fix_creation_time_completed_with_errors": "Cập nhật thời gian tệp không thành công cho một số tệp, vui lòng thử lại",
+ "fix_creation_time_completed_with_errors": "Cập nhật thời gian một số tệp không thành công, vui lòng thử lại",
"fix_creation_time_options": "Chọn tùy chọn bạn muốn sử dụng",
"exif_date_time_original": "Exif:DateTimeOriginal",
"exif_date_time_digitized": "Exif:DateTimeDigitized",
@@ -396,7 +396,7 @@
"participants_count_one": "1 người tham gia",
"participants_count": "{{count, number}} người tham gia",
"add_viewers": "Thêm người xem",
- "change_permission_to_viewer": "{{selectedEmail}} sẽ không thể thêm nhiều ảnh hơn vào album
Họ vẫn có thể xóa ảnh đã thêm bởi họ
", + "change_permission_to_viewer": "{{selectedEmail}} sẽ không thể thêm ảnh vào album
Họ vẫn có thể xóa ảnh đã thêm bởi họ
", "change_permission_to_collaborator": "{{selectedEmail}} sẽ có thể thêm ảnh vào album", "change_permission_title": "Thay đổi quyền?", "confirm_convert_to_viewer": "Có, chuyển thành người xem", @@ -417,10 +417,10 @@ "link_expired": "Liên kết đã hết hạn", "link_expired_message": "Liên kết này đã hết hạn hoặc đã bị vô hiệu hóa", "manage_link": "Quản lý liên kết", - "link_request_limit_exceeded": "Album này đã được xem trên quá nhiều thiết bị", + "link_request_limit_exceeded": "Album này đang được xem trên quá nhiều thiết bị", "allow_downloads": "Cho phép tải xuống", "allow_adding_photos": "Cho phép thêm ảnh", - "allow_adding_photos_hint": "Cho phép người có liên kết cũng thêm ảnh vào album chia sẻ.", + "allow_adding_photos_hint": "Cho phép người có liên kết thêm ảnh vào album chia sẻ.", "device_limit": "Giới hạn thiết bị", "none": "Không", "link_expiry": "Hết hạn liên kết", @@ -440,30 +440,30 @@ "public_link_created": "Liên kết công khai đã được tạo", "public_link_enabled": "Liên kết công khai đã được bật", "collect_photos": "Thu thập ảnh", - "disable_file_download": "Vô hiệu hóa tải xuống", - "disable_file_download_message": "Bạn có chắc chắn muốn vô hiệu hóa nút tải xuống cho các tệp không?
Người xem vẫn có thể chụp ảnh màn hình hoặc lưu bản sao của ảnh của bạn bằng các công cụ bên ngoài.
", + "disable_file_download": "Tắt tải xuống", + "disable_file_download_message": "Bạn có chắc muốn tắt nút tải xuống các tệp không?
Người xem vẫn có thể chụp ảnh màn hình hoặc sao chép ảnh của bạn bằng các công cụ bên ngoài.
", "shared_using": "Chia sẻ bằng {{url}}", - "sharing_referral_code": "Sử dụng mã {{referralCode}} để nhận 10 GB miễn phí", + "sharing_referral_code": "Dùng mã {{referralCode}} để nhận 10 GB miễn phí", "disable_password": "Vô hiệu hóa khóa mật khẩu", - "disable_password_message": "Bạn có chắc chắn muốn vô hiệu hóa khóa mật khẩu không?", + "disable_password_message": "Bạn có chắc muốn vô hiệu hóa khóa mật khẩu không?", "password_lock": "Khóa mật khẩu", "lock": "Khóa", "file": "Tệp", "folder": "Thư mục", - "google_takeout": "Google takeout", - "deduplicate_files": "Xóa trùng tệp", - "remove_duplicates": "", - "total_size": "", - "count": "", - "deselect_all": "", - "no_duplicates": "", - "duplicate_group_description": "", - "remove_duplicates_button_count": "", + "google_takeout": "Google Takeout", + "deduplicate_files": "Xóa tệp trùng", + "remove_duplicates": "Xóa trùng lặp", + "total_size": "Tổng dung lượng", + "count": "Số lượng", + "deselect_all": "Bỏ chọn tất cả", + "no_duplicates": "Không có trùng lặp", + "duplicate_group_description": "{{count}} mục, {{itemSize}} mỗi mục", + "remove_duplicates_button_count": "Xóa {{count, number}} mục", "stop_uploads_title": "Dừng tải lên?", - "stop_uploads_message": "Bạn có chắc chắn muốn dừng tất cả các tải lên đang diễn ra không?", + "stop_uploads_message": "Bạn có chắc muốn dừng tất cả mục đang tải lên không?", "yes_stop_uploads": "Có, dừng tải lên", "stop_downloads_title": "Dừng tải xuống?", - "stop_downloads_message": "Bạn có chắc chắn muốn dừng tất cả các tải xuống đang diễn ra không?", + "stop_downloads_message": "Bạn có chắc muốn dừng tất cả mục đang tải xuống không?", "yes_stop_downloads": "Có, dừng tải xuống", "albums": "Album", "albums_count_one": "1 Album", @@ -478,14 +478,14 @@ "upgrade_now": "Nâng cấp ngay", "renew_now": "Gia hạn ngay", "storage": "Lưu trữ", - "used": "đã sử dụng", + "used": "đã dùng", "you": "Bạn", "family": "Gia đình", "free": "miễn phí", "of": "của", "watch_folders": "Theo dõi thư mục", "watched_folders": "Thư mục đã theo dõi", - "no_folders_added": "Chưa có thư mục nào được thêm", + "no_folders_added": "Chưa thêm thư mục nào", "watch_folders_hint_1": "Các thư mục bạn thêm ở đây sẽ được theo dõi tự động", "watch_folders_hint_2": "Tải lên tệp mới vào Ente", "watch_folders_hint_3": "Xóa tệp đã xóa khỏi Ente", @@ -495,51 +495,51 @@ "stop_watching_folder_message": "Các tệp hiện có của bạn sẽ không bị xóa, nhưng Ente sẽ ngừng tự động cập nhật album Ente liên kết khi có thay đổi trong thư mục này.", "yes_stop": "Có, dừng lại", "change_folder": "Thay đổi Thư mục", - "view_logs": "", - "view_logs_message": "", - "weak_device_hint": "Trình duyệt web bạn đang sử dụng không đủ mạnh để mã hóa ảnh của bạn. Vui lòng thử đăng nhập vào Ente trên máy tính của bạn, hoặc tải xuống ứng dụng di động/desktop của Ente.", - "drag_and_drop_hint": "Hoặc kéo và thả vào cửa sổ Ente", + "view_logs": "Xem log", + "view_logs_message": "Tải xuống nhật ký lỗi, để bạn có thể gửi qua email cho chúng tôi.
Lưu ý rằng, trong nhật ký lỗi sẽ bao gồm tên các tệp để giúp theo dõi vấn đề với từng tệp cụ thể.
", + "weak_device_hint": "Trình duyệt bạn đang sử dụng không đủ mạnh để mã hóa ảnh. Vui lòng dùng Ente trên máy tính, hoặc tải xuống ứng dụng di động/máy tính của Ente.", + "drag_and_drop_hint": "Hoặc kéo thả vào cửa sổ Ente", "authenticate": "Xác thực", "uploaded_to_single_collection": "Đã tải lên một bộ sưu tập", "uploaded_to_separate_collections": "Đã tải lên các bộ sưu tập riêng biệt", "nevermind": "Không sao", - "update_available": "Cập nhật có sẵn", - "update_installable_message": "Một phiên bản mới của Ente đã sẵn sàng để được cài đặt.", + "update_available": "Phiên bản mới", + "update_installable_message": "Ente có một phiên bản mới, sẵn sàng để cài đặt.", "install_now": "Cài đặt ngay", - "install_on_next_launch": "Cài đặt khi khởi động tiếp theo", - "update_available_message": "Một phiên bản mới của Ente đã được phát hành, nhưng không thể tự động tải xuống và cài đặt.", + "install_on_next_launch": "Cài đặt trong lần khởi động sau", + "update_available_message": "Ente có một phiên bản mới, nhưng không thể tự động tải xuống và cài đặt.", "download_and_install": "Tải xuống và cài đặt", "ignore_this_version": "Bỏ qua phiên bản này", "today": "Hôm nay", "yesterday": "Hôm qua", "enter_name": "Nhập tên", - "uploader_name_hint": "Thêm một tên để bạn bè biết ai là người đáng cảm ơn cho những bức ảnh tuyệt vời này!", + "uploader_name_hint": "Thêm một tên để bạn bè biết ai là người chụp những tấm ảnh tuyệt vời này!", "name_placeholder": "Tên...", "more_details": "Thêm chi tiết", "ml_search": "Học máy", - "ml_search_description": "Ente hỗ trợ học máy trên thiết bị cho nhận diện khuôn mặt, tìm kiếm kỳ diệu và các tính năng tìm kiếm nâng cao khác", - "ml_search_footnote": "Tìm kiếm kỳ diệu cho phép tìm kiếm ảnh theo nội dung của chúng, ví dụ: 'xe hơi', 'xe hơi đỏ', 'Ferrari'", + "ml_search_description": "Ente hỗ trợ học máy trên-thiết-bị nhằm nhận diện khuôn mặt, tìm kiếm vi diệu và các tính năng tìm kiếm nâng cao khác", + "ml_search_footnote": "Tìm kiếm vi diệu cho phép tìm ảnh theo nội dung của chúng, ví dụ: 'xe hơi', 'xe hơi đỏ', 'Ferrari'", "indexing": "Đang lập chỉ mục", "processed": "Đã xử lý", "indexing_status_running": "Đang chạy", "indexing_status_fetching": "Đang lấy", "indexing_status_scheduled": "Đã lên lịch", "indexing_status_done": "Đã hoàn thành", - "ml_search_disable": "Vô hiệu hóa học máy", - "ml_search_disable_confirm": "Bạn có muốn vô hiệu hóa học máy trên tất cả các thiết bị của bạn không?", + "ml_search_disable": "Tắt học máy", + "ml_search_disable_confirm": "Bạn có muốn tắt học máy trên tất cả các thiết bị của bạn không?", "ml_consent": "Bật học máy", "ml_consent_title": "Bật học máy?", - "ml_consent_description": "Nếu bạn bật học máy, Ente sẽ trích xuất thông tin như hình dạng khuôn mặt từ các tệp, bao gồm cả những tệp được chia sẻ với bạn.
Điều này sẽ xảy ra trên thiết bị của bạn, và bất kỳ thông tin sinh trắc học nào được tạo ra sẽ được mã hóa đầu cuối.
", + "ml_consent_description": "Nếu bạn bật học máy, Ente sẽ trích xuất thông tin như hình dạng khuôn mặt từ các tệp, gồm cả những tệp mà bạn được chia sẻ.
Việc này sẽ diễn ra trên thiết bị của bạn, với mọi thông tin sinh trắc học tạo ra đều được mã hóa đầu cuối.
", "ml_consent_confirmation": "Tôi hiểu và muốn bật học máy", - "labs": "Phòng thí nghiệm", + "labs": "Thử nghiệm", "password_strength_weak": "Độ mạnh mật khẩu: Yếu", "password_strength_moderate": "Độ mạnh mật khẩu: Trung bình", "password_strength_strong": "Độ mạnh mật khẩu: Mạnh", - "preferences": "Tùy chọn", + "preferences": "Thiết lập", "language": "Ngôn ngữ", "advanced": "Nâng cao", "export_directory_does_not_exist": "Thư mục xuất không hợp lệ", - "export_directory_does_not_exist_message": "Thư mục xuất mà bạn đã chọn không tồn tại.
Vui lòng chọn một thư mục hợp lệ.
", + "export_directory_does_not_exist_message": "Thư mục xuất mà bạn đã chọn không tồn tại.
Vui lòng chọn một thư mục khác.
", "storage_unit": { "b": "B", "kb": "KB", @@ -549,33 +549,33 @@ }, "stop": "Dừng", "sync_continuously": "Đồng bộ liên tục", - "export_starting": "Xuất bắt đầu...", + "export_starting": "Bắt đầu xuất...", "export_preparing": "Đang chuẩn bị...", "export_renaming_album_folders": "Đang đổi tên thư mục album...", - "export_trashing_deleted_files": "Đang xóa tệp đã xóa...", - "export_trashing_deleted_albums": "Đang xóa album đã xóa...", + "export_trashing_deleted_files": "Đang xóa vĩnh viễn các tệp...", + "export_trashing_deleted_albums": "Đang xóa vĩnh viễn các album...", "export_progress": "{{progress.success, number}} / {{progress.total, number}} mục đã đồng bộ", "pending_items": "Mục đang chờ", "delete_account_reason_label": "Lý do chính bạn xóa tài khoản là gì?", "delete_account_reason_placeholder": "Chọn một lý do", "delete_reason": { "missing_feature": "Thiếu một tính năng quan trọng mà tôi cần", - "behaviour": "Ứng dụng hoặc một tính năng nhất định không hoạt động như tôi nghĩ nó nên", - "found_another_service": "Tôi đã tìm thấy một dịch vụ khác mà tôi thích hơn", - "not_listed": "Lý do của tôi không có trong danh sách" + "behaviour": "Ứng dụng hoặc một tính năng nhất định không hoạt động như tôi muốn", + "found_another_service": "Tôi tìm thấy một dịch vụ khác mà tôi thích hơn", + "not_listed": "Lý do không có trong danh sách" }, "delete_account_feedback_label": "Chúng tôi rất tiếc khi thấy bạn ra đi. Vui lòng giải thích lý do bạn rời đi để giúp chúng tôi cải thiện.", "delete_account_feedback_placeholder": "Phản hồi", - "delete_account_confirm_checkbox_label": "Có, tôi muốn xóa tài khoản này và tất cả dữ liệu của nó vĩnh viễn", + "delete_account_confirm_checkbox_label": "Có, tôi muốn xóa vĩnh viễn tài khoản này và tất cả dữ liệu của nó", "delete_account_confirm": "Xác nhận xóa tài khoản", - "delete_account_confirm_message": "Tài khoản này được liên kết với các ứng dụng Ente khác, nếu bạn sử dụng bất kỳ.
Dữ liệu bạn đã tải lên, trên tất cả các ứng dụng Ente, sẽ được lên lịch để xóa, và tài khoản của bạn sẽ bị xóa vĩnh viễn.
", - "feedback_required": "Xin vui lòng giúp chúng tôi với thông tin này", + "delete_account_confirm_message": "Tài khoản này được liên kết với các ứng dụng Ente khác, nếu bạn có dùng.
Dữ liệu bạn đã tải lên, trên tất cả ứng dụng Ente, sẽ được lên lịch để xóa, và tài khoản của bạn sẽ bị xóa vĩnh viễn.
", + "feedback_required": "Mong bạn giúp chúng tôi thông tin này", "feedback_required_found_another_service": "Dịch vụ khác làm tốt hơn điều gì?", - "recover_two_factor": "Khôi phục xác thực hai yếu tố", + "recover_two_factor": "Khôi phục xác thực 2 bước", "at": "tại", "auth_next": "tiếp theo", "auth_download_mobile_app": "Tải xuống ứng dụng di động của chúng tôi để quản lý bí mật của bạn", - "no_codes_added_yet": "Chưa có mã nào được thêm", + "no_codes_added_yet": "Chưa thêm mã nào", "hide": "Ẩn", "unhide": "Hiện", "sort_by": "Sắp xếp theo", @@ -583,30 +583,30 @@ "oldest_first": "Cũ nhất trước", "pin_album": "Ghim album", "unpin_album": "Bỏ ghim album", - "unpreviewable_file_message": "Tệp này không thể được xem trước", - "download_complete": "Tải xuống hoàn tất", + "unpreviewable_file_message": "Không thể xem trước tệp này", + "download_complete": "Tải xuống xong", "downloading_album": "Đang tải xuống {{name}}", "download_failed": "Tải xuống thất bại", "download_progress": "{{count, number}} / {{total, number}} tệp", - "christmas": "Giáng sinh", - "christmas_eve": "Đêm Giáng sinh", - "new_year": "Năm mới", - "new_year_eve": "Đêm giao thừa", + "christmas": "Giáng Sinh", + "christmas_eve": "Đêm Thánh", + "new_year": "Năm Mới", + "new_year_eve": "Đêm Giao Thừa", "image": "Hình ảnh", "video": "Video", - "live_photo": "Ảnh trực tiếp", - "live": "", - "edit_image": "", + "live_photo": "Ảnh Live", + "live": "Live", + "edit_image": "Chỉnh sửa ảnh", "photo_editor": "Trình chỉnh sửa ảnh", - "confirm_editor_close": "Bạn có chắc chắn muốn đóng trình chỉnh sửa không?", - "confirm_editor_close_message": "Tải xuống hình ảnh đã chỉnh sửa của bạn hoặc lưu bản sao vào Ente để giữ lại các thay đổi của bạn.", + "confirm_editor_close": "Bạn có chắc muốn đóng trình chỉnh sửa không?", + "confirm_editor_close_message": "Tải xuống hình ảnh đã chỉnh sửa hoặc lưu bản sao vào Ente để giữ các thay đổi của bạn.", "brightness": "Độ sáng", "contrast": "Độ tương phản", "saturation": "Độ bão hòa", - "blur": "Mờ", + "blur": "Độ mờ", "transform": "Biến đổi", "crop": "Cắt", - "aspect_ratio": "Tỷ lệ khung hình", + "aspect_ratio": "Tỉ lệ khung hình", "square": "Hình vuông", "freehand": "Vẽ tự do", "apply_crop": "Áp dụng cắt", @@ -614,27 +614,27 @@ "rotate_left": "Xoay trái", "rotate_right": "Xoay phải", "flip": "Lật", - "flip_vertically": "Lật theo chiều dọc", - "flip_horizontally": "Lật theo chiều ngang", + "flip_vertically": "Lật dọc", + "flip_horizontally": "Lật ngang", "download_edited": "Tải xuống đã chỉnh sửa", "save_a_copy_to_ente": "Lưu một bản sao vào Ente", "restore_original": "Khôi phục gốc", - "photo_edit_required_to_save": "Ít nhất một biến đổi hoặc điều chỉnh màu sắc phải được thực hiện trước khi lưu.", + "photo_edit_required_to_save": "Phải thực hiện ít nhất một biến đổi hoặc điều chỉnh màu sắc trước khi lưu.", "colors": "Màu sắc", "invert_colors": "Đảo ngược màu", "reset": "Đặt lại", "faster_upload": "Tải lên nhanh hơn", - "faster_upload_description": "Định tuyến tải lên qua các máy chủ gần đó", - "open_ente_on_startup": "", + "faster_upload_description": "Tải lên các máy chủ gần bạn", + "open_ente_on_startup": "Mở Ente khi khởi động", "cast_album_to_tv": "Phát album trên TV", - "cast_to_tv": "", + "cast_to_tv": "Phát trên TV", "enter_cast_pin_code": "Nhập mã bạn thấy trên TV bên dưới để ghép nối thiết bị này.", "code": "Mã", "pair_device_to_tv": "Ghép nối thiết bị", "tv_not_found": "Không tìm thấy TV. Bạn đã nhập mã PIN đúng chưa?", "cast_auto_pair": "Ghép nối tự động", "cast_auto_pair_description": "Ghép nối tự động chỉ hoạt động với các thiết bị hỗ trợ Chromecast.", - "choose_device_from_browser": "Chọn một thiết bị tương thích với phát từ cửa sổ trình duyệt.", + "choose_device_from_browser": "Chọn một thiết bị phát tương thích từ cửa sổ trình duyệt.", "cast_auto_pair_failed": "Ghép nối tự động Chromecast thất bại. Vui lòng thử lại.", "pair_with_pin": "Ghép nối bằng PIN", "pair_with_pin_description": "Ghép nối bằng PIN hoạt động với bất kỳ màn hình nào bạn muốn xem album của mình.", @@ -643,29 +643,29 @@ "passkey_fetch_failed": "Không thể lấy khóa truy cập của bạn.", "manage_passkey": "Quản lý khóa truy cập", "delete_passkey": "Xóa khóa truy cập", - "delete_passkey_confirmation": "Bạn có chắc chắn muốn xóa khóa truy cập này không? Hành động này không thể hoàn tác.", + "delete_passkey_confirmation": "Bạn có chắc muốn xóa khóa truy cập này không? Hành động này không thể hoàn tác.", "rename_passkey": "Đổi tên khóa truy cập", "add_passkey": "Thêm khóa truy cập", "enter_passkey_name": "Nhập tên khóa truy cập", - "passkeys_description": "Khóa truy cập là một yếu tố thứ hai hiện đại và an toàn cho tài khoản Ente của bạn. Chúng sử dụng xác thực sinh trắc học trên thiết bị để tiện lợi và an toàn.", - "created_at": "Được tạo vào", + "passkeys_description": "Khóa truy cập là một yếu tố bảo mật hiện đại cho tài khoản Ente của bạn. Chúng sử dụng xác thực sinh trắc học trên thiết bị để tiện lợi và an toàn.", + "created_at": "Đã tạo vào", "passkey_add_failed": "Không thể thêm khóa truy cập", "passkey_login_failed": "Đăng nhập bằng khóa truy cập thất bại", "passkey_login_invalid_url": "URL đăng nhập không hợp lệ.", "passkey_login_already_claimed_session": "Phiên này đã được xác minh.", "passkey_login_generic_error": "Đã xảy ra lỗi khi đăng nhập bằng khóa truy cập.", "passkey_login_credential_hint": "Nếu khóa truy cập của bạn ở trên thiết bị khác, bạn có thể mở trang này trên thiết bị đó để xác minh.", - "passkeys_not_supported": "Khóa truy cập không được hỗ trợ trong trình duyệt này", + "passkeys_not_supported": "Khóa truy cập không được hỗ trợ trên trình duyệt này", "try_again": "Thử lại", "check_status": "Kiểm tra trạng thái", "passkey_login_instructions": "Thực hiện các bước từ trình duyệt của bạn để tiếp tục đăng nhập.", "passkey_login": "Đăng nhập bằng khóa truy cập", "totp_login": "Đăng nhập bằng TOTP", - "passkey": "Mã khóa", - "passkey_verify_description": "Xác minh mã khóa của bạn để đăng nhập vào tài khoản.", + "passkey": "Khóa truy cập", + "passkey_verify_description": "Xác minh khóa truy cập của bạn để đăng nhập vào tài khoản.", "waiting_for_verification": "Đang chờ xác minh...", "verification_still_pending": "Xác minh vẫn đang chờ", - "passkey_verified": "Mã khóa đã được xác minh", + "passkey_verified": "Khóa truy cập đã được xác minh", "redirecting_back_to_app": "Đang chuyển hướng bạn trở lại ứng dụng...", "redirect_close_instructions": "Bạn có thể đóng cửa sổ này sau khi ứng dụng mở.", "redirect_again": "Chuyển hướng lại", @@ -675,15 +675,15 @@ "server_endpoint": "Điểm cuối máy chủ", "more_information": "Thêm thông tin", "save": "Lưu", - "theme": "", - "system": "", - "light": "", - "dark": "", - "streamable_videos": "", - "processing_videos_status": "", - "share_favorites": "", - "person_favorites": "", - "shared_favorites": "", - "added_by_name": "", - "unowned_files_not_processed": "" + "theme": "Chủ đề", + "system": "Giống hệ thống", + "light": "Sáng", + "dark": "Tối", + "streamable_videos": "Video có thể phát", + "processing_videos_status": "Đang xử lý video...", + "share_favorites": "Chia sẻ những mục thích", + "person_favorites": "{{name}} đã thích", + "shared_favorites": "Những mục thích đã chia sẻ", + "added_by_name": "Được thêm bởi {{name}}", + "unowned_files_not_processed": "Các tệp được thêm bởi người dùng khác không được xử lý" } diff --git a/web/packages/base/locales/zh-CN/translation.json b/web/packages/base/locales/zh-CN/translation.json index 95b6ff8d84..0bfb3cce8e 100644 --- a/web/packages/base/locales/zh-CN/translation.json +++ b/web/packages/base/locales/zh-CN/translation.json @@ -32,7 +32,7 @@ "set_password": "设置密码", "sign_in": "登录", "incorrect_password": "密码错误", - "incorrect_password_or_no_account": "", + "incorrect_password_or_no_account": "密码错误或邮箱未注册", "pick_password_hint": "请输入我们可以用来加密您数据的密码", "pick_password_caution": "我们不会存储您的密码,因此如果您忘记密码, 我们将无法帮助您在没有恢复密钥的情况下恢复您的数据。", "key_generation_in_progress": "正在生成加密密钥...", @@ -40,7 +40,7 @@ "referral_source_hint": "您是如何知道Ente的? (可选的)", "referral_source_info": "我们不跟踪应用程序安装情况,如果您告诉我们您是在哪里找到我们的,将会有所帮助!", "password_mismatch_error": "两次输入的密码不一致", - "show_or_hide_password": "", + "show_or_hide_password": "显示或隐藏密码", "welcome_to_ente_title": "欢迎来到 ", "welcome_to_ente_subtitle": "端到端加密的照片存储和共享", "new_album": "新建相册", @@ -58,12 +58,12 @@ "add_photos_count": "添加 {{count, number}} 个项目", "select_photos": "选择照片", "file_upload": "上传文件", - "preparing": "", - "processed_counts": "", - "upload_reading_metadata_files": "", + "preparing": "准备中", + "processed_counts": "{{count, number}} / {{total, number}}", + "upload_reading_metadata_files": "正在读取元数据文件", "upload_cancelling": "正在取消剩余的上传内容", - "upload_done": "", - "upload_skipped": "", + "upload_done": "{{count, number}} 个已上传", + "upload_skipped": "{{count, number}} 个已跳过", "initial_load_delay_warning": "第一次加载可能需要一些时间", "no_account": "没有账号", "existing_account": "已有账号", @@ -96,15 +96,15 @@ "exit_fullscreen": "退出全屏", "go_fullscreen": "全屏显示", "zoom": "缩放", - "play": "", - "pause": "", + "play": "播放", + "pause": "暂停", "previous": "上一个", "next": "下一个", - "video_seek": "", - "quality": "", - "auto": "", - "original": "", - "speed": "", + "video_seek": "视频跳转", + "quality": "质量", + "auto": "自动", + "original": "原始", + "speed": "速度", "title_photos": "Ente 照片", "title_auth": "Ente 验证器", "title_accounts": "Ente 账户", @@ -162,7 +162,7 @@ "ok": "确定", "success": "成功", "error": "错误", - "note": "", + "note": "提示", "offline_message": "您处于离线状态,正在显示已缓存的回忆", "install": "安装", "install_mobile_app": "安装我们的 Android 或 iOS 应用程序来自动备份您的所有照片", @@ -225,7 +225,7 @@ "delete_album_message": "也删除此相册中存在的照片(和视频),从 他们所加入的所有 个其他相册?", "delete_photos": "删除照片", "keep_photos": "保留照片", - "share_album": "分享相册", + "share_album": "共享相册", "sharing_with_self": "您不能与自己共享", "sharing_already_shared": "您已经与 {{email}} 共享了", "sharing_album_not_allowed": "不允许分享相册", @@ -389,7 +389,7 @@ "modify_sharing": "更改共享", "add_collaborators": "添加协作者", "add_new_email": "添加新的电子邮件", - "shared_with_people_count_zero": "与特定人员分享", + "shared_with_people_count_zero": "与特定人员共享", "shared_with_people_count_one": "已与1个人共享", "shared_with_people_count": "已与 {count, number} 个人共享", "participants_count_zero": "暂无参与者", @@ -442,7 +442,7 @@ "collect_photos": "收集照片", "disable_file_download": "禁止下载", "disable_file_download_message": "您确定要禁用文件下载按钮吗?
观看者仍然可以使用外部工具进行屏幕截图或保存您的照片副本。
", - "shared_using": "分享方式 {{url}}", + "shared_using": "共享方式 {{url}}", "sharing_referral_code": "使用代码 {{referralCode}} 获得 10 GB 免费空间", "disable_password": "禁用密码锁", "disable_password_message": "您确定要禁用密码锁吗?", @@ -627,7 +627,7 @@ "faster_upload_description": "通过附近的服务器路由上传", "open_ente_on_startup": "启动时打开 Ente", "cast_album_to_tv": "在电视上播放相册", - "cast_to_tv": "", + "cast_to_tv": "在电视上播放", "enter_cast_pin_code": "输入您在下面的电视上看到的代码来配对此设备。", "code": "代码", "pair_device_to_tv": "配对设备", @@ -679,11 +679,11 @@ "system": "系统", "light": "浅色", "dark": "深色", - "streamable_videos": "", - "processing_videos_status": "", - "share_favorites": "", - "person_favorites": "", - "shared_favorites": "", - "added_by_name": "", - "unowned_files_not_processed": "" + "streamable_videos": "可流媒体播放的视频", + "processing_videos_status": "正在处理视频...", + "share_favorites": "共享收藏", + "person_favorites": "{{name}}的收藏", + "shared_favorites": "已共享的收藏", + "added_by_name": "由{{name}}添加", + "unowned_files_not_processed": "由其他用户添加的文件未被处理" } diff --git a/web/packages/base/origins.ts b/web/packages/base/origins.ts index 597eb5b908..8e1ef1ddac 100644 --- a/web/packages/base/origins.ts +++ b/web/packages/base/origins.ts @@ -81,6 +81,13 @@ export const customAPIHost = async () => { export const uploaderOrigin = async () => (await customAPIOrigin()) ?? "https://uploader.ente.io"; +/** + * A static build time constant that is `true` if {@link albumsAppOrigin} has + * been customized. + */ +export const isCustomAlbumsAppOrigin = + !!process.env.NEXT_PUBLIC_ENTE_ALBUMS_ENDPOINT; + /** * Return the origin that serves public albums. * diff --git a/web/packages/gallery/components/utils/save-groups.ts b/web/packages/gallery/components/utils/save-groups.ts new file mode 100644 index 0000000000..f37fd40b69 --- /dev/null +++ b/web/packages/gallery/components/utils/save-groups.ts @@ -0,0 +1,157 @@ +import { useCallback, useState } from "react"; + +/** + * An object that keeps track of progress of a user-initiated download of a set + * of files to the user's device. + * + * This "download" is distinct from the downloads the app does from remote (e.g. + * when the user is viewing them). + * + * What we're doing here is perhaps more accurately described "a user initiated + * download of files to the user's device", but that is too long, so we instead + * refer to this process as "saving them". + * + * Note however that the app's UI itself takes the user perspective, so the + * upper (UI) layers use the word "download", while this implementation layer + * uses the word "save", and there is an unavoidable incongruity in the middle. + */ +export interface SaveGroup { + /** + * A randomly generated unique identifier of this set of saves. + */ + id: number; + /** + * The user visible title of the save group. + * + * Depending on the context can either be an auto generated string (e.g "5 + * files"), or the name of the collection which is being downloaded. + */ + title: string; + /** + * If this save group is associated with a {@link CollectionSummary}, then + * the ID of that collection summary. + */ + collectionSummaryID?: number; + /** + * `true` if the collection summary associated with the save group is + * hidden. + */ + isHiddenCollectionSummary?: boolean; + /** + * The path to a directory on the user's file system that was selected by + * the user to save the files in when they initiated the download on the + * desktop app. + * + * This property is only set when running in the context of the desktop app. + * The web app downloads to the user's default downloads folder, and when + * running in the web app this property will not be set. + */ + downloadDirPath?: string; + /** + * The total number of files to save to the user's device. + */ + total: number; + /** + * The number of files that have already been save. + */ + success: number; + /** + * The number of failures. + */ + failed: number; + /** + * An {@link AbortController} that can be used to cancel the save. + */ + canceller?: AbortController; +} + +export const isSaveStarted = (group: SaveGroup) => group.total > 0; + +/** + * Return `true` if there are no files in this save group that are pending. + */ +export const isSaveComplete = ({ total, success, failed }: SaveGroup) => + total == success + failed; + +/** + * Return `true` if there are no files in this save group that are pending, but + * one or more files had failed to download. + */ +export const isSaveCompleteWithErrors = (group: SaveGroup) => + group.failed > 0 && isSaveComplete(group); + +/** + * Return `true` if this save was cancelled on a user request. + */ +export const isSaveCancelled = (group: SaveGroup) => + group.canceller?.signal.aborted; + +/** + * A function that can be used to add a save group. + * + * It returns a function that can subsequently be used to update the save group + * by applying a transform to it (see {@link UpdateSaveGroup}). The UI will + * react and update itself on updates done this way. + */ +export type AddSaveGroup = (group: Partial